⛄一、元胞自动机简介

1 元胞自动机发展历程
最初的元胞自动机是由冯 · 诺依曼在 1950 年代为模拟生物 细胞的自我复制而提出的. 但是并未受到学术界重视.
1970 年, 剑桥大学的约翰 · 何顿 · 康威设计了一个电脑游戏 “生命游戏” 后, 元胞自动机才吸引了科学家们的注意.

1983 年 S.Wolfram 发表了一系列论文. 对初等元胞机 256 种 规则所产生的模型进行了深入研究, 并用熵来描述其演化行 为, 将细胞自动机分为平稳型, 周期型, 混沌型和复杂型.

2 对元胞自动机的初步认识
元胞自动机(CA)是一种用来仿真局部规则和局部联系的方法。典型的元胞自动机是定义在网格上的,每一个点上的网格代表一个元胞与一种有限的状态。变化规则适用于每一个元胞并且同时进行。典型的变化规则,决定于元胞的状态,以及其( 4 或 8 )邻居的状态。

3 元胞的变化规则&元胞状态
典型的变化规则,决定于元胞的状态,以及其( 4 或 8 )邻居的状态。

4 元胞自动机的应用
元胞自动机已被应用于物理模拟,生物模拟等领域。

5 元胞自动机的matlab编程
结合以上,我们可以理解元胞自动机仿真需要理解三点。一是元胞,在matlab中可以理解为矩阵中的一点或多点组成的方形块,一般我们用矩阵中的一点代表一个元胞。二是变化规则,元胞的变化规则决定元胞下一刻的状态。三是元胞的状态,元胞的状态是自定义的,通常是对立的状态,比如生物的存活状态或死亡状态,红灯或绿灯,该点有障碍物或者没有障碍物等等。

6 一维元胞自动机——交通规则
定义:
6.1 元胞分布于一维线性网格上.
6.2 元胞仅具有车和空两种状态.

7 二维元胞自动机——生命游戏
定义:
7.1 元胞分布于二维方型网格上.
7.2 元胞仅具有生和死两种状态.

元胞状态由周围八邻居决定.
规则:

骷髅:死亡;笑脸:生存
周围有三个笑脸,则中间变为笑脸
少于两个笑脸或者多于三个,中间则变死亡。

8 什么是元胞自动机
离散的系统: 元胞是定义在有限的时间和空间上的, 并且元 胞的状态是有限.
动力学系统: 元胞自动机的举止行为具有动力学特征.
简单与复杂: 元胞自动机用简单规则控制相互作用的元胞 模拟复杂世界.


9 构成要素

(1)元胞 (Cell)

元胞是元胞自动机基本单元:
状态: 每一个元胞都有记忆贮存状态的功能.
离散: 简单情况下, 元胞只有两种可能状态; 较复杂情况下, 元胞具有多种状态.
更新: 元胞的状态都安照动力规则不断更新.
(2)网格 (Lattice)
不同维网格

常用二维网格

(3)邻居 (Neighborhood)

(4)边界 (Boundary)

反射型:以自己作为边界的状态
吸收型:不管边界(车开到边界就消失)

(5)规则(状态转移函数)
定义:根据元胞当前状态及其邻居状况确定下一时刻该元胞状态的动力学函数, 简单讲, 就是一个状态转移函数.
分类 :
总和型: 某元胞下时刻的状态取决于且仅取决于它所有邻居 的当前状态以及自身的当前状态.
合法型: 总和型规则属于合法型规则. 但如果把元胞自动机 的规则限制为总和型, 会使元胞自动机具有局限性.
(6)森林火灾

绿色:树木;红色:火;黑色:空地。
三种状态循环转化:
树:周围有火或者被闪电击中就变成火。
空地:以概率p变为树木
理性分析:红为火;灰为空地;绿是树

元胞三种状态的密度和为1

火转化为空地的密度等于空地转换为树的密度(新长出来的树等于烧没的树)

