DAA - Algoritma Mendaki Bukit
Algoritma yang dibahas pada bab-bab sebelumnya berjalan secara sistematis. Untuk mencapai tujuan, satu atau lebih jalur yang dieksplorasi sebelumnya menuju solusi perlu disimpan untuk menemukan solusi optimal.
Untuk banyak masalah, jalan menuju tujuan tidak relevan. Misalnya, dalam masalah N-Queens, kita tidak perlu peduli tentang konfigurasi akhir dari ratu serta urutan penambahan ratu.
Mendaki Bukit
Hill Climbing adalah teknik untuk memecahkan masalah optimasi tertentu. Dalam teknik ini, kita mulai dengan solusi sub-optimal dan solusi tersebut diperbaiki berulang kali hingga beberapa kondisi dimaksimalkan.
Ide memulai dengan solusi sub-optimal dibandingkan dengan memulai dari dasar bukit, memperbaiki solusi dibandingkan dengan berjalan di atas bukit, dan terakhir memaksimalkan beberapa kondisi dibandingkan mencapai puncak bukit.
Oleh karena itu, teknik mendaki bukit dapat dianggap sebagai tahapan berikut -
- Membangun solusi sub-optimal dengan mematuhi kendala masalah
- Memperbaiki solusi langkah demi langkah
- Memperbaiki solusi sampai tidak ada lagi perbaikan yang mungkin dilakukan
Teknik Hill Climbing terutama digunakan untuk menyelesaikan masalah komputasi yang sulit. Ini hanya terlihat pada keadaan saat ini dan keadaan segera di masa depan. Oleh karena itu, teknik ini hemat memori karena tidak mempertahankan pohon pencarian.
Algorithm: Hill Climbing
Evaluate the initial state.
Loop until a solution is found or there are no new operators left to be applied:
- Select and apply a new operator
- Evaluate the new state:
goal -→ quit
better than current state -→ new current state
Peningkatan Iteratif
Dalam metode perbaikan berulang, solusi optimal dicapai dengan membuat kemajuan menuju solusi optimal di setiap iterasi. Namun, teknik ini mungkin menemui maksima lokal. Dalam situasi ini, tidak ada negara bagian terdekat untuk solusi yang lebih baik.
Masalah ini dapat dihindari dengan berbagai metode. Salah satu metode ini adalah simulasi anil.
Mulai Ulang Acak
Ini adalah metode lain untuk memecahkan masalah optima lokal. Teknik ini melakukan serangkaian pencarian. Setiap kali, ini dimulai dari keadaan awal yang dibuat secara acak. Oleh karena itu, solusi optima atau hampir optimal dapat diperoleh dengan membandingkan solusi pencarian yang dilakukan.
Permasalahan Teknik Mendaki Bukit
Maxima Lokal
Jika heuristik tidak cembung, Hill Climbing dapat menyatu dengan maksimum lokal, bukan maksimum global.
Ridges dan Alleys
Jika fungsi target membuat punggungan sempit, maka pemanjat hanya bisa naik punggungan atau menuruni gang dengan cara zig-zag. Dalam skenario ini, pemanjat perlu mengambil langkah-langkah yang sangat kecil yang membutuhkan lebih banyak waktu untuk mencapai tujuan.
Dataran
Dataran tinggi ditemui saat ruang pencarian datar atau cukup datar sehingga nilai yang dikembalikan oleh fungsi target tidak dapat dibedakan dari nilai yang dikembalikan untuk wilayah terdekat, karena presisi yang digunakan oleh mesin untuk mewakili nilainya.
Kompleksitas Teknik Mendaki Bukit
Teknik ini tidak mengalami masalah terkait ruang, karena hanya melihat keadaan saat ini. Jalur yang dijelajahi sebelumnya tidak disimpan.
Untuk sebagian besar masalah dalam teknik Random-restart Hill Climbing, solusi optimal dapat dicapai dalam waktu polinomial. Namun, untuk masalah NP-Complete, waktu komputasi dapat menjadi eksponensial berdasarkan jumlah maksima lokal.
Aplikasi Teknik Hill Climbing
Teknik Hill Climbing dapat digunakan untuk menyelesaikan banyak masalah, dimana keadaan saat ini memungkinkan untuk fungsi evaluasi yang akurat, seperti Aliran Jaringan, masalah Penjual Perjalanan, masalah 8-Ratu, desain Sirkuit Terpadu, dll.
Hill Climbing juga digunakan dalam metode pembelajaran induktif. Teknik ini digunakan dalam robotika untuk koordinasi di antara beberapa robot dalam satu tim. Ada banyak masalah lain di mana teknik ini digunakan.
Contoh
Teknik ini dapat diterapkan untuk mengatasi masalah travelling salesman. Pertama, solusi awal ditentukan bahwa mengunjungi semua kota tepat satu kali. Oleh karena itu, solusi awal ini tidak optimal dalam banyak kasus. Bahkan solusi ini bisa sangat buruk. Algoritme Hill Climbing dimulai dengan solusi awal seperti itu dan memperbaikinya secara berulang. Akhirnya, rute yang jauh lebih pendek kemungkinan akan diperoleh.