1 简介

本文属于计算机科学和交通工程的交叉领域,涉及一种基于元胞自动机的商场行人微观仿真方法,首先对商场行人区域网格化处理,得到元胞自动机模型相应的元胞空间,并将其划分为一些凸多边形区域;其次判断每个区域里是否有行人,并规定好每个行人的临时目的地;然后计算每个行人的转移概率,进行模拟移动,观察是否会出现冲突;最后解决冲突,并更新每个行人的实际位置,直到行人到达相应的目的地;本发明使得仿真模型能对复杂步行环境做出相应反应,而不仅仅是区别行人和障碍物,同时,模拟区域行人流室内疏散过程中呈现的自组织现象,有效提高了模型仿真效果,更加适宜于仿真分析商场行人流的运动演化.

【元胞自动机】基于元胞自动机模拟商场人流量matlab代码_初始化

2 部分代码

%% lzu
close all ; clear all ;clc
a=rand(200,50);                                  %生成元胞自动机的大小(200,50)200行50列
m=find(a<0.1); n=find(a>0.9);                  %向上,向下的各占10%
aa=zeros(size(a));aa(m)=1;up=aa;
bb=zeros(size(a));bb(n)=3;down=bb;               %初始化元胞 up,down
clear a* m n bb
% 生成 up down
N=nnz(up)+nnz(down);
%% 循环开始的地方
for t=1:10000
up1=[up(2:end,:);up(1,:)];                       %向上走的向上一步,探探前面有没有路 %向下走的不动
c=up+down;
jud=up1+down;
%% 找出相碰处的两种表示
w_z1=find(jud==4);w_z1=w_z1';                                      % 一维位置(都是先下的所在)
[w_zx1,w_zy1]=find(jud==4);a=[w_zx1,w_zy1]';w_zx=w_zx1';w_zy=w_zy1';
%w_z2=[w_zx;w_zy];
clear w_zx1 w_zy1 a                                                % 二维位置
%% 找出相碰的人后面的粒子数
down_z_g=zeros(size(down));
for i=1:length(w_z1)
d_b(i)=0;
x=cutx(w_zx(i));y=w_zy(i);
down_z_g(andx(x),y)=3;
while down(x,y)==3
down_z_g(x,y)=3;
d_b(i)=d_b(i)+1;
x=cutx(x);
end
end
clear x y i
up_z_g=zeros(size(up));
for i=1:length(w_z1)
u_b(i)=0;
x=andx(andx(w_zx(i)));y=w_zy(i);
up_z_g(cutx(x),y)=1;
while up(x,y)==1
up_z_g(x,y)=1;
u_b(i)=u_b(i)+1;
x=andx(x);
end
end
clear x y i
% u_b 向下走的后面跟的个数
% d_b 向上走的后面跟的个数
%[w_z1;w_zx; w_zy ;u_b ;d_b]
%% 找出拐的那串粒子
%% 找出直走的(不包含相碰的后面跟的)
down_d=down;
for i=1:length(w_z1)
x=w_zx(i);y=w_zy(i);
for j=0:d_b(i)
down_d(x,y)=0;
x=cutx(x);
end
end                                                 % down_d (down_directly)直接向下走的粒子
clear x y i j
up_d=up;
for i=1:length(w_z1)
x=andx(w_zx(i));y=w_zy(i);
for j=0:u_b(i)
up_d(x,y)=0;
x=andx(x);
end
end                                                  % up_d (up_directly)直接向上走的粒子
clear x y i j
%f=nnz(up_d)+length(w_zx)+sum(u_b)-nnz(up)
%g=nnz(down_d)+length(w_zy)+sum(d_b)-nnz(down)
%end
a_down_d=[down_d(end,:);down_d(1:end-1,:)];               % alread_down_directly
a_up_d=[up_d(2:end,:);up_d(1,:)];                           % alread_down_directly(是假的还要考虑碰头的中间隔一个得情况)
%% 两个粒子对头时中间空一个(定义往下走的占了这个空格)
judge=a_down_d+a_up_d;
[ww_zx,ww_zy]=find(judge==4);
for i=1:length(ww_zx)
x=ww_zx(i);y=ww_zy(i);
judge(x,y)=3;
x=andx(x);
while judge(x,y)==1
x=andx(x);
end
judge(x,y)=1;
end
clear a* c* d_b down_*  i j* r* u_b up1 up_* w* x y
end
figure(2)
plot(V)

3 仿真结果

【元胞自动机】基于元胞自动机模拟商场人流量matlab代码_二维_02

4 参考文献

[1]覃征, 杨晓, 王斌旭,等. 一种基于元胞自动机的室内行人微观仿真方法:. 

部分理论引用网络文献,若有侵权联系博主删除。

【元胞自动机】基于元胞自动机模拟商场人流量matlab代码_二维_03