الگوریتم شعله پروانه MFO — شرح جامع

الگوریتم شعله پروانه MFO

الگوریتم شعله پروانه یا الگوریتم Moth-flame Optimization Algorithm که به اختصار الگوریتم MFO یا الگوریتم شمع و پروانه نیز نامیده می شود یکی از الگوریتم های بهینه سازی و فراابتکاری است که از رفتار پروانه ها در کنار شعله یا آتش روشی برای حل مسئله پیدا می کند.

الگوریتم شعله پروانه با نام‌های دیگری همچون الگوریتم پروانه آتش، الگوریتم MFO، الگوریتم پروانه شعله و الگوریتم شمع و پروانه نیز شناخته می‌شود. این الگوریتم یک الگوی اکتشافی نوین الهام گرفته از طبیعت و رفتار پروانه‌ها و علاقه مندی آن‌ها به شعله یا آتش است.

الگوریتم های بهینه سازی

بهینه سازی به فرآیند یافتن بهترین راه حل (های) ممکن برای یک مسئله خاص اشاره دارد. با افزایش پیچیدگی مسائل، طی چند دهه گذشته ، نیاز به تکنیک‌های جدید بهینه سازی بیش از گذشته آشکار می‌شود. تکنیک‌های بهینه سازی ریاضی قبل از پیشنهاد تکنیک‌های بهینه سازی اکتشافی ، تنها ابزار برای بهینه سازی مسائل بوده است. روش‌های بهینه سازی ریاضی اکثراً قطعی هستند که از یک گرفتاری اپتیم‌های محلی رنج می‌برند.

الگوریتم‌های فرا اکتشافی از یک سری راه حل اولیه شروع می‌کنند و در طی تکرارهای بعدی به جواب یا راه حل مسئله نزدیک‌تر می‌شوند. از الگوریتم‌های معروف در این زمینه می‌توان به الگوریتم ژنتیک، دیفرانسیل تکامل، کلونی مورچگان، کلونی زنبور عسل، کرم شب تاب، گرگ خاکستری، شکار نهنگ و … اشاره کرد.

برای درک کامل الگوریتم MFO از دوره جامع ما نیز استفاده کنید. دوره جامع آموزش الگوریتم شمع پروانه MFO در متلب به صورت کامل به توضیح و تشریح تئوری الگوریتم و پیاده سازی آن در متلب می پردازد پیشنهاد می‌شود برای درک کامل این الگوریتم حتماً از این آموزش که در زیر قرار داده شده استفاده کنید.

الگوریتم MFO چیست؟

در این مقاله از سری مقالات آموزشی مجله پی استور، یک الگوریتم بهینه سازی جدید با الهام از طبیعت با نام الگوریتم بهینه سازی شعله (MFO) یا الگوریتم شمع و پروانه ارائه شده است. الهام بخش اصلی این بهینه ساز روش ناوبری پروانه‌ها در طبیعت به نام جهت گیری عرضی (transverse orientation) است. پروانه‌ها با حفظ یک زاویه ثابت با توجه به ماه، پرواز در شب را برای مسافت‌های طولانی انجام می‌دهند. ولی این حشرات فانتزی در یک مسیر مارپیچی بی فایده و کشنده در اطراف چراغ‌های مصنوعی به دام می‌افتند.

در الگوریتم پروانه آتش به صورت ریاضی از این رفتار پروانه‌ها برای انجام بهینه سازی استفاده می‌شود. الگوریتم MFO با سایر الگوریتم‌های شناخته شده الهام گرفته از طبیعت شباهت‌های زیادی دارد و نتایج آماری در مورد توابع معیار نشان می‌دهد که این الگوریتم قادر به ارائه نتایج بسیار امیدوارکننده و رقابتی است.

الگوریتم MFO

الگوریتم بهینه سازی پروانه آتش Moth-Flame Optimiser

