Metode Nelder-Mead

'

Metode Nelder-Mead diterapkan untuk mencari nilai minimum fungsi Himmelblau.

Metode Nelder-Mead, dikenal pula sebagai metode polihedron fleksibel, metode amoeba, atau metode downhill simplex, adalah suatu metode numerik untuk menemukan nilai minimum atau maksimum dari sebuah fungsi objektif multivariabel. Metode ini termasuk metode telusur langsung (dengan membandingkan nilai fungsi) dan umum diterapkan pada masalah optimisasi nonlinear dengan turunan fungsi objektif yang mungkin tidak diketahui. Akan tetapi, metode Nelder-Mead juga merupakan metode telusur heuristik, yang dapat konvergen ke titik non-stasioner[1] pada masalah yang bisa diselesaikan oleh metode-metode alternatif.[2]

Metode Nelder-Mead diperkenalkan oleh John Nelder dan Roger Mead pada tahun 1965,[3] sebagai pengembangan metode Spendley et al.[4] Sebagai contoh penerapan, metode ini dapat dipakai untuk menghitung komposisi beton bertulang pada struktur beton bertulang, sehingga dapat diketahui komposisi struktur yang efisien apabila diketahui harga masing-masing komponen struktur beton bertulang.

Gambaran umum sunting

Metode Nelder-Mead menggunakan konsep simpleks, yakni suatu bentuk politop yang memiliki   sisi dalam   dimensi. Contoh-contoh simpleks antara lain adalah: ruas garis dalam ruang satu dimensi, segitiga dalam ruang dua dimensi, tetrahedron dalam ruang tiga dimensi, dan seterusnya. Metode ini menentukan hampiran nilai optimal dari masalah dengan   variabel, yang fungsi objektifnya bersifat mulus dan unimodal. Penerapan metode yang umum adalan untuk mencari minimum fungsi; mencari maksimum fungsi   dilakukan dengan meminimumkan  .

Sebagai contoh, seorang insinyur jembatan gantung harus menentukan tebal setiap penyangga, kabel, dan tiang dari jembatan. Semua komponen tersebut saling bergantung, namun tidak mudah untuk memvisualisasikan dampak dari mengubah tebal dari suatu komponen. Simulasi struktur yang rumit seperti itu sering kali sangat mahal secara komputasi untuk dijalankan, mungkin membutuhkan waktu berjam-jam untuk setiap eksekusi. Metode Nelder-Mead membutuhkan, dalam varian aslinya, tidak lebih dari dua evaluasi per iterasi, kecuali untuk operasi penyusutan yang akan dijelaskan nanti. Hal tersebut yang membuat metode ini menarik, dibandingkan dengan beberapa metode optimasi penelusuran langsung lainnya. Tapi, metode ini mungkin memerlukan total iterasi yang besar untuk mencapai nilai optimal.

 
Titik-titik pada iterasi metode Nelder-Mead pada ruang dimensi dua.
 
Pencarian nilai minimum fungsi Simionescu menggunakan Nelder–Mead.

Nelder-Mead dalam   dimensi mencatat sebuah himpunan   titik uji yang disusun sebagai sebuah simpleks. Metode ini lalu mengekstrapolasi perilaku fungsi objektif yang diukur pada setiap titik uji untuk menemukan titik uji baru, yang selanjutnya digunakan untuk menggantikan satu titik uji yang lama; lalu proses diulangi lagi. Cara penerapan termudah adalah mengganti titik uji terburuk dengan titik uji yang dihasilkan dari pencerminannya dengan sentroid (titik pusat) dari   titik uji yang lain. Jika titik baru ini lebih baik daripada titik uji terbaik saat ini, kita dapat mencoba merenggangkan titik uji ini dari sentroid. Tapi jika titik baru tidak lebih baik daripada sebelumnya, kita akan mengecilkan ukuran simpleks. Berikut penjelasan yang intuitif dari Numerical Recipes:[5]

