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

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

python實(shí)現(xiàn)人工蜂群算法

瀏覽:28日期:2022-07-10 17:48:44

ABSIndividual.py

import numpy as npimport ObjFunctionclass ABSIndividual: ’’’ individual of artificial bee swarm algorithm ’’’ def __init__(self, vardim, bound): ’’’ vardim: dimension of variables bound: boundaries of variables ’’’ self.vardim = vardim self.bound = bound self.fitness = 0. self.trials = 0 def generate(self): ’’’ generate a random chromsome for artificial bee swarm 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)

ABS.py

import numpy as npfrom ABSIndividual import ABSIndividualimport randomimport copyimport matplotlib.pyplot as pltclass ArtificialBeeSwarm: ’’’ the class for artificial bee swarm algorithm ’’’ def __init__(self, sizepop, vardim, bound, MAXGEN, params): ’’’ sizepop: population sizepop vardim: dimension of variables bound: boundaries of variables MAXGEN: termination condition params: algorithm required parameters, it is a list which is consisting of[trailLimit, C] ’’’ self.sizepop = sizepop self.vardim = vardim self.bound = bound self.foodSource = self.sizepop / 2 self.MAXGEN = MAXGEN self.params = params self.population = [] self.fitness = np.zeros((self.sizepop, 1)) self.trace = np.zeros((self.MAXGEN, 2)) def initialize(self): ’’’ initialize the population of abs ’’’ for i in xrange(0, self.foodSource): ind = ABSIndividual(self.vardim, self.bound) ind.generate() self.population.append(ind) def evaluation(self): ’’’ evaluation the fitness of the population ’’’ for i in xrange(0, self.foodSource): self.population[i].calculateFitness() self.fitness[i] = self.population[i].fitness def employedBeePhase(self): ’’’ employed bee phase ’’’ for i in xrange(0, self.foodSource): k = np.random.random_integers(0, self.vardim - 1) j = np.random.random_integers(0, self.foodSource - 1) while j == i:j = np.random.random_integers(0, self.foodSource - 1) vi = copy.deepcopy(self.population[i]) # vi.chrom = vi.chrom + np.random.uniform(-1, 1, self.vardim) * ( # vi.chrom - self.population[j].chrom) + np.random.uniform(0.0, self.params[1], self.vardim) * (self.best.chrom - vi.chrom) # for k in xrange(0, self.vardim): # if vi.chrom[k] < self.bound[0, k]: # vi.chrom[k] = self.bound[0, k] # if vi.chrom[k] > self.bound[1, k]: # vi.chrom[k] = self.bound[1, k] vi.chrom[k] += np.random.uniform(low=-1, high=1.0, size=1) * (vi.chrom[k] - self.population[j].chrom[k]) if vi.chrom[k] < self.bound[0, k]:vi.chrom[k] = self.bound[0, k] if vi.chrom[k] > self.bound[1, k]:vi.chrom[k] = self.bound[1, k] vi.calculateFitness() if vi.fitness > self.fitness[fi]:self.population[fi] = viself.fitness[fi] = vi.fitnessif vi.fitness > self.best.fitness: self.best = vi vi.calculateFitness() if vi.fitness > self.fitness[i]:self.population[i] = viself.fitness[i] = vi.fitnessif vi.fitness > self.best.fitness: self.best = vi else:self.population[i].trials += 1 def onlookerBeePhase(self): ’’’ onlooker bee phase ’’’ accuFitness = np.zeros((self.foodSource, 1)) maxFitness = np.max(self.fitness) for i in xrange(0, self.foodSource): accuFitness[i] = 0.9 * self.fitness[i] / maxFitness + 0.1 for i in xrange(0, self.foodSource): for fi in xrange(0, self.foodSource):r = random.random()if r < accuFitness[i]: k = np.random.random_integers(0, self.vardim - 1) j = np.random.random_integers(0, self.foodSource - 1) while j == fi: j = np.random.random_integers(0, self.foodSource - 1) vi = copy.deepcopy(self.population[fi]) # vi.chrom = vi.chrom + np.random.uniform(-1, 1, self.vardim) * ( # vi.chrom - self.population[j].chrom) + np.random.uniform(0.0, self.params[1], self.vardim) * (self.best.chrom - vi.chrom) # for k in xrange(0, self.vardim): # if vi.chrom[k] < self.bound[0, k]: # vi.chrom[k] = self.bound[0, k] # if vi.chrom[k] > self.bound[1, k]: # vi.chrom[k] = self.bound[1, k] vi.chrom[ k] += np.random.uniform(low=-1, high=1.0, size=1) * (vi.chrom[k] - self.population[j].chrom[k]) if vi.chrom[k] < self.bound[0, k]: vi.chrom[k] = self.bound[0, k] if vi.chrom[k] > self.bound[1, k]: vi.chrom[k] = self.bound[1, k] vi.calculateFitness() if vi.fitness > self.fitness[fi]: self.population[fi] = vi self.fitness[fi] = vi.fitness if vi.fitness > self.best.fitness: self.best = vi else: self.population[fi].trials += 1 break def scoutBeePhase(self): ’’’ scout bee phase ’’’ for i in xrange(0, self.foodSource): if self.population[i].trials > self.params[0]:self.population[i].generate()self.population[i].trials = 0self.population[i].calculateFitness()self.fitness[i] = self.population[i].fitness def solve(self): ’’’ the evolution process of the abs algorithm ’’’ self.t = 0 self.initialize() self.evaluation() 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.employedBeePhase() self.onlookerBeePhase() self.scoutBeePhase() 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 printResult(self): ’’’ plot the result of abs 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('Artificial Bee Swarm algorithm for function optimization') plt.legend() plt.show()

