U informatici i operacionim istraživanjima, pčelinji algoritam (eng. Bees algorithm) je algoritam pretrage na osnovu populacije koji je razvijen 2005. godine.[1] Algoritam imitira ponašanje kolonija pčela prilikom potrage za hranom. U svojoj osnovnoj verziji izvršava pretraživanje susedstva u kombinaciji sa globalnim pretraživanjem, i može se koristiti i za kombinatornu i za kontinuiranu optimizaciju. Jedini uslov za upotrebu pčelinjeg algoritma je da su neke mere topološke udaljenosti između rešenja definisane. Efikasnost ovog algoritma se pokazala u mnogim istraživanjima.[2][3]
Kolonija pčela se može raširiti u nekoliko pravaca istovremeno sa ciljem prikupljanja nektara ili polena i na taj način pokriti veliko prostranstvo (preko 14 km).[4] Mali deo kolonije konstantno pretražuje oruženje tražeći nove izvore nektara. Ove pčele izviđači se kreću nasumično u okolini košnice, procenjujući vrednost resursa na koje naiđu.[4] Kada se vrate u košnicu, skladište pokupljenu hranu. Pčele koje su pronašle vredne izvore nektara, odlaze u deo košnice koji se naziva "podijum za igru" i tu izvode ritual plešući.[5] Pomoću ovog plesa, pčele komuniciraju sa ostalim pčelama koje nisu bile u ekspediciji, objašnjavajući im na taj način gde se željeni ivor hrane nalazi. Pošto je vreme trajanja plesa proporcionalno oceni resursa pčele izviđača, još dodatnih sakupljača se organizuje da ide u potragu za hranom. Nakon plesa, pčela se vraća cvetu kako bi sakupila još hrane. Dokle god se smatraju vrednim, izvori hrane će biti "reklamirani" od strane pčela sakupljača kroz ples u košnici. Novi regruti mogu takođe učestvovati u plesu i na taj način pozivati što više novih pčela da se priključe sakupljanju. Zahvaljujući ovom procesu, kolonija je u stanju da se fokusira samo na najvrednije izvore hrane.[4]
Pčelinji algoritam[2][6] imitira strategiju pčela u traženju najboljeg rešenja za optimizaciju problema. Svaki kandidat za rešenje se smatra izvorom hrane (cvetom), a populacija (kolonija) pčela se koristi za pretragu. Svaki put kada pčela poseti cvet, ona procenjuje njegovu vrednost. Algoritam se sastoji od inicijalizacije i glavnog ciklusa pretrage kroz koji se prolazi puta, ili dok se ne pronađe odgovarajuće rešenje. Svaki ciklus pretrage se sastoji iz pet koraka: regrutovanje, lokalna pretraga, sužavanje komšiluka pretrage, napuštanje teritorije i globalna pretraga.
Pseudo kod osnovnog pčelinjeg algoritma
1 for i=1,…,ns
i scout[i]=Initialise_scout()
ii flower_patch[i]=Initialise_flower_patch(scout[i])
2 do until stopping_condition=TRUE
i Recruitment()
ii for i =1,…,nb
1 flower_patch[i]=Local_search(flower_patch[i])
2 flower_patch[i]=Site_abandonment(flower_patch[i])
3 flower_patch[i]=Neighbourhood_shrinking(flower_patch[i])
iii for i = nb,…,ns
1 flower_patch[i]=Global_search(flower_patch[i])}
Prilikom inicijalizacije, pčela izviđača se nasumice postavlja u području pretrage, procenjujući vrednost rešenja (polje cveća) kod kojeg su se zatekle. Za svako rešenje, polje cveća (u algoritmu flower_patch) se označava. Tokom procesa regrutovanja, izviđači koji su posetili najboljih rešenja izvode ritual plesa. Naime, regrutuju dodatne pčele sakupljače da istražuju komšiluk rešenja koja najviše obećavaju. Svaki od izviđača koji su locirali najbolja rešenja regrutuju pčela sakupljača, dok svaki od preostaliih izviđača regrutuje sakupljača. Na taj način broj sakupljača zavisi od vrednosti pronađenog izvora hrane. U toku lokalne pretrage, regrutovani sakupljači su nasumice raštrkani po cveću u okolini rešenja (trenutno najboljih) posećenih od strane izviđača (lokalna eksploatacija). Ako bilo koja od pčela sakupljača u cveću naiđe na rešenje veće vrednosti od onog koje je pronašla pčela istraživač, ta pčela postaje novi istraživač. U koliko nijedan sakupljač ne pronađe rešenje veće vrednosti od tekućeg, veličina polja cveća se sužava (procedura sužavanje komšiluka pretrage). Polja cveća se u procesu inicijalizacije obično definišu tako da pokrivaju veliku površinu, a zatim se postepeno smanjuju tokom procedure sužavanja. Rezultat toga je da se područje lokalne pretrage postepeno fokusira na prostor uz samo cveće najveće lokalne vrednosti. Ako za predoređen broj ciklusa pretrage nije pronađeno veće rešenje u okviru polja cveća, lokalno rešenje najveće vrednosti se smatra pronađenim, polje se napušta i novi izviđač se nasumice generiše. Kao i kod pčela u realnom svetu, mali broj izviđača nastavlja sa pretragom prostora rešenja, u nadi da će pronaći deo velike vrednosti (globalna pretraga). Procedura globalne pretrage reinicijalizuje poslednjih polja cveća sa nasumice generisanim rešenjima.
Na kraju svakog ciklusa pretrage, broj izviđača se ponovo sastoji iz pčela: izviđača proizvedenih tokom lokalne pretrage (od kojih su neki možda reinicijalizovani tokom napuštanja područja), i izviđača generisanih tokom globalne pretrage. Ukupna veličina veštačke kolonije pčela je:
(sakupljači sa elitnih polja + sakupljači sa preostalih najboljih polja + izviđači).
^Pham DT, Ghanbarzadeh A, Koc E, Otri S, Rahim S and Zaidi M. The Bees Algorithm. Technical Note, Manufacturing Engineering Centre, Cardiff University, UK, 2005.
^Von Frisch, K. (1967) The Dance Language and Orientation of Bees. Harvard University Press, Cambridge, MA.
^Pham D.T., Ghanbarzadeh A., Koc E., Otri S., Rahim S., Zaidi M., The Bees Algorithm, A Novel Tool for Complex Optimisation Problems, Proc 2nd Int Virtual Conf on Intelligent Production Machines and Systems (IPROMS 2006), Oxford: Elsevier. стр. 454-459, 2006.
^Pham D.T., Castellani M., Ghanbarzadeh A. (2007), Preliminary design using the Bees Algorithm, Proceedings Eighth LAMDAMAP International Conference on Laser Metrology, CMM and Machine Tool Performance. Cardiff - UK, 420-429.
^Pham, D.T., Otri S., Darwish A.H. (2007), Application of the Bees Algorithm to PCB assembly optimisation, Proceedings 3rd International Virtual Conference on Intelligent Production Machines and Systems (IPROMS 2007), Whittles, Dunbeath, Scotland, 511-516.
^Pham D.T., Koç E., Lee J.Y., Phrueksanant J. (2007), Using the Bees Algorithm to Schedule Jobs for a Machine, Proceedings 8th international Conference on Laser Metrology, CMM and Machine Tool Performance (LAMDAMAP). Cardiff, UK, Euspen, 430-439.
^Xu, Wenjun; Zhou, Zude; Pham, D. T.; Liu, Quan; Ji, C.; Meng, Wei (2012). „Quality of service in manufacturing networks: A service framework and its implementation”. The International Journal of Advanced Manufacturing Technology. 63 (9–12): 1227—1237. S2CID253681068. doi:10.1007/s00170-012-3965-y.
^Alfi A., Khosravi A., Razavi S.E. (2011), Bee Algoritm–Based Nolinear Optimal Control Applied To A Continuous Stirred-Tank Chemical Reactor, Global Journal of Pure & Applied Science and Technology - GJPAST 1(2), 73-79.
^Bahamish H.A.A., Abdullah R., Salam R.A. (2008), Protein Conformational Search Using Bees Algorithm, Second Asia International Conference on Modeling & Simulation (AICMS 08), Kuala Lumpur, Malaysia, IEEE Press, 911-916.
^Ruz, Gonzalo A.; Goles, Eric (2013). „Learning gene regulatory networks using the bees algorithm”. Neural Computing and Applications. 22: 63—70. S2CID254037353. doi:10.1007/s00521-011-0750-z.
^Pham, D. T.; Koç, Ebubekir (2010). „Design of a two-dimensional recursive filter using the bees algorithm”. International Journal of Automation and Computing. 7 (3): 399—402. S2CID124240746. doi:10.1007/s11633-010-0520-x.
^Lee, Ji Young; Darwish, Ahmed Haj (2008). „Multi-objective Environmental/Economic Dispatch Using the Bees Algorithm with Weighted Sum”. EKC2008 Proceedings of the EU-Korea Conference on Science and Technology. Springer Proceedings in Physics. 124. стр. 267—274. ISBN978-3-540-85189-9. doi:10.1007/978-3-540-85190-5_28.
^Sayadi F., Ismail M., Misran N., Jumari K. (2009), Multi-Objective Optimization Using the Bees Algorithm in Time-Varying Channel for MIMO MC-CDMA Systems, European Journal of Scientific Research 33(3), 411-428.
^Mansouri Poor M., Shisheh Saz M. (2012), Multi-Objective Optimization of Laminates with Straight Free Edges and Curved Free Edges by Using Bees Algorithm, American Journal of Advanced Scientific Research 1(4), 130-136.