f是闪电的概率:远远小于树生成的概率;T s m a x T_{smax}T smax
​是一大群树被火烧的时间尺度
程序实现
周期性边界条件
购进啊

其中的数字为编号
构建邻居矩阵

上面矩阵中的数字编号,对应原矩阵相同位置编号的上邻居编号,一 一对应
同样道理:

(7)交通概念
车距和密度

流量方程

守恒方程

时空轨迹(横轴是空间纵轴为时间)

红线横线与蓝色交点表示每个时间车的位置。
如果是竖线则表示车子在该位置对应的时间

宏观连续模型:

最常用的规则:

红色条表示速度是满的。

1 加速规则:不能超过v m a x ( 2 格 / s ) v_{max}(2格/s)v
max(2格/s)
2 防止碰撞:不能超过车距

理论分析:

结果分析: 密度与流量

第一个图:横坐标是归一化后的密度,纵坐标是车流量。第二个图:理论值与CA的结果

结果分析: 时空轨迹

中间的深色区域是交通堵塞的区域。

⛄二、部分源代码

clear all
clf
nx=130; %must be divisible by 4
ny=122;
Pbridge = .05;
z=zeros(nx,ny);
o=ones(nx,ny);
traf = z ;
trafNew = z;
trafB=z;
gnd = z ;
gn=z;
gnd(50, 1:ny) = 1 ;
gnd(79, 1:ny) = 1 ;
gnd(1:nx, 50) = 1 ;
gnd(1:nx,71) = 1 ;
gnd(nx/2, 1: 50) = 1 ;
gnd(nx/2, 71:ny) = 1 ;
gnd(1: 50, ny/2) = 1 ;
gnd(79:nx,ny/2)=1;
imh = image(cat(3,z’,traf’,gnd’));
set(imh, ‘erasemode’, ‘none’);
%第一相位 0到38秒
%进口
for i=1:100
%绿灯
%东进口
%直行 右转
traf(129,55) =round(rand(1,1)/1.8); %add a grain at the top
xind = [80:129];
yind=55;
trafNew(xind-1,yind)=traf(xind,yind);
traf(129,53) =round(rand(1,1)/1.76); %add a grain at the top
xind = [79:129];
yind=53;
trafNew(xind-1,yind)=traf(xind,yind);
%西进口
%直行 右转
traf(1,66) =round(rand(1,1)/1.76); %add a grain at the top
xind = [1:49];
yind=66;
trafNew(xind+1,yind)=traf(xind,yind);
trafNew(xind+1,yind)=traf(xind,yind);
traf(1,68) =round(rand(1,1)/1.76); %add a grain at the top
xind = [1:49];
yind=68;
trafNew(xind+1,yind)=traf(xind,yind);
%南进口
%右转
traf(77,122) =round(rand(1,1)/1.76); %add a grain at the top
yind = [71:122];
xind=77;
trafNew(xind,yind-1)=traf(xind,yind);
%北进口
%右转
traf(53,1) =round(rand(1,1)/1.76); %add a grain at the top
yind = [1:50];
xind=53;
trafNew(xind,yind+1)=traf(xind,yind);
%交叉口内部
%东进口直行
xind = [50:80];
yind=55;
trafNew(xind-1,yind)=traf(xind,yind);
%西进口直行;
xind = [50:80];
yind=66;
trafNew(xind+1,yind)=traf(xind,yind);
%出口
%东出口
xind = [79:122];
yind=[65:79];
trafNew(xind+1,yind)=traf(xind,yind);
%西出口
xind = [2:50];
yind=[50:60];
trafNew(xind-1,yind)=traf(xind,yind);
%南出口
yind = [71:120];
xind=[50:63];
trafNew(xind,yind+1)=traf(xind,yind);
%北出口
yind = [2:50];
xind=[67:77];
trafNew(xind,yind-1)=traf(xind,yind);
%针对右转车道的代码
%东进口右转
trafNew(77,50)=traf(79,53);
%西进口右转
trafNew(53,71)=traf(50,68);
%南进口右转
trafNew(79,68)=traf(77,71);
%北进口右转
trafNew(50,53)=traf(53,50);

