تجريبية (خوارزميات)

يستخدم مصطلح الاستكشافية[1] أو الكسبية[2] أو الإرشادية[3] أو اللا منهجية[4] أو التجريبية[بحاجة لمصدر] في مجال تقانة المعلومات والذكاء الصنعي والاستمثال الرياضي (أي الطرق الرياضية في إيجاد الحلول الأمثلية للمسائل), الاستكشافية تعتبر طريقة مساعدة في حل المسائل عندما تكون الطرق التقليدية بطيئة، أو لإيجاد حلول تقريبية عندما تفشل الطرق التقليدية في إيجاد حل محدد. يتم تحقيق ما سبق مع الأخذ بعين الاعتبار أننا بذلك نتخلى عن فكرة الوصول إلى الحل الأمثل بل نحن بذلك نسعى للوصول إلى حل مقبول وبوقت معقول كما نتخلى عن السلامة (soundness) و كمال الحل (completeness) حيث يمكن اعتبار استخدام التجريبية طريقاً مختصراً لتوفير الجهد[بحاجة لمصدر].

رسم بياني مرجح بالحافة مع عقدة البداية "A" والعقدة المستهدفة "Z". يكشف عن مجريات الخوارزمية

تعريف وتوطئة

عدل

الهدف من الاستكشافية هو الحصول على حل ضمن وقت منطقي بحيث يكون جيداً بما فيه الكفاية ويبسط حل المسألة لتصبح قابلة للحل بالورقة والقلم. هذا الحل قد لا يكون الامثل بين جميع الحلول الممكنة للمسألة المطروحة أو قد يكون تقريباً للحل الأمثل لكنه يبقى حلاً ذو قيمة لاننا اوجدناه ضمن وقت قصير. يمكن ان نجد حلاً باستخدام الاستكشافية وحدها أو يمكن استخدام الاستكشافية بالإضافة إلى خوارزميات استمثال لتحسين فاعلية الاستكشافية في الحصول على الحل أي يمكن استخدام الاستكشافية للحصول على حلول ابتدائية تستخدمها خوارزميات الاستمثال. النتائج التي تم الحصول عليها من مسائل علم الحواسيب التي تندرج تحت نوعمسائل NP صعبة تؤكدأن الاستكشافية هي الخيار الوحيد الذي ستكتب له الحياة والتطبيق على هذا الكلام موجود بتنوع في الحياة العملية.

المقايضات في استخدام الاستكشافية

عدل

عندما نقف أمام مسألة ونريد أن نعرف إن كان استخدام التجريبيات سيفيد أما لا يجب أن ننظر إلى ماذا سنخسر مقابل ماذا سنربح عند استخدام الاستكشافية وهذه المقايضات هي:

  • الأمثلية: أي عندما يوجد عدة حلول لمسألة ما معطاة، هل تضمن لنا الاستكشافية الوصول إلى الحل الأمثل؟ هل من المجدي الوصول إلى الحل الأمثل؟
  • الكمال (completeness) : أي عندما يوجد أكثر من حل للمسألة هل تستطيع التجربيات إيجاد كافة الحلول؟ هل نحن بحاجة لإيجاد كافة الحلول؟العديد من التجريبيات تصمم للحصول على حل وحيد.
  • الدقة: أي هل سيكون مقدار الخطأ الناتج عن استخدام الاستكشافية كبيراً جداً؟
  • وقت التنفيذ : هل هذه أفضل تجريبية لحل هذا النوع من المشاكل؟ حيث أن بعض التجريبيات تتقارب أسرع من تجريبيات أخرى.

في بغض الحالات من الصعب جداً معرفة إن كان استخدام الاستكشافية جيد بما فيه الكفاية حيث أن القسم النظري أثبت أن الاستكشافية ليست دقيقة.

أمثلة

عدل

استخدام مسائل أبسط

عدل

