انتقل إلى المحتوى الرئيسي

البحث غير المنظم

ملخص

سنبدأ بوصف المشكلة التي تحلها خوارزمية Grover. كالمعتاد، سنستخدم Σ={0,1}\Sigma = \{0,1\} للدلالة على الأبجدية الثنائية طوال هذا النقاش.

لنفترض أن

f:ΣnΣf:\Sigma^n \rightarrow \Sigma

هي دالة من السلاسل الثنائية بطول nn إلى البتات. سنفترض أننا نستطيع حساب هذه الدالة بكفاءة، لكنها فيما عدا ذلك اعتباطية ولا يمكننا الاعتماد على وجود بنية خاصة أو تنفيذ محدد يلائم احتياجاتنا.

ما تفعله خوارزمية Grover هو البحث عن سلسلة xΣnx\in\Sigma^n تُحقق f(x)=1.f(x) = 1. سنُسمي مثل هذه السلاسل حلولًا لمسألة البحث. إذا وُجدت حلول متعددة، يُعدّ أيٌّ منها إجابةً صحيحة، وإذا لم يوجد أي حل فإن الإجابة الصحيحة تستلزم التصريح بعدم وجود حلول.

تُوصف هذه المهمة بمسألة بحث غير منظم (unstructured search) لأننا لا يمكننا الاعتماد على وجود أي بنية خاصة في ff تجعل المهمة سهلة. نحن لا نبحث في قائمة مرتبة أو داخل هيكل بيانات مُصمَّم خصيصًا لتسهيل البحث، بل نبحث في جوهره عن إبرة في كومة قش.

بشكل حدسي، يمكننا تخيّل أن لدينا دائرة بوليانية بالغة التعقيد تحسب ff، ويمكننا بسهولة تشغيل هذه الدائرة على سلسلة مُدخَلة مختارة. لكن لأن الدائرة بالغة التعقيد، لا أمل لنا في فهمها بفحصها (سوى امتلاك القدرة على تقييمها على سلاسل مُدخَلة مختارة).

إحدى طرق أداء مهمة البحث هذه كلاسيكيًا هي ببساطة المرور عبر جميع السلاسل xΣnx\in\Sigma^n، وتقييم ff على كل منها للتحقق من كونها حلًا أم لا. من الآن فصاعدًا، لنكتب

N=2nN = 2^n

لاختصار العبارة. يوجد NN سلسلة في Σn\Sigma^n، ويستلزم المرور عبرها جميعًا NN تقييمًا لـ ff. انطلاقًا من افتراض أننا مقيّدون بتقييم ff على مدخلات مختارة، هذا أفضل ما يمكننا تحقيقه بخوارزمية حتمية إذا أردنا ضمان النجاح. مع خوارزمية احتمالية، يمكن الأمل في توفير الوقت باختيار سلاسل مُدخَلة عشوائية لـ ff، لكننا سنحتاج كذلك إلى O(N)O(N) تقييمًا لـ ff إذا أردنا لهذه الطريقة أن تنجح باحتمال مرتفع.

تحل خوارزمية Grover مسألة البحث هذه باحتمال مرتفع بـ O(N)O(\sqrt{N}) تقييمًا فقط لـ ff. وللتوضيح، يجب أن تتم تقييمات الدالة هذه في تراكب (in superposition)، على غرار خوارزميات الاستعلام الكمومي التي نوقشت في درس خوارزميات الاستعلام الكمومي، بما فيها خوارزمية Deutsch، وخوارزمية Deutsch-Jozsa، وخوارزمية Simon. على خلاف تلك الخوارزميات، تتبنى خوارزمية Grover نهجًا تكراريًا: تُقيِّم ff على تراكبات سلاسل المُدخَلات وتتخلل هذه التقييمات بعمليات أخرى ذات تأثير في إنشاء أنماط تداخل (interference patterns)، مما يُفضي إلى حل باحتمال مرتفع (إذا وُجد) بعد O(N)O(\sqrt{N}) تكرارًا.

صياغة رسمية للمسألة

سنُصوِّغ المسألة التي تحلها خوارزمية Grover بشكل رسمي باستخدام نموذج الحساب بالاستعلام (query model). أي سنفترض أن بإمكاننا الوصول إلى الدالة f:ΣnΣf:\Sigma^n\rightarrow\Sigma عبر بوابة استعلام مُعرَّفة بالطريقة المعتادة:

Uf(ax)=af(x)xU_f \bigl( \vert a\rangle \vert x\rangle \bigr) = \vert a \oplus f(x) \rangle \vert x \rangle

لكل xΣnx\in\Sigma^n و aΣa\in\Sigma. هذا هو تأثير UfU_f على حالات الأساس القياسية، ويُحدَّد تأثيرها عمومًا بالخطية.

كما نُوقش في درس أسس الخوارزميات الكمومية، إذا كان لدينا دائرة بوليانية لحساب ff، يمكننا تحويل وصف تلك الدائرة إلى دائرة كمومية تُنفِّذ UfU_f (باستخدام عدد من كيوبتات مساحة العمل التي تبدأ وتنتهي الحساب في حالة 0\vert 0\rangle). لذا، رغم استخدامنا نموذج الاستعلام لتصوير المسألة التي تحلها خوارزمية Grover، فإنها ليست مقتصرة على هذا النموذج؛ يمكن تشغيل خوارزمية Grover على أي دالة ff تتوفر لها دائرة بوليانية.

إليك صياغة دقيقة للمسألة، التي تُسمى بحث (Search) لأننا نبحث عن حل، أي عن سلسلة xx تجعل ff تُقيَّم بـ 11.

بحث (Search)

المُدخَل: دالة f:ΣnΣf:\Sigma^n\rightarrow\Sigma
المُخرَج: سلسلة xΣnx\in\Sigma^n تُحقق f(x)=1f(x) = 1، أو "لا حل" إذا لم توجد سلسلة xx كهذه

لاحظ أن هذه ليست مسألة وعد (promise problem) — الدالة ff اعتباطية. سيكون مفيدًا مع ذلك تناول النوع التالي من المسألة مع وعد، حيث يُضمن وجود حل واحد فقط. ظهرت هذه المسألة كمثال على مسألة وعد في درس خوارزميات الاستعلام الكمومي.

بحث فريد (Unique search)

المُدخَل: دالة من النوع f:ΣnΣf:\Sigma^n \rightarrow \Sigma
الوعد: توجد سلسلة فريدة zΣnz\in\Sigma^n تُحقق f(z)=1f(z) = 1، مع f(x)=0f(x) = 0 لجميع السلاسل xzx\neq z
المُخرَج: السلسلة zz

لاحظ أيضًا أن مسألة Or المذكورة في الدرس نفسه وثيقة الصلة بمسألة البحث. في تلك المسألة، الهدف هو تحديد ما إذا كان يوجد حل أم لا، في مقابل إيجاد الحل فعليًا.