ਈਵੇਲੂਸ਼ਨਰੀ ਖੋਜ ਐਲਗੋਰਿਦਮ ਕੁਦਰਤੀ ਵਿਕਾਸ ਦੀ ਵਿਧੀ 'ਤੇ ਅਧਾਰਤ ਇੱਕ ਅਨੁਕੂਲਨ ਵਿਧੀ ਹੈ। ਇਹ ਐਲਗੋਰਿਦਮ ਇੱਕ ਸਮੱਸਿਆ ਦਾ ਸਭ ਤੋਂ ਵਧੀਆ ਹੱਲ ਲੱਭਣ ਲਈ ਪੀੜ੍ਹੀਆਂ ਵਿੱਚ ਇੱਕ ਆਬਾਦੀ ਦੇ ਅੰਦਰ ਵਿਅਕਤੀਆਂ ਦੀ ਵਿਕਾਸ ਪ੍ਰਕਿਰਿਆ ਦੀ ਨਕਲ ਕਰਦਾ ਹੈ।
ਕਿਦਾ ਚਲਦਾ
- ਆਬਾਦੀ ਦੀ ਸ਼ੁਰੂਆਤ: ਬੇਤਰਤੀਬੇ ਤੌਰ 'ਤੇ ਤਿਆਰ ਕੀਤੇ ਵਿਅਕਤੀਆਂ ਦੀ ਸ਼ੁਰੂਆਤੀ ਆਬਾਦੀ ਬਣਾਓ।
- ਮੁਲਾਂਕਣ: ਉਦੇਸ਼ ਫੰਕਸ਼ਨ ਜਾਂ ਮੁਲਾਂਕਣ ਮਾਪਦੰਡ ਦੇ ਅਧਾਰ ਤੇ ਆਬਾਦੀ ਵਿੱਚ ਹਰੇਕ ਵਿਅਕਤੀ ਦੀ ਗੁਣਵੱਤਾ ਦਾ ਮੁਲਾਂਕਣ ਕਰੋ।
- ਚੋਣ: ਸੰਭਾਵਨਾਵਾਂ ਜਾਂ ਚੋਣ ਮਾਪਦੰਡਾਂ ਦੇ ਆਧਾਰ 'ਤੇ ਮੌਜੂਦਾ ਆਬਾਦੀ ਵਿੱਚੋਂ ਸਭ ਤੋਂ ਵਧੀਆ ਵਿਅਕਤੀਆਂ ਦਾ ਸਬਸੈੱਟ ਚੁਣੋ।
- ਈਵੇਲੂਸ਼ਨ: ਚੁਣੇ ਗਏ ਵਿਅਕਤੀਆਂ ਲਈ ਕਰਾਸਓਵਰ ਅਤੇ ਪਰਿਵਰਤਨ ਕਾਰਜਾਂ ਨੂੰ ਲਾਗੂ ਕਰਕੇ ਇੱਕ ਨਵੀਂ ਪੀੜ੍ਹੀ ਬਣਾਓ।
- ਦੁਹਰਾਓ: ਕਈ ਪੀੜ੍ਹੀਆਂ ਵਿੱਚ ਕਦਮ 2 ਤੋਂ 4 ਨੂੰ ਦੁਹਰਾਓ ਜਦੋਂ ਤੱਕ ਕੋਈ ਤਸੱਲੀਬਖਸ਼ ਹੱਲ ਪ੍ਰਾਪਤ ਨਹੀਂ ਹੋ ਜਾਂਦਾ ਜਾਂ ਦੁਹਰਾਓ ਦੀ ਇੱਕ ਪਹਿਲਾਂ ਤੋਂ ਪਰਿਭਾਸ਼ਿਤ ਸੰਖਿਆ ਤੱਕ ਪਹੁੰਚ ਨਹੀਂ ਜਾਂਦੀ।
ਉਦਾਹਰਨ: Fibonacci ਵਿਕਾਸਵਾਦੀ ਖੋਜ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਫੰਕਸ਼ਨ ਨੂੰ ਅਨੁਕੂਲਿਤ ਕਰਨਾ
Fibonacci ਫੰਕਸ਼ਨ F(x) = F(x-1) + F(x-2) ਦੇ ਨਾਲ F(0) = 0, F(1) = 1 ਦੀ ਆਪਟੀਮਾਈਜ਼ੇਸ਼ਨ ਸਮੱਸਿਆ 'ਤੇ ਗੌਰ ਕਰੋ। ਅਸੀਂ x ਦਾ ਮੁੱਲ ਲੱਭਣਾ ਚਾਹੁੰਦੇ ਹਾਂ ਜਿਸ ਲਈ F(x) ਵੱਧ ਤੋਂ ਵੱਧ ਹੈ। ਈਵੇਲੂਸ਼ਨਰੀ ਖੋਜ ਵਿਧੀ ਬੇਤਰਤੀਬ x ਮੁੱਲਾਂ ਦੀ ਆਬਾਦੀ ਪੈਦਾ ਕਰ ਸਕਦੀ ਹੈ, ਅਨੁਕੂਲ x ਮੁੱਲ ਲੱਭਣ ਲਈ ਉਹਨਾਂ ਨੂੰ ਪੀੜ੍ਹੀਆਂ ਵਿੱਚ ਵਿਕਸਤ ਕਰ ਸਕਦੀ ਹੈ।
C++ ਵਿੱਚ ਕੋਡ ਦੀ ਉਦਾਹਰਨ
ਇਸ ਉਦਾਹਰਨ ਵਿੱਚ, ਅਸੀਂ ਫੰਕਸ਼ਨ ਨੂੰ ਅਨੁਕੂਲ ਬਣਾਉਣ ਲਈ ਈਵੇਲੂਸ਼ਨਰੀ ਖੋਜ ਵਿਧੀ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹਾਂ Fibonacci । ਅਸੀਂ ਬੇਤਰਤੀਬ x ਮੁੱਲਾਂ ਦੀ ਆਬਾਦੀ ਪੈਦਾ ਕਰਦੇ ਹਾਂ, ਸਭ ਤੋਂ ਵਧੀਆ ਵਿਅਕਤੀਆਂ ਦੀ ਚੋਣ ਕਰਕੇ ਅਤੇ ਕਰਾਸਓਵਰ ਅਤੇ ਪਰਿਵਰਤਨ ਕਾਰਜਾਂ ਨੂੰ ਲਾਗੂ ਕਰਕੇ ਉਹਨਾਂ ਨੂੰ ਪੀੜ੍ਹੀ ਦਰ ਪੀੜ੍ਹੀ ਵਿਕਸਿਤ ਕਰਦੇ ਹਾਂ।