Algoritma Genetik - Dasar-dasar
Bagian ini memperkenalkan terminologi dasar yang diperlukan untuk memahami GA. Juga, struktur umum GAs disajikan di keduanyapseudo-code and graphical forms. Pembaca disarankan untuk memahami dengan baik semua konsep yang diperkenalkan di bagian ini dan mengingatnya saat membaca bagian lain dari tutorial ini juga.
Terminologi Dasar
Sebelum memulai diskusi tentang Algoritma Genetika, penting untuk memahami beberapa terminologi dasar yang akan digunakan di sepanjang tutorial ini.
Population- Ini adalah bagian dari semua kemungkinan solusi (dikodekan) untuk masalah yang diberikan. Populasi untuk GA dapat dianalogikan dengan populasi manusia, kecuali manusia, kami memiliki Solusi Kandidat yang mewakili manusia.
Chromosomes - Kromosom adalah salah satu solusi untuk masalah yang diberikan.
Gene - Gen adalah salah satu posisi elemen kromosom.
Allele - Ini adalah nilai yang diambil gen untuk kromosom tertentu.
Genotype- Genotipe adalah populasi dalam ruang komputasi. Dalam ruang komputasi, solusi direpresentasikan dengan cara yang dapat dengan mudah dipahami dan dimanipulasi menggunakan sistem komputasi.
Phenotype - Fenotipe adalah populasi dalam ruang solusi dunia nyata yang sebenarnya di mana solusi direpresentasikan dengan cara direpresentasikan dalam situasi dunia nyata.
Decoding and Encoding - Untuk masalah sederhana, file phenotype and genotypespasinya sama. Namun, dalam kebanyakan kasus, ruang fenotipe dan genotipe berbeda. Decoding adalah proses mentransformasikan larutan dari ruang genotipe ke ruang fenotipe, sedangkan pengkodean adalah proses transformasi dari ruang fenotipe ke ruang genotipe. Penguraian kode harus cepat karena dilakukan berulang kali dalam GA selama penghitungan nilai kebugaran.
Misalnya, pertimbangkan Masalah Knapsack 0/1. Ruang Fenotipe terdiri dari solusi yang hanya berisi nomor item dari item yang akan dipilih.
Namun, dalam ruang genotipe dapat direpresentasikan sebagai string biner dengan panjang n (di mana n adalah jumlah item). SEBUAH0 at position x mewakili itu xthitem diambil sedangkan 1 mewakili kebalikannya. Ini adalah kasus di mana ruang genotipe dan fenotipe berbeda.
Fitness Function- Fungsi fitness yang didefinisikan secara sederhana adalah fungsi yang mengambil solusi sebagai input dan menghasilkan kesesuaian solusi sebagai output. Dalam beberapa kasus, fungsi kebugaran dan fungsi tujuan mungkin sama, sementara di kasus lain mungkin berbeda berdasarkan masalahnya.
Genetic Operators- Ini mengubah komposisi genetik keturunan. Ini termasuk persilangan, mutasi, seleksi, dll.
Struktur dasar
Struktur dasar GA adalah sebagai berikut -
Kami mulai dengan populasi awal (yang dapat dihasilkan secara acak atau diunggulkan oleh heuristik lain), pilih tetua dari populasi ini untuk kawin. Terapkan operator crossover dan mutasi pada orang tua untuk menghasilkan pegas baru. Dan akhirnya mata air ini menggantikan individu-individu yang ada dalam populasi dan prosesnya berulang. Dengan cara ini, algoritma genetika sebenarnya mencoba meniru evolusi manusia sampai batas tertentu.
Masing-masing langkah berikut ini dibahas sebagai bab terpisah nanti dalam tutorial ini.
Pseudo-code umum untuk GA dijelaskan dalam program berikut -
GA()
initialize population
find fitness of population
while (termination criteria is reached) do
parent selection
crossover with probability pc
mutation with probability pm
decode and fitness calculation
survivor selection
find best
return best