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

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

python實現人工蜂群算法

瀏覽:24日期: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()

運行程序:

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

ObjFunction見簡單遺傳算法-python實現。

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

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
午夜一级在线看亚洲| 成人污污视频| 久久久成人网| av在线资源| 日韩精品一区二区三区免费观影| 精品亚洲二区| 给我免费播放日韩视频| 日产午夜精品一线二线三线| 国产精品99久久精品| av中文字幕在线观看第一页| 91亚洲国产| 亚洲精选久久| 久久av资源| 久久精品国产福利| 在线国产日韩| 精品国产乱码久久久| 久久国产亚洲| 欧产日产国产精品视频| 91看片一区| 国产精品久久久久77777丨| 国产欧美日韩在线一区二区 | 日韩欧美高清一区二区三区| 欧美精品二区| bbw在线视频| 日韩精品一二区| 日本色综合中文字幕| 麻豆成人综合网| 亚洲大全视频| 亚洲综合不卡| 精品一区电影| 国产精品极品国产中出| 日韩在线观看一区| 69堂免费精品视频在线播放| 午夜影院欧美| 国产精成人品2018| 国产精品一区毛片| 国产精品久久久久久久久久白浆| 日韩欧美在线精品| 国产精品第十页| 亚洲免费成人av在线| 欧美日韩少妇| 少妇精品在线| 99热精品久久| 亚洲人www| 亚洲大全视频| 日韩精品一页| 国产乱子精品一区二区在线观看 | 国产精品嫩模av在线| 久久99精品久久久野外观看| 欧美日韩一区二区三区不卡视频 | 中文字幕一区二区三区在线视频| 亚洲高清成人| 日本va欧美va精品发布| 日韩一区二区久久| 美女视频黄免费的久久| 六月天综合网| 欧美黄色一区| 日韩精品电影一区亚洲| 亚洲乱码视频| 成人久久一区| 日韩88av| 久久一区亚洲| 久久国产精品毛片| 国产精品一区二区av日韩在线| 人人香蕉久久| 免费久久99精品国产| 精品在线99| 国产精品一区二区av交换| 国产精品.xx视频.xxtv| 欧美天堂在线| 国产欧美在线| 九九色在线视频| 精品国产亚洲日本| 日韩黄色av| 91av一区| 日韩综合一区| 日本免费在线视频不卡一不卡二| 国产精品av久久久久久麻豆网| 不卡中文字幕| 国产欧美综合一区二区三区| 午夜精品一区二区三区国产| 日韩影院二区| 久久麻豆视频| 国产成人调教视频在线观看| 欧美a在线观看| 久久精品 人人爱| 国产精品久久久久久模特 | 日韩中文字幕区一区有砖一区 | 日韩国产一二三区| 亚洲二区精品| 国模精品一区| 国产免费播放一区二区| 亚洲小说春色综合另类电影| 成人亚洲欧美| 国产精品美女午夜爽爽| 伊人国产精品| 日韩亚洲国产欧美| 久久精品亚洲欧美日韩精品中文字幕| 国产精品宾馆| 欧美日韩中出| 日韩精品视频中文字幕| 亚洲婷婷丁香| 日韩视频一区| 激情欧美日韩一区| 日韩欧美中文| 国产精品久久观看| 精品三级av在线导航| 国产午夜久久av| 日韩一区二区三区在线看| 国产精品日韩| 女人天堂亚洲aⅴ在线观看| 久久精品国产99久久| 日韩在线视频精品| 蜜桃av在线播放| av一区在线| 日韩中文在线播放| 久久国产欧美| 日韩欧美自拍| 久久免费国产| 欧美a级片一区| 亚洲大全视频| 午夜亚洲福利在线老司机| 久久av一区| 天堂va蜜桃一区二区三区| 美女国产精品| 亚洲精品影视| 欧美天堂一区| 麻豆视频一区| 日韩网站在线| 蜜桃视频在线观看一区二区| 中文字幕一区日韩精品| 日韩国产精品久久久| 91嫩草精品| 国产精品啊v在线| 精品美女视频 | 欧美日韩91| 国产精品**亚洲精品| 精品少妇一区| 日韩成人高清| 五月婷婷亚洲| 蜜桃av一区二区在线观看| 亚洲精品免费观看| 国产福利一区二区三区在线播放| 精品伊人久久久| 女生影院久久| 免费久久久久久久久| 亚洲精品极品| 国产精品chinese| 日韩国产一区| 日韩天堂av| 国产日韩视频在线| 在线中文字幕播放| 91久久国产| 香蕉久久夜色精品国产| 国产亚洲久久| 日韩在线不卡| 蜜桃视频第一区免费观看| 免费观看亚洲天堂| 99久久久久| 亚洲精品九九| 久久男人天堂| 石原莉奈一区二区三区在线观看| 欧美亚洲色图校园春色| 久久精品国产99| 亚洲福利专区| 欧美片第1页综合| 韩国三级一区| 亚洲欧美日本国产| 成人一区不卡| 视频一区中文字幕国产| 国产欧美日韩精品一区二区三区| 91综合网人人| 伊人国产精品| 日韩精品2区| 日本一区二区中文字幕| аⅴ资源天堂资源库在线| 免费观看在线综合| 国产成人久久| 国产视频一区三区| 麻豆国产欧美日韩综合精品二区| 91精品一区国产高清在线gif | 久久不射网站| 久久精品一本| 视频在线在亚洲| 福利一区视频| 亚洲综合五月| 蜜桃精品在线| 国产精品流白浆在线观看| 91久久国产| 精品一区二区三区中文字幕视频| 亚洲成人精选| 久久这里只有精品一区二区| 91国语精品自产拍| 久久精品国产久精国产| 亚洲精品字幕| 国产精品av一区二区| 欧美aa在线视频| 亚洲精品自拍| 合欧美一区二区三区| 久久精品日韩欧美|