पायथन के साथ एआई - जेनेटिक एल्गोरिदम

इस अध्याय में AI के जेनेटिक एल्गोरिदम पर विस्तार से चर्चा की गई है।

जेनेटिक एल्गोरिदम क्या हैं?

जेनेटिक एल्गोरिदम (जीए) प्राकृतिक चयन और आनुवंशिकी की अवधारणाओं के आधार पर खोज आधारित एल्गोरिदम हैं। GAs संगणना की एक बहुत बड़ी शाखा का एक उपसमूह है जिसे विकासवादी संगणना के रूप में जाना जाता है।

GA को जॉन हॉलैंड और उनके छात्रों और सहयोगियों द्वारा मिशिगन विश्वविद्यालय में विकसित किया गया था, विशेष रूप से डेविड ई। गोल्डबर्ग। तब से उच्च अनुकूलन सफलता के साथ विभिन्न अनुकूलन समस्याओं पर प्रयास किया गया है।

जीएएस में, हमारे पास दी गई समस्या के संभावित समाधानों का एक पूल है। ये समाधान तब पुनर्संयोजन और उत्परिवर्तन (प्राकृतिक आनुवंशिकी की तरह) से गुजरते हैं, नए बच्चे पैदा करते हैं, और प्रक्रिया विभिन्न पीढ़ियों के लिए दोहराई जाती है। प्रत्येक व्यक्ति (या उम्मीदवार समाधान) को एक फिटनेस मूल्य (इसके उद्देश्य समारोह मूल्य के आधार पर) सौंपा गया है और फिटर व्यक्तियों को संभोग और उपज के लिए एक उच्च मौका दिया जाता हैfitterव्यक्तियों। यह डार्विनियन थ्योरी के अनुरूप हैSurvival of the Fittest

इस प्रकार, यह रहता है evolving पीढ़ियों से बेहतर व्यक्ति या समाधान, जब तक यह एक रोक की कसौटी पर नहीं पहुंचता।

जेनेटिक एल्गोरिदम प्रकृति में पर्याप्त रूप से यादृच्छिक हैं, लेकिन वे यादृच्छिक स्थानीय खोज की तुलना में बहुत बेहतर प्रदर्शन करते हैं (जहां हम सिर्फ यादृच्छिक समाधान का प्रयास करते हैं, अब तक का सबसे अच्छा ट्रैक रखते हुए), क्योंकि वे ऐतिहासिक जानकारी का भी शोषण करते हैं।

अनुकूलन समस्याओं के लिए GA का उपयोग कैसे करें?

अनुकूलन डिजाइन, स्थिति, संसाधन और प्रणाली को यथासंभव प्रभावी बनाने की एक क्रिया है। निम्नलिखित ब्लॉक आरेख अनुकूलन प्रक्रिया को दर्शाता है -

अनुकूलन प्रक्रिया के लिए GA तंत्र के चरण

समस्याओं के अनुकूलन के लिए उपयोग किए जाने पर जीए तंत्र के चरणों का क्रम निम्न है।

  • चरण 1 - प्रारंभिक जनसंख्या को अनियमित रूप से उत्पन्न करें।

  • चरण 2 - सबसे अच्छा फिटनेस मूल्यों के साथ प्रारंभिक समाधान का चयन करें।

  • चरण 3 - म्यूटेशन और क्रॉसओवर ऑपरेटरों का उपयोग करके चयनित समाधानों को पुन: निर्धारित करें।

  • चरण 4 - आबादी में एक वंश डालें।

  • चरण 5 - अब, यदि स्टॉप की स्थिति पूरी हो गई है, तो उनके सर्वोत्तम फिटनेस मूल्य के साथ समाधान वापस करें। एल्स चरण 2 पर जाएं।

आवश्यक पैकेज स्थापित करना

पायथन में जेनेटिक एल्गोरिदम का उपयोग करके समस्या को हल करने के लिए, हम जीए नामक एक शक्तिशाली पैकेज का उपयोग करने जा रहे हैं DEAP। यह तेजी से प्रोटोटाइप और विचारों के परीक्षण के लिए उपन्यास विकासवादी संगणना ढांचे का एक पुस्तकालय है। हम कमांड प्रॉम्प्ट पर निम्नलिखित कमांड की मदद से इस पैकेज को स्थापित कर सकते हैं -

pip install deap

यदि आप उपयोग कर रहे हैं anaconda पर्यावरण, फिर निम्न आदेश का उपयोग बधिया करने के लिए किया जा सकता है -

conda install -c conda-forge deap

जेनेटिक एल्गोरिदम का उपयोग कर समाधान लागू करना

यह खंड आपको जेनेटिक एल्गोरिदम का उपयोग करके समाधान के कार्यान्वयन के बारे में बताता है।

बिट पैटर्न बनाना