شب پره‌ها حشرات فانتزی هستند که بسیار شبیه خانواده پروانه‌ها هستند. اصولاً بیش از ۱۶۰،۰۰۰ گونه مختلف از این حشره در طبیعت وجود دارد. آنها دو مرحله اصلی در طول زندگی خود دارند: لارو و بزرگسال. لاروها در پیله‌ها به پروانه تبدیل می‌شوند. جالب ترین واقعیت در مورد پروانه‌ها روش‌های ویژه ناوبری آنها در شب است. آنها تکامل یافته‌اند تا در شب با استفاده از نور ماه پرواز کنند. آنها از مکانیسمی به نام جهت دهی عرضی برای ناوبری استفاده کردند. در این روش ، یک پروانه با حفظ یک زاویه ثابت با توجه به ماه پرواز می‌کند، مکانیسم بسیار موثری برای سفر در مسافت های طولانی در یک مسیر مستقیم است.

مثال مدل مفهومی جهت گیری عرضی

شکل زیر مدل مفهومی جهت گیری عرضی را نشان می دهد. از آنجا که ماه بسیار دور از پروانه است ، این مکانیسم پرواز را به صورت مستقیم تضمین می‌کند. همین روش ناوبری توسط انسانها قابل انجام است. فرض کنید ماه در ضلع جنوبی آسمان است و انسان می‌خواهد به سمت شرق برود. اگر او هنگام راه رفتن ماه سمت چپ خود را نگه داشته باشد ، می‌تواند با یک خط مستقیم به سمت شرق حرکت کند.

سیستم ناوبری پروانه

با وجود اثربخشی جهت گیری عرضی (transverse orientation)، معمولاً مشاهده می‌کنیم که پروانه‌ها به صورت مارپیچ در اطراف چراغ‌ها پرواز می‌کنند. در حقیقت، پروانه‌ها توسط چراغ‌های مصنوعی فریب خورده و چنین رفتارهایی را نشان می‌دهند. این امر به دلیل ناکار آمدی جهت گیری عرضی است که در آن تنها هنگامی که منبع نور بسیار دور است، برای حرکت در خط مستقیم مفید است. هنگامی که پروانه‌ها نور مصنوعی ساخته شده توسط انسان را مشاهده می‌کنند، سعی می‌کنند زاویه‌ای مشابه با نور را حفظ کنند تا به صورت مستقیم پرواز کنند.

از آنجا که چنین نوری در مقایسه با ماه بسیار نزدیک است، اما حفظ زاویه‌ای مشابه با منبع نور باعث می‌شود مسیر پرواز مارپیچی بی فایده یا کشنده برای پروانه‌ها باشد. یک مدل مفهومی از این رفتار در شکل زیر نشان داده شده است. ممکن است در شکل زیر مشاهده شود که پروانه در نهایت به سمت نور همگرا می‌شود. این رفتار از لحاظ ریاضی مدل سازی شده است تا یک بهینه ساز بنام الگوریتم بهینه سازی شعله (MFO) یا الگوریتم شمع و پروانه را بوجود آورد.

حرکت مارپیچی پروانه

توضیح و تشریح الگوریتم MFO

در الگوریتم MFO، فرض بر این است که راه حل‌های کاندید پروانه‌ها هستند و متغیرهای مسئله موقعیت پروانه‌ها در فضا است. بنابراین، پروانه‌ها با تغییر بردارهای موقعیتی خود می‌توانند در فضای یک بعدی، دو بعدی یا سه بعدی پرواز کنند. از آنجا که الگوریتم MFO یک الگوریتم مبتنی بر جمعیت است، مجموعه پروانه در یک ماتریس (مثلاً M) نمایش داده می‌شوند.

آرایه‌ای نیز برای تمامی پروانه‌ها برای ذخیره مقادیر تناسب (OM) وجود دارد. یکی دیگر از مؤلفه‌های اصلی در الگوریتم یک ماتریس شبیه به ماتریس پروانه‌ها است که ماتریس شعله یا آتش (F) است و یک آرایه نیز با نام OF برای ذخیره کردن مقدار تابع تناسب آن استفاده می‌شود.

