อัลกอริทึมทางพันธุกรรม - พื้นฐาน
ส่วนนี้จะแนะนำคำศัพท์พื้นฐานที่จำเป็นในการทำความเข้าใจ GAs นอกจากนี้โครงสร้างทั่วไปของ GAs ยังแสดงอยู่ในทั้งสองอย่างpseudo-code and graphical forms. ขอแนะนำให้ผู้อ่านทำความเข้าใจแนวคิดทั้งหมดที่แนะนำในส่วนนี้อย่างถูกต้องและควรคำนึงถึงแนวคิดเหล่านี้เมื่ออ่านส่วนอื่น ๆ ของบทช่วยสอนนี้ด้วย
คำศัพท์พื้นฐาน
ก่อนที่จะเริ่มการสนทนาเกี่ยวกับอัลกอริทึมทางพันธุกรรมจำเป็นอย่างยิ่งที่จะต้องทำความคุ้นเคยกับคำศัพท์พื้นฐานบางประการซึ่งจะใช้ตลอดบทแนะนำนี้
Population- เป็นชุดย่อยของโซลูชัน (เข้ารหัส) ที่เป็นไปได้ทั้งหมดสำหรับปัญหาที่กำหนด ประชากรสำหรับ GA นั้นคล้ายคลึงกับประชากรสำหรับมนุษย์ยกเว้นว่าแทนที่จะเป็นมนุษย์เรามี Candidate Solutions ที่เป็นตัวแทนของมนุษย์
Chromosomes - โครโมโซมเป็นวิธีแก้ปัญหาที่กำหนด
Gene - ยีนเป็นตำแหน่งองค์ประกอบหนึ่งของโครโมโซม
Allele - เป็นค่าที่ยีนใช้สำหรับโครโมโซมเฉพาะ
Genotype- จีโนไทป์คือประชากรในพื้นที่คำนวณ ในพื้นที่การคำนวณโซลูชันจะแสดงในลักษณะที่สามารถเข้าใจและจัดการได้ง่ายโดยใช้ระบบคอมพิวเตอร์
Phenotype - ฟีโนไทป์คือประชากรในพื้นที่โซลูชันในโลกแห่งความเป็นจริงที่มีการแสดงโซลูชันในลักษณะที่แสดงในสถานการณ์จริง
Decoding and Encoding - สำหรับปัญหาง่ายๆไฟล์ phenotype and genotypeช่องว่างเหมือนกัน อย่างไรก็ตามในกรณีส่วนใหญ่ฟีโนไทป์และจีโนไทป์จะแตกต่างกัน การถอดรหัสเป็นกระบวนการเปลี่ยนสารละลายจากจีโนไทป์ไปเป็นพื้นที่ฟีโนไทป์ในขณะที่การเข้ารหัสเป็นกระบวนการเปลี่ยนจากฟีโนไทป์เป็นพื้นที่จีโนไทป์ การถอดรหัสควรรวดเร็วเนื่องจากมีการดำเนินการซ้ำ ๆ ใน GA ระหว่างการคำนวณค่าสมรรถภาพ
ตัวอย่างเช่นพิจารณาปัญหา 0/1 เป้ ช่องว่างฟีโนไทป์ประกอบด้วยโซลูชันที่มีเพียงหมายเลขสินค้าของรายการที่จะเลือก
อย่างไรก็ตามในพื้นที่จีโนไทป์สามารถแสดงเป็นสตริงไบนารีของความยาว n (โดยที่ n คือจำนวนรายการ) ก0 at position x แสดงถึงสิ่งนั้น xthรายการจะถูกเลือกในขณะที่ 1 แทนการย้อนกลับ นี่เป็นกรณีที่ช่องว่างของจีโนไทป์และฟีโนไทป์แตกต่างกัน
Fitness Function- ฟังก์ชั่นฟิตเนสที่กำหนดไว้เพียงอย่างเดียวคือฟังก์ชันที่รับโซลูชันเป็นอินพุตและสร้างความเหมาะสมของโซลูชันเป็นเอาต์พุต ในบางกรณีฟังก์ชันฟิตเนสและฟังก์ชันวัตถุประสงค์อาจเหมือนกันในขณะที่ฟังก์ชันอื่นอาจแตกต่างกันไปตามปัญหา
Genetic Operators- สิ่งเหล่านี้เปลี่ยนแปลงองค์ประกอบทางพันธุกรรมของลูกหลาน ซึ่งรวมถึงการไขว้การกลายพันธุ์การคัดเลือก ฯลฯ
โครงสร้างพื้นฐาน
โครงสร้างพื้นฐานของ GA มีดังนี้ -
เราเริ่มต้นด้วยประชากรเริ่มต้น (ซึ่งอาจถูกสร้างขึ้นโดยการสุ่มหรือเพาะจากพฤติกรรมอื่น ๆ ) เลือกพ่อแม่จากประชากรกลุ่มนี้เพื่อผสมพันธุ์ ใช้ตัวดำเนินการครอสโอเวอร์และการกลายพันธุ์กับพ่อแม่เพื่อสร้างสปริงใหม่ และในที่สุดสิ่งเหล่านี้ก็เข้ามาแทนที่บุคคลที่มีอยู่ในประชากรและกระบวนการนี้ก็เกิดขึ้นซ้ำ ๆ ด้วยวิธีนี้ขั้นตอนวิธีทางพันธุกรรมพยายามที่จะเลียนแบบวิวัฒนาการของมนุษย์ในระดับหนึ่ง
แต่ละขั้นตอนต่อไปนี้ครอบคลุมเป็นบทที่แยกจากกันในบทช่วยสอนนี้
รหัสหลอกทั่วไปสำหรับ GA มีอธิบายไว้ในโปรแกรมต่อไปนี้ -
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