Wolfram Function Repository
Instant-use add-on functions for the Wolfram Language
Function Repository Resource:
Get the index of a list of integers in standard order
ResourceFunction["StandardOrderIndex"][list] gives the index of a list of integers in standard order. |
{1,2,2,1,3,2,1,4,3} | integers >0 in standard order start with 1, then can never be more than 1 higher than all previous integers. |
{1,2,0,0,3,0,0,4,0} | some of the digits are new highest digits. |
{0,0,2,1,0,2,1,0,3} | other digits acquire a mixed radix based on the previous highest digit. |
{1,0,0,1,0,0,1,0} | without the initial 1, the sequence of highest digits mapped to 1 values makes a binary number B. |
223241 | any binary number with 1's→{2,…,n} and sequential zeros acting as powers gives a Bell index. |
BellB[n] | equals the sum of Bell indices of length n-1 binary numbers. |
{146, 86}->5867 | the total of the first B Bell indices plus the mixed radix value gives the index. |
Find the index of a standard order:
In[1]:= | ![]() |
Out[1]= | ![]() |
Index of a larger standard order:
In[2]:= | ![]() |
Out[2]= | ![]() |
Define a Bell indexing function:
In[3]:= | ![]() |
The total number of standard orders of length n is given by BellB[n] or the total of the Bell indices with the last standard order being Range[n]:
In[4]:= | ![]() |
Out[4]= | ![]() |
If a list isn’t in standard order it will be put into standard order before the indexing. Here is a random list:
In[5]:= | ![]() |
Out[5]= | ![]() |
Here is its index:
In[6]:= | ![]() |
Out[6]= | ![]() |
Define a standard ordering function:
In[7]:= | ![]() |
Order the random list:
In[8]:= | ![]() |
Out[8]= | ![]() |
Compare the index of the unordered version with that of the ordered one:
In[9]:= | ![]() |
Out[9]= | ![]() |
Some auxiliary functions:
In[10]:= | ![]() |
Here are the 52 standard orders of length 5:
In[11]:= | ![]() |
Out[11]= | ![]() |
Give the indices of these standard orders:
In[12]:= | ![]() |
Out[12]= | ![]() |
A particular standard order:
In[13]:= | ![]() |
Out[13]= | ![]() |
Recover that data using the StandardOrders function:
In[14]:= | ![]() |
Out[14]= | ![]() |
Find the index of a standard order:
In[15]:= | ![]() |
Out[15]= | ![]() |
Define a Bell indexing function:
In[16]:= | ![]() |
Here is how the function finds the index:
In[17]:= | ![]() |
Out[17]= | ![]() |
For length n, 2n indices need to be generated, so this function will start slowing down at length 20:
In[18]:= | ![]() |
Out[18]= | ![]() |
There are lots of standard orders of length 20:
In[19]:= | ![]() |
Out[19]= | ![]() |
This work is licensed under a Creative Commons Attribution 4.0 International License