ماتریس پروانه و شعله

در اینجا لازم به ذکر است که پروانه‌ها و شعله‌ها هر دو راه حل هستند. تفاوت بین آنها نحوه برخورد و بروزرسانی آنها در هر تکرار است. پروانه‌ها عوامل جستجوی واقعی هستند که در فضای جستجو حرکت می‌کنند ، در حالی که شعله‌های آتش بهترین موقعیت پروانه‌ای هستند که تاکنون بدست آمده است. به عبارت دیگر ، شعله‌ها را می‌توان پرچم‌ها یا پین‌هایی دانست که هنگام جستجوی فضای جستجو ، توسط پروانه‌ها فرو می‌روند.

بنابراین ، هر پروانه در اطراف یک پرچم (شعله) جستجو می‌کند و در صورت پیدا کردن راه حل بهتر ، آن را به روز می‌کند. با استفاده از این مکانیسم ، یک پروانه هرگز بهترین راه حل خود را از دست نمی‌دهد.

سورس کد الگوریتم MFO به زبان پایتون نوشته و اجرا شده است. این سورس کد بر اساس ۱۲ توابع تست الگوریتم شعله و پروانه را اجرا می‌کند. برای تهیه و دانلود این سورس کد می‌توانید بر روی لینک زیر کلیک کنید.

مقدار دهی اولیه

برای تولید راه حل‌های اولیه و محاسبه مقادیر تناسب هر یک از آنها از هر توزیع تصادفی می‌توان استفاده کرد. روش زیر به عنوان پیش فرض استفاده می‌شود:

الگوریتم پروانه آتش

که ub کران بالا و ul کران پایین مقدار متغیر i است. بدین ترتیب برای n در d بعد قادر به تولید جواب اولیه هستیم. پس از مقدار دهی اولیه می‌توان تناسب هر یک از راه حل را حساب کرد بنابراین OM مقدار تابع تناسب ماتریس M یا پروانه‌ها خواهد بود.

تکرار الگوریتم

پس از مقدار دهی اولیه،حرکت پروانه‌ها یا تابع P به طور تکراری اجرا می‌شود تا عملکرد T یعنی حد همگرایی به شعله یا شمع، مقدار True را برگرداند. عملکرد P عملکرد اصلی است که پروانه‌ها را در فضای جستجو حرکت می‌دهد. همانطور که گفته شد الهام بخش این الگوریتم جهت گیری عرضی است.

مارپیچ لگاریتمی

مارپیچ لگاریتمی (logarithmic spiral) به عنوان مکانیزم اصلی بروزرسانی پروانه در این الگوریتم انتخاب شده است. با این وجود، هر نوع مارپیچ با توجه به شرایط زیر قابل استفاده است:

  • نقطه اولیه Spiral باید از پروانه شروع شود.
  • نقطه آخر Spiral باید موقعیت شعله باشد.
  • نوسان دامنه مارپیچ نباید از فضای جستجو تجاوز کند.

با توجه به این نکات ، یک مارپیچ لگاریتمی برای الگوریتم MFO به شرح زیر تعریف می‌شود:

الگوریتم پروانه آتش

که در این رابطه Di فاصله پروانه i ام برای شعله j ام را نشان می‌دهد ، b یک ثابت برای تعیین شکل مارپیچ لگاریتمی است و t یک عدد تصادفی در بازه [۱ ، ۱-] است. D به شرح زیر محاسبه می‌شود:

الگوریتم پروانه آتش

