آلة تورنغ

من أرابيكا، الموسوعة الحرة
اذهب إلى التنقل اذهب إلى البحث

آلة تورنغ هي نموذج نظري بسيط يحاكي طريقة عمل الحاسوب.[1] سميت بهذا الاسم نسبة لعالم الرياضيات الإنجليزي آلان تورنغ الذي أوجد هذا النموذج سنة 1936م. هذا النموذج يعطي تعريفا رياضيا دقيقا للمصطلح خوارزم Algorithm, أهمية هذا النموذج تكمن في بساطته مقارنة بجهاز الحاسوب المعقد وبالرغم من ذلك فهو قادر على تنفيذ كل خوارزمية قابلة للتنفيذ بواسطة أي حاسوب متطور. لذلك يمكن معرفة إذا كانت عملية معينة قابلة للتنفيذ بواسطة الحاسوب أم لا عن طريق فحصها بواسطة آلة تورنغ. من هنا فإن لآلة تورنغ استعمال واسع في مجال دراسة قدرة الحاسوب والعمليات التي يمكنه أو لا يمكنه تنفيذها، وهو ما يسمى علم قابلية الحساب. يعتبر نموذج آلة التورينغ نموذج رياضياً بسيطاً للحاسوب وينمذج المقدرة الحسابية لحاسوب ذي وظائف عمومية وهو أيضاً من أهم اللغات الصورية إذ يقبل أوسع مجموعة منها وهي اللغات القابلة للعد عمودياً والتي يمكن توليدها بنماذج قواعدية من النوع صفر. يتألف النموذج الأساسي لآلة التورينغ من تحكم منته وشريط دخل منته من جهة واحدة هي جهة اليسار وغير منته من جهة اليمين ومقسم إلى عدة خلايا كل منها يحمل رمزاً واحداً من مجموعة منتهية تسمى «رموز الشريط» ورأس يسمى رأس القراءة والكتابة الذي يمر في كل مرة على خلية واحدة من الشريط. تحتوي الخلايا الn اليسارية من شريط الدخل (n عدد منته)في الحالة الابتدائية رموز الدخلفي حين تحتوي الخلايا المتبقة من الشريط رمزاً فارغاً.

تقوم آلة التورينغ في الحركة الواحدة واعتماداً على رمز الدخل المقروء من شريط الدخل وحالة التحكم المنتهي بالعمليات التالية:

  • تغيير حالة التحكم المنتهي.
  • كتابة رمز شريط في الخلية المقروءة.
  • التحرك خلية واحدة إلى اليسار أو إلى اليمين أو عدم التحرك بتاتا.

تعريف

من الناحية الرياضية آلة تورنغ هي رباعية M=(K,Σ,δ,S) حيث أن K هي مجموعة نهائية من الحالات (states), Σ هي مجموعة نهائية من الرموز وعادة ما تُسمى هذه المجموعة أبجدية M . سنفرض أنَّ ΣK= , Σ دائما يحتوي على رمزين خاصين هما رمز البداية () ورمز الفراغ (), δ هي دالة الانتقال أي δ:K×Σ(K{h,yes,no})×Σ×{,,} في حين أنَّ h هو حالة التوقف و-"yes" هي حالة القبول و-"no" هي حالة الرفض. ومؤشرات الاتجاه تعني تحرك يمينا و- تحرك يسارا و- معناه لا تتحرك وهذه المؤشرات ليست ضمن المجموعة: ΣK .

طريقة عمل الآلة

يمكن اعتبار δ «برنامج» الآلة وهو يحدد، لكل زوج من الحالة الحالية qK والرمز الحالي σΣ , ثلاثي أي: δ(q,σ)=(p,ρ,D) حيث أنَّ p هو الحال التالية و- ρ هو الرمز الذي تم استبداله مع σ . و- D{,,} هو اتجاه تحرك المؤشر. وعند الرمز إذا δ(q,)=(p,ρ,D) حينها ρ= و- D= أي انه دائما يوجه المؤشر إلى اليمين ولا يمحى ابدا.

