当前位置: 首页 > news >正文

遗传算法与深度学习实战——生命模拟及其应用

遗传算法与深度学习实战——生命模拟及其应用

    • 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_BOUNDSDEATH_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 函数中的 healthstrength 的初始值后,运行模拟

模拟是一个多样化的领域,但我们主要关注利用模拟进化进行优化。
上示生命模拟缺失的关键是细胞传递其优秀特征给后代的能力。达尔文首次提出生物会将其优秀特征传递给后代,并称之为进化。事实证明,进化理论不仅是地球上生命的基础,也是进化计算的基础。

小结

生命游戏演示了基于规则的生命模拟的基本形式,生命模拟可以帮助我们优化计算和模拟实际问题。生命模拟可通过使用函数定义繁殖和死亡来观察简单行为。本节中,我们介绍了生命模拟的基本概念及其应用。

系列链接

遗传算法与深度学习实战——进化深度学习

相关文章:

遗传算法与深度学习实战——生命模拟及其应用

遗传算法与深度学习实战——生命模拟及其应用 0. 前言1. 康威生命游戏1.1 康威生命游戏的规则1.2 实现康威生命游戏1.3 空间生命和智能体模拟 2. 实现生命模拟3. 生命模拟应用小结系列链接 0. 前言 生命模拟是进化计算的一个特定子集&#xff0c;模拟了自然界中所观察到的自然…...

大数据|使用Apache Spark 删除指定表中的指定分区数据

文章目录 概述方法 1: 使用 Spark SQL 语句方法 2: 使用 DataFrame API方法 3: 使用 Hadoop 文件系统 API方法 4: 使用 Delta Lake使用注意事项常见相关问题及处理结论 概述 Apache Spark 是一个强大的分布式数据处理引擎&#xff0c;支持多种数据处理模式。在处理大型数据集时…...

OSPF动态路由协议实验

首先地址划分 一个骨干网段分成三个&#xff0c;r1&#xff0c;r2&#xff0c;r5三个环回网段 &#xff0c;总共要四个网段 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 的创始成员之一&#xff0c;曾领导特斯拉的 AI 部门&#xff0c;目前仍处于 AI 社区的前沿。 在第一部分中&#xff0c;我们重点介绍如何实现 GPT-2 的架构。虽然 GPT-2 于 2018 年由 …...

第十九天内容

上午 1、构建vue发行版本 2、java环境配置 jdk软件包路径&#xff1a; https://download.oracle.com/java/22/latest/jdk-22_linux-x64_bin.tar.gz 下午 1、安装tomcat软件 tomcat软件包路径&#xff1a; https://dlcdn.apache.org/tomcat/tomcat-10/v10.1.26/bin/apache-to…...

Hive之扩展函数(UDF)

Hive之扩展函数(UDF) 1、概念讲解 当所提供的函数无法解决遇到的问题时&#xff0c;我们通常会进行自定义函数&#xff0c;即&#xff1a;扩展函数。Hive的扩展函数可分为三种&#xff1a;UDF,UDTF,UDAF。 UDF&#xff1a;一进一出 UDTF&#xff1a;一进多出 UDAF&#xff1a…...

jdk1.8中HashMap为什么不直接用红黑树

最开始使用链表的时候&#xff0c;空间占用比较少&#xff0c;而且由于链表短&#xff0c;所以查询时间也没有太大的问题。可是当链表越来越长&#xff0c;需要用红黑树的形式来保证查询的效率。 参考资料&#xff1a; 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自带的功能&#xff0c;具备间隔重试、包含异常、排除异常、控制重试频率等特点&#xff0c;是项目开发中很实用的一种框架。 1、引入依赖 坑点&#xff1a;需要引入AOP&#xff0c;否则会抛异常。 xml <!-- Spring-Retry --> <dependency&…...

人工智能在医疗领域的应用与挑战

随着人工智能技术的不断发展&#xff0c;其在医疗领域的应用也越来越广泛。从辅助诊断到治疗决策&#xff0c;人工智能正在逐步改变着传统的医疗模式。然而&#xff0c;人工智能在医疗领域的应用也面临着诸多挑战&#xff0c;如数据隐私、伦理道德等问题。本文将探讨人工智能在…...

Windows下nmap命令及Zenmap工具的使用方法

一、Nmap简介 nmap是一个网络连接端扫描软件&#xff0c;用来扫描网上电脑开放的网络连接端。确定哪些服务运行在哪些连接端&#xff0c;并且推断计算机运行哪个操作系统&#xff08;这是亦称 fingerprinting&#xff09;。它是网络管理员必用的软件之一&#xff0c;以及用以评…...

深入了解-什么是CUDA编程模型

CUDA&#xff08;Compute Unified Device Architecture&#xff0c;统一计算架构&#xff09;是NVIDIA推出的一种面向GPU的并行计算平台和编程模型。它允许开发者利用NVIDIA的GPU进行通用目的的并行计算&#xff0c;从而加速应用程序的运行速度。CUDA编程模型为开发者提供了强大…...

111111111111111111

11111111111111111111...

环境如何搭建部署Nacos

这里我使用的是Centos7&#xff0c; Nacos 依赖 Java环境来运行。如果您是从代码开始构建并运行Nacos&#xff0c;还需要为此配置 Maven环境&#xff0c;请确保是在以下版本环境中安装使用 ## 1、下载安装JDK wget https://download.oracle.com/java/17/latest/jdk-17_linux-x6…...

什么是 5G?

