资源简介
python遗传算法求函数极值
代码片段和文件信息
from math import e
from math import pi
import numpy as np
import random
k = pow(213)-1#每个基因的二进制序列种类数
def f(x):#目标函数
n = len(x)
return -20*np.exp(-0.2*np.sqrt(1/n*sum(np.power(x2))))\
-np.exp(1/n*sum(np.cos(2*pi*x))) + 20
def translation(L):#将二进制编码还原为变量
n = 0
for i in range(13):
n += L[i]*pow(2i)
return -32.77 + n * (65.54/k)
def fitness(popular):
fit = [0] * len(popular)
n = len(popular[0])//13 #数据维度
maxfit = -1e5
for i in range(popular):
x = []
for j in range(n):
x.append(translation(i[13*j:13*j+13]))
fit[i] = f(np.array(x))
if fit[i] > maxfit:
maxfit = fit[i]
for i in range(len(fit)):
fit[i] = maxfit - fit[i]
total = sum(fit)#总适应度
for i in range(len(fit)):
fit[i] /= total
return fit
def choose(popular):#进行自然选择
popular_len = len(popular)#个体个数
survival_rate = []
for i in range(popular_len):
survival_rate.append(random.random())
fit = fitness(popular)#每个个体的存活率
best_individual = popular[fit.index(max(fit))]#保存下当前种群最优个体(其实写这里不太会)
survival_rate.sort()
fitin = 0
newin = 0
newpopular = popular
# 开始轮盘赌
# 结束之后,适应度更高的个体在新种群中应该更多
while newin < popular_len:
if survival_rate[newin] < fit[fitin]:
newpopular[newin] = popular[fitin]
newin += 1#旋转轮盘
else:
fitin += 1#旋转轮盘
popular = newpopular
return best_individual
def crossover(popularpc):#pc为交叉率
popular_len=len(popular)
for i in range(popular_len-1):
crosspoint = random.randint(0len(popular[0]))#随机生成交叉点
相关资源
- 用自己的数据制作python版本cifar10数据
- Python教程.rar
- python数据挖掘分类聚类回归关联算法
- Python爬虫源码—爬取猫途鹰官方旅游
- 密度聚类(Density peaks Clustering)Pyth
- python摄像头视频显示到TK窗口
- 国际麻将AI-根据向听数计算最优操作
- 爬取瓜子二手车.py
- 人脸识别UI Pythone+pyq5+opencv 多线程模式
- pcap-1.1.win32-py2.7.exe
- Python制作的汉诺塔演示小脚本
- python django+bootstrap实现用户管理系统
- python+MySQL+bootstrap+ajax项目
- 基于Python的双路视频传输及双显示系
- python模型restful接口
- Python3—EM&GMM;
- python+numpy实现自适应阈值分割函数O
- python+numpy实现均值滤波
- python代码实现录音
- 初学者练习python编程的100个小程序
- python入门到实践 外星人入侵项目代码
- 合并BN层的python脚本
- 语音读邮件的小程序python实现
- python入账管理系统源码
- python调用opencv实现人脸识别的简单D
- python界面GUI实现k-means聚类算法
- python版flappybird源码
- 简明Python教程.pdf
- Python的入门代码银行管理系统
- Python科学计算 张若愚 第二版-书及全
评论
共有 条评论