Periodicity in Cellular Automata
The new function FindTransientRepeat identifies the transient and repeated parts of a list. It can be used to investigate cellular automata.
Look at the rule 30 cellular automaton (CA). The Version 11 function RulePlot is a useful tool to find the associated transformation rules.
In[1]:=
data:image/s3,"s3://crabby-images/4fc70/4fc70efbc4cfc60b613b09d20b3af8019585cfaf" alt="Click for copyable input"
RulePlot[CellularAutomaton[30]]
Out[1]=
data:image/s3,"s3://crabby-images/189ae/189ae364a52a67e692312a4c767c48efaabd3d91" alt=""
Define the initial conditions of the CA by using the new function CenterArray.
In[2]:=
data:image/s3,"s3://crabby-images/8642a/8642ac9ee562264f272f023255ad647f0811b5a0" alt="Click for copyable input"
initc = CenterArray[7]
Out[2]=
data:image/s3,"s3://crabby-images/75230/75230f0f44694218a9b949bc06645c8d74018bb8" alt=""
Compute the rule 30 CA with the above initial conditions and plot it in a discrete array of squares.
In[3]:=
data:image/s3,"s3://crabby-images/3d618/3d618f92a44740cf7ee5eccf12588dc24817dfd4" alt="Click for copyable input"
ca30 = CellularAutomaton[30, initc, 20];
ArrayPlot[ca30, Mesh -> True]
Out[3]=
data:image/s3,"s3://crabby-images/7cf02/7cf020e7677ba17be196a1dc8a7590b7215bdceb" alt=""
FindTransientRepeat gives the repeated part of this CA.
In[4]:=
data:image/s3,"s3://crabby-images/4b590/4b5906206b7f4b0a61864969fb250bfda32dc8c6" alt="Click for copyable input"
tr30 = FindTransientRepeat[ca30, 2];
ArrayPlot[Last[tr30], Mesh -> True]
Out[4]=
data:image/s3,"s3://crabby-images/07e0f/07e0f515c25421de299114e717905dcb4d724ad6" alt=""
Repeat the same steps for the rule 90 cellular automaton.
In[5]:=
data:image/s3,"s3://crabby-images/78da1/78da1bb44d65a36f14646ec37f8df17a7802ff13" alt="Click for copyable input"
RulePlot[CellularAutomaton[90]]
Out[5]=
data:image/s3,"s3://crabby-images/e21f5/e21f521c31580d41bcbdf76adaed3167268cda9c" alt=""
In[6]:=
data:image/s3,"s3://crabby-images/f3a9b/f3a9b03c7ce1c421b63a43a98cefba6578fb84ca" alt="Click for copyable input"
ca90 = CellularAutomaton[90, initc, 20];
ArrayPlot[ca90, Mesh -> True]
Out[6]=
data:image/s3,"s3://crabby-images/440a8/440a8ff5651ba13124f54abbccbf1c24a3ef00e6" alt=""
In[7]:=
data:image/s3,"s3://crabby-images/0fb05/0fb052ae0045d9ef71cd65931fa6acb4ef470022" alt="Click for copyable input"
tr90 = FindTransientRepeat[ca90, 2];
ArrayPlot[Last[tr90], Mesh -> True]
Out[7]=
data:image/s3,"s3://crabby-images/a1266/a12667530745accc9cdf1dd6a86d7c43a8c96fe6" alt=""