Metode downhill simplex sekarang mengambil serangkaian langah, sebagian besar langkah hanyalah menggerakkan titik pada simpleks dengan nilai fungsi terbesar (titik tertinggi) melewati sisi simpleks yang menghadapnya, ke titik yang lebih rendah. Tahap ini disebut pencerminan, dan dilakukan dengan cara yang menjaga volume dari simpleks (untuk mempertahankan sifat non-degeneratifnya). Jika tahap tersebut bisa dilakukan, Metode akan memperbesar simpleks ke suatu arah tertentu untuk mengambil "langkah yang lebih besar". Ketika mencapai "dasar lembah", Metode akan menyempitkan ukuran dirinya dan mencoba mengalir menelurusi lembah. Jika ada situasi ketika metode mencoba "melewati lubang jarum", simpleks akan menyusut dari semua arah, menarik dirinya sendiri disekitar titik terendahnya (terbaik).

Berbeda dengan metode-metode optimisasi modern, heuristik yang digunakan Nelder-Mead dapat konvergen ke titik non-stasioner, kecuali jika masalah memenuhi kondisi-kondisi kuat yang lebih banyak daripada yang diperlukan metode-metode modern.[1] Perbaikan-perbaikan modern untuk heuristik Nelder-Mead telah ditemukan sejak tahun 1979.[2]

Banyak variasi metode yang muncul bergantung dari sifat dari masalah yang ingin diselesaikan. Salah satu variasi yang umum menggunakan simpleks kecil berukuran tetap, yang bergerak mengikuti arah gradien (mirip metode penurunan gradien). Hal ini dapat dibayangkan sebagai sebuah segitiga mengelinding menuruni lembah menuju dasarnya. Metode ini juga dikenal dengan metode polihedron fleksibel. Tapi performa metode ini cenderung buruk ketimbang metode yang dijelaskan pada artikel ini, karena melakukan langkah-langkah kecil yang tidak diperlukan, pada daerah fungsi yang tidak diminati.

Salah satu variasi metode Nelder-Mead sunting

Variasi yang disajikan di bagian ini mirip dengan prosedur yang disajikan pada artikel asli Nelder-Mead. Dalam metode ini, kita ingin meminimumkan fungsi  , dengan  . Titik-titik uji saat ini adalah  .

  1. Pengurutan dilakukan berdasarkan nilai dari setiap titik uji,  Titik   akan menjadi titik dengan nilai fungsi terburuk. Cek jika metode perlu dihentikan. Lihat bagian Kriteria penghentian (juga disebut dengan "kekonvergenan").
  2. Hitung  , sentroid dari semua titik uji selain  .
  3. Pencerminan Hitung titik hasil pencerminan   dengan  . Jika titik pencerminan lebih baik daripada titik kedua terburuk namun tidak daripada titik terbaik, dengan kata lain  , maka buat simpleks baru dengan menukar titik terburuk   dengan titik pencerminan  , dan kembali ke Tahap 1.
  4. Perluasan terjadi jika titik pencerminan lebih baik daripada titik terbaik saat ini,  . Hal ini dilakukan dengan menghitung titik perluasan   dengan  . Jika titik perluasan lebih baik daripada titik pencerminan,  , maka buat simpleks baru dengan menukar titik terburuk   dengan titik perluasan  . Tapi jika tidak, simpleks baru dibuat dengan menukar titik terburuk dengan titik pencerminan  , dan kembali ke Tahap 1.
  5. Penyempitan. Pada tahap ini jelas titik pencerminan lebih buruk daripada titik kedua terburuk,  . Selanjutnya:
    • Jika  , maka hitung titik penyempitan   dengan  . Lalu, jika titik penyempitan lebih baik daripada titik pencerminan,  , buat simpleks baru dengan menukar titik terburuk   dengan titik penyempitan  , dan kembali ke Tahap 1.
    • Tapi jika tidak, yakni  , titik penyempitan dihitung sebagai   dengan  . Lalu, jika titik penyempitan lebih baik daripada titik terburuk  , buat simpleks baru dengan menukar titik terburuk   dengan titik penyempitan  , dan kembali ke Tahap 1.
  6. Penyusutan. Tukar nilai setiap titik uji selain titik terbaik ( ) dengan  , lalu kembali ke Tahap 1.

Pada prosedur metode di atas, simbol  ,  ,   dan   secara berurutan menyatakan koefisien besar pencerminan, perluasan, penyempitan, dan penyusutan. Nilai yang umum digunakan adalah  ,  ,   dan  .