%红灯
p=mod(i,2); %margolis neighborhood
%西进口左转 正向
traf(1,64) =round(rand(1,1)/1.85); %add a grain at the top
xind = [1+p:2:nx-2+p];
yind=64;
trafNew(xind,yind) = gnd(xind,yind).*traf(xind,yind)+…
(1-gnd(xind,yind)).*traf(xind,yind).*traf(xind+1,yind);
trafNew(xind+1,yind)=traf(xind+1,yind)+…
(1-traf(xind+1,yind)).traf(xind,yind).(1-gnd(xind,yind));
%北进口直行左转 正向
traf(55:2:63,1) =round(rand(5,1)/1.85); %add a grain at the top
yind = [1+p:2:51-2+p];
xind=55:2:63;
trafNew(xind,yind) = gnd(xind,yind).*traf(xind,yind)+…
(1-gnd(xind,yind)).*traf(xind,yind).*traf(xind,yind+1);
trafNew(xind,yind+1)=traf(xind,yind+1)+…
(1-traf(xind,yind+1)).traf(xind,yind).(1-gnd(xind,yind));

%东进口左转 反向
traf=trafNew;
traf(79,57) =round(rand(1,1)/1.85);
xind = [79+p:2:129-2+p];
yind=57;
gn(57,129)=1;
trafNew(xind,yind) = gn(xind,yind).*traf(xind,yind)+…
(1-gn(xind,yind)).*traf(xind,yind).*traf(xind+1,yind);
trafNew(xind+1,yind)=traf(xind+1,yind)+…
(1-traf(xind+1,yind)).traf(xind,yind).(1-gn(xind,yind));
for x=79:129
trafB(x,yind)=trafNew(208-x,yind);
end
traf=trafNew;
traf(79:129,57)=trafB(79:129,57);
%南进口直行左转 反向
gn(67:2:75,122)=1;
traf(67:2:75,72) =round(rand(5,1)/1.85); %add a grain at the top
yind = [72+p:2:122-2+p];
xind=67:2:75;
trafNew(xind,yind) = gnd(xind,yind).*traf(xind,yind)+…
(1-gnd(xind,yind)).*traf(xind,yind).*traf(xind,yind+1);
trafNew(xind,yind+1)=traf(xind,yind+1)+…
(1-traf(xind,yind+1)).traf(xind,yind).(1-gnd(xind,yind));
for y=72:122
trafB(xind,y)=trafNew(xind,194-y);
end
traf(67:2:75,72:122)=trafB(67:2:75,72:122);

pause(0.1);
set(imh, ‘cdata’, cat(3,z’,traf’,gnd’) )
drawnow
end

for i=101:200
%交叉口内部
%东进口直行
xind = [53:75];
yind=55;
trafNew(xind-1,yind)=traf(xind,yind);
%西进口直行;
xind = [52:79];
yind=66;
trafNew(xind+1,yind)=traf(xind,yind);

%出口
%东出口
xind = [79:122];
yind=[65:79];
trafNew(xind+1,yind)=traf(xind,yind);
%西出口
xind = [2:50];
yind=[50:60];
trafNew(xind-1,yind)=traf(xind,yind);
%南出口
yind = [71:120];
xind=[50:63];
trafNew(xind,yind+1)=traf(xind,yind);
%北出口
yind = [2:50];
xind=[67:77];
trafNew(xind,yind-1)=traf(xind,yind);

