۱. مقدمه:
در بسیاری از ابداعات بشر، انسان از موارد موجود در طبیعت الهام گرفته است. مطلبی که در این پروژه مد نظر قرار داده شده است استفاده از رفتار مورچهها در طبیعت برای یافت غذا میباشد. مورچهها برای به دست آوردن غذا رفتار جالبی از خود نشان میدهند. انها وقتی برای یافتن غذا از لانه خود بیرون میآیند به صورت اتفاقی در یک جهت به حرکت خود ادامه میدهند و پس از یافتن غذا در مسیر بازگشت به لانه مادهای را بر روی زمین برجا میگذارند. در هنگام رسیدن به لانه بقیه مورچهها متوجه میشوند که باید مسیر بو را دنبال کنند تا به غذا برسند. اما نکتهای که باعث شده است تا این رفتار مورچهها الهام بخش استفاده از آن در زمینه علوم کامپیوتر شود قابلیت تشخیص شدت بو توسط مورچههاست. بویی که مورچهها از خود بر روی زمین باقی میگذارند مادهای است که پس از گذشت مدتی بخار میشود و شدت آن کاهش مییابد. در این صورت هنگامی که مورچه میخواهد مسیری را دنبال کند با استفاده از قابلیت ذکر شده مسیری را انتخاب میکند که بوی باقیمانده بر روی آن بیشتر باشد. این مسیر به دلیل اینکه مسیر کوتاهتری برای رسیدن به غذاست بوی باقیمانده بر روی آن کمتر از بین میرود. لازم به ذکر است که مورچهها پس از طی مسیر دوباره همان ماده را در راه ترشح میکنند تا از بین نرود. پس از گذشت مدتی مورچهها کوتاهترین مسیر را برای رسیدن به هدف خود مییابند.
این مسئله برای اولین بار با انجام آزمایشی اثبات شد که یک کلننی مورچه را در یک محفظه قرار دادند و دو راه برای رسیدن به غذا برای مورچهها قرار دادند که یکی از آنها کوتاهتر بود. با گذشت زمان رفت آمد مورچهها تغییر کرد و به حالتی در آمد که همه از مسیر کوتاهتر میرفتند.[1]
با مطالعه این رفتار مورچهها برای اولین بار در سال 1991 آقای M. Dorigo مبدع ایجاد الگوریتمهایی شدند که امروزه به Ant Colony Optimization یا به طور مخفف ACO شناخته میشوند. [2] ایشان از جمله افرادی بودند که رفتارهای حشرات را وارد دنیای کامپیوتر کردند. [12] این الگوریتمها با استفاده از شبیهسازی همین رفتار در مورچهها قادر به حل تعدادی از مسائل ترکیبیاتی هستند. از جمله این مسائل میتوان به فروشنده دورهگرد و مسئله کولهپشتی اشاره کرد. این دسته از الگوریتمها کاربردهای بسیاری دارند که در بخش بعدیبه برخی از آنها پرداخته شده است. هدف این پروژه این است که نوعی از ACO را برای حل مسئله فروشنده دورهگرد پیادهسازی کرد.[3]
۲. کاربردهای ACO:
الگوریتمهای ACO دارای انواع مختلفی هستند که به صورت جدول زیر میباشند.[4]
در زیر برخی از کاربردهای این نوع الگوریتمها به طور خاص به اختصار ذکر شده است.
برنامهنویسی خودکار به وسیله ACO:
برنامهنویسی خودکار نوعی تکنیک جستوجو برای یافتن یک برنامه که یک مسئله را حل میکند میباشد. شناخته شده ترین راه این نوع برنامهنویسی، برنامهنویسی ژنتیک میباشد که در آن از الگوریتمهای ژنتیک برای یافتن برنامه استفاده میشود. در روشی جدیدتر از تکنیکی به نام Ant Colony Programming که به اختصار به آن ACP گفته میشود استفاده شده است. [5]
دادهکاوی با استفاده از ACO:
تحقیقاتی بر روی دادهکاوی با استفاده از ACO صورت گرفته است که یکی از آنها دادهکاوی برای کلاسبندی میباشد. الگوریتمی که برای این کار ارائه شده است Ant-Miner نام دارد. شواهد به دست آمده از این تحقیقات حاکی از آن است که این روش قابلیت رقابت با الگوریتم CN2 که یکی از شناخته شده ترین الگوریتمها برای کلاسبندی است قابل رقابت میباشد. از ACO برای دادهکاوی برای Clustering نیز استفاده شده است.[7]
تحلیل تصویر با استفاده از ACO:
روشی برای تشخیص کنارههای یک تصویر با استفاده از ACO ارائه شده است. با استفاده از این روش میتوان کنارههای یک عکس دیجیتال را تشخیص داد که در زمینههای دید ماشین و تحلیل تصویر و دانستن محتوای درون تصویر کاربرد دارد.[6]
۳. مراجع:
S. Goss, S. Aron, J.-L. Deneubourg et J.-M. Pasteels, Self-organized shortcuts in the Argentine ant, Naturwissenschaften, volume 76, pages 579-581, 1989
M. Dorigo, Optimization, Learning and Natural Algorithms, PhD thesis, Politecnico di Milano, Italy, 1992.
Michel Gendreau, Jean-Yves PotwinHandbook of Metaheuristics 2nd Edition, Springer 2010
M. Dorigo & T. Stützle, 2004. Ant Colony Optimization, MIT Press. ISBN 0-262-04219-3
Green, Jennifer, Jacqueline L. Whalley, and Colin G. Johnson. "Automatic programming with ant colony optimization." Proceedings of the 2004 UK Workshop on Computational Intelligence. Loughborough University, 2004.
Baterina, Anna Veronica, and Carlos Oppus. "Image edge detection using ant colony optimization." WSEAS Transactions on Signal Processing 6.2 (2010): 58-67.
Parpinelli, Rafael S., Heitor S. Lopes, and Alex Alves Freitas. "Data mining with an ant colony optimization algorithm." Evolutionary Computation, IEEE Transactions on 6.4 (2002): 321-332.
Darquennes, Denis. "Implementation and Applications of Ant Colony Algorithms." Facultées Universitaires Notre-Dame de la Paix, Namur Institut d’Informatique 40 (2005).
Dorigo, Marco. "Ant algorithms solve difficult optimization problems." Advances in Artificial Life. Springer Berlin Heidelberg, 2001. 11-22.
Yaseen, Saad Ghaleb, and Nada MA Al-Slamy. "Ant colony optimization."IJCSNS 8.6 (2008): 351.
Gutjahr, Walter J. "First steps to the runtime complexity analysis of ant colony optimization." Computers & Operations Research 35.9 (2008): 2711-2727.
Bonabeau, Eric, Marco Dorigo, and Guy Theraulaz. "Inspiration for optimization from social insect behaviour." Nature 406.6791 (2000): 39-42.
Doerr, Benjamin, et al. "On the influence of pheromone updates in ACO algorithms." (2007).
GiriRajkumar, S. M., Dr K. Ramkumar, and O. V. Sanjay Sarma. "Real time application of ants colony optimization." International Journal of Computer Applications (0975-8887) Vol (2010).