जेनेटिक एल्गोरिदम - बुनियादी बातों
यह खंड GA को समझने के लिए आवश्यक मूल शब्दावली का परिचय देता है। इसके अलावा, दोनों में GAs की एक सामान्य संरचना प्रस्तुत की गई हैpseudo-code and graphical forms। पाठक को सलाह दी जाती है कि इस खंड में प्रस्तुत सभी अवधारणाओं को ठीक से समझें और इस ट्यूटोरियल के अन्य खंडों को भी पढ़ते समय उन्हें ध्यान में रखें।
मूल शब्दावली
जेनेटिक एल्गोरिदम पर चर्चा शुरू करने से पहले, कुछ बुनियादी शब्दावली से परिचित होना आवश्यक है जो इस पूरे ट्यूटोरियल में उपयोग की जाएगी।
Population- यह दी गई समस्या के सभी संभावित (एन्कोडेड) समाधानों का सबसेट है। जीए के लिए जनसंख्या मानव के लिए जनसंख्या के अनुरूप है, सिवाय इसके कि मनुष्य के बजाय, हमारे पास कैंडीडेट सॉल्यूशंस हैं जो मानव का प्रतिनिधित्व करते हैं।
Chromosomes - गुणसूत्र दी गई समस्या का एक ऐसा समाधान है।
Gene - एक जीन एक गुणसूत्र का एक तत्व स्थिति है।
Allele - यह वह मान है जो एक जीन एक विशेष गुणसूत्र के लिए लेता है।
Genotype- जीनोटाइप गणना स्थान में जनसंख्या है। कम्प्यूटेशन स्पेस में, समाधानों को एक ऐसे तरीके से दर्शाया जाता है जिसे कंप्यूटिंग सिस्टम का उपयोग करके आसानी से समझा और हेरफेर किया जा सकता है।
Phenotype - फेनोटाइप वास्तविक वास्तविक विश्व समाधान स्थान में जनसंख्या है जिसमें समाधानों का प्रतिनिधित्व एक तरह से किया जाता है ताकि वे वास्तविक विश्व स्थितियों में प्रतिनिधित्व कर सकें।
Decoding and Encoding - सरल समस्याओं के लिए, phenotype and genotypeरिक्त स्थान समान हैं। हालांकि, ज्यादातर मामलों में, फेनोटाइप और जीनोटाइप रिक्त स्थान भिन्न होते हैं। डिकोडिंग जीनोटाइप से फेनोटाइप स्पेस में एक समाधान को बदलने की एक प्रक्रिया है, जबकि एन्कोडिंग फेनोटाइप से जीनोटाइप स्पेस में बदलने की एक प्रक्रिया है। डिकोडिंग तेजी से होनी चाहिए क्योंकि यह फिटनेस मान गणना के दौरान जीए में बार-बार किया जाता है।
उदाहरण के लिए, 0/1 नैकस्पेस समस्या पर विचार करें। फेनोटाइप स्पेस में ऐसे समाधान होते हैं जिनमें केवल आइटम के आइटम नंबर होते हैं जिन्हें उठाया जाना है।
हालांकि, जीनोटाइप स्पेस में इसे लंबाई n (जहां n वस्तुओं की संख्या है) के बाइनरी स्ट्रिंग के रूप में दर्शाया जा सकता है। ए0 at position x उस का प्रतिनिधित्व करता है xthआइटम उठाया जाता है, जबकि 1 रिवर्स का प्रतिनिधित्व करता है। यह एक ऐसा मामला है जहां जीनोटाइप और फेनोटाइप स्पेस अलग हैं।
Fitness Function- केवल परिभाषित एक फिटनेस फ़ंक्शन एक फ़ंक्शन है जो समाधान को इनपुट के रूप में लेता है और आउटपुट के रूप में समाधान की उपयुक्तता पैदा करता है। कुछ मामलों में, फिटनेस फ़ंक्शन और उद्देश्य फ़ंक्शन समान हो सकते हैं, जबकि अन्य में यह समस्या के आधार पर भिन्न हो सकता है।
Genetic Operators- ये संतानों की आनुवंशिक संरचना में परिवर्तन करते हैं। इनमें क्रॉसओवर, म्यूटेशन, चयन आदि शामिल हैं।
बुनियादी संरचना
जीए की मूल संरचना इस प्रकार है -
हम एक प्रारंभिक जनसंख्या से शुरू करते हैं (जो यादृच्छिक या अन्य उत्तराधिकारियों द्वारा विकसित की जा सकती है), संभोग के लिए इस आबादी से माता-पिता का चयन करें। नई ऑफ-स्प्रिंग्स उत्पन्न करने के लिए माता-पिता पर क्रॉसओवर और म्यूटेशन ऑपरेटरों को लागू करें। और अंत में ये ऑफ-स्प्रिंग्स आबादी में मौजूदा व्यक्तियों की जगह लेते हैं और प्रक्रिया दोहराते हैं। इस तरह से आनुवंशिक एल्गोरिदम वास्तव में कुछ हद तक मानव विकास की नकल करने की कोशिश करते हैं।
इस ट्यूटोरियल में निम्नलिखित प्रत्येक चरण को एक अलग अध्याय के रूप में कवर किया गया है।
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