%红灯
p=mod(i,2); %margolis neighborhood
%西进口左转直行 正向
traf(1,64:2:68) =round(rand(1,3)/1.85); %add a grain at the top
xind = [1+p:2:50-2+p];
yind=64:2:68;
trafNew(xind,yind) = gnd(xind,yind).*traf(xind,yind)+…
(1-gnd(xind,yind)).*traf(xind,yind).*traf(xind+1,yind);
trafNew(xind+1,yind)=traf(xind+1,yind)+…
(1-traf(xind+1,yind)).traf(xind,yind).(1-gnd(xind,yind));
%北进口左转 正向
traf(53:2:63,1) =round(rand(6,1)/1.85); %add a grain at the top
yind = [1+p:2:51-2+p];
xind=53:2:63;
trafNew(xind,yind) = gnd(xind,yind).*traf(xind,yind)+…
(1-gnd(xind,yind)).*traf(xind,yind).*traf(xind,yind+1);
trafNew(xind,yind+1)=traf(xind,yind+1)+…
(1-traf(xind,yind+1)).traf(xind,yind).(1-gnd(xind,yind));
%东进口左转直行 反向
traf=trafNew;
traf(79,53:2:57) =round(rand(1,3)/1.85);
xind = [79+p:2:129-2+p];
yind=53:2:57;
gn(53:2:57,129)=1;
trafNew(xind,yind) = gn(xind,yind).*traf(xind,yind)+…
(1-gn(xind,yind)).*traf(xind,yind).*traf(xind+1,yind);
trafNew(xind+1,yind)=traf(xind+1,yind)+…
(1-traf(xind+1,yind)).traf(xind,yind).(1-gn(xind,yind));
for x=79:129
trafB(x,53)=trafNew(208-x,53);
trafB(x,55)=trafNew(208-x,55);
trafB(x,57)=trafNew(208-x,57);
end
traf(79:129, 53:2:57)=trafB(79:129, 53:2:57);
%南进口左转 反向
gn(67:2:77,122)=1;
traf(67:2:77,72) =round(rand(6,1)/1.85); %add a grain at the top
yind = [72+p:2:122-2+p];
xind=67:2:77;
trafNew(xind,yind) = gnd(xind,yind).*traf(xind,yind)+…
(1-gnd(xind,yind)).*traf(xind,yind).*traf(xind,yind+1);
trafNew(xind,yind+1)=traf(xind,yind+1)+…
(1-traf(xind,yind+1)).traf(xind,yind).(1-gnd(xind,yind));
for y=72:122
trafB(xind,y)=trafNew(xind,194-y);
end
traf(67:2:77,72:122)=trafB(67:2:77,72:122);

pause(0.1);
set(imh, ‘cdata’, cat(3,z’,traf’,gnd’) )
drawnow
end

⛄三、运行结果

⛄四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]党珊,蒋太刚,巫承军.基于元胞自动机方法的消防疏散仿真研究[J].现代电子技术. 2022,45(21)
[2]帅斌,秦梦瑶,许旻昊.基于元胞自动机的高速铁路列车运行仿真研究[J].计算机仿真. 2022,39(08)
[3]张睿洋.元胞自动机在两类传染病模型中的应用[J].现代信息科技. 2022,6(10)

3 备注
简介此部分摘自互联网,仅供参考,若侵权,请联系删除

