MATLAB-元胞自动机-森林火灾

%CA driver
%
%forest fire
clf
clear all
n=100;
Plightning = .001;
Pgrowth = .0001; 
z=zeros(n,n);
o=ones(n,n);
veg=2*o;
sum=z;
imh = image(cat(3,z,veg==2,z));
set(imh, 'erasemode', 'none')
axis equal
axis tight
% burning -> empty
% green -> burning if one neigbor burning or with prob=f (lightning)
% empty -> green with prob=p (growth)
% veg = {empty=0 burning=1 green=2}


for i=1:50000
%nearby fires?
c=rand(n);%统一的一个随机矩阵 否则执行两次rand会产生不同结果
sum = (veg(1:n,[n 1:n-1])==1) + (veg(1:n,[2:n 1])==1) + ...
(veg([n 1:n-1], 1:n)==1) + (veg([2:n 1],1:n)==1) ;
veg =2*((veg==2)&(c>=Plightning))+((veg==2) &(c<Plightning))...
    +0*(veg==1)+(2*(veg==0)&(c<Pgrowth))+((veg==2)&(sum>0)); %加号之间均为互斥的事件 &与|连接的命题最好带括号


set(imh, 'cdata', cat(3,(veg==1),(veg==2),z) )
drawnow


end
  • 7
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值