Algoritma kunang-kunang

Dari testwiki
Revisi sejak 10 Maret 2025 23.22 oleh imported>InternetArchiveBot (Add 1 book for Wikipedia:Pemastian (20250309)) #IABot (v2.0.9.5) (GreenC bot)
(beda) ← Revisi sebelumnya | Revisi terkini (beda) | Revisi selanjutnya → (beda)
Loncat ke navigasi Loncat ke pencarian

Dalam 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]

Algoritma

Dalam bentuk pseudocode, algoritma ini dapat dinyatakan sebagai:

Begin
  1) Fungsi objektif: Templat:Nowrap
  2) Inisialisasi populasi awal kunang-kunang Templat:Nowrap
  3) Tentukan intensitas cahaya Templat:Mvar sehingga berhubungan dengan Templat:Nowrap
    (misalnya, untuk masalah maksimalisasi, Templat:Nowrap
  4) Definisikan koefisien light absorption Templat:Mvar

  while (t < MaksGenerasi) atau (KriteriaBerhenti = true)
    for i = 1 : n (semua n kunang-kunang)
      for j = 1 : i (n kunang-kunang)
        Templat:Nowrap
          Variasikan daya tarik (attractiveness) dengan jarak r melalui Templat:Nowrap
          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 𝐱i dan 𝐱j adalah

𝐱it+1=𝐱it+βexp[γrij2](𝐱jt𝐱it)+αtϵt

Di mana αt adalah suatu parameter yang mengatur besar langkah atau ukuran langkah. Parameter ini menentukan sejauh mana firefly bergerak untuk setiap iterasi. Dengan nilai αt yang lebih besar, firefly akan bergerak lebih jauh dalam ruang pencarian solusi. Jika αt lebih kecil, pergerakan firefly akan lebih terbatas. Sedangkan ϵt 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 γ0, firefly algorithm mendekati standar Particle Swarm Optimization (PSO). Faktanya, jika iterasi looping bagian dalam (for j) dihilangkan dan kecerahan Ij digantikan dengan g*, 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.

Kritik

Metaheuristik 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 juga

Referensi

  1. Templat:Cite book
  2. Templat:Cite journal
  3. Templat:Cite book
  4. Templat:Cite journal

Pranala luar

  • [1] File program Matlab yang terdapat dalam buku: Xin-She Yang, Algoritma Metaheuristik Terinspirasi Alam, Edisi Kedua, Luniver Press, (2010).