निम्नलिखित उदाहरण आपको दिखाता है कि कैसे एक बिट स्ट्रिंग उत्पन्न करना है जिसमें 15 लोग शामिल होंगे, जिसके आधार पर One Max मुसीबत।

दिखाए गए अनुसार आवश्यक पैकेज आयात करें -

import random
from deap import base, creator, tools

मूल्यांकन समारोह को परिभाषित करें। यह एक आनुवंशिक एल्गोरिथ्म बनाने के लिए पहला कदम है।

def eval_func(individual):
   target_sum = 15
   return len(individual) - abs(sum(individual) - target_sum),

अब, सही मापदंडों के साथ टूलबॉक्स बनाएं -

def create_toolbox(num_bits):
   creator.create("FitnessMax", base.Fitness, weights=(1.0,))
   creator.create("Individual", list, fitness=creator.FitnessMax)

टूलबॉक्स को प्रारंभ करें

toolbox = base.Toolbox()
toolbox.register("attr_bool", random.randint, 0, 1)
toolbox.register("individual", tools.initRepeat, creator.Individual,
   toolbox.attr_bool, num_bits)
toolbox.register("population", tools.initRepeat, list, toolbox.individual)

मूल्यांकन ऑपरेटर पंजीकृत करें -

toolbox.register("evaluate", eval_func)

अब, क्रॉसओवर ऑपरेटर को पंजीकृत करें -

toolbox.register("mate", tools.cxTwoPoint)

एक म्यूटेशन ऑपरेटर को पंजीकृत करें -

toolbox.register("mutate", tools.mutFlipBit, indpb = 0.05)

प्रजनन के लिए ऑपरेटर को परिभाषित करें -

toolbox.register("select", tools.selTournament, tournsize = 3)
return toolbox
if __name__ == "__main__":
   num_bits = 45
   toolbox = create_toolbox(num_bits)
   random.seed(7)
   population = toolbox.population(n = 500)
   probab_crossing, probab_mutating = 0.5, 0.2
   num_generations = 10
   print('\nEvolution process starts')

संपूर्ण जनसंख्या का मूल्यांकन करें -

fitnesses = list(map(toolbox.evaluate, population))
for ind, fit in zip(population, fitnesses):
   ind.fitness.values = fit
print('\nEvaluated', len(population), 'individuals')

पीढ़ियों के माध्यम से बनाएँ और पुनरावृति -

for g in range(num_generations):
   print("\n- Generation", g)

अगली पीढ़ी के व्यक्तियों का चयन -

offspring = toolbox.select(population, len(population))

अब, चयनित व्यक्तियों को क्लोन करें -

offspring = list(map(toolbox.clone, offspring))

संतान पर क्रॉसओवर और म्यूटेशन लागू करें -

for child1, child2 in zip(offspring[::2], offspring[1::2]):
   if random.random() < probab_crossing:
   toolbox.mate(child1, child2)

बच्चे के फिटनेस मूल्य को हटा दें

del child1.fitness.values
del child2.fitness.values

अब, म्यूटेशन लागू करें -

for mutant in offspring:
   if random.random() < probab_mutating:
   toolbox.mutate(mutant)
   del mutant.fitness.values

अमान्य फिटनेस वाले व्यक्तियों का मूल्यांकन करें -

invalid_ind = [ind for ind in offspring if not ind.fitness.valid]
fitnesses = map(toolbox.evaluate, invalid_ind)
for ind, fit in zip(invalid_ind, fitnesses):
   ind.fitness.values = fit
print('Evaluated', len(invalid_ind), 'individuals')

अब, अगली पीढ़ी के व्यक्ति के साथ जनसंख्या बदलें -

population[:] = offspring

वर्तमान पीढ़ियों के आंकड़े छापें -

fits = [ind.fitness.values[0] for ind in population]
length = len(population)
mean = sum(fits) / length
sum2 = sum(x*x for x in fits)
std = abs(sum2 / length - mean**2)**0.5
print('Min =', min(fits), ', Max =', max(fits))
print('Average =', round(mean, 2), ', Standard deviation =',
round(std, 2))
print("\n- Evolution ends")

अंतिम आउटपुट प्रिंट करें -

best_ind = tools.selBest(population, 1)[0]
   print('\nBest individual:\n', best_ind)
   print('\nNumber of ones:', sum(best_ind))
Following would be the output:
Evolution process starts
Evaluated 500 individuals
- Generation 0
Evaluated 295 individuals
Min = 32.0 , Max = 45.0
Average = 40.29 , Standard deviation = 2.61
- Generation 1
Evaluated 292 individuals
Min = 34.0 , Max = 45.0
Average = 42.35 , Standard deviation = 1.91
- Generation 2
Evaluated 277 individuals
Min = 37.0 , Max = 45.0
Average = 43.39 , Standard deviation = 1.46
… … … …
- Generation 9
Evaluated 299 individuals
Min = 40.0 , Max = 45.0
Average = 44.12 , Standard deviation = 1.11
- Evolution ends
Best individual:
[0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 
 1, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0,
 1, 0, 0, 1, 1, 1, 0, 0, 1, 0, 1]
