元胞自动机--Matlab实现简单问题

元胞自动机(cellular automata,CA)是一种时间、空间、状态都离散,空间相互作用和时间因果关系为局部的网格动力学模型,具有模拟复杂系统时空演化过程的能力。文章主要借鉴B站连大数学建模,侵权立删。

目录

元胞自动机构成(四部分)

元胞:元胞可称为单元或基元,是元胞自动机最基本的部分。

元胞空间:元胞空间就是元胞在空间分布上的集合。

 邻居:某一元胞状态更新时所要搜索的空间域就是该元胞的邻居。

 规则:根据元胞当前状态及邻居的状态来决定下一时刻该元胞状态。

一维元胞自动机:

 应用实例:

奇偶规则:

运行代码 

运行结果

 生命游戏

运行代码

运行结果

 澳洲火灾

运行代码

运行结果


元胞自动机构成(四部分)

元胞:元胞可称为单元或基元,是元胞自动机最基本的部分。

--元胞状态:在最简单的情况下,元胞有两种可能状态;较复杂情况下,具有多种状态。元胞的状态都按照元胞自动机的动力规则不断更新。

元胞空间:元胞空间就是元胞在空间分布上的集合。

--元胞空间类型:正方形,三角形,六边形......

 邻居:某一元胞状态更新时所要搜索的空间域就是该元胞的邻居。

--邻居类型:橙色的为邻居,能够对元胞下一时刻的状态进行影响。

 

 --边界条件:

1.固定型边界(自己随心定义)

2.周期型边界

 3.绝热型边界(自己是多少,邻居就是多少)

 4.映射型边界(左右邻居对称)

 规则:根据元胞当前状态及邻居的状态来决定下一时刻该元胞状态。


如当围棋中黑棋周围都是白棋的时候,黑棋为空。

--特征:

  1. 离散型:空间、时间及状态都是离散的
  2. 同质性:服从相同的贵规律、分布方式相同
  3. 并行性:元胞的状态更新规则变化是同步进行的
  4. 高维度:元胞自动机是一类无穷维动力系统

一维元胞自动机:

元胞邻居半径为1,元胞只有两种状态{1,0}。

初始状态为2^3=8种,由此产生的变化规则为2^8=256种。

 应用实例:

奇偶规则:

运行代码 

clc
clear
n=200;
Se=zeros(n);%元胞空间
z=zeros(n);
Se(n/2-2:n/2+2,n/2-2:n/2+2)=1;%初始元胞
Ch=imagesc(cat(3,Se,z,z));%这一步只是使图画的更好看
axis square;
Sd=zeros(n+2);%边界条件
while(1)
    Sd(2:n+1,2:n+1)=Se;
    sum=Sd(1:n,2:n+1)+Sd(3:n+2,2:n+1)+Sd(2:n+1,1:n)+Sd(2:n+1,3:n+2);%上下左右的邻居
    Se=mod(sum,2);
    set(Ch,'cdata',cat(3,Se,z,z))
    pause(0.03)
end

运行结果

 

 生命游戏

在一个正方形的棋盘中,每个小格有两种状态,“生”或“死”,每个小格有8个邻居。
1、对于“生”的格子,若它的8个邻居中有两个或者三个为“生”,则该格继续保持“生”,否则就变为“死”。
2、对于“死”的格子,若它的8个邻居中有3个“生”,则该格变为“生”,否则继续保持“死”。

运行代码

clc
clear
n=200;
p=0.4;
z=zeros(n);
Se=rand(n)<p;
Sd=zeros(n+2);%矩阵初始化
Ph=image(cat(3,Se,z,z));%初始矩阵可视化
while(1)
    Sd(2:n+1,2:n+1)=Se;
    Sum=Sd(1:n,2:n+1)+Sd(3:n+2,2:n+1)+Sd(2:n+1,1:n)+Sd(2:n+1,3:n+2)+Sd(1:n,1:n)+Sd(3:n+2,1:n)+Sd(1:n,3:n+2)+Sd(3:n+2,3:n+2);
%邻居之和(邻居中生的细胞数目)
    for i=1:n
        for j=1:n
            if Sum(i,j)==3||(Sum(i,j)==2&&Se(i,j)==1)%生的条件
                Se(i,j)=1;
            else
                Se(i,j)=0;
            end
        end
    end
    set(Ph,'cdata',cat(3,Se,z,z))%更新可视化
    drawnow
end

运行结果

 澳洲火灾

经典的森林火灾元胞自动机模型是由Drossel和Schwabl在1992年提出。森林火灾元胞自动机模型定义在正方形网格上,元胞有三种状态:树,火和空地。


运行代码

