If there are multiple successors to a particular state in a substitution system one thing to do would be just to assume that each of these successors is a new, unique state. The result of this will always be to produce a tree of states, here shown for the rule {A BBB, BB A}:
data:image/s3,"s3://crabby-images/7af96/7af96539083a3bc12074269226b79021c79e36d3" alt=""
But in our construction of multiway systems, we assume that actually the states produced are not all unique, and instead that states at a given step consisting of the same string can be merged, thereby reducing the tree above to the directed graph:
data:image/s3,"s3://crabby-images/6bfc9/6bfc9ce7c167a477f8a50a0df1788731621b2c8e" alt=""
But if we are going to merge identical states, why do so only at a given step? Why not merge identical states whenever they occur in the evolution of the system? After all, given the setup, a particular state—wherever it occurs—will always evolve in the same way, so in some sense it is redundant to show it multiple times.
The particular rule {A BBB, BB A} that we have just used as an example has the special feature that it always “makes progress” and never repeats itself—with the result that a given string only ever appears once in its evolution. Most rules, however, do not have this property.
Consider for example the rule {AB BAB, BA A}. Starting from ABA, here is our normal “evolution graph”:
data:image/s3,"s3://crabby-images/8d480/8d480f7904809970ee9510039f797dc6c789eb51" alt=""
Notice that in this evolution even the original state ABA appears again, both at step 3 and at step 5—and each time it appears, it necessarily makes a complete repeat of the same evolution graph. To remove this redundancy, we can make a graph in which we effectively merge all instances of a given state, so that we show each state only once, connecting it to whatever states it evolves to under the rule:
data:image/s3,"s3://crabby-images/05d22/05d223ee5660bf8c94b10acea62b121dedc02486" alt=""
But in this graph there are, for example, two connections from ABA to BABA, because this transformation happens twice in the 4 steps of evolution that we are considering. But in a sense this multiplicity again always gives redundant information, so in what we will call our “states graph” [1:p209], we only ever keep one connection between any given pair of states, so that in this case we get:
data:image/s3,"s3://crabby-images/2ccd3/2ccd38a16d673d5048eeee455939fcc5c5e43d79" alt=""
There is one further subtlety in the construction of a states graph. The graph only records which state can be transformed into which other: it does not record how many different replacements could be applied to achieve this. In the rule we just showed, it is never possible to have different replacements on a single string yield the same result.
Consider the rule {A AA, A B} starting with AA. There are, for example, two different ways that this rule can be applied to AA to get AAA:
data:image/s3,"s3://crabby-images/b8410/b84108a777e230e1b1448dec27585e57fa956876" alt=""
In our standard states graph, however, we show only that AA is transformed to AAA, and we do not record how many different possible replacements can achieve this:
data:image/s3,"s3://crabby-images/caa89/caa894fd9fcc786adea5869dafa131c5657f8b77" alt=""
The degree of compression achieved in going from evolution graphs to states graphs can be quite dramatic. For example, for the rule {BA AB, AB BA} the evolution graph is
data:image/s3,"s3://crabby-images/acaf9/acaf91187a008de0dd34026a500aeee9e42362e6" alt=""
and the states graph is
data:image/s3,"s3://crabby-images/3a26a/3a26abaff4355ba4ede4979634a7c526be3c43a2" alt=""
or in our standard rendering:
data:image/s3,"s3://crabby-images/d8c9b/d8c9b56ad6abd10bc750d82c619194486e679f0f" alt=""
Note that causal invariance works the same in states graphs as it does in evolution graphs: if a rule is causal invariant, any two paths that diverge must eventually reconverge.