【元胞自动机】基于matlab元胞自动机多车道信号交叉口仿真【含Matlab源码 818期】相关推荐

  1. 【Matlab语音分析】语音信号分析【含GUI源码 1718期】

    一.代码运行视频(哔哩哔哩) [Matlab语音分析]语音信号分析[含GUI源码 1718期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]韩纪庆,张磊,郑铁 ...

  2. 【Matlab身份证识别】身份证号码识别【含GUI源码 014期】

    一.代码运行视频(哔哩哔哩) [Matlab身份证识别]身份证号码识别[含GUI源码 014期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅.MAT ...

  3. 【Matlab语音处理】声音信号频谱分析仪【含GUI源码 325期】

    一.代码运行视频(哔哩哔哩) [Matlab语音处理]声音信号频谱分析仪[含GUI源码 325期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]韩纪庆,张磊, ...

  4. 【Matlab心音信号】EMD心音信号特征提取【含GUI源码 1735期】

    一.代码运行视频(哔哩哔哩) [Matlab心音信号]EMD心音信号特征提取[含GUI源码 1735期] 二.matlab版本及参考文献 1 matlab版本 2014a *2 参考文献 [1] 沈再 ...

  5. 【Matlab车牌识别】停车计费系统【含GUI源码 735期】

    一.代码运行视频(哔哩哔哩) [Matlab车牌识别]停车计费系统[含GUI源码 735期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅.MATLA ...

  6. 【Matlab水果识别】自助水果超市【含GUI源码 594期】

    一.代码运行视频(哔哩哔哩) [Matlab水果识别]自助水果超市[含GUI源码 594期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]倪云峰,叶健,樊娇娇 ...

  7. 【Matlab生物电信号】生物电信号仿真【含GUI源码 684期】

    一.代码运行视频(哔哩哔哩) [Matlab生物电信号]生物电信号仿真[含GUI源码 684期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]董兵,超于毅,李 ...

  8. 【Matlab验证码识别】遗传算法和最大熵优化+大津法(OTSU)+自定义阈值数字验证码识别【含GUI源码 1694期】

    一.代码运行视频(哔哩哔哩) [Matlab验证码识别]遗传算法和最大熵优化+大津法(OTSU)+自定义阈值数字验证码识别[含GUI源码 1694期] 二.matlab版本及参考文献 1 matlab ...

  9. 【Matlab人脸识别】BP神经网络人脸识别(含识别率)【含GUI源码 891期】

    一.代码运行视频(哔哩哔哩) [Matlab人脸识别]BP神经网络人脸识别(含识别率)[含GUI源码 891期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] ...

  10. 【Matlab人脸识别】形态学教室人数统计(带面板)【含GUI源码 1703期】

    一.代码运行视频(哔哩哔哩) [Matlab人脸识别]形态学教室人数统计(带面板)[含GUI源码 1703期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]孟 ...

最新文章

  1. java三维滑雪,第六章 三维数据空间分析方法.ppt
  2. VTK:IO之ImageWriter
  3. [NOTE] XVWA靶场练习笔记
  4. CTF之文件包含的猥琐思路
  5. layer:好看的弹出窗口
  6. 如何将qq客服搬到我们的flex应用中
  7. VMware 多款产品中存在严重漏洞
  8. VS2013、VS2015中,新建项目没有看到解决方案的问题(已解决)
  9. 建造游乐园(play)
  10. python中导入模块的方式_在python中导入模块中的对象有哪几种方式
  11. Hypervisor小记
  12. 盘点最近 火火火 的 7 个 GitHub 项目
  13. 手机耳机插入电脑没有反应
  14. Enscape 设置预设功能能够在保存的设置之间切换
  15. Magento银联支付模块|Magento1.9 Unionpay中国银联支付插件|支持PC、手机移动端支付|2016最新Unionpay5.0.0支付接口...
  16. 天邑ty1208z海思3798刷版本_天邑TY1208Z海思3798芯片强刷安卓系统固件rom刷机包下载...
  17. 【转】canvas save restore详解(包你懂,绝对不是百度里千篇一律的教程)
  18. js中的 与或运算顺序 (包含例子)
  19. 一个屌丝程序员的青春(一八八)
  20. 对生产订单月结的理解

热门文章

  1. 【Day2.2】茶卡盐湖
  2. 论文研究 | 机器视觉在无人机领域的发展
  3. 王建宙五进36dj中挪动包围国际化
  4. 2022年长三角地区数学建模B题:齿轮箱故障诊断
  5. Flutter _ 状态管理指南篇,Android开发两年
  6. Cluster analysis :Basic Concepts and Algorithms -- Part 5 Cluster Evalation
  7. JAVA第三方工具类
  8. 基于node.js和Vue的运动装备网上商城
  9. vivo陷全国手机行业反垄断第一案
  10. VMware发表新版桌面虚拟化软件View 3