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

news2024/9/21 20:35:26

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

    • 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 plt

def 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 nb

def 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 direction
        return 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 rules
        X = np.logical_or(np.logical_and(X, Y ==2), Y==3)
        X = X.astype(int)
        yield X

X = 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 manimation

FFMpegWriter = 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 = 25

def 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 的初始值后,运行模拟

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

小结

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

系列链接

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

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

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

相关文章

两种字符串有什么区别——字符数组和字符串,初步认识STL

两种字符串有什么区别——字符数组和字符串&#xff0c;初步认识STL 1.字符数组1.1.基础语法介绍1.2.例题1——自动修正题目描述输入格式输出格式输入输出样例输入 #1输出 #1 1.3.另解——getchar和putchar函数1.4.字符数组相关函数 2.字符串2.1.字符串简介和基础功能2.2.例题2…

MATLAB(6)水纹碰撞覆盖地形

前言 在MATLAB中模拟水纹&#xff08;如水波&#xff09;碰撞并覆盖地形的效果涉及到几个复杂的步骤&#xff0c;包括地形的生成、水波的模拟&#xff08;通常使用波动方程&#xff09;以及两者的交互。下面我将给出一个简化的示例&#xff0c;展示如何在MATLAB中创建一个基本的…

学琴笔记

1-初级钢琴入门课程介绍_哔哩哔哩_bilibili 一些乐理记录&#xff1a; 1.5&#xff1a;

大语言模型稀疏水印技术

面对大型语言模型&#xff08;LLMs&#xff09;在假新闻制造与作弊方面的潜在风险&#xff0c;研究者提出了稀疏水印&#xff08;Sparse Watermark&#xff09;——种创新的文本水印技术&#xff0c;旨在监测和追溯LLMs生成的内容。不同于传统水印方法在可检测性与文本质量间的…

CI522一款电动车仪表NFC开发方案

电动车NFC一键启动 NFC智能刷卡解锁&#xff0c;为你解决四处寻找钥匙的困扰&#xff0c;提升电动车智能化。 Ci522是一款高度集成的13.56MHz非接触式读写器芯片&#xff0c;专为电动车NFC一键启动系统&#xff08;包括仪表总成和电源锁&#xff09;而设计。这款芯片支持ISO/IE…

Python基础教程(一)

1.编程基础 1.1标识符 标识符是变量、函数、模块和其他对象的名称。Python中标识符的命名不是随意的&#xff0c;而是要遵守一定的命名规则&#xff0c;比如说: 1、标识符是由字母 (A~Z 和 a~z) 、下划线和数字组成&#xff0c;但第一个字符不 能是数字。 2、标识符不…

jmeter-beanshell学习14-字符串替换

前面做断言的时候&#xff0c;会记录各种失败信息&#xff0c;比如&#xff1a;“失败原因1,失败原因2,失败原因3”&#xff0c;中间英文逗号隔开&#xff0c;最后写失败报告的时候&#xff0c;再根据英文逗号&#xff0c;写到不同行 即使不分行&#xff0c;写csv文件&#xff…

一文学会CUDA编程:深入了解CUDA编程与架构(一)

前言&#xff1a; CUDA&#xff08;Compute Unified Device Architecture&#xff0c;统一计算设备架构&#xff09;是由NVIDIA公司开发的一种并行计算平台和编程模型。CUDA于2006年发布&#xff0c;旨在通过图形处理器&#xff08;GPU&#xff09;解决复杂的计算问题。在早期…

x264 环路滤波原理系列:x264_macroblock_deblock_strength 函数

x264_macroblock_deblock_strength 函数 功能:计算去块滤波强度值,去块强度值决定了去块滤波器对像素值调整的程度。这些值通常基于以下因素:量化参数(QP):较高的QP值可能导致更强烈的去块;宏块的纹理复杂度:具有更复杂纹理的宏块可能需要更细致的去块处理;宏块的类型…

选项卡切换组件容器的实例

实现效果 点击选项卡A、B、C、D、E分别控制组件容器内各个形状组件的显隐。 实现流程 首先需要选择组件容器内的形状组件&#xff0c;默认实例是3个&#xff0c;如需添加多个可在数据中继续添加。 添加【选项卡】组件&#xff0c;在样式中设置5列&#xff0c;数据添加一列&am…