clc
clear
n=300;%定义表示森林的矩阵大小
Plight=5e-6;Pgrowth=1e-2;%定义闪电和生长的概率
UL=[n,1:n-1];DR=[2:n,1];%定义上左,下右邻居
veg=zeros(n,n);%初始化表示森林的矩阵
imh=image(cat(3,veg,veg,veg));%可视化表示森林的矩阵
%veg=0——空地,veg=1——着火,veg=2——树
for i=1:3000
    sum=(veg(UL,:)==1)+(veg(:,UL)==1)+(veg(:,DR)==1)+(veg(DR,:)==1);
%根据规则更新森林矩阵:是否树=是否树-是否着火的树+是否新生的树(0-1运算)
    veg=2*(veg==2)-((veg==2)&(sum>0|rand(n,n)<Plight))+2*((veg==0)&rand(n,n)<Pgrowth);
    set(imh,'cdata',cat(3,(veg==1),(veg==2),zeros(n)))
    drawnow%可视化表示森林的矩阵
end

运行结果

 

 

 

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1 2/3维图像分割工具箱 2 PSORT粒子群优化工具箱 3 matlab计量工具箱Lesage 4 MatCont7p1 5 matlab模糊逻辑工具箱函数 6 医学图像处理工具箱 7 人工蜂群工具箱 8 MPT3安装包 9 drEEM toolbox 10 DOMFluor Toolbox v1.7 11 Matlab数学建模工具箱 12 马尔可夫决策过程(MDP)工具箱MDPtoolbox 13 国立SVM工具箱 14 模式识别与机器学习工具箱 15 ttsbox1.1语音合成工具箱 16 分数阶傅里叶变换的程序FRFT 17 魔方模拟器与规划求解 18 隐马尔可夫模型工具箱 HMM 19 图理论工具箱GrTheory 20 自由曲线拟合工具箱ezyfit 21 分形维数计算工具箱FracLab 2.2 22 For-Each 23 PlotPub 24 Sheffield大学最新遗传算法工具箱 25 Camera Calibration 像机标定工具箱 26 Qhull(二维三维三角分解、泰森图)凸包工具箱 2019版 27 jplv7 28 MatlabFns 29 张量工具箱Tensor Toolbox 30 海洋要素计算工具箱seawater 31 地图工具箱m_map 32 othercolor配色工具包 33 Matlab数学建模工具箱 34 元胞自动机 35 量子波函数演示工具箱 36 图像局域特征匹配工具箱 37 图像分割graphcut工具箱 38 NSGA-II工具箱 39 chinamap国地图数据工具箱(大陆地区) 40 2D GaussFit高斯拟合工具箱 41 dijkstra最小成本路径算法 42 多维数据快速矩阵乘法 43 约束粒子群优化算法 44 脑MRI肿瘤的检测与分类 45 Matlab数值分析算法程序 46 matlab车牌识别完整程序 47 机器人工具箱robot-10.3.1 48 cvx凸优化处理工具箱 49 hctsa时间序列分析工具箱 50 神经科学工具箱Psychtoolbox-3-PTB 51 地震数据处理工具CREWES1990版 52 经济最优化工具箱CompEcon 53 基于约束的重构分析工具箱Cobratoolbox 54 Schwarz-Christoffel Toolbox 55 Gibbs-SeaWater (GSW)海洋学工具箱 56 光声仿真工具箱K-Wave-toolbox-1.2.1 57 语音处理工具箱Sap-Voicebox 58 贝叶斯网工具箱Bayes Net Toolbox(BNT) 59 计算机视觉工具箱VFfeat-0.9.21 60 全向相机校准工具箱OCamCalib_v3.0 61 心理物理学数据分析工具箱Palamedes1_10_3 62 生理学研究工具箱EEGLAB 63 磁共振成像处理工具箱CONN 18b 64 matlab 复杂网络工具箱 65 聚类分析工具箱FuzzyClusteringToolbox 66 遗传规划matlab工具箱 67 粒子群优化工具箱 68 数字图像处理工具箱DIPUM Toolbax V1.1.3 69 遗传算法工具箱 70 鱼群算法工具箱OptimizedAFSAr 71 蚁群算法工具箱 72 matlab优化工具箱 73 数据包络分析工具箱 74 图像分割质量评估工具包 75 相关向量机工具箱 76 音频处理工具箱 77 nurbs工具箱 78 Nurbs-surface工具箱 79 grabit数据提取工具箱 80 量子信息工具箱QLib 81 DYNAMO工具箱 82 NEDC循环的整车油耗量 83 PlotHub工具箱 84 MvCAT_Ver02.01 85 Regularization Tools Version 4.1 86 MatrixVB 4.5(含注册) 87 空间几何工具箱 matGeom-1.2.2 88 大数计算工具箱 VariablePrecisionIntegers 89 晶体织构分析工具包 mtex-5.7.0 90 Minimal Paths 2工具箱 91 Matlab数学建模工具箱
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

面壁十年忘何图

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值