Number of ones: 15

प्रतीक प्रतिगमन समस्या

यह आनुवंशिक प्रोग्रामिंग में सबसे अच्छी ज्ञात समस्याओं में से एक है। सभी प्रतीकात्मक प्रतिगमन समस्याएं एक मनमाना डेटा वितरण का उपयोग करती हैं, और एक प्रतीकात्मक सूत्र के साथ सबसे सटीक डेटा को फिट करने का प्रयास करती हैं। आमतौर पर, किसी व्यक्ति की फिटनेस को मापने के लिए RMSE (रूट मीन स्क्वायर एरर) जैसे माप का उपयोग किया जाता है। यह एक क्लासिक regressor समस्या है और यहां हम समीकरण का उपयोग कर रहे हैं5x3-6x2+8x=1। हमें उपरोक्त उदाहरण में दिए गए सभी चरणों का पालन करने की आवश्यकता है, लेकिन मुख्य भाग आदिम सेट बनाना होगा क्योंकि वे व्यक्तियों के लिए बिल्डिंग ब्लॉक हैं इसलिए मूल्यांकन शुरू हो सकता है। यहां हम आदिम के क्लासिक सेट का उपयोग करेंगे।

निम्नलिखित पायथन कोड इसे विस्तार से बताता है -

import operator
import math
import random
import numpy as np
from deap import algorithms, base, creator, tools, gp
def division_operator(numerator, denominator):
   if denominator == 0:
      return 1
   return numerator / denominator
def eval_func(individual, points):
   func = toolbox.compile(expr=individual)
   return math.fsum(mse) / len(points),
def create_toolbox():
   pset = gp.PrimitiveSet("MAIN", 1)
   pset.addPrimitive(operator.add, 2)
   pset.addPrimitive(operator.sub, 2)
   pset.addPrimitive(operator.mul, 2)
   pset.addPrimitive(division_operator, 2)
   pset.addPrimitive(operator.neg, 1)
   pset.addPrimitive(math.cos, 1)
   pset.addPrimitive(math.sin, 1)
   pset.addEphemeralConstant("rand101", lambda: random.randint(-1,1))
   pset.renameArguments(ARG0 = 'x')
   creator.create("FitnessMin", base.Fitness, weights = (-1.0,))
   creator.create("Individual",gp.PrimitiveTree,fitness=creator.FitnessMin)
   toolbox = base.Toolbox()
   toolbox.register("expr", gp.genHalfAndHalf, pset=pset, min_=1, max_=2)
   toolbox.expr)
   toolbox.register("population",tools.initRepeat,list, toolbox.individual)
   toolbox.register("compile", gp.compile, pset = pset)
   toolbox.register("evaluate", eval_func, points = [x/10. for x in range(-10,10)])
   toolbox.register("select", tools.selTournament, tournsize = 3)
   toolbox.register("mate", gp.cxOnePoint)
   toolbox.register("expr_mut", gp.genFull, min_=0, max_=2)
   toolbox.register("mutate", gp.mutUniform, expr = toolbox.expr_mut, pset = pset)
   toolbox.decorate("mate", gp.staticLimit(key = operator.attrgetter("height"), max_value = 17))
   toolbox.decorate("mutate", gp.staticLimit(key = operator.attrgetter("height"), max_value = 17))
   return toolbox
if __name__ == "__main__":
   random.seed(7)
   toolbox = create_toolbox()
   population = toolbox.population(n = 450)
   hall_of_fame = tools.HallOfFame(1)
   stats_fit = tools.Statistics(lambda x: x.fitness.values)
   stats_size = tools.Statistics(len)
   mstats = tools.MultiStatistics(fitness=stats_fit, size = stats_size)
   mstats.register("avg", np.mean)
   mstats.register("std", np.std)
   mstats.register("min", np.min)
   mstats.register("max", np.max)
   probab_crossover = 0.4
   probab_mutate = 0.2
   number_gen = 10
   population, log = algorithms.eaSimple(population, toolbox,
      probab_crossover, probab_mutate, number_gen,
      stats = mstats, halloffame = hall_of_fame, verbose = True)

ध्यान दें कि सभी मूल चरण बिट पैटर्न उत्पन्न करते समय उपयोग किए जाते हैं। यह कार्यक्रम हमें 10 पीढ़ियों के बाद न्यूनतम, अधिकतम, एसटीडी (मानक विचलन) के रूप में आउटपुट देगा।