जेनेटिक एल्गोरिदम - बुनियादी बातों

यह खंड 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