什么是 5G&#xff1f; 5G 是第五代无线蜂窝技术&#xff0c;与以前的网络相比&#xff0c;它提供了更高的上传和下载速度、更一致的连接以及更高的容量。5G 比目前流行的 4G 网络更快、更可靠&#xff0c;并有可能改变我们使用互联网访问应用程序、社交网络和信息的方式。例如…...

优化冗余代码:提升前端项目开发效率的实用方法

目录 前言代码复用与组件化模块化开发与代码分割工具辅助与自动化结束语 前言 在前端开发中&#xff0c;我们常常会遇到代码冗余的问题&#xff0c;这不仅增加了代码量&#xff0c;还影响了项目的可维护性和开发效率。还有就是有时候会接到紧急业务需求&#xff0c;要求立马完…...

SpringCloud Alibaba 微服务(四):Sentinel

目录 前言 一、什么是Sentinel&#xff1f; Sentinel 的主要特性 Sentinel 的开源生态 二、Sentinel的核心功能 三、Sentinel 的主要优势与特性 1、丰富的流控规则 2、完善的熔断降级机制 3、实时监控和控制台 4、多数据源支持 5、扩展性强 四、Sentinel 与 Hystrix …...

Python 3.12新功能(1)

Python 3.12正式发布已经很久了&#xff0c;我才将主要电脑的Python版本从3.11升级到最新。最近刚好工作没有那么紧张了&#xff0c;就来领略下这个最新版本中的新特性。 改善了错误消息 Python作为一门编程语言&#xff0c;简单易学容易上手&#xff0c;童叟无欺&#xff0c;深…...

c++STL容器中vector的使用,模拟实现及迭代器使用注意事项和迭代器失效问题

目录 前言&#xff1a; 1.vector的介绍及使用 1.2 vector的使用 1.2 1 vector的定义 1.2 2 vector iterator&#xff08;迭代器&#xff09;的使用 1.2.3 vector 空间增长问题 1.2.4 vector 增删查改 1.2.5vector 迭代器失效问题。 2.vector模拟实现 2.1 std::vect…...

Flask RESTful 示例

目录 1. 环境准备2. 安装依赖3. 修改main.py4. 运行应用5. API使用示例获取所有任务获取单个任务创建新任务更新任务删除任务 中文乱码问题&#xff1a; 下面创建一个简单的Flask RESTful API示例。首先&#xff0c;我们需要创建环境&#xff0c;安装必要的依赖&#xff0c;然后…...

java_网络服务相关_gateway_nacos_feign区别联系

1. spring-cloud-starter-gateway 作用&#xff1a;作为微服务架构的网关&#xff0c;统一入口&#xff0c;处理所有外部请求。 核心能力&#xff1a; 路由转发&#xff08;基于路径、服务名等&#xff09;过滤器&#xff08;鉴权、限流、日志、Header 处理&#xff09;支持负…...

leetcodeSQL解题:3564. 季节性销售分析

leetcodeSQL解题&#xff1a;3564. 季节性销售分析 题目&#xff1a; 表&#xff1a;sales ---------------------- | Column Name | Type | ---------------------- | sale_id | int | | product_id | int | | sale_date | date | | quantity | int | | price | decimal | -…...

vue3+vite项目中使用.env文件环境变量方法

vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量&#xff0c;这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...

CMake控制VS2022项目文件分组

我们可以通过 CMake 控制源文件的组织结构,使它们在 VS 解决方案资源管理器中以“组”(Filter)的形式进行分类展示。 🎯 目标 通过 CMake 脚本将 .cpp、.h 等源文件分组显示在 Visual Studio 2022 的解决方案资源管理器中。 ✅ 支持的方法汇总(共4种) 方法描述是否推荐…...

蓝桥杯3498 01串的熵

问题描述 对于一个长度为 23333333的 01 串, 如果其信息熵为 11625907.5798&#xff0c; 且 0 出现次数比 1 少, 那么这个 01 串中 0 出现了多少次? #include<iostream> #include<cmath> using namespace std;int n 23333333;int main() {//枚举 0 出现的次数//因…...

Hive 存储格式深度解析:从 TextFile 到 ORC,如何选对数据存储方案?

在大数据处理领域&#xff0c;Hive 作为 Hadoop 生态中重要的数据仓库工具&#xff0c;其存储格式的选择直接影响数据存储成本、查询效率和计算资源消耗。面对 TextFile、SequenceFile、Parquet、RCFile、ORC 等多种存储格式&#xff0c;很多开发者常常陷入选择困境。本文将从底…...

【Java学习笔记】BigInteger 和 BigDecimal 类

BigInteger 和 BigDecimal 类 二者共有的常见方法 方法功能add加subtract减multiply乘divide除 注意点&#xff1a;传参类型必须是类对象 一、BigInteger 1. 作用&#xff1a;适合保存比较大的整型数 2. 使用说明 创建BigInteger对象 传入字符串 3. 代码示例 import j…...

C++课设:简易日历程序(支持传统节假日 + 二十四节气 + 个人纪念日管理)

名人说:路漫漫其修远兮,吾将上下而求索。—— 屈原《离骚》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 专栏介绍:《编程项目实战》 目录 一、为什么要开发一个日历程序?1. 深入理解时间算法2. 练习面向对象设计3. 学习数据结构应用二、核心算法深度解析…...

tomcat指定使用的jdk版本

说明 有时候需要对tomcat配置指定的jdk版本号&#xff0c;此时&#xff0c;我们可以通过以下方式进行配置 设置方式 找到tomcat的bin目录中的setclasspath.bat。如果是linux系统则是setclasspath.sh set JAVA_HOMEC:\Program Files\Java\jdk8 set JRE_HOMEC:\Program Files…...