元胞自动机-森林火灾模型MATLAB代码
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
end
Ss(Sk==1)=1;%%讨论绿树情况
Ss(2:301,2:301)=Ss(1:300,1:300)+Ss(1:300,2:301)+Ss(1:300,3:302) +...
Ss(2:301,1:300)+Ss(2:301,3:302)+Ss(3:302,1:300) + ...
Ss(3:302,2:301)+Ss(3:302,3:302);
Sk=St;
%更新t时刻的森林St
R=zeros(302);
G=zeros(302);
R(Sk==2)=1;
G(Sk==1)=1;
C(:,:,1)=R;
C(:,:,2)=G;
set(Ci,'CData',C);
set(tp,'string',['T = ',num2str(ti)])
pause(0.2);
Sf(2:301,1:300)+Sf(2:301,3:302)+Sf(3:302,1:300) + ...
Sf(3:302,2:301)+Sf(3:302,3:302);%%平移后八个方向叠加,记录下su周围八个点,有多少个在燃烧
St(Su>0.5)=2;%% for rule (2)Sf->su
Se=Sk(2:301,2:301);%%Se中将初始的森林,空白处变为1,其他地方为0
Sk=zeros(302);
Sk(2:301,2:301)=S;%%加边开始的森林初值
% 红色表示正在燃烧(S中等于2的位置)
% 绿色表示绿树(S中等于1的位置)
% 黑色表示空格位(S中等于0的位置)
C=zeros(302,302,3);
R=zeros(300);
G=zeros(300);
R(S==2)=1;
Su=zeros(302);
Sf=Sk;%%Sf表示模拟着火的过程
Sf(Sf<1.5)=0;%%只留下着火点
Sf=Sf/2;
%%着火点变为1,此处Sf只有着火和空格两种
Su(2:301,2:301)=Sf(1:300,1:300)+Sf(1:300,2:301)+Sf(1:300,3:302) +...
close all;
c百度文库c;
clear;
figure;
p=0.3;% 概率p
f=6e-5;% 概率f
axes;
rand('state',0);
set(gcf,'DoubleBuffer','on');
% S=round((rand(300)/2+0.5)*2);
S=round(rand(300)*2);
% 元胞自动机:森林火灾模型
% 规则:
% (1)正在燃烧的树变成空格位;
% (2)如果绿树格位的最近邻居中有一个树在燃烧,则它变成正在燃烧的树;
% (3)在空格位,树以概率p生长;
% (4)在最近的邻居中没有正在燃烧的树的情况下树在每一时步以概率f(闪
%? 电)变为正在燃烧的树。
% 参考文献:
% 祝玉学,赵学龙译,<<物理系统的元胞自动机模拟>>, p23
G(S==1)=1;
C(2:301,2:301,1)=R;
C(2:301,2:301,2)=G;
Ci=imshow(C);
ti=0;
tp=title(['T = ',num2str(ti)]);%%时间记录
while 1;
ti=ti+1;
St=Sk; %%St表示t时刻的森林情况
St(Sk==2)=0; % for rule (1)
%%平移后八个方向叠加,记录下Ss周围八个点,有多少个绿树
Ss(Ss<7.5)=0;
Ss(Ss>7.5)=1;
d=find(Ss==1 & Sk==1);
for k=1:length(d);
r=rand;
St(d(k))=round(2*(r<=f)+(r>f));
end% for rule (4)%%t时刻的着火还是没着火,记为1or2
Se(Se<0.5)=4;%% 空白地方赋值为4
Se(Se<3)=0;%%有树和着火赋值为0
Se(Se>3)=1;%%空白地方赋值为1
St(2:301,2:301)=St(2:301,2:301)+Se.*(rand(300)<p); %for rule (3)%长树,更新t时刻的森林St
Ss=zeros(302);
Ss(Sk==1)=1;%%讨论绿树情况
Ss(2:301,2:301)=Ss(1:300,1:300)+Ss(1:300,2:301)+Ss(1:300,3:302) +...
Ss(2:301,1:300)+Ss(2:301,3:302)+Ss(3:302,1:300) + ...
Ss(3:302,2:301)+Ss(3:302,3:302);
Sk=St;
%更新t时刻的森林St
R=zeros(302);
G=zeros(302);
R(Sk==2)=1;
G(Sk==1)=1;
C(:,:,1)=R;
C(:,:,2)=G;
set(Ci,'CData',C);
set(tp,'string',['T = ',num2str(ti)])
pause(0.2);
Sf(2:301,1:300)+Sf(2:301,3:302)+Sf(3:302,1:300) + ...
Sf(3:302,2:301)+Sf(3:302,3:302);%%平移后八个方向叠加,记录下su周围八个点,有多少个在燃烧
St(Su>0.5)=2;%% for rule (2)Sf->su
Se=Sk(2:301,2:301);%%Se中将初始的森林,空白处变为1,其他地方为0
Sk=zeros(302);
Sk(2:301,2:301)=S;%%加边开始的森林初值
% 红色表示正在燃烧(S中等于2的位置)
% 绿色表示绿树(S中等于1的位置)
% 黑色表示空格位(S中等于0的位置)
C=zeros(302,302,3);
R=zeros(300);
G=zeros(300);
R(S==2)=1;
Su=zeros(302);
Sf=Sk;%%Sf表示模拟着火的过程
Sf(Sf<1.5)=0;%%只留下着火点
Sf=Sf/2;
%%着火点变为1,此处Sf只有着火和空格两种
Su(2:301,2:301)=Sf(1:300,1:300)+Sf(1:300,2:301)+Sf(1:300,3:302) +...
close all;
c百度文库c;
clear;
figure;
p=0.3;% 概率p
f=6e-5;% 概率f
axes;
rand('state',0);
set(gcf,'DoubleBuffer','on');
% S=round((rand(300)/2+0.5)*2);
S=round(rand(300)*2);
% 元胞自动机:森林火灾模型
% 规则:
% (1)正在燃烧的树变成空格位;
% (2)如果绿树格位的最近邻居中有一个树在燃烧,则它变成正在燃烧的树;
% (3)在空格位,树以概率p生长;
% (4)在最近的邻居中没有正在燃烧的树的情况下树在每一时步以概率f(闪
%? 电)变为正在燃烧的树。
% 参考文献:
% 祝玉学,赵学龙译,<<物理系统的元胞自动机模拟>>, p23
G(S==1)=1;
C(2:301,2:301,1)=R;
C(2:301,2:301,2)=G;
Ci=imshow(C);
ti=0;
tp=title(['T = ',num2str(ti)]);%%时间记录
while 1;
ti=ti+1;
St=Sk; %%St表示t时刻的森林情况
St(Sk==2)=0; % for rule (1)
%%平移后八个方向叠加,记录下Ss周围八个点,有多少个绿树
Ss(Ss<7.5)=0;
Ss(Ss>7.5)=1;
d=find(Ss==1 & Sk==1);
for k=1:length(d);
r=rand;
St(d(k))=round(2*(r<=f)+(r>f));
end% for rule (4)%%t时刻的着火还是没着火,记为1or2
Se(Se<0.5)=4;%% 空白地方赋值为4
Se(Se<3)=0;%%有树和着火赋值为0
Se(Se>3)=1;%%空白地方赋值为1
St(2:301,2:301)=St(2:301,2:301)+Se.*(rand(300)<p); %for rule (3)%长树,更新t时刻的森林St
Ss=zeros(302);