Wolfram Function Repository
Instant-use add-on functions for the Wolfram Language
Function Repository Resource:
Attempt to find a canonical representation for a Wolfram model
ResourceFunction["CanonicalWolframModelRule"][rule] attempts to find a canonical version of the specified Wolfram model rule. | |
ResourceFunction["CanonicalWolframModelRule"][rule,"Letter"] produces a canonical letter form of the specified Wolfram model rule. |
1. | Tuples are sorted by length, with longest tuples occurring first |
2. | Tuples of the same length on the same side of a rule are considered a rule part |
3. | A rule part with 3 tuples of length 2 has signature 32 |
4. | Rule parts are ordered so that new alphabet terms are introduced with maximal frugality |
Rename nodes and re-sort rules to find a canonical form:
In[1]:= |
|
Out[1]= |
|
In[2]:= |
|
Out[2]= |
|
In[3]:= |
|
Out[3]= |
|
In[4]:= |
|
Out[4]= |
|
A slightly more complicated case:
In[5]:= |
|
Out[5]= |
|
In[6]:= |
|
Out[6]= |
|
CanonicalWolframModelRule can handle any names for elements:
In[7]:= |
|
Out[7]= |
|
In[8]:= |
|
Out[8]= |
|
Some difficult cases:
In[9]:= |
|
Out[9]= |
|
In[10]:= |
|
Out[10]= |
|
In[11]:= |
|
Out[11]= |
|
In[12]:= |
|
Out[12]= |
|
This work is licensed under a Creative Commons Attribution 4.0 International License