遗传算法与深度学习实战——生命模拟及其应用
遗传算法与深度学习实战——生命模拟及其应用
- 0. 前言
- 1. 康威生命游戏
- 1.1 康威生命游戏的规则
- 1.2 实现康威生命游戏
- 1.3 空间生命和智能体模拟
- 2. 实现生命模拟
- 3. 生命模拟应用
- 小结
- 系列链接
0. 前言
生命模拟是进化计算的一个特定子集,模拟了自然界中所观察到的自然过程,例如粒子或鸟群的聚集方式。生命模拟只是用来探索和优化问题的模拟形式之一,还有很多其他形式的模拟,可以更好地建模各种过程,但它们都源于康威生命游戏 (Conway’s Game of Life
)。在本节中,我们将介绍生命模拟的基本概念,并使用 Python
实现康威生命游戏。
1. 康威生命游戏
生命游戏是由约翰·霍顿·康威 (John Horton Conway
) 于 1970
年开发的一种简单的细胞自动机;这个“游戏”被认为是计算机模拟的起源。虽然模拟的规则很简单,但它的确能够得到优雅的图案和表现形式。
1.1 康威生命游戏的规则
康威生命游戏之所以优雅,归结于用于模拟细胞生命的规则的简洁性。使用以下四个简单的规则模拟细胞的生命周期:
- 任何活细胞如果周围少于两个存活邻居,则会死亡(因为人口稀少)
- 任何活细胞如果周围有两个或三个存活邻居,则会存活到下一代
- 任何活细胞如果周围有多于三个存活邻居,则会死亡(因为人口过剩)
- 任何死细胞如果周围恰好有三个存活邻居,则会变成一个活细胞(因为繁殖)
1.2 实现康威生命游戏
使用 Python
实现康威生命游戏:
import glob
import io
import base64
from IPython.display import HTML
from IPython import display as ipythondisplay
import matplotlib.pyplot as pltdef show_video():mp4list = glob.glob('*.mp4')if len(mp4list) > 0:mp4 = mp4list[0]video = io.open(mp4, 'r+b').read()encoded = base64.b64encode(video)ipythondisplay.display(HTML(data='''<video alt="test" autoplay loop controls style="height: 400px;"><source src="data:video/mp4;base64,{0}" type="video/mp4" /></video>'''.format(encoded.decode('ascii'))))else: print("Could not find video")import numpy as np
import tqdm.notebook as nbdef life(X, steps):"""Conway's Game of Life.- X, matrix with the initial state of the game.- steps, number of generations."""def roll_it(x, y):# rolls the matrix X in a given directionreturn np.roll(np.roll(X, y, axis=0), x, axis=1)for _ in range(steps):# count the number of neighbours Y = roll_it(1, 0) + roll_it(0, 1) + roll_it(-1, 0) \+ roll_it(0, -1) + roll_it(1, 1) + roll_it(-1, -1) \+ roll_it(1, -1) + roll_it(-1, 1)# game of life rulesX = np.logical_or(np.logical_and(X, Y ==2), Y==3)X = X.astype(int)yield XX = np.zeros((40, 40)) # 40 by 40 dead cells
# R-pentomino
X[23, 22:24] = 1
X[24, 21:23] = 1
X[25, 22] = 1
plt.imshow(X)
plt.show()from matplotlib import pyplot as plt
import matplotlib.animation as manimationFFMpegWriter = manimation.writers['ffmpeg']
metadata = dict(title='Game of life', artist='JustGlowing')
writer = FFMpegWriter(fps=10, metadata=metadata)
fig = plt.figure()
fig.patch.set_facecolor('black')
with writer.saving(fig, "game_of_life.mp4", 200):plt.spy(X)plt.axis('off')writer.grab_frame()plt.clf()for x in nb.tqdm(life(X, 800),total=800):plt.spy(x)plt.axis('off')writer.grab_frame()plt.clf()
show_video()
运行程序,并观察输出,如下图所示。对于这个简单的生命模拟,起始细胞图案很简单,我们还可以使用其他的初始位置观察输出结果。
当模拟完成时,函数 show_video()
可以在输出中显示一个短视频片段。
在进程完成后播放视频,观看细胞模拟的运行。生命游戏的简洁和优雅展示了计算机模拟的强大威力,并由此诞生了多个学科。它展示了如何使用简单的规则来模拟生命,只要给定一些非常基本的规则和输入就能够生成新颖的的解决方案。虽然生命模拟逐渐发展的有别于康威生命游戏,但我们依然努力遵循康威生命游戏中宣扬的简单原则:利用一套简单的规则模拟一个复杂过程,目标是获取一些新颖的模式或解决方案。
在我们开始使用进化或其他方法推导更复杂的生命模拟之前,首先使用一个简单的实现来帮助我们理解。接下来,我们继续探索细胞生命的模拟,为简单起见,只考虑细胞属性,忽略物理条件。
1.3 空间生命和智能体模拟
使用空间表示的模拟,如生命游戏,可以用来进行多种建模和预测,例如交通建模、病毒传播。但在进化深度学习 (Evolutionary Deep Learning
, EDL
) 中模拟的运行并不是我们的重点,我们关注更多地是数学驱动的,意味着需要更多地关注分析向量或距离,而不是物理空间。
2. 实现生命模拟
接下来,我们将实现一个简单的细胞生命模拟,旨在演示一些基本概念的简单实例。
(1) 首先,导入所需库:
import random
import time
import matplotlib.pyplot as plt
(2) 编写函数用于创建一个新的细胞,并根据所需的后代数量生成一个细胞列表或集合:
def create_cell():return dict(health = random.randint(1, 100))def birth(offspring):return [create_cell() for i in range(offspring)]cells = birth(10)
print(cells)
# [{'health': 2}, {'health': 10}, {'health': 16}, {'health': 6}, {'health': 66}, {'health': 16}, {'health': 15}, {'health': 95}, {'health': 78}, {'health': 82}]
(3) 定义繁殖和死亡的代码/规则,与生命游戏不同,使用一个预定义的参数 RPRD_RATE
来定义新细胞产生的可能性;同样,代码还根据随机评估来检查细胞的死亡情况:
RPRD_RATE = 25
DEATH_RATE = 25
(4) 创建繁殖和死亡函数,设置基本的生命模拟函数:
def reproduce(cells):return [create_cell() for cell in cells if random.randint(1, 100) < RPRD_RATE] def death(cells):return [cell for cell in cells if random.randint(1, 100) > DEATH_RATE ]def run_generation(cells):cells.extend(reproduce(cells))return death(cells)
(5) 接下来,执行模拟,目标是增加细胞种群:
generations = 10 #@param {type:"slider", min:1, max:25, step:1}
initial_offspring = 10 #@param {type:"slider", min:10, max:1000, step:1}
reproduction_rate = 50 #@param {type:"slider", min:1, max:100, step:1}
death_rate = 25 #@param {type:"slider", min:1, max:100, step:1}RPRD_RATE = reproduction_rate
DEATH_RATE = death_rate
cells = birth(initial_offspring)history = []
for i in range(generations): cells = run_generation(cells)history.append(len(cells))
plt.plot(history)
plt.show()
观察模拟的运行,如果繁殖和死亡率设置正确,种群将会增加。可以修改驱动模拟的参数,修改参数后再次运行以查看更新的模拟结果。
以上实例的目标只是建立一个简单的细胞模拟,并通过定义控制细胞繁殖和死亡的速率尝试令种群增长。这个模拟并无太多新颖之处,主要目的是为了易于理解和使用。现在我们已经了解了如何实现生命模拟,接下来我们将介绍生命模拟的具体应用。
3. 生命模拟应用
在本节中,我们重用上一小节中的简单实例,并增加执行对细胞上定义的属性的优化。对于大多数进化算法而言,最终的目标是优化过程、参数或结构。
在本节中,我们为每个细胞增加一个新参数 strength
。我们的目标是优化整个种群的细胞的 strength
参数,strength
参数代表生物体中能够使其在环境中成功存活的特征,因此我们的目标是在整个种群中最大化参数 strength
。
使用实时绘图库 LiveLossPlot
绘制机器学习 (Machine Learning
, ML
) /深度学习 ( Deep learning
, DL
) 模型的训练损失,LiveLossPlot
库用于实时可视化训练过程中的损失和指标,可以在训练模型时实时更新和显示损失和指标的变化,有助于直观地监控模型的训练进展,首先使用 pip
安装 LiveLossPlot
库。
pip install livelossplot
(1) 导入 PlotLosses
类以及其他所需库:
import random
import time
import matplotlib.pyplot as plt
from livelossplot import PlotLosses
(2) 修改定义生命模拟的函数代码,使用新的参数 strength
来推导细胞的健康状况:
RPRD_BOUNDS = 25
DEATH_BOUNDS = 25def create_cell():return dict(health = random.randint(1, 100),strength = random.randint(1, 100)) def birth(offspring):return [create_cell() for i in range(offspring)]def evaluate(cells):for cell in cells:cell["health"] *= cell["strength"]/100 return cells
(3) 同样,修改繁殖和死亡函数,不再选择随机细胞进行繁殖或死亡。相反,新函数根据健康属性来确定细胞是否繁殖或死亡。新增两个参数,RPRD_BOUNDS
和 DEATH_BOUNDS
控制细胞在何种健康水平下可以繁殖或何时会死亡:
def reproduce(cells):return [create_cell() for cell in cells if cell["health"] > RPRD_BOUNDS] def death(cells): return [cell for cell in cells if cell["health"] > DEATH_BOUNDS ]def run_generation(cells):cells = evaluate(cells)cells.extend(reproduce(cells))return death(cells)
(4) 在以上代码中,根据细胞健康状况调整了明确的规则来确定细胞在何种情况下会死亡或繁殖。模拟的目标是优化细胞的种群属性,最后一个修改是在生成输出时使用 PlotLosses
类输出模拟的实时图形:
generations = 25 #@param {type:"slider", min:1, max:25, step:1}
initial_offspring = 10 #@param {type:"slider", min:10, max:1000, step:1}
reproduction_bounds = 50#@param {type:"slider", min:1, max:100, step:1}
death_bounds = 25 #@param {type:"slider", min:1, max:100, step:1}RPRD_RATE = reproduction_bounds
DEATH_RATE = death_bounds
cells = birth(initial_offspring)groups = {'Population': ['population'], 'Attributes' : ['avg_strength','avg_health']}
liveloss = PlotLosses(groups=groups)history = {}
for i in range(generations): cells = run_generation(cells) history["population"] = len(cells)history["avg_strength"] = sum([cell["strength"] for cell in cells])/(len(cells)+1) history["avg_health"] = sum([cell["health"] for cell in cells])/(len(cells)+1) liveloss.update(history)liveloss.send()
运行代码,下图显示了运行25代模拟后的输出。可以看到,在左侧的属性图中,strength的平均值和健康状况都呈上升趋势。
通过修改生命模拟代码,我们能够进行单个属性的简单优化,虽然可以看到种群的 strength
和健康状况逐渐增加,但结果并不令人满意。实际上,如果仅仅使用上示生命模拟复制现实世界,那么世界可能永远无法进化成现在的样子。可以通过完成以下问题进一步理解上示生命模拟过程:
- 修改死亡率和出生率参数,观察运行结果
- 修改
evaluate
函数,改变返回的健康参数,然后重新运行模拟,观察其对运行结果的影响 - 修改
create_cell
函数中的health
和strength
的初始值后,运行模拟
模拟是一个多样化的领域,但我们主要关注利用模拟进化进行优化。
上示生命模拟缺失的关键是细胞传递其优秀特征给后代的能力。达尔文首次提出生物会将其优秀特征传递给后代,并称之为进化。事实证明,进化理论不仅是地球上生命的基础,也是进化计算的基础。
小结
生命游戏演示了基于规则的生命模拟的基本形式,生命模拟可以帮助我们优化计算和模拟实际问题。生命模拟可通过使用函数定义繁殖和死亡来观察简单行为。本节中,我们介绍了生命模拟的基本概念及其应用。
系列链接
遗传算法与深度学习实战——进化深度学习
相关文章:
遗传算法与深度学习实战——生命模拟及其应用
遗传算法与深度学习实战——生命模拟及其应用 0. 前言1. 康威生命游戏1.1 康威生命游戏的规则1.2 实现康威生命游戏1.3 空间生命和智能体模拟 2. 实现生命模拟3. 生命模拟应用小结系列链接 0. 前言 生命模拟是进化计算的一个特定子集,模拟了自然界中所观察到的自然…...
大数据|使用Apache Spark 删除指定表中的指定分区数据
文章目录 概述方法 1: 使用 Spark SQL 语句方法 2: 使用 DataFrame API方法 3: 使用 Hadoop 文件系统 API方法 4: 使用 Delta Lake使用注意事项常见相关问题及处理结论 概述 Apache Spark 是一个强大的分布式数据处理引擎,支持多种数据处理模式。在处理大型数据集时…...
OSPF动态路由协议实验
首先地址划分 一个骨干网段分成三个,r1,r2,r5三个环回网段 ,总共要四个网段 192.168.1.0/24 192.168.1.0/26---骨干网段 192.168.1.0/28 192.168.1.16/28 192.168.1.32/28 备用 192.168.1.64/28 192.168.1.64/26---r1环回 192.1…...
tcp中accept()的理解
源码 参数理解 NAMEaccept, accept4 - accept a connection on a socketSYNOPSIS#include <sys/types.h> /* See NOTES */#include <sys/socket.h>int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);#define _GNU_SOURCE …...
让我们逐行重现 GPT-2:第 1 部分
欢迎来到雲闪世界。Andrej Karpathy 是人工智能 (AI) 领域的顶尖研究人员之一。他是 OpenAI 的创始成员之一,曾领导特斯拉的 AI 部门,目前仍处于 AI 社区的前沿。 在第一部分中,我们重点介绍如何实现 GPT-2 的架构。虽然 GPT-2 于 2018 年由 …...
第十九天内容
上午 1、构建vue发行版本 2、java环境配置 jdk软件包路径: https://download.oracle.com/java/22/latest/jdk-22_linux-x64_bin.tar.gz 下午 1、安装tomcat软件 tomcat软件包路径: https://dlcdn.apache.org/tomcat/tomcat-10/v10.1.26/bin/apache-to…...
Hive之扩展函数(UDF)
Hive之扩展函数(UDF) 1、概念讲解 当所提供的函数无法解决遇到的问题时,我们通常会进行自定义函数,即:扩展函数。Hive的扩展函数可分为三种:UDF,UDTF,UDAF。 UDF:一进一出 UDTF:一进多出 UDAF:…...
jdk1.8中HashMap为什么不直接用红黑树
最开始使用链表的时候,空间占用比较少,而且由于链表短,所以查询时间也没有太大的问题。可是当链表越来越长,需要用红黑树的形式来保证查询的效率。 参考资料: https://blog.51cto.com/u_13294304/3075723...
消息推送只会用websocket、轮询?试试SSE,轻松高效。
SSE介绍 HTTP Server-Sent Events (SSE) 是一种基于 HTTP 的服务器推送技术,它允许服务器向客户端推送数据,而无需客户端发起请求。以下是 HTTP SSE 的主要特点: 单向通信: SSE 是一种单向通信协议,服务器可以主动向客户端推送数据,而客户端只能被动接收数据。 持久连接: SS…...
Spring-Retry 框架实战经典重试场景
Spring-Retry框架是Spring自带的功能,具备间隔重试、包含异常、排除异常、控制重试频率等特点,是项目开发中很实用的一种框架。 1、引入依赖 坑点:需要引入AOP,否则会抛异常。 xml <!-- Spring-Retry --> <dependency&…...
人工智能在医疗领域的应用与挑战
随着人工智能技术的不断发展,其在医疗领域的应用也越来越广泛。从辅助诊断到治疗决策,人工智能正在逐步改变着传统的医疗模式。然而,人工智能在医疗领域的应用也面临着诸多挑战,如数据隐私、伦理道德等问题。本文将探讨人工智能在…...
Windows下nmap命令及Zenmap工具的使用方法
一、Nmap简介 nmap是一个网络连接端扫描软件,用来扫描网上电脑开放的网络连接端。确定哪些服务运行在哪些连接端,并且推断计算机运行哪个操作系统(这是亦称 fingerprinting)。它是网络管理员必用的软件之一,以及用以评…...
深入了解-什么是CUDA编程模型
CUDA(Compute Unified Device Architecture,统一计算架构)是NVIDIA推出的一种面向GPU的并行计算平台和编程模型。它允许开发者利用NVIDIA的GPU进行通用目的的并行计算,从而加速应用程序的运行速度。CUDA编程模型为开发者提供了强大…...
111111111111111111
11111111111111111111...
环境如何搭建部署Nacos
这里我使用的是Centos7, Nacos 依赖 Java环境来运行。如果您是从代码开始构建并运行Nacos,还需要为此配置 Maven环境,请确保是在以下版本环境中安装使用 ## 1、下载安装JDK wget https://download.oracle.com/java/17/latest/jdk-17_linux-x6…...
什么是 5G?
什么是 5G? 5G 是第五代无线蜂窝技术,与以前的网络相比,它提供了更高的上传和下载速度、更一致的连接以及更高的容量。5G 比目前流行的 4G 网络更快、更可靠,并有可能改变我们使用互联网访问应用程序、社交网络和信息的方式。例如…...
优化冗余代码:提升前端项目开发效率的实用方法
目录 前言代码复用与组件化模块化开发与代码分割工具辅助与自动化结束语 前言 在前端开发中,我们常常会遇到代码冗余的问题,这不仅增加了代码量,还影响了项目的可维护性和开发效率。还有就是有时候会接到紧急业务需求,要求立马完…...
SpringCloud Alibaba 微服务(四):Sentinel
目录 前言 一、什么是Sentinel? Sentinel 的主要特性 Sentinel 的开源生态 二、Sentinel的核心功能 三、Sentinel 的主要优势与特性 1、丰富的流控规则 2、完善的熔断降级机制 3、实时监控和控制台 4、多数据源支持 5、扩展性强 四、Sentinel 与 Hystrix …...
Python 3.12新功能(1)
Python 3.12正式发布已经很久了,我才将主要电脑的Python版本从3.11升级到最新。最近刚好工作没有那么紧张了,就来领略下这个最新版本中的新特性。 改善了错误消息 Python作为一门编程语言,简单易学容易上手,童叟无欺,深…...
c++STL容器中vector的使用,模拟实现及迭代器使用注意事项和迭代器失效问题
目录 前言: 1.vector的介绍及使用 1.2 vector的使用 1.2 1 vector的定义 1.2 2 vector iterator(迭代器)的使用 1.2.3 vector 空间增长问题 1.2.4 vector 增删查改 1.2.5vector 迭代器失效问题。 2.vector模拟实现 2.1 std::vect…...
Android笔试面试题AI答之Activity常见考点
Activity的常见考点可以总结如下: 生命周期管理:理解Activity在不同情况下(如屏幕旋转、配置更改、用户操作等)的生命周期变化,包括但不限于onCreate、onStart、onResume、onPause、onStop和onDestroy等回调方法。 启…...
RK3568笔记四十九:W25Q64驱动开发(硬件SPI1)
若该文为原创文章,转载请注明原文出处。 一、SPI介绍 串行外设接口 (Serial Peripheral interface) 简称 SPI,是一种高速的,全双工,同步的通信总线,并 且在芯片的管脚上只占用四根线,节约了芯片的管脚。 …...
TypeScript 定义不同的类型(详细示例)
还是大剑师兰特:曾是美国某知名大学计算机专业研究生,现为航空航海领域高级前端工程师;CSDN知名博主,GIS领域优质创作者,深耕openlayers、leaflet、mapbox、cesium,canvas,webgl,ech…...
[工具推荐]前端加解密之Burp插件Galaxy
如果觉得该文章有帮助的,麻烦师傅们可以搜索下微信公众号:良月安全。点个关注,感谢师傅们的支持。 免责声明 本号所发布的所有内容,包括但不限于信息、工具、项目以及文章,均旨在提供学习与研究之用。所有工具安全性…...
课题项目结题测试的作用
课题项目结题测试是课题项目研究过程中的一个重要环节,它对于确保课题项目的质量和成果具有重要的作用。本文将详细介绍课题项目结题测试的作用。 一、确保课题项目质量 课题项目结题测试是对课题项目研究成果的全面评估和检测。通过结题测试,可以对课…...
中国工商银行长春分行开展“工驿幸福 健康财富”长辈客群康养活动
中国工商银行长春分行作为国有大行,持续完善有温度、专业化、安全稳健的养老场景服务,以工行驿站为依托、以长辈客群养老需求为中心,积极对接社区构建敬老、康养的“金融泛金融”工行驿站服务生态,进一步提升长辈客群的到店体验。…...
机器学习 第十四章
目录 前言 一、隐马尔可夫模型 二、马尔可夫随机场 三、条件随机场 四、学习和推断 1.变量消去 2.信念传播 五、近似推断 1.MCMC采样 2.变分推断 六、话题模型 总结 前言 机器学习最重要的任务是根据一些已观察到的证据来对感兴趣的未知变量进行估计和推测。概率模…...
未来RPA财税的发展前景
近年来,全球数字化进程持续提速,越来越多企业受到效率及运营成本的压力,正努力寻求企业增长发展的新路径,而财务作为企业战略的“大脑”,成为企业数字化转型的重要突破口。RPA技术由于能够自动化各种重复性和繁琐的任务…...
快速设置 terminator 透明背景
看图,按步骤设置后⭐重启一个终端则为透明效果 效果展示:...
Redis+Unity 数据库搭建
游戏中需要存放排行榜等数据,而且是实时存放,所以就涉及到数据库的问题。这里找服务器大神了解到可以用Redis来做存储,免费的效率极高。 Redis的搭建参考上文的文章,同时也感谢这位网友。 搭建Redis 并测试数据 搭建Redis 1.下…...
昆明seo网站/千锋教育
首先jquery的文件是要导入的 color.js //改变背景色的插件 //$.fn. (function($) {/*1.方式一* * $.fn.changeColorfunction(){if$(this).css("background-color","yellow").css("color","red");return $(this)}*///方式二$.fn.ext…...
自己做名片的网站/旅行网站排名
..江苏省五年一贯制专转本《C 语言程序设计》模拟试卷一(晓庄)一、填空題(每空1 分,共 20 分)1.C 程序是由构成的,一个 C 源程序至少且仅包含一个。2.C 语言规定标识符只能由、和下划线 3 种字符组成, 且第一个字符必须为或下划线。3. 设有说…...
商机互联做的网站和推广怎么样/seo网站优化系统
| | | | HEADING | | ---------------- | | | | | | ---------------- | | | | REPORT | | ---------------- | | | | | | ---------------- | | | | ENDING | | ---------------- | | | | | | ---------------- | | | |...
淄博网络营销网站/域名批量查询注册
近年来,随着科技的快速发展,人工智能不断进入我们的视野中。作为人工智能的核心技术,机器学习和深度学习也变得越来越火。一时间,它们几乎成为了每个人都在谈论的话题。那么,机器学习和深度学习到底是什么,…...
学做炒菜的网站/需要优化的网站有哪些
题号: 10247 时限:1000ms 限制内存:32768KB 题目: 字符串包含判断描述给定两个字符串a,b。问在a中是否包含b,如果包含则输出yes,否则输出no。 输入格式一行两个字符串,使用空格分开。 输出格式y…...
手机网站建设哪家便宜/百度小说搜索风云榜排行榜
概述 byval是将实参所占的内存空间复制一份出来;byref是给实参另起一个别名,就好像是一个人两个名字。这两个的区别针对于一般的数据类型,大家都非常的清楚,但是,当用遇到对象类型的变量的时候,要小心了&am…...