خوارزمية مجتمع النحل الاصطناعي

في مجالي علم الحاسوب وبحوث العمليات، خوارزمية مجتمع النحل (بالإنجليزية: Artificial bee colony algorithm، اختصارا: ABC)، هي خوارزمية استمثالية تعتمد على نموذج ذكاء سلوك سرب النحل في البحث عن الطعام. فمن المعلوم أن النحل عندما يجد الطعام خلال رحلة البحث فإنه يعود للخلية بعيّنة منه ليخبر بقية النحل العاملة عن مكان الطعام واتجاهه من خلال قيام النحلة برقصة اهتزازية في اتجاه معين وبعدد مرات معينة للإشارة إلى مكان وجود الطعام. اقترحها كارابوغا عام 2005.[1]

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

لمحة عامة عدل

يتكون مجتمع النحل من ثلاث مجموعات: العاملات، المتفرجات، والكشافة. ويفترض أن هناك عاملة واحدة لكل مصدر طعام، يعني أن عدد العاملات يساوي عدد مصادر الطعام حول الخلية.

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

الخطوات الأساسية عدل

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

تعتمد هذه الخوارزمية على عدد النحلات في المجتمع ومكان الغذاء يمثل حل محتمل للمسألة  وكمية الرحيق يتطابق مع جودة الحل، ويمثل عدد النحلات العاملات عدد الحلول.

القاعدة وطريقة العمل عدل

تعتمد هذه الخوارزمية على حجم الخلية (عدد النحلات) ، حيث يقسم سرب النحل إلى 50% نحلات عاملات و 50% نحلات كشافة وعدد المتفرجات يساوي 1.كما أن عدد النحلات العاملات يساوي عدد الحلول، حيث   متّجه يمثّل الحل رقم   في الخلية،   مصادر الطعام (وبالتالي عدد النحلات العاملات).

كل نحلة عاملة   تعطي حل   (في خلية النحل يمثل   موقع غذاء) ويُعطى   بالمعادلة:  

حيث   حل يتم اختياره عشوائياً بشرط  ، كذلك   مُحدد للبعد يتم اختياره عشوائياً، وعدد عشوائي   ضمن الفترة  .

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

تالياً يتم ايجاد الحل الأمثل وهو الحل الحاصل على أعلى احتمال  . بعد انتهاء عملية البحث عن مصادر الغذاء (الحلول) تُشارك النحلات العاملات النحلة المتفرجة المعلومات حول مصدر الغذاء (الحل) ثم تقوم النحلة المتفرجة باختيار الحل الامثل الحاصل على أفضل احتمال بين الحلول المقترحة الأخرى حيث يتم حساب الاحتمال بالمعادلة:

 

حيث أن  : هي قيمة التناسب للحل   ومجموعة باقي الحلول، وتحدد من خلال اقتران يناسب المسألة.

إذن الحل الامثل هو الحل (المصدر) ذو الاحتمال الاعلى، فإذا لم تتحسن قيمة   لمصدر غذاء وفق قيمة معرفة سابقا تسمى النهاية (limit) بعد عدد من الدورات، فسوف يتم استثناء هذا المصدر (الحل).

انظر أيضًا عدل

مراجع عدل

  1. ^ Karaboga، Dervis (2005). "An Idea Based on Honey Bee Swarm For Numerical Optimization" (PDF). مؤرشف من الأصل (PDF) في 15 ديسمبر 2017. اطلع عليه بتاريخ أغسطس 2020. {{استشهاد بدورية محكمة}}: الاستشهاد بدورية محكمة يطلب |دورية محكمة= (مساعدة) وتحقق من التاريخ في: |تاريخ الوصول= (مساعدة)

وصلات خارجية عدل