10.1.1 启用python达成第一个遗传算法

news/2025/9/26 13:10:34/文章来源:https://www.cnblogs.com/lxjshuju/p/19113285

举例如下:

求函数的在x=[-3,3],y=[-3,3]上的最大值:

【思路】

1. 把DNA设为:48个bit的数组。 奇数为x,  偶数为y;就是说24个位组成x,24个位组成y。

如何得到x,y: 24个奇数位转换成数值比如b,  则 x =  b/(2^24-1)* (3 - (-3))  -3 

2.交叉因子:

        就是父的前一部分+母DNA的后一部分

3. 变异因子:

        就是某个位取反。

【代码】

代码如下,使用200条DNA,迭代100次,得到结果 (x,y)=(0,1.582), z=8.1.  结果比较稳定。

import numpy as np
import matplotlib.pyplot as plt
from jmespath.ast import projection
from matplotlib import  cm
from mpl_toolkits.mplot3d import Axes3D
DNA_SIZE=24
POP_SIZE=200
N_GENERATIONS=100
CROSSOVER_RATE=0.8
MUTATION_RATE=0.005
X_BOUND =[-3,3]
Y_BOUND =[-3,3]
def F(x,y):
# 2(3-x)^2 e( -x^2 - (y+1)^2) - 4 e(-(x+2)^2-y^2) - 6 e(-(x-2)^2-y(y-2)^2)
#return   2*(3-x)**2* np.exp(-x**2-(y+1)**2)-4*np.exp(-(x+2)**2-y**2)-6*np.exp(-(x-2)**2-(y-2)**2)
return 3*(1-x)**2*np.exp(-(x**2)-(y+1)**2)-10*(x/5-x**3-y**5)*np.exp(-x**2-y**2)-1/2*np.exp(-(x+1)**2-y**2)
#return 10-x**2-y**2
def plot_3d(ax):
x = np.linspace(*X_BOUND, 100)
y = np.linspace(*Y_BOUND, 100)
X, Y = np.meshgrid(x, y)
Z = F(X, Y)
surf = ax.plot_surface(X,Y,Z,rstride=1,cstride=1,cmap = cm.coolwarm)
# 添加颜色条
fig.colorbar(surf, ax=ax, shrink=0.5, aspect=10)
# 设置坐标轴标签
ax.set_zlim((-20,20))
ax.set_xlabel('X轴')
ax.set_ylabel('Y轴')
ax.set_zlabel('Z轴')
# 设置标题
ax.set_title(':z=f(x,y)')
plt.pause(3)
plt.show()
def translateDNA(pop):
x_pop = pop[:,1::2] #奇数列表示x
y_pop = pop[:,::2] #偶数列表示y
x = x_pop.dot(  2** np.arange(DNA_SIZE) [::-1]   )/float(2**DNA_SIZE-1)*(X_BOUND[1]-X_BOUND[0])+ X_BOUND[0]
y = y_pop.dot(  2** np.arange(DNA_SIZE) [::-1]   )/float(2**DNA_SIZE-1)*(Y_BOUND[1]-Y_BOUND[0])+ Y_BOUND[0]
return  x,y
def crossover_and_mutaion(pop,Crossover_rate=CROSSOVER_RATE):
halfpop = int(POP_SIZE/2)
fitness = get_fitness(pop)
indices = np.argpartition(fitness, -halfpop)[-halfpop:]  #得到前50%最好的样本进行保留
new_pop=[]
#保留原来比较好的50%.
for pepole in pop[indices]:
new_pop.append(pepole)
#其他的进行交叉以及变异
for father in pop:
child = father
if(np.random.rand()

【附录】

1.np.argpartition可以取数组中最大的k个值的序号;或者最小k个值的序号

最小3个值的序号: np.argpartition(arr, 3)[:3]

最大3个值的序号: np.argpartition(arr, -3)[-3:]

最小值序号举例如下:

arr = np.array([3, 1, 4, 1, 5, 9, 2, 6])   ---> [3, 1, 4, 1, 5, 9, 2, 6]    
indices = np.argpartition(arr, 3)           ---> [1 3   6  0  2  4  7  5]

np.argpartition(arr, 3)[:3]                   -----> array([1, 3, 6])
最大值序号举例如下:

np.argpartition(arr, -3)[-3:]               ----> array([4, 7, 5])

2.np.random.choice(a),从数组中选择,可指定概率,可放回/不放回

np.random.choice(a, size=None, replace=True, p=None)
参数说明默认值
a输入数组或整数必需
size输出形状None
replace是否允许重复抽样True
p每个元素的概率分布None

np.random.choice(data,7,replace=False)         --》  array([5, 6, 3, 2, 9, 0, 4])

np.random.choice(data,7,replace=True)         -》array([6, 4, 6, 9, 1, 7, 6])

data = np.arange(5)         ---》  array([0, 1, 2, 3, 4])
p=[0.1,0.1,0.2,0.3,0.3]

np.random.choice(data, size=8, p=p)    ----》 array([3, 1, 4, 4, 2, 1, 4, 3])

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/918303.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[iOS] OC高级编程 - 引用计数 (1) - 详解

[iOS] OC高级编程 - 引用计数 (1) - 详解pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "M…

Docker Docker Compose 完整入门与实用技巧 - 教程

Docker & Docker Compose 完整入门与实用技巧 - 教程2025-09-26 13:10 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important;…

建网站过程网站制作报价优惠

[html] 说说你对属性data-的理解 data- 属性是H5新增的自定义属性,也可以用来存储值。我个人用的不多,这个data- 属性倒是和vue中的v-bind 功能相似, 自定义属性,绑定数据。也和上面说的一样可以通过js进行获取使用个人简介 我是…

营销型网站建设合同戚墅堰做网站

云原生之使用Docker部署RSS阅读器Huntly 一、Huntly介绍1.1 Huntly简介1.2 Huntly功能2.1 本地环境规划2.2 本次实践介绍 三、本地环境检查3.1 检查Docker服务状态3.2 检查Docker版本3.3 检查docker compose 版本 四、下载Huntly镜像五、部署Huntly5.1 创建挂载目录5.2 创建Hun…

达州网站建设的公司怎么自己搭建梯子

最近在练习搭建网站,遇到游览器找不到服务器上的php文件的问题。后来查找发现,apache文档根目录跟apache虚拟主机文档根目录不同,服务器开启了虚拟主机功能。这导致游览器找不到php文件。 使用的环境是LAMP,它 的操作系统和软件版…

西安网站建设公司电话wordpress 删除 评论

事件以及事件相关的兼容性问题 事件最早是在 IE3 和 Navigator2 中出现的,当时是作为分担服务器运算负担的一种手段。要实现和网页的交互,就需要通过 JavaScript 里面的事件来实现。 每次用户与一个网页进行交互,例如点击链接,按下…

网站模板兼容手机端灰色推广引流联系方式

文章目录 📄前言一. Mybatis简介✈️1. 什么是Mybatis🚀2. 为什么使用Mybatis 二. Mybatis快速入门🍆1. mybatis使用前准备1.1 创建springboot项目并引入相关依赖1.2 在 application.ym中进行数据源的配置1.3 创建数据表,准备表数…

杭州网站建设哪个好想创建一个网站

🌼未封装 在项目中往往一个页面存在着要联调好几个接口,此时用下面的写法就会显得代码很冗余 // 向给定ID的用户发起请求 axios.get(/user?ID123456,{ params: { //发送请求的数据ID: 123456 } }) .then(function (response) { // 处理成功情…

网站详情页用什么软件做如何制作自己的网站模版

理解依赖属性 依赖属性支持的特征包括:动画、数据绑定、样式。由WPF元素暴露的属性大部分都是依赖属性。依赖属性和常规属性的使用方法相同。 WPF设计了依赖属性支持其特有的动态特性,并且不干扰其他系统的.net代码。 定义依赖属性 创造一个依赖属性的语…

PySide6 之鼠标事件写字板

一、效果图二、示例代码from PySide6.QtWidgets import * from PySide6.QtCore import * from PySide6.QtGui import * import sysclass ImageWidget(QWidget):pass鼠标控制图片缩放、拖动,鼠标滚动放大、缩小 class …

深入解析:golang基础语法(三)常量、指针、别名、关键字、运算符、字符串类型转换

深入解析:golang基础语法(三)常量、指针、别名、关键字、运算符、字符串类型转换pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; fo…

烟台网站建设方案成都市建设局官方网站

目录 一. 空属性null 二. 默认值default 三. 列描述comment 四. 填充零zerofill 五. 主键primary key 六. 自增长auto_increment 七. 唯一键unique 八. 外键foreign key 一. 空属性null 对于表中的数据,如果在进行插入的时候不显示地给定值,那么…

单B细胞技术如何实现兔单抗高通量高特异制备

单B细胞技术如何实现兔单抗高通量高特异制备 在单克隆抗体(mAb)研发领域,兔源单抗以其高亲和力和高特异性备受关注。传统的杂交瘤技术虽然成熟,但周期长、效率低,而且抗体多样性有限。近年来,单B细胞技术的出现,…

HP激光墨盒换墨粉

墨盒分区加墨是先清理使用过的墨粉,在加入要使用的墨粉。 清理使用过的墨粉 可拆开使用过的墨粉的墨盒去清理,也可用不拆下清理。打开红色框的盖子,到出里面的墨粉,最好用袋子装好清理,防止粉尘到处飞。 拆下来清…

实用指南:Golang学习笔记: 常用标准库

实用指南:Golang学习笔记: 常用标准库pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Mo…

AI论文速读 | 当大语言模型遇上时间序列:大语言模型能否执行多步时间序列推理与推断 - 指南

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

unordered_map性能被吊打!我用基数树让内存池性能暴涨几十倍的秘密

哈喽,大家好,我是小康! 今天要和大家聊一个特别有意思的话题——基数树。 说实话,我第一次听到这个名词的时候,内心是懵逼的。基数?树?这玩意儿到底是啥? 直到有一天,我在研究TCMalloc内存池源码的时候,发现…

网站备案后可以更换域名吗网红营销优势

Title 题目 Automated anomaly-aware 3D segmentation of bones and cartilages in kneeMR images from the Osteoarthritis Initiative 来自骨关节炎计划的膝关节MR图像的自动异常感知3D骨骼和软骨分割 Background 背景 近年来,多个机器学习算法被提出用于图像…

asp网站配置伪静态重庆注册公司核名在哪个网站

上次提到的开机自启动的配置,获得了LD的称赞,然而LD的要求,都是“既得陇复望蜀”的,他又期望我们能实现openGauss安装的“自动化”,于是尝试了下用shell脚本部署,附件中的脚本实测有效,openEule…

详细介绍:《 Linux 点滴漫谈: 一 》开源之路:Linux 的历史、演进与未来趋势

详细介绍:《 Linux 点滴漫谈: 一 》开源之路:Linux 的历史、演进与未来趋势pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-fa…