इवोल्यूशनरी सर्च एल्गोरिदम प्राकृतिक विकास के तंत्र पर आधारित एक अनुकूलन विधि है। यह एल्गोरिदम किसी समस्या का सर्वोत्तम समाधान खोजने के लिए पीढ़ियों के बीच आबादी के भीतर व्यक्तियों की विकास प्रक्रिया का अनुकरण करता है।
यह काम किस प्रकार करता है
- जनसंख्या आरंभीकरण: बेतरतीब ढंग से उत्पन्न व्यक्तियों की प्रारंभिक जनसंख्या बनाएं।
- मूल्यांकन: वस्तुनिष्ठ कार्य या मूल्यांकन मानदंड के आधार पर जनसंख्या में प्रत्येक व्यक्ति की गुणवत्ता का मूल्यांकन करें।
- चयन: संभावनाओं या चयन मानदंडों के आधार पर वर्तमान जनसंख्या में से सर्वश्रेष्ठ व्यक्तियों के एक उपसमूह का चयन करें।
- विकास: चयनित व्यक्तियों पर क्रॉसओवर और म्यूटेशन ऑपरेशन लागू करके एक नई पीढ़ी बनाएं।
- पुनरावृत्ति: संतोषजनक समाधान प्राप्त होने तक या पुनरावृत्तियों की पूर्वनिर्धारित संख्या तक पहुंचने तक चरण 2 से 4 को कई पीढ़ियों तक दोहराएँ।
उदाहरण: Fibonacci विकासवादी खोज का उपयोग करके फ़ंक्शन को अनुकूलित करना
Fibonacci F(0) = 0, F(1) = 1 के साथ फ़ंक्शन F(x) = F(x-1) + F(x-2) की अनुकूलन समस्या पर विचार करें। हम x का मान ज्ञात करना चाहते हैं जिसके लिए F(x) अधिकतम है. विकासवादी खोज विधि यादृच्छिक x मानों की जनसंख्या उत्पन्न कर सकती है, इष्टतम x मान खोजने के लिए उन्हें पीढ़ियों में विकसित कर सकती है।
C++ में कोड उदाहरण
Fibonacci इस उदाहरण में, हम फ़ंक्शन को अनुकूलित करने के लिए इवोल्यूशनरी सर्च पद्धति का उपयोग करते हैं । हम यादृच्छिक x मानों की जनसंख्या उत्पन्न करते हैं, सर्वश्रेष्ठ व्यक्तियों का चयन करके और क्रॉसओवर और म्यूटेशन ऑपरेशन लागू करके उन्हें पीढ़ियों तक विकसित करते हैं।