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/4f7b3/4f7b33d34ef941b4d271b805f844bb4986994bdc" 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/4f2d2/4f2d23a0aac292ebcc0aa7ef7d592da4dba89087" 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/647d5/647d521f0d17b722778190a5733c842a66c0a087" 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/b7549/b7549f1cc968499832fdeb2ef783b6797f34c3f9" alt=""
and the sequence of steps is:
data:image/s3,"s3://crabby-images/5b728/5b7289b97d11885397351a8826179f317bf51407" 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/c78a4/c78a4e731be2a944b9b765e4fb9c7b9eae82cf87" alt=""
Laying out nodes differently makes it easier to see some features of the graphs:
data:image/s3,"s3://crabby-images/ac841/ac841764288db05730ea45c6f430311145d08b10" alt=""
Continuing for a few more steps with the original layout gives the result:
data:image/s3,"s3://crabby-images/bbcdd/bbcddbcb154eaf9e74ab527258b0f8c4e5ef4502" 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/bc121/bc1216f9356231d7200af61b8a3af345d9a540bf" 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).