遗传算法与深度学习实战——生命模拟及其应用
遗传算法与深度学习实战——生命模拟及其应用
- 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…...
后进先出(LIFO)详解
LIFO 是 Last In, First Out 的缩写,中文译为后进先出。这是一种数据结构的工作原则,类似于一摞盘子或一叠书本: 最后放进去的元素最先出来 -想象往筒状容器里放盘子: (1)你放进的最后一个盘子(…...
浅谈 React Hooks
React Hooks 是 React 16.8 引入的一组 API,用于在函数组件中使用 state 和其他 React 特性(例如生命周期方法、context 等)。Hooks 通过简洁的函数接口,解决了状态与 UI 的高度解耦,通过函数式编程范式实现更灵活 Rea…...
uniapp 对接腾讯云IM群组成员管理(增删改查)
UniApp 实战:腾讯云IM群组成员管理(增删改查) 一、前言 在社交类App开发中,群组成员管理是核心功能之一。本文将基于UniApp框架,结合腾讯云IM SDK,详细讲解如何实现群组成员的增删改查全流程。 权限校验…...

UE5 学习系列(三)创建和移动物体
这篇博客是该系列的第三篇,是在之前两篇博客的基础上展开,主要介绍如何在操作界面中创建和拖动物体,这篇博客跟随的视频链接如下: B 站视频:s03-创建和移动物体 如果你不打算开之前的博客并且对UE5 比较熟的话按照以…...

【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例
文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...

CocosCreator 之 JavaScript/TypeScript和Java的相互交互
引擎版本: 3.8.1 语言: JavaScript/TypeScript、C、Java 环境:Window 参考:Java原生反射机制 您好,我是鹤九日! 回顾 在上篇文章中:CocosCreator Android项目接入UnityAds 广告SDK。 我们简单讲…...
Spring AI 入门:Java 开发者的生成式 AI 实践之路
一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...

什么是Ansible Jinja2
理解 Ansible Jinja2 模板 Ansible 是一款功能强大的开源自动化工具,可让您无缝地管理和配置系统。Ansible 的一大亮点是它使用 Jinja2 模板,允许您根据变量数据动态生成文件、配置设置和脚本。本文将向您介绍 Ansible 中的 Jinja2 模板,并通…...

技术栈RabbitMq的介绍和使用
目录 1. 什么是消息队列?2. 消息队列的优点3. RabbitMQ 消息队列概述4. RabbitMQ 安装5. Exchange 四种类型5.1 direct 精准匹配5.2 fanout 广播5.3 topic 正则匹配 6. RabbitMQ 队列模式6.1 简单队列模式6.2 工作队列模式6.3 发布/订阅模式6.4 路由模式6.5 主题模式…...

【Redis】笔记|第8节|大厂高并发缓存架构实战与优化
缓存架构 代码结构 代码详情 功能点: 多级缓存,先查本地缓存,再查Redis,最后才查数据库热点数据重建逻辑使用分布式锁,二次查询更新缓存采用读写锁提升性能采用Redis的发布订阅机制通知所有实例更新本地缓存适用读多…...