أحد طرق الحصول على أداء حاسوبي أفضل في حل المشاكل هو حل المشكلة عن طريق حل مشكلة أسهل منها يكون حلها هو أيضاً حل للمشكلة الابتدائية. إن هذا النوع من التجريبيات غير قادرة على إيجاد كافة الحلول للمشكلة الأساسية لكن يمكنها أن تجد حلاً بسرعة وذلك لسهولة حل المسألة الأبسط التي تشبه المسألة الأساسية

مسألة البائع الجوال الشهيرة

عدل

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

مسائل البحث

عدل

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

نويل وسايمون: فرضية تجريبية البحث

عدل

خلال حفل استلامهما لجائزة تورينغ ناقش العالمان آلن نويل وهربرت سايمون فرضية تجريبية البحث: باستخدام نظام معالجة الرموز سيتم توليد وتعديل الرموز المعروفة حتى تكون البنى المنشأة مطابقة لبنية الحل.(يشار إلى أن نظام معالجة الرموز المذكور هو من إنشاء العالمين وهو تعد آلية عمله جزءاً من فلسفة الذكاء الصنعي). كل دورة تعاقبية من مراحل العمل تعتمد على الخطوة السابقة لها بالتالي تجريبية البحث تتعلم السب التي يجب اتباعها والسبل التي يجب الابتعاد عنها وذلك من خلال حساب بعد الدور الحالي عن الحل بعض الاحتماليات لن يتم حسابها أبداً إذ أنها بعيداً جداً عن الهدف المرجوّ. تستطيع الاستكشافية إتمام المهمة الخاصة بها من خلال أشجار البحث. لسنا بحاجة إلى توليد كل العقد في شجرة البحث حيث أن الاستكشافية تختار العقد التي نحتاجها في البحث عن حل فقط.[5]

البحث عن الفيروسات

عدل

العديد من برامج البحث عن التطبيقات الخبيثة كالفيروسات تستخدم تجريبيات في البحث. هذا النوع من البحث يتعمد البحث عن أجزاء من برامج معينة تدعى (block of code) أو طابع مميز لنوع معين من أنواع البرمجيات الخبيثة. عند إيجاد تطابق بين الخواص التي نبحث عنها وجزء من مكونات ملف معين أو مهمة معينة يتم تنفيذها عندها يرسل البرنامج المضاد رسالة بوجود تطبيق غير آمن. أهم خاصية للتجريبيات المبنية على السلوك هو أنها تسطيع التعامل مع فيروسات مبنية بشكل عشوائي عالي وبطريقة تدعى (polymorphic) حيث أن الفيروسات المبينة بهذا الأسلوب تغير بنيتها البرمجية بشكل مستمر علماً أن الخوارزمية تبقيى ذاتها.

أخطاء ومزالق

عدل

إن استخدام نجريبية معينة في مجالات متعددة فقط لأنه بدا أنها تعمل في مجال معين دون البرهان الرياضي على مدى فاعليتها على متطلبات المسألة يجعل الحلول الناتجة عن هذا الاستخدام الخاطئ قريبة من الضجيج

مراجع

عدل
  1. ^ موفق دعبول؛ مروان البواب؛ نزار الحافظ؛ نوار العوا (2017)، قائمة مصطلحات المعلوماتية (بالعربية والإنجليزية)، دمشق: مجمع اللغة العربية بدمشق، ص. 145، QID:Q112244705
  2. ^ معجم مصطلحات المعلوماتية (بالعربية والإنجليزية)، دمشق: الجمعية العلمية السورية للمعلوماتية، 2000، ص. 256، OCLC:47938198، QID:Q108408025
  3. ^ معجم البيانات والذكاء الاصطناعي (PDF) (بالعربية والإنجليزية)، الهيئة السعودية للبيانات والذكاء الاصطناعي، 2022، ص. 74، QID:Q111421033
  4. ^ معجم الحاسبات (بالعربية والإنجليزية) (ط. 3). القاهرة: مجمع اللغة العربية بالقاهرة. 2003. ص. 137. ISBN:978-977-01-8550-6. OCLC:784561745. QID:Q113638576.
  5. ^ Allen Newell and Herbert A. Simon (1976). "Computer Science as Empirical Inquiry: Symbols and Search". Comm. of the ACM. ج. 19: 113–126.