در معادله مارپیچی لگاریتمی مسیر پرواز مارپیچی پروانه‌ها در الگوریتم شمع و پروانه شبیه سازی می‌شود. همانطور که در این معادله دیده می‌شود، موقعیت بعدی پروانه با توجه به شعله تعریف می‌شود. پارامتر t در معادله مارپیچی مشخص می‌کند که موقعیت بعدی پروانه باید نزدیک شعله باشد (t=-1 نزدیکترین موقعیت به شعله است ، در حالی که t =1 دورترین را نشان می‌دهد). بنابراین می توان یک شکل بیضی وار از اطراف شعله در همه جهات فرض کرد و موقعیت بعدی پروانه در این فضا قرار گرفت.

حرکت مارپیچی

حرکت مارپیچ اصلی ترین روش پیشنهادی است زیرا چگونگی به روزرسانی پروانه‌ها مواضع خود را در اطراف شعله‌ها نشان می‌دهد. معادله مارپیچی به پروانه‌ای اجازه می‌دهد تا “اطراف” شعله‌ها پرواز کند و نه لزوماً در فضای بین آنها. بنابراین ، اکتشاف و بهره برداری از فضای جستجو می‌تواند تضمین شود. مارپیچ لگاریتمی ، فضای اطراف شعله و موقعیت با در نظر گرفتن t متفاوت در منحنی در شکل زیر نشان داده شده است.

الگوریتم MFO

به روزرسانی موقعیت یک پروانه

شکل زیر یک مدل مفهومی از به روزرسانی موقعیت یک پروانه در اطراف شعله در الگوریتم شمع و پروانه را نشان می‌دهد. توجه داشته باشید که محور عمودی تنها یک بعد را نشان می‌دهد، اما از الگوریتم شعله پروانه می‌توان برای تغییر کلیه متغیرهای مسئله استفاده کرد. موقعیت‌های احتمالی (خطوط سیاه رنگی) که می‌توانند بعنوان موقعیت بعدی پروانه (خط افقی آبی) در اطراف شعله (خط افقی سبز) در شکل انتخاب شوند.

در ادامه مطلب پاورپوینت آماده الگوریتم شعله و پروانه در Microsoft Powerpoint با پسوند pptx. در ۱۶ اسلاید بصورت فارسی به توضیح کامل الگوریتم شمع و پروانه MFO و اصول کلی در آن می پردازد. برای تهیه این پاورپوینت بر روی لینک زیر کلیک کنید.

به وضوح نشان می‌دهند که یک پروانه می‌تواند فضای جستجوی اطراف اطراف را کاوش و بهره برداری کند. شعله در یک بعد. اکتشاف هنگامی اتفاق می‌افتد که موقعیت بعدی در خارج از فضای بین پروانه و شعله باشد ، همانطور که در فلش‌های دارای برچسب ۱ ، ۳ و ۴ مشاهده می‌شود. بهره برداری زمانی اتفاق می‌افتد که موقعیت بعدی در فضای بین پروانه و شعله قرار داشته باشد. در فلش با برچسب ۲. مشاهدات جالبی برای این مدل وجود دارد:

الگوریتم MFO

نتیجه گیری

در این مقاله سعی شد تا روش کار الگوریتم MFO یا الگوریتم شمع و پروانه تشریح شود. این الگوریتم با توجه به رفتار پروانه ها در چرخش به دور شعله مدلی ارائه می دهد تا راه حل های احتمالی یعنی همان پروانه ها نسبت به شعله یعنی جواب های بهینه همگرا شوند. این الگوریتم کارایی زیادی در زمینه حل مسائل پیوسته و NP-Hard دارد و به استناد مقاله اصلی می توان از این روش برای حل بسیاری از مسائل سخت استفاده کرد.

میزان رضایتمندی
لطفاً میزان رضایت خودتان را از این مطلب با دادن امتیاز اعلام کنید.
[ امتیاز میانگین 0 از 0 نفر ]
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع و مراجع:
sciencedirect

دیدگاه‌ خود را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *



برچسب‌ها:
الگوریتم فرا ابتکاری


پیمایش به بالا