Beberapa tahap dapat dijelaskan secara intuitif sebagai berikut. Dalam tahap pencerminan,   merupakan titik uji dengan nilai terbesar dibandingkan titik-titik uji lainnya. Kita dapat mengharapkan titik uji yang lebih baik (nilai fungsi yang lebih kecil) dengan mencerminkan titik ini ke sisi simpleks (dengan sentroid  ) yang menghadap dirinya. Lalu pada tahap perluasan, jika titik   menjadi minimum terbaik saat ini, kita dapat mengharapkan ada nilai yang lebih baik diantara titik   dan  . Di tahap penyempitan, jika  , kita dapat mengharapkan nilai yang lebih baik di dalam simpleks saat ini. Terakhir, tahap penyusutan mengurus kasus langka ketika titik penyempitan menghasilkan nilai fungsi yang lebih besar, yang menurut kutipan Nelder-Mead dijelaskan berikut:

Proses penyempitan yang gagal jarang ditemui, namun dapat terjadi ketika pada lembah melengkung dan satu titik simpleks terletak sangat jauh dari dasar lembah daripada yang lain; penyempitan dapat menyebabkan titik pencerminan menjauhi dasar lembah dan bukannya menuju ke sana. Alhasil penyempitan-penyempitan berikutnya menjadi tidak berguna. Tindakan yang diusulkan akan menyusutkan simpleks ke arah titik uji terendah, yang pada akhirnya akan membawa semua titik ke dasar lembah.

Akan tetapi, Nash menunjukkan implementasi pada aritmetika presisi-tetap dapat gagal untuk menyusutkan simpleks, sehingga sebuah uji tambahan untuk mengecek ukuran simpleks diperlukan.[6]

Penentuan simpleks awal sunting

Hasil dari metode Nelder-Mead bergantung pada simpleks awal yang dipilih. Simpleks dengan ukuran yang kecil dapat membuat metode sering terjebak dalam penelurusan lokal, dan tidak menghasilkan minimum global. Nelder dan Mead menyarankan simpleks dibuat dari suatu titik   dan titik pada setiap dimensi lainnya berjarak konstan dari   Alhasil cara ini sensitif terhadap penskalaan dari variabel-variabel yang menyusun  .

Kriteria penghentian sunting

Suatu kriteria diperlukan untuk menghentikan siklus iterasi. Nelder dan Mead menggunakan nilai standar deviasi sampel dari nilai-nilai fungsi dari simpleks terbaru. Jika nilai tersebut berada dibawah suatu batas toleransi, maka siklus dihentikan dan nilai fungsi terkecil dari simpleks dipilih sebagai nilai optimal. Kriteria ini dapat sensitif terhadap toleransi, khususnya pada fungsi yang "datar", nilai setiap titik uji dapat sangat mirip walau simpleks masih berukuran besar. Nash mengusulkan uji penyusutan sebagai alternatif kriteria penghentian.[6]

Referensi sunting

  1. ^ a b * Powell, Michael J. D. (1973). "On Search Directions for Minimization Algorithms". Mathematical Programming. 4: 193–201. doi:10.1007/bf01584660. 
  2. ^ a b * Yu, Wen Ci. 1979. "Positive basis and a class of direct search techniques". Scientia Sinica [Zhongguo Kexue]: 53—68.
  3. ^ Nelder, John A.; R. Mead (1965). "A simplex method for function minimization". Computer Journal. 7 (4): 308–313. doi:10.1093/comjnl/7.4.308. 
  4. ^ Spendley, W.; Hext, G. R.; Himsworth, F. R. (1962). "Sequential Application of Simplex Designs in Optimisation and Evolutionary Operation". Technometrics. 4 (4): 441–461. doi:10.1080/00401706.1962.10490033. 
  5. ^ Press, W. H.; Teukolsky, S. A.; Vetterling, W. T.; Flannery, B. P. (2007). "Section 10.5. Downhill Simplex Method in Multidimensions". Numerical Recipes: The Art of Scientific Computing (edisi ke-3rd). New York: Cambridge University Press. ISBN 978-0-521-88068-8. 
  6. ^ a b Nash, J. C. (1979). Compact Numerical Methods: Linear Algebra and Function Minimisation. Bristol: Adam Hilger. ISBN 978-0-85274-330-0. 

Bacaan lebih lanjut sunting

Pranala luar sunting

Templat:Algoritma optimisasi