البرنامج يبدأ في الحالية الابتدائية (S) . السلسلة تُهيئ فيكون في أولها الرمز ويتبعه سلسلة طولها نهائي: x(Σ{})* ونسمي x مُدخل الآلة. في البداية المؤشر يؤشر على بداية المُدخل وبشكل عام هو . من هذه الصورة (configuration) الأولية الآلة تتحرك حسب δ وخلال هذا يتغير الحال وتطبع الآلة المُخرج وتحرك المؤشر وبعدها تتحرك خطوة أخرى وعلى هذا المنوال...

كما ذكرنا سالفا بالنسبة δ(q,) فانه لا يمكن للمؤشر ان «يقع يسارا» أي أنه دوما سيتحرك المؤشر ضمن نطاق تواجد سلسلة المُدخل. اما بالنسبة لليمين فان نهاية السلسلة تكون عندما يصل المؤشر إلى الرمز حينها يمكنه إعادة كتابة المحتوى هكذا السلسلة تصبح أطول ولا يمكنها ان تصبح أقصر وهذه صفة مهمة لان الآلة مُعدة لتقوم بحسابات بشكل عام.

تتوقف الآلة عندما تصل إلى واحد من ثلاث حالات التوقف وهي "yes", "no", h والتي تم ذكرها انفا، عندما تصل إلى هذه الحالة نقول ان الآلة توقفت. ونقول ان الآلة «قبلت» المدخل إذا توقفت في الحال "yes" اما إذا توقفت على الحال "no" فاننا نقول ان الآلة «رفضت» المُدخل. نرمز للمُخرج الآلة M(x) لذا فانه في حال قبلت أو رفضت الآلة المُدخل M(x)=yesorno حسب الجواب.

إذا دخلت الآلة حالة التوقف حينها السلسلة التي تبدأ من الرمز حتى الرمز الفارغ نقول انها سلسلة المُخرج (أو باختصار المُخرج) نرمز لها ب-y حينها نكتب M(x)=y للدلالة على أنها المُخرج، في بعض الأحيان قد لا تتوقف الآلة M عندما المُدخل يكون x وحينها نكتب: M(x)= .

صورة آلة تورنغ

بشكل عام لوصف الفعالية لالات تورنغ نستخدم بشكل عام مصطلح «صورة»(Configuration). وبشكل غير دقيق صورة آلة تورنغ في لحظة مُعينة تحوي كل الحسابات التي قامت بها الآلة في تلك اللحظة، أي انه صورة آلة تورنغ M هي ثلاثي: (q,w,u) حيث أن qK هو الحال الحالي، و- w,uΣ* هما سلسلتان اللتين تصفان ما على يمين المؤشر (الذي قد يكون فارغا) وما على يساره. نقول أن الصورة (q,w,u) تنتج الصورة (q,w,u) في خطوة واحدة نرمز لها ب- (q,w,u)M(q,w,u) إذا خطوة الآلة بعد الصورة (q,w,u) نرى الصورة (q,w,u) أي انه: فلنفرض أنَّ σ هو الرمز الأخير في السلسلة w ولنفرض أن δ(q,σ)=(p,ρ,D) حينها q=p , اما بالنسبة ل-D فعندنا ثلاث حالات:

  1. إذا D= حينها 'w هي w غير أن الرمز الأخير في w الذي كان σ بدلناه ليكون ρ وأول رمز في u هو الرمز الحالي أي انَّ 'u هو u غير أن الرمز الأول في u قد حذف.
  2. إذا D= حينها 'w هي w غير أن الرمز الأخير في w حُذف، و 'u هو u غير أننا اضفنا ρ لبدايته.
  3. إذا D= حينها 'w هي w غير أن الرمز الأخير في w الذي كان σ بدلناه ليكون ρ ولكن u=u .