Jupyter Notebook无法自动打开浏览器解决方案

Step1&#xff1a; 在C盘&#xff08;默认C盘&#xff09;&#xff0c;找到用户文件夹 Step2&#xff1a; 打开用户文件夹&#xff0c;找到自己的“电脑名”文件夹 Step3&#xff1a; 打开“电脑名”文件夹&#xff0c;找到“.jupyter”文件夹 Step4&#xff1a; 打开“.ju…

猫头虎分享:9个实用的GPT-4o提示词

&#x1f389; 猫头虎分享&#xff1a;9个实用的GPT-4o提示词 摘要 在这篇文章中&#xff0c;猫头虎将与大家分享9个非常实用的GPT-4o提示词。这些提示词涵盖了从草图到App代码生成、通用网络爬虫到求职助理等多个领域。我们将深入探讨如何利用这些提示词提升工作效率和创作能…

【前端 · 面试 】HTTP 总结(十)—— HTTP 缓存应用

最近我在做前端面试题总结系列&#xff0c;感兴趣的朋友可以添加关注&#xff0c;欢迎指正、交流。 争取每个知识点能够多总结一些&#xff0c;至少要做到在面试时&#xff0c;针对每个知识点都可以侃起来&#xff0c;不至于哑火。 前端面试http总结.012 前言 通过前面几篇内容…

2024宁波工业装备博览会-相聚12月

2024宁波工业装备博览会-相聚12月 时间&#xff1a;2024年12月2-4日 地点&#xff1a;宁波国际会展中心 2024中国(宁波)工业装备博览会展出面积、展品内容在不断扩大&#xff0c;专业观众成倍增加&#xff0c;极大地推动宁波智能制造产业的国际交流及贸易市场的发展。展会不…

企业如何通过有效的库存管理来降低库存成本?

企业如何通过有效的库存管理来降低库存成本&#xff1f; 那么如何在满足市场需求的同时&#xff0c;最大限度地减少资金占用、降低仓储成本、避免库存积压与损耗呢&#xff1f; 这个问题很好回答&#xff0c;本文我想带你了解WMS仓库管理系统&#xff0c;其能够有效并精准的帮…

选择最佳SOLIDWORKS服务商:您的成功之钥

在当今快速发展的制造业环境中&#xff0c;选择合适的SOLIDWORKS服务商对于确保您的项目成功至关重要。无论是初次接触SOLIDWORKS还是希望提升现有的设计流程&#xff0c;找到一位可靠的服务商都能为您提供所需的技术支持和服务。本文将帮助您了解如何选择最佳的SOLIDWORKS服务…

推荐3款电脑上不可或缺的神仙软件

Allen Explorer Allen Explorer是一款功能强大的文件管理软件&#xff0c;旨在替代Windows系统的“我的电脑”。它采用了类似Chrome的界面设计&#xff0c;简洁美观&#xff0c;支持多标签页、双窗口、收藏夹等功能&#xff0c;极大地优化了文件操作体验。用户可以对文件项目进…

使用 JavaScript 对图像进行量化并提取主要颜色

前言 前段时间在 Halo 的 应用市场 中遇到希望主题和插件的封面图背景色为封面图主色的问题&#xff0c;于是乎需要根据封面图提取主色就想到使用 K-Means 算法来提取。 在图像处理中&#xff0c;图像是由像素点构成的&#xff0c;每个像素点都有一个颜色值&#xff0c;颜色值…

Gstreamer结合腾讯云进行rtmp直播

直播效果&#xff1a; 一、注册腾讯云直播账户&#xff0c;生成rtmp推流地址 腾讯云直播地址&#xff1a; https://console.cloud.tencent.com/live 首先需要注册登录。然后电机生成直播地址&#xff1a; 输入自己的流名字&#xff0c;比如test 复制这个RTMP地址。 这时候&am…

【数据结构与算法】循环队列

循环队列 一.循环队列的引入二.循环队列的原理三.循环队列判断是否为满或空1.是否为空2.是否为满 四.循环队列入队五.循环队列出队六.循环队列的遍历七.循环队列获取长度八.总结 一.循环队列的引入 还记得我们顺序队列的删除元素嘛,我们有两种方式,一种是将数组要删除元素后面…