Substitution Systems
SubstitutionSystem generates a list representing the evolution of a given initial state following the iterative applications of a set of rules.
Consider the following initial state and set of rules.
In[1]:=
data:image/s3,"s3://crabby-images/2337c/2337cf77afbd56d999fe1207bcc6253d6cc75a87" alt="Click for copyable input"
init = "\[Wolf]";
rules = {"\[HappySmiley]" -> "\[Wolf]\[HappySmiley]",
"\[Wolf]" -> "\[HappySmiley]"};
Use SubstitutionSystem to get its evolution over 8 iterations.
In[2]:=
data:image/s3,"s3://crabby-images/1b9cd/1b9cdf81dadb978182e5f31210e76617c9dfb8bc" alt="Click for copyable input"
SubstitutionSystem[{"\[HappySmiley]" -> "\[Wolf]\[HappySmiley]",
"\[Wolf]" -> "\[HappySmiley]"}, "\[Wolf]", 8] // Column
Out[2]=
data:image/s3,"s3://crabby-images/a489f/a489f785ab6c0c37291b36e9ff856fd101d72b32" alt=""
Use a two-dimensional set of rules to construct the Sierpiński carpet.
In[3]:=
data:image/s3,"s3://crabby-images/dbd9e/dbd9e580f377858adbc80fd56b1bc4c76a894aff" alt="Click for copyable input"
rules2D = {1 -> {{1, 1, 1}, {1, 0, 1}, {1, 1, 1}},
0 -> ConstantArray[0, {3, 3}]};
Visualize this substitution system using RulePlot.
In[4]:=
data:image/s3,"s3://crabby-images/c701f/c701f1acdc33c94c9dff09e7605a5398191d394b" alt="Click for copyable input"
RulePlot@SubstitutionSystem[rules2D]
Out[4]=
data:image/s3,"s3://crabby-images/b8d1f/b8d1ffbb82a1d6cc4fbf0f6f3212c48d56a2935b" alt=""
Generate the Sierpiński carpet.
In[5]:=
data:image/s3,"s3://crabby-images/e1bbf/e1bbf1cff03453a3429ae7f21008a86460eb5a48" alt="Click for copyable input"
ArrayPlot /@ SubstitutionSystem[rules2D, {{1}}, 5]
Out[5]=
data:image/s3,"s3://crabby-images/8a638/8a63812350075235f88815ee2e8e8636f4ccb7cd" alt=""