運(yùn)行程序:

if __name__ == '__main__': bound = np.tile([[-600], [600]], 25) abs = ABS(60, 25, bound, 1000, [100, 0.5]) abs.solve()

ObjFunction見(jiàn)簡(jiǎn)單遺傳算法-python實(shí)現(xiàn)。

以上就是python實(shí)現(xiàn)人工蜂群算法的詳細(xì)內(nèi)容,更多關(guān)于python 人工蜂群算法的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲成人国产| 日韩在线精品| 石原莉奈一区二区三区在线观看| 99久久久久久中文字幕一区| 久久久噜噜噜| 在线精品视频在线观看高清| 三上悠亚国产精品一区二区三区 | 99视频精品| 国产婷婷精品| 亚洲精品日韩久久| 日韩中文一区二区| 日本99精品| 久久国产三级| 国产精品传媒麻豆hd| 国产精品啊v在线| 精品国产乱码久久久| 福利精品在线| 日韩在线综合| 国产精品毛片| 日韩三级一区| 国产精品v一区二区三区| 精品国产精品久久一区免费式| sm久久捆绑调教精品一区| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 天堂俺去俺来也www久久婷婷| 午夜精品福利影院| 欧美一级久久| 四虎成人av| 精品1区2区3区4区| 91国内精品| 日韩在线视频精品| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲精品大全| 久久久亚洲欧洲日产| 91青青国产在线观看精品| 99精品电影| 日韩一区二区久久| 国产精品v日韩精品v欧美精品网站 | 免费久久精品视频| 91亚洲国产| 亚洲2区在线| 日韩一级不卡| 精品中文一区| 久久久久久自在自线| 国产精品毛片视频| 7m精品国产导航在线| 欧美一区二区三区高清视频| 伊人久久大香线蕉av不卡| 玖玖玖国产精品| 亚洲一级少妇| 国产日产一区| 亚洲成av人片一区二区密柚| 日韩av资源网| 成人综合一区| 亚洲中午字幕| 久久精品国产99| 国产一区白浆| 国产videos久久| 久热re这里精品视频在线6| 国产精品欧美在线观看| 久久久久国产| 国产探花在线精品| 欧美成人高清| 美女久久久精品| 日韩中文影院| 国产精品日本一区二区三区在线| 欧洲激情综合| 精品视频亚洲| 久久成人精品| 欧美13videosex性极品| 日韩精品a在线观看91| 久久精品国产网站| 日韩在线一区二区| 成人看片网站| 麻豆精品新av中文字幕| 中日韩男男gay无套| 精品国产亚洲一区二区在线观看| 蜜桃视频在线观看一区二区| 亚洲黄色网址| 日本视频一区二区| 亚洲深夜福利| 日韩免费福利视频| 国产精品一区二区三区四区在线观看| 亚洲作爱视频| 欧美日韩在线播放视频| 精品黄色一级片| 91成人福利| 一区二区精彩视频| 伊人成人在线视频| 黄色aa久久| 国产精品视频一区二区三区四蜜臂| 午夜在线一区二区| 欧美日韩精品一区二区视频| 国产一区二区三区四区二区| 色婷婷成人网| 午夜在线一区| 99re国产精品| 国精品一区二区| 中文字幕系列一区| 国产va免费精品观看精品视频| 国产情侣一区在线| 婷婷综合福利| 蜜桃久久精品一区二区| 午夜影院欧美| 久久激情网站| se01亚洲视频| 夜鲁夜鲁夜鲁视频在线播放| 国产在线观看91一区二区三区| 国产精品自拍区| 97精品久久| 欧美在线91| 日本a口亚洲| 日韩av一区二区三区四区| 免费在线观看不卡| 美女精品在线观看| 免费欧美日韩| 亚洲欧美久久久| 亚洲欧美日韩精品一区二区| 性色av一区二区怡红| 国产毛片一区| 中文久久精品| 日韩一区精品字幕| 美女日韩在线中文字幕| 日韩一区精品字幕| 九九在线精品| 最新亚洲激情| 视频一区中文字幕国产| 久久av一区| 亚洲ww精品| 青青青国产精品| 国产精品久久久久9999高清| 久久91视频| 日本在线啊啊| 精品欧美一区二区三区在线观看| 快播电影网址老女人久久| 久久激情网站| 99亚洲精品| 日本伊人久久| 国产日本亚洲| 国产精品手机在线播放| 精品国产亚洲一区二区三区大结局| 麻豆mv在线观看| 蜜臀久久99精品久久一区二区| 91精品观看| 亚洲黄色影院| 在线看片一区| 青草综合视频| 麻豆传媒一区二区三区| 久久久久久色 | 久久福利一区| 婷婷五月色综合香五月| 国产精品中文字幕亚洲欧美 | 日韩视频网站在线观看| 激情久久婷婷| 亚洲精品少妇| 麻豆国产一区| 欧美.日韩.国产.一区.二区| 蜜臀a∨国产成人精品| 国产美女亚洲精品7777| 精品视频久久| 免费视频国产一区| 免费在线欧美视频| 国产美女久久| 日韩天堂在线| 免费在线成人网| 国产亚洲人成a在线v网站| 精品国产91| 日韩视频二区| 国产毛片精品| 婷婷亚洲综合| 国产欧美日韩一区二区三区四区 | 日韩欧美激情| 国产成人1区| 亚洲综合国产| 美日韩一区二区三区| 色婷婷狠狠五月综合天色拍| 蘑菇福利视频一区播放| 久久不见久久见免费视频7 | 国产欧美一区二区精品久久久 | 亚洲激情精品| 欧美极品中文字幕| 午夜欧美精品| 欧美伊人影院| 久久影视一区| 久久国产人妖系列| 亚洲激情欧美| 精品视频国产| 天堂久久av| 国产一区视频在线观看免费| 91欧美极品| 久久一区二区三区喷水| 国产探花一区| 亚洲美洲欧洲综合国产一区| 老色鬼精品视频在线观看播放| 夜夜精品视频| 国产精品不卡| 亚欧成人精品| 秋霞影院一区二区三区| 国产日韩视频| 国产亚洲一级|