日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python實現簡單遺傳算法

瀏覽:20日期:2022-07-10 18:02:33

ObjFunction.py

import mathdef GrieFunc(vardim, x, bound): ''' Griewangk function ''' s1 = 0. s2 = 1. for i in range(1, vardim + 1): s1 = s1 + x[i - 1] ** 2 s2 = s2 * math.cos(x[i - 1] / math.sqrt(i)) y = (1. / 4000.) * s1 - s2 + 1 y = 1. / (1. + y) return ydef RastFunc(vardim, x, bound): ''' Rastrigin function ''' s = 10 * 25 for i in range(1, vardim + 1): s = s + x[i - 1] ** 2 - 10 * math.cos(2 * math.pi * x[i - 1]) return s

GAIndividual.py

import numpy as npimport ObjFunctionclass GAIndividual: ’’’ individual of genetic algorithm ’’’ def __init__(self, vardim, bound): ’’’ vardim: dimension of variables bound: boundaries of variables ’’’ self.vardim = vardim self.bound = bound self.fitness = 0. def generate(self): ’’’ generate a random chromsome for genetic algorithm ’’’ len = self.vardim rnd = np.random.random(size=len) self.chrom = np.zeros(len) for i in xrange(0, len): self.chrom[i] = self.bound[0, i] + (self.bound[1, i] - self.bound[0, i]) * rnd[i] def calculateFitness(self): ’’’ calculate the fitness of the chromsome ’’’ self.fitness = ObjFunction.GrieFunc( self.vardim, self.chrom, self.bound)

GeneticAlgorithm.py

import numpy as npfrom GAIndividual import GAIndividualimport randomimport copyimport matplotlib.pyplot as pltclass GeneticAlgorithm: ’’’ The class for genetic algorithm ’’’ def __init__(self, sizepop, vardim, bound, MAXGEN, params): ’’’ sizepop: population sizepop vardim: dimension of variables bound: boundaries of variables MAXGEN: termination condition param: algorithm required parameters, it is a list which is consisting of crossover rate, mutation rate, alpha ’’’ self.sizepop = sizepop self.MAXGEN = MAXGEN self.vardim = vardim self.bound = bound self.population = [] self.fitness = np.zeros((self.sizepop, 1)) self.trace = np.zeros((self.MAXGEN, 2)) self.params = params def initialize(self): ’’’ initialize the population ’’’ for i in xrange(0, self.sizepop): ind = GAIndividual(self.vardim, self.bound) ind.generate() self.population.append(ind) def evaluate(self): ’’’ evaluation of the population fitnesses ’’’ for i in xrange(0, self.sizepop): self.population[i].calculateFitness() self.fitness[i] = self.population[i].fitness def solve(self): ’’’ evolution process of genetic algorithm ’’’ self.t = 0 self.initialize() self.evaluate() best = np.max(self.fitness) bestIndex = np.argmax(self.fitness) self.best = copy.deepcopy(self.population[bestIndex]) self.avefitness = np.mean(self.fitness) self.trace[self.t, 0] = (1 - self.best.fitness) / self.best.fitness self.trace[self.t, 1] = (1 - self.avefitness) / self.avefitness print('Generation %d: optimal function value is: %f; average function value is %f' % ( self.t, self.trace[self.t, 0], self.trace[self.t, 1])) while (self.t < self.MAXGEN - 1): self.t += 1 self.selectionOperation() self.crossoverOperation() self.mutationOperation() self.evaluate() best = np.max(self.fitness) bestIndex = np.argmax(self.fitness) if best > self.best.fitness: self.best = copy.deepcopy(self.population[bestIndex]) self.avefitness = np.mean(self.fitness) self.trace[self.t, 0] = (1 - self.best.fitness) / self.best.fitness self.trace[self.t, 1] = (1 - self.avefitness) / self.avefitness print('Generation %d: optimal function value is: %f; average function value is %f' % ( self.t, self.trace[self.t, 0], self.trace[self.t, 1])) print('Optimal function value is: %f; ' % self.trace[self.t, 0]) print 'Optimal solution is:' print self.best.chrom self.printResult() def selectionOperation(self): ’’’ selection operation for Genetic Algorithm ’’’ newpop = [] totalFitness = np.sum(self.fitness) accuFitness = np.zeros((self.sizepop, 1)) sum1 = 0. for i in xrange(0, self.sizepop): accuFitness[i] = sum1 + self.fitness[i] / totalFitness sum1 = accuFitness[i] for i in xrange(0, self.sizepop): r = random.random() idx = 0 for j in xrange(0, self.sizepop - 1): if j == 0 and r < accuFitness[j]: idx = 0 break elif r >= accuFitness[j] and r < accuFitness[j + 1]: idx = j + 1 break newpop.append(self.population[idx]) self.population = newpop def crossoverOperation(self): ’’’ crossover operation for genetic algorithm ’’’ newpop = [] for i in xrange(0, self.sizepop, 2): idx1 = random.randint(0, self.sizepop - 1) idx2 = random.randint(0, self.sizepop - 1) while idx2 == idx1: idx2 = random.randint(0, self.sizepop - 1) newpop.append(copy.deepcopy(self.population[idx1])) newpop.append(copy.deepcopy(self.population[idx2])) r = random.random() if r < self.params[0]: crossPos = random.randint(1, self.vardim - 1) for j in xrange(crossPos, self.vardim): newpop[i].chrom[j] = newpop[i].chrom[ j] * self.params[2] + (1 - self.params[2]) * newpop[i + 1].chrom[j] newpop[i + 1].chrom[j] = newpop[i + 1].chrom[j] * self.params[2] + (1 - self.params[2]) * newpop[i].chrom[j] self.population = newpop def mutationOperation(self): ’’’ mutation operation for genetic algorithm ’’’ newpop = [] for i in xrange(0, self.sizepop): newpop.append(copy.deepcopy(self.population[i])) r = random.random() if r < self.params[1]: mutatePos = random.randint(0, self.vardim - 1) theta = random.random() if theta > 0.5: newpop[i].chrom[mutatePos] = newpop[i].chrom[ mutatePos] - (newpop[i].chrom[mutatePos] - self.bound[0, mutatePos]) * (1 - random.random() ** (1 - self.t / self.MAXGEN)) else: newpop[i].chrom[mutatePos] = newpop[i].chrom[ mutatePos] + (self.bound[1, mutatePos] - newpop[i].chrom[mutatePos]) * (1 - random.random() ** (1 - self.t / self.MAXGEN)) self.population = newpop def printResult(self): ’’’ plot the result of the genetic algorithm ’’’ x = np.arange(0, self.MAXGEN) y1 = self.trace[:, 0] y2 = self.trace[:, 1] plt.plot(x, y1, ’r’, label=’optimal value’) plt.plot(x, y2, ’g’, label=’average value’) plt.xlabel('Iteration') plt.ylabel('function value') plt.title('Genetic algorithm for function optimization') plt.legend() plt.show()

