TA的每日心情 | 衰 2019-11-19 15:32 |
|---|
签到天数: 1 天 [LV.1]初来乍到
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
; q3 `$ W$ F; k1 g什么是元胞自动机?
# d- n7 N: S, }. w0 N7 C) ]元胞自动机(cellular automata,CA) 是一种时间、空间、状态都离散,空间相互作用和时间因果关系为局部的网格动力学模型,具有模拟复杂系统时空演化过程的能力。它能构建随时间推移发生状态转移的系统,细胞存在于一维或多维网格中,每个细胞都有一个或多个状态,每个细胞都有邻居(即邻近的细胞)。5 a# l5 P, Q" }
7 Q0 H- [ A: p4 _
元胞自动机分类# B& o9 g1 \8 @$ |# H
平稳型:自任何初始状态开始,经过一定时间运行后,元胞空间趋于一个空间平稳的构形,这里空间平稳即指每一个元胞处于固定状态。不随时间变化而变化。) U3 I: f8 S: o0 E7 C7 L
周期型:经过一定时间运行后,元胞空间趋于一系列简单的固定结构(Stable Patterns)或周期结构(Perlodical Patterns)。由于这些结构可看作是一种滤波器(Filter),故可应用到图像处理的研究中。
9 G9 Z6 m# ^) J( b混沌型:自任何初始状态开始,经过一定时间运行后,元胞自动机表现出混沌的非周期行为,所生成的结构的统计特征不再变止,通常表现为分形分维特征。
9 ]6 Z- f* J; H( N- c1 ]9 U复杂型:出现复杂的局部结构,或者说是局部的混沌,其中有些会不断地传播。# h, m! D1 Y, Q" t
# o+ j( c/ s! O3 N4 {
: G% I( C. x/ D. o/ U5 Y
. t- t, W0 X1 o- ~) c奇偶规则* F# d! ?& W* |2 Z z6 u N/ {( C3 {
奇偶规则是定义在二维网格上的一种元胞自动机。每个网格的状态用0各1表示。
4 ]4 V# R8 a0 |9 u% q! Z5 J2 r+ K, N
(1) 对应于每一个元胞位置(i,j)计算出其八个最近领居在t时刻的状态值St的总和M(i,j)。
1 s( G' \; M9 G5 S! p2 ^- D: g9 M& m4 D; z6 U$ ?2 q* |
(2) 根据M(i,j)取值的奇偶性来决定下一时刻t+1该点的状态St+1(i,j)。当M(i,j)为偶数时,St+1(i,j)等于0;当M(i,j)为奇数时,St+1(i,j)等于1。八个点和为偶数,则变为0,为奇数则变为 1: l: V; M# n! ?' d8 k3 @
% o) t9 ~* A# `平稳型元胞自动机实现
, S3 I; U( F3 {' ?% L4 T s) {: ^' r, O" B4 G. x
- % 规则,先把中间点置为1,每一时间步对每一点,如果周围
- % 八个点和为偶数,则变为0,为奇数则变为 1
- Map = [1 1 1; 0 0 0];
- colormap(Map);
- % 设置网格大小
- S = 121;
- L = zeros(S);
- % 把中间一个数设置为 1 作为元胞种子
- M = (S+1)/2;
- L(M, M) = 1;
- Temp = L;
- imagesc(L);
- % 计算层数
- Layer = (S-1)/2 + 1;
- for t=2:Layer
- for x=M-t+1:M+t-1
- if x==M-t+1 || x==M+t-1
- for y=M-t+1:M+t-1
- SUM = 0;
- for m=-1:1
- for n=-1:1
- if x+m>0 && x+m<=S && y+n>0 && y+n<=S
- SUM = SUM + L(x+m, y+n);
- end
- end
- end
- SUM = SUM - L(x, y);
- Temp(x, y) = mod(SUM, 2);
- end
- else
- y = M-t+1;
- SUM = 0;
- for m=-1:1
- for n=-1:1
- if x+m>0 && x+m<=S && y+n>0 && y+n<=S
- SUM = SUM + L(x+m, y+n);
- end
- end
- end
- SUM = SUM - L(x, y);
- Temp(x, y) = mod(SUM, 2);
- y = M+t-1;
- SUM = 0;
- for m=-1:1
- for n=-1:1
- if x+m>0 && x+m<=S && y+n>0 && y+n<=S
- SUM = SUM + L(x+m, y+n);
- end
- end
- end
- SUM = SUM - L(x, y);
- Temp(x, y) = mod(SUM, 2);
- end
- end
- L = Temp;
- imagesc(L);
- pause(0.1);
- end" Z- x6 b i. P3 @0 H/ Q( j
X, N; M+ d2 @& x
, v+ h. r# b5 D; y4 ]/ U1 g
效果图
5 B+ z6 s1 p0 i" N7 Z
! ]. X* b$ s g5 n) e2 f1 U2 q
; `0 u; s0 {# d |
|