The core of our models are rules for rewriting collections of relations. A very simple example of a rule is:
data:image/s3,"s3://crabby-images/8dd11/8dd11f29a0cd676ba869f9060e915ad7f786b8a6" alt=""
Here x, y and z stand for any elements. (The elements they stand for need not be distinct; for example, x and y could both stand for the element 1.) The rule states that wherever a relation that matches {x,y} appears, it should be replaced by {{x,y},{y,z}}, where z is a new element. So given {{1,2}} the rule will produce {{1,2},{2,}} where is a new element. The label for the new element could be anything—so long as it is distinct from 1 and 2. Here we will use 3, so that the result of applying the rule to {{1,2}} becomes:
data:image/s3,"s3://crabby-images/add2a/add2a1720faa2e8b296c2da0fdccadf3319320a5" alt=""
If one applies the rule again, it will now operate again on {1,2}, and also on {2,3}. On {1,2} it again gives {{1,2},{2,}}, but now the new node cannot be labeled 3, because that label is already taken—so instead we will label it 4. When the rule operates on {2,3} it gives {{2,3},{3,}}, where again is a new node, which can now be labeled 5. Combining these gives the final result:
data:image/s3,"s3://crabby-images/a2259/a22597015a718c1aafbfc58f8918fdacc06883e3" alt=""
(We have written this so that the results from {{1,2}} are followed by those from {{2,3}}—but there is no significance to the order in which the relations appear.)
In graphical terms, the rule we have used is
data:image/s3,"s3://crabby-images/1293a/1293a19d419b95ed448cac16675ead91c350798a" alt=""
and the sequence of steps is:
data:image/s3,"s3://crabby-images/1d8b9/1d8b9a2d3fbb9fbd8d92f614bdbf5b9100952a41" alt=""
It is important to note that all that matters in these graphs is their connectivity. Where nodes are placed on the page in drawing the graph has no fundamental significance; it is usually just done to make the graphs as easy to read as possible.
Continuing to apply the same rule for three more steps gives:
data:image/s3,"s3://crabby-images/7778a/7778a65eefd837e063facdb4b4b1d97714c0656a" alt=""
Laying out nodes differently makes it easier to see some features of the graphs:
data:image/s3,"s3://crabby-images/0f33f/0f33fdfb618a3925f88603e102053044b91c082a" alt=""
Continuing for a few more steps with the original layout gives the result:
data:image/s3,"s3://crabby-images/5ac52/5ac52b9596c9702fa8d431652716a940e0579895" alt=""
Showing the last 3 steps with the other layout makes it a little clearer what is going on:
data:image/s3,"s3://crabby-images/a3ee9/a3ee90357e666486708c8b6c5b36b3f19e9db90d" alt=""
The rule is generating a binomial tree, with 2n edges (relations) and 2n+1 nodes (distinct elements) at step n (and with Binomial[n, s–1] nodes at level s).