運行程序:

if __name__ == '__main__': bound = np.tile([[-600], [600]], 25) ga = GA(60, 25, bound, 1000, [0.9, 0.1, 0.5]) ga.solve()

作者:Alex Yu出處:http://www.cnblogs.com/biaoyu/

以上就是python實現簡單遺傳算法的詳細內容,更多關于python 遺傳算法的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
激情久久五月| 久久国产欧美| 精精国产xxxx视频在线播放| 国产乱码午夜在线视频| 国产精品精品国产一区二区| 久久久久黄色| 91视频一区| 丝袜美腿诱惑一区二区三区 | 天堂成人国产精品一区| 在线精品小视频| 亚洲欧美日韩专区| 日韩国产91| 国产aa精品| 好看的av在线不卡观看| 蜜臀精品久久久久久蜜臀 | 视频一区日韩精品| 欧美在线黄色| 成人精品久久| 日韩视频中文| 欧美亚洲一级| 成人午夜毛片| 99xxxx成人网| 国内精品亚洲| 久久国产精品毛片| 国产精品视频一区视频二区| 极品av在线| 亚洲精品乱码久久久久久蜜桃麻豆| 久久国产视频网| 婷婷综合网站| 久久精品国产成人一区二区三区| 欧美日韩一二三四| 欧美国产日韩电影| 亚洲一区免费| 日韩国产欧美| 国产精品亲子伦av一区二区三区| 免费看av不卡| 国产精品日韩精品中文字幕| 亚洲少妇在线| 欧美国产小视频| 在线中文字幕播放| 欧美a在线观看| 免费在线成人| 日韩三级久久| 亚洲欧美日韩高清在线| 国产伊人久久| 88久久精品| 在线观看视频免费一区二区三区| 深夜福利亚洲| 天堂成人国产精品一区| 欧美一级精品| 免费在线小视频| 大香伊人久久精品一区二区| 国产欧美三级| 日韩av中文字幕一区| 久久一区二区中文字幕| 国产一区二区三区四区五区| 麻豆久久久久久久| 久久超级碰碰| 国产精品欧美在线观看| 国产亚洲在线观看| 久久久久久黄| 99久久夜色精品国产亚洲狼 | 91精品精品| 福利一区二区三区视频在线观看| 亚洲一区二区三区在线免费| 视频一区二区三区入口| 在线综合亚洲| 久久在线电影| 蜜臀av一区二区三区| 中文一区一区三区免费在线观 | 激情欧美一区| 欧美日韩在线网站| 欧美成人日韩| 亚洲丝袜啪啪| 国产精品xxx| 蜜桃成人精品| 蜜桃免费网站一区二区三区| 亚洲精品亚洲人成在线观看| 国产欧美日韩精品高清二区综合区| 国产日韩在线观看视频| 久久精品亚洲| 欧美日韩精品一区二区视频| 亚洲精品一级| 风间由美中文字幕在线看视频国产欧美| 精品国产欧美日韩| 91高清一区| 欧美亚洲人成在线| 精品72久久久久中文字幕| 久久久久中文| 欧美一区免费| 99免费精品| 国产精品黄色片| 日韩精品影视| 日韩av黄色在线| 亚洲小说欧美另类婷婷| 国产精品天天看天天狠| 亚洲婷婷在线| 欧美黄色精品| 亚洲一区av| 免费不卡中文字幕在线| 国产精品一区二区三区美女 | 久久久人人人| 欧美在线亚洲| 国产精品久久| 99xxxx成人网| 亚洲网站视频| 成人三级高清视频在线看| 日韩高清一区| 99亚洲精品| 一区二区三区视频免费观看| 97久久亚洲| 亚洲在线久久| 久久国产精品久久久久久电车| 成人日韩在线观看| 开心激情综合| 久久国产尿小便嘘嘘| 香蕉久久一区| 亚洲精品少妇| 亚洲视频二区| 模特精品在线| 亚洲精选久久| 亚洲精品小说| 激情综合在线| 久久只有精品| 国产乱码精品一区二区三区四区| 99免费精品| 蜜臀久久99精品久久一区二区| 日韩在线短视频| 亚洲精品一级二级| 日韩不卡在线| 红桃视频欧美| 免费在线观看不卡| 中文字幕中文字幕精品| 日韩中文字幕区一区有砖一区| 黄色亚洲免费| 综合国产在线| 欧美日韩亚洲一区二区三区在线| 偷拍亚洲精品| 欧美黄色精品| 久久蜜桃资源一区二区老牛| 国产一区二区三区视频在线| 日韩高清不卡| 国产婷婷精品| 日韩国产欧美在线播放| 国产欧美日本| 四虎884aa成人精品最新| 91精品xxx在线观看| 日韩欧美国产精品综合嫩v| 久久国产直播| 最新亚洲国产| 日韩中文字幕| 日本欧美在线| 日本免费久久| 国产精品av久久久久久麻豆网| 欧美日韩国产一区精品一区| 亚洲精品国产偷自在线观看| 日韩精品欧美精品| 麻豆成人av在线| 午夜日韩在线| 蜜臀av一区二区在线免费观看| 国产乱码精品一区二区三区亚洲人 | 欧美片网站免费| 国产日韩欧美一区| 激情综合婷婷| 亚州av乱码久久精品蜜桃| 久久亚洲精品伦理| 亚洲欧美日本国产专区一区| 综合激情在线| 成人在线视频免费看| 免费毛片在线不卡| 天堂va在线高清一区| 欧美aⅴ一区二区三区视频| 久久精品国产亚洲一区二区三区| 里番精品3d一二三区| 国产成人精品免费视| 亚洲国产专区| 国产亚洲一区| 国产精品福利在线观看播放| 国产精品88久久久久久| 日本成人在线视频网站| 国产传媒av在线| 久久激情一区| 日韩和欧美一区二区三区| а√天堂8资源中文在线| 在线精品视频一区| 亚洲精品福利电影| 亚洲精品日本| 亚洲天堂久久| 首页国产精品| 国产精品一区二区99| 亚洲免费成人| а√天堂8资源在线| 国产欧美日韩一级| 免费观看日韩电影| aa亚洲婷婷| 日本欧美不卡| 日本特黄久久久高潮| 午夜宅男久久久| 午夜久久免费观看| 精品日韩视频|