بشكل مشابه يمكن القول أن الصورة (q,w,u) تنتج الصورة (q,w,u) خلال k خطوات نرمز لها ب-(q,w,u)Mk(q,w,u) , ونقول أنَّ الصورة (q,w,u) تنتج الصورة (q,w,u) ونرمز لهذا ب- (q,w,u)M*(q,w,u) إذا يوجد k0 بحيث يتحقق: (q,w,u)Mk(q,w,u) .

مخطط الصور

فلتكن M آلة تورنغ، لكل x{0,1}* مخطط الصور،GM,x , هو مخطط الذي فيه كل رأس هو صورة آلة تورنغ M أثناء حساب x , ويوجد ضلع بين رأسين c1 ,c2 فقط إذا يمكن الوصول من c1 إلى c2 بخطوة حسابية واحدة.

لهذا المخطط أهمية كبيرة في نظرية التعقيد حيث أن له استخدامات عديدة من بينها في مبرهنة سافيتش، L⊆ NL , NL⊆ P , PSPACE ⊆EXP ...

لغات آلة تورنغ

فلتكن L(Σ{})* لغة أي: مجموعة سلاسل من المركبة من رموز. ولتكن M آلة تورنغ بحيث أنه لكل x(Σ{})* يتحقق التالي:

  • إذا xL حينها: M(x)=``yes''
  • إذا xL حينها: M(x)=``no''

حينها نقول أنَّ M تقرر اللغة L , ونكتب L(M)=L . نسمي L لغة عودية (recursive language) إذا يوجد آلة تورنغ تقررها.

مقاييس التعقيد

