Algoritma kunang-kunangDalam kasus optimasi matematika, algoritma kunang-kunang atau firefly algorithm adalah salah satu algoritma metaheuristik yang pertama kali dikemukakan oleh Xin-She Yang. Algoritma ini terinspirasi oleh perilaku berkedip yang dilakukan oleh kunang-kunang.[1] AlgoritmaDalam bentuk pseudocode, algoritma ini dapat dinyatakan sebagai: Begin 1) Fungsi objektif: ; 2) Inisialisasi populasi awal kunang-kunang ;. 3) Tentukan intensitas cahaya I sehingga berhubungan dengan (misalnya, untuk masalah maksimalisasi, atau ;) 4) Definisikan koefisien light absorption γ while (t < MaksGenerasi) atau (KriteriaBerhenti = true) for i = 1 : n (semua n kunang-kunang) for j = 1 : i (n kunang-kunang) if (), Variasikan daya tarik (attractiveness) dengan jarak r melalui ; Gerakkan kunang-kunang i menuju j untuk semua dimensi d; Evaluasi solusi baru dan perbarui intensitas cahaya (light intensity); end if end for j end for i Buat peringkat kunang-kunang dan cari yang terbaik saat ini (current best); end while end Perhatikan bahwa jumlah evaluasi terhadap fungsi objektif pada setiap iterasi adalah satu evaluasi untuk setiap kunang-kunang, meskipun pseudocode di atas menunjukkan sebesar n × n. (Berdasarkan kode MATLAB oleh Yang). Jadi, banyaknya evaluasi terhadap fungsi objektif adalah sebesar (jumlah generasi) × (jumlah kunang-kunang). Rumus pembaruan utama untuk sepasang kunang-kunang dan adalah Di mana adalah suatu parameter yang mengatur besar langkah atau ukuran langkah. Parameter ini menentukan sejauh mana firefly bergerak untuk setiap iterasi. Dengan nilai yang lebih besar, firefly akan bergerak lebih jauh dalam ruang pencarian solusi. Jika lebih kecil, pergerakan firefly akan lebih terbatas. Sedangkan adalah sebuah vektor yang diambil dari distribusi Gaussian atau distribusi lainnya, parameter ini digunakan untuk memberikan komponen acak pada pergerakan firefly. Hal ini dapat memberikan variasi pada posisi firefly dan membantu mencegah terjebaknya proses pencarian pada minimum lokal. Hal ini dapat ditunjukkan bahwa dengan kasus pembatas , firefly algorithm mendekati standar Particle Swarm Optimization (PSO). Faktanya, jika iterasi looping bagian dalam (for j) dihilangkan dan kecerahan digantikan dengan , global terbaik saat ini, maka FA pada dasarnya menjadi PSO standar. Artinya, FA dan PSO memiliki keterkaitan yang mendalam, dan ketika suatu parameter pada FA didekati nol, FA akan berkembang menjadi PSO. KritikMetaheuristik yang terinspirasi dari alam secara umum telah menuai kritik dari komunitas riset karena menyembunyikan kurangnya kebaruan di balik metafora yang digunakan. Firefly algorithm telah dikritik karena perbedaan dari Particle Swarm Optimization (PSO) yang sudah ada hanya dalam hal yang dapat diabaikan atau sederhana (kurang signifikan).[2] [3] [4] Lihat jugaReferensi
Pranala luar
|