التعقيد هو تحديد أحد خصل الآلة لكل المُدخلات (مثل: الوقت أو كمية المساحة الاضافية) والتي نريد قياسها، كما في الخوارزميات كان هناك مقياس «النجاعة» هو وقت الخوارزمية ولعلنا أردنا في بعض المسائل تحديد كمية الوقت مثلا: في مسألة تصفيف الاعداد، يمكننا حل هذه المسألة بواسطة تصفيف الفقاعة بوقت (O(n2 بهذا نكون قد حصرنا الوقت وهكذا فاننا نعلم أن كل مُدخل لن يلزمه أكثر من هذا الوقت، وقياس وقت آلة تورنغ يكون بعد عدد الخطوات حتى توقف الآلة وإخراج النتيجة. بشكل رياضي: لتكن f:NN دالة، نقول أن آلة تورنغ تعمل خلال وقت f(n) إذا لكل مُدخل x الوقت (عدد خطوات الحساب أو بشكل مكافئ عدد الصور حتى الوصول لصورة نهائية) اللازم للالة M هو f(|x|) (نرمز لطول x ب-|x|). الدالة (f(n هي حد على وقت M .

أنواع الات تورنغ

هنالك عدة أنواع من الالات تورنغ أو الات شبيهة ولكن بالرغم من هذا فانه قد تبين أنَّ آلة تورنغ عمومية بما يكفي لتشمل هذه الأنواع من الالات هذه النظرة تبناها تورنغ وتشرتش في اطرحتهما المشهورة إذ انهما فرضا ان كل تعريف لمصطلح الخوارزمية من الناحية الرياضية مكافئ لالة تورنغ انفة الذكر، يعني ان كل نموذج حسابي يوجد آلة تورنغ التي تحاكي عمله واضف ان المسائل التي لا يمكن حلها بمساعدة آلة تورنغ حينها لا يمكن حلها بنموذج اخر الذي قد يكون أكثر تعقيدا. بالرغم من ان هذه الفرضية صعب جدا فحصها والتدقيق فيها ولكن كل نموذج حاسوبي تبين أنه مكافئ لالة تورنغ.

آلة تورنغ عديدة الاشرطة

وهي آلة تورنغ كما عرفناها سابقا غير ان فيها اختلاف بسيط: بدل أن يكون هناك شريط مُدخل واحد هنالك عدة اشرطة، وهذا النموذج هو لمحاكاة الخوارزميات الموازية ولكن كما تم الذكر فان هذه الآلة يمكن محاكاتها بواسطة آلة تورنغ عادية. في الواقع إذا كان وقت عمل آلة تورنغ عديدة الاشرطة هو f(n) حينها يمكن بناء آلة تورنغ مع شريط واحد 'M تحاكي الآلة M بحيث أنَّ وقتها هو O(f2(n)) أو بكلمات أخرى كل ما نستطيع فعله مع آلة تورنغ عديد الاشرطة يمكن فعله أيضا مع آلة تورنغ بشريط واحد.

آلة تورنغ غير حتمية

بينما تنص اطروحة تشرتش على أن كل نموذج حسابي معقول مساوي لالة تورنغ مع فرق وقت كثير الحدود هذه الآلة، أي آلة تورنغ غير حتمية، يُعتقد بانها لا تحقق هذه الاطروحة حيث أنه حتى يومنا ما زالت مسألة محاكاة هذه الآلة هو الأصعب إذ انه لا يوجد الا محاكاة التي وقتها على آلة تورنغ أسية وهذا هو أساس المسألة الشهيرة NP≠P .

تعريف

آلة تورنغ غير حتمية هي رباعية N=(K,Σ,Δ,(S)) وهي قريبة جدا من الآلة العادية: K,Σ,(S) هي كما في السابق، ولكن الآن لا يوجد خيار واحد للانتقال ولكن مجموعة من الخيارات، وهذا نراه في أن Δ لم تعد دالة ولكن علاقة (relation) ΔK×Σ(K{h,yes,no})×Σ×{,,} .

صورة آلة تورنغ غير حتمية

الصورة هي ثلاثي كما عرفناه سابقا، غير انه الآن نقول أن (q,w,u) ينتج (q,w,u) في خطوة واحدة ونرمز لها ب- (q,w,u)N(q,w,u) إذا يوجد قانون في Δ الذي يجعل هذا ممكنا أي: يوجد تحرك ((q,σ),(q,ρ,D))Δ بحيث أنَّ:

  1. إذا D= حينها 'w هي w غير أن الرمز الأخير في w الذي كان σ بدلناه ليكون ρ وأول رمز في u هو الرمز الحالي أي انَّ 'u هو u غير أن الرمز الأول في u قد حذف.
  2. إذا D= حينها 'w هي w غير أن الرمز الأخير في w حُذف، و 'u هو u غير أننا اضفنا ρ لبدايته.
  3. إذا D= حينها 'w هي w غير أن الرمز الأخير في w الذي كان σ بدلناه ليكون ρ ولكن u=u .

محاكاة الآلة

يمكن محاكاة هذه الآلة بواسطة آلة تورنغ عادية (وحتى نفرق بينها يمكن تسميتها آلة تورنغ حتمية) ولكن الوقت اللازم للمحاكاة أُسي وحدسية NP≠P تقترح انه لا يوجد محاكاة كثيرة الحدود ما يعنيه انه قد يكون صعبا الاتيان بمحاكاة عملية.

آلة تورنغ مع اوركل

هذا النوع من الالات ما هو الا توسيع لالة تورنغ العادية، وفي هذا النموذج تُعطى الآلة القدرة على حل مسألة ربما صعبة بخطوة حسابية واحدة، ولهذه الالات أهمية عظمى في نظرية التعقيد الحسابي إذ انه ينظر لهذا النوع من الالات على أنه اختصار (reduction) وقد تبين ان هذا التوسيع مُفيد جدا في كثير من التعريفات المهمة منها تعريف PCP , وهرم كثير الحدود...

آلة تورنغ احتمالية

عندما خضنا في آلة تورنغ غير حتمية كان العامل الأساسي هناك هو «التحزر» أي حتى نعلم إذا ما مُدخل جوابه «نعم» تحزرنا مسار حسابي وإذا كان المسار «نعم» اجبنا نعم وغير هذا عدنا وبحثنا من جديد. بشكل حدسي آلة تورنغ الاحتمالية تعتمد على عدد مسارات الحساب التي جوابها «نعم» وبناء على هذا فانه لو كان هنالك عدد كاف من مسارات الحساب التي جوابها نعم حينها إذا اخترنا بشكل عشوائي (هذه العملية تحتاج لمولد اعداد عشوائية حقيقية واحد هذه المولدات هو القاء قطعة نقدية «عادلة» غير منحازة) مسار حساب فاننا قد نحصل وباحتمال كبير على مسار «نعم», مقارنة هذه الالات بالة تورنغ غير حتمية هو سؤال أساسي في علم الحاسوب إذ انه لم يتم للان برهنة ان هذه الآلة مكافئة بقدرتها لالة تورنغ غير الحتمية، وفي نظرية التعقيد الحاسوبي هذا السؤال هو: هل BPP=NP ؟ كما أنه لا يُعرف هل هذه الآلة اقوى من آلة تورنغ حتمية ولكن اغلب علماء الحاسوب يؤمنون بشدة ان هذه الالات مكافئة لالات تورنغ حتمية (أي ان العشوائية لا تساعد).

آلة تورنغ كمومية

وهي آلة تورنغ التي هي نموذج للحساب كمومي بشكل رياضي، وهو فرع من الفيزياء، وهو يختلف عن النموذج العادي بانه يحتوي على كيوبت والذي هو عنده ثلاث حالات: 0,1 , 0 و1 معاً الحالة الأخيرة تسمى الحالة الفائقة. هذا النموذج لا يُعرف إذا ما يمكن محاكاته بواسطة حاسوب عادي ويعتقد أنها مهمة صعبة للغاية وقد تكون مستحيلة ! وهذا النموذج سطع نجمه عندما قدم بيتر شور خوارزمية لتحليل عدد لعوامله الأولية بوقت كثير الحدود بواسطة هذه الآلة.

الالات تورنغ على انها سلاسل وآلة تورنغ الكونية

بشكل واضح يمكن تمثيل آلة تورنغ على أنها سلسلة إذ انه يمكن كتابتها وبالتالي يمكن تحويل هذه الآلة إلى سلسلة 0 و- 1 , وهذه الملاحظة لها اهميتها العظمى على علم الحاسوب النظري والعملي إذ انه من دونها ما كان ليكون هناك حاسوب متعدد الاستخدامات. لكل آلة تورنغ حتى نستطيع تمثيلها بواسطة سلسلة سنقوم أيضا بتمثيل دالة الانتقال، كما أن كل x0,1* سيكون عبارة عن تمثيل لالة تورنغ، كما أن كل آلة تورنغ يوجد عدد لا نهائي من السلاسل التي تمثل هذه الآلة.

فلتكن M آلة تورنغ نرمز ب- M تمثيل الآلة M على أنها سلسلة. ولنفرض أنَّ α هي سلسلة حينها نكتب ان آلة تورنغ التي تمثلها α ب- Mα .

آلة تورنغ الكونية

هي آلة تورنغ التي تحاكي عمل الالات تورنغ، بشكل غير رسمي آلة تورنغ الكونية عملها مشابه لعمل المُصرف (compiler) حيث أنَّ مُدخل المُصرف برنامج بلغة برمجة مُعينة ويقوم بكتابة برنامج الحاسوب قادر على تنفيذه خطوة خطوة، بشكل رسمي: يوجد آلة تورنغ كونية U بحيث أنَّ لكل x,α{0,1}* , U(x,α)=Mα(x) . بالإضافة إذا Mα تتوقف خلال T خطوات على المُدخل x , حينها U(x,α) تتوقف خلال CTlog(T) حيث أنَّ C هو عدد يتعلق بكبر أبجدية M وعدد الاشرطة وعدد الحالات.

انظر أيضا

مراجع

  1. ^ « FINAL », CNRTL : {{استشهاد}}: استشهاد فارغ! (مساعدة). "نسخة مؤرشفة". مؤرشف من الأصل في 2012-05-02. اطلع عليه بتاريخ 2017-12-13.{{استشهاد ويب}}: صيانة الاستشهاد: BOT: original URL status unknown (link)