Wolfram Function Repository
Instant-use add-on functions for the Wolfram Language
Function Repository Resource:
Perform replacements and give the positions at which they occur
ResourceFunction["MultiReplace"][expr,rule] returns all possible subexpressions of expr after application of rule, with information about each replacement. | |
ResourceFunction["MultiReplace"][expr,{rule1,rule2,…}] returns the result after applying a list of rules. | |
ResourceFunction["MultiReplace"][expr,{x1,x2,…}→{y1,y2,…}] uses a list of patterns to replace subexpression tuples/subsets. | |
ResourceFunction["MultiReplace"][expr,rules,level] specifies a level spec. | |
ResourceFunction["MultiReplace"][expr,rules,level,head] uses a custom head to specify subexpression tuples/subsets. | |
ResourceFunction["MultiReplace"][expr,subexpr,…] returns subexpression matches without performing substitution. |
| "Mode" | "Tuples" | how to match multiple subexpressions: "Tuples", "OrderedTuples", "Subsets" or "OrderlessSubsets" |
| "PatternSubstitutions" | False | whether to include pattern substitutions |
| "ReturnMatches" | False | return subexpression matches by ignoring the right-hand side of rules if present |
| Method | "Substitution" | substitution strategy to use: "Susbtitution", "Cosubstitution" or "Bisubstitution" |
| Heads | True | whether to match heads of expressions and their parts |
Apply a rule at each possible position of an expression:
| In[1]:= |
| Out[1]= |
Apply multiple rules:
| In[2]:= |
| Out[2]= | ![]() |
Apply a tuple replacement rule:
| In[3]:= |
| Out[3]= |
Subexpressions are spliced in the order of matched elements:
| In[4]:= |
| Out[4]= |
Splicing continues after the last element:
| In[5]:= |
| Out[5]= |
A single element can be matched more than once:
| In[6]:= |
| Out[6]= |
Specify a level:
| In[7]:= |
| Out[7]= |
Specify an explicit list of positions at which to replace:
| In[8]:= |
| Out[8]= |
Use a custom head for designating tuples:
| In[9]:= |
| Out[9]= |
| In[10]:= |
| Out[10]= |
| In[11]:= |
| Out[11]= |
Specify a matching condition:
| In[12]:= |
| Out[12]= |
Ignore heads:
| In[13]:= |
| Out[13]= |
Change the mode of matching multiple subexpressions:
| In[14]:= |
| Out[14]= |
| In[15]:= |
| Out[15]= |
| In[16]:= |
| Out[16]= |
| In[17]:= |
| Out[17]= |
Three substitution strategies are supported, based on the direction of pattern unification:
| In[18]:= |
| Out[18]= |
| In[19]:= |
| Out[19]= |
| In[20]:= |
| Out[20]= |
Get all tuple bisubstitutions:
| In[21]:= |
| Out[21]= |
Return corresponding matches only without performing a substitution (note the HoldForm wrapping of individual matched subexpressions to prevent evaluation):
| In[22]:= |
| Out[22]= | ![]() |
This is equivalent to just dropping the right-hand side of a rule:
| In[23]:= |
| Out[23]= | ![]() |
Include all corresponding pattern substitutions:
| In[24]:= |
| Out[24]= |
"Cosubstitution" and "Bisubstitution" include substitutions of patterns from the expression to subexpressions from the left-hand side of the rule:
| In[25]:= |
| Out[25]= |
| In[26]:= |
| Out[26]= |
Replacement is done in all possible ways similar to ReplaceList but at multiple positions:
| In[27]:= |
| Out[27]= |
| In[28]:= |
| Out[28]= |
SequenceReplace and SubsetReplace replace all the matches and destroy subexpressions, while MultiReplace does all possible single replacements and preserves subexpressions:
| In[29]:= |
| Out[29]= |
| In[30]:= |
| Out[30]= |
| In[31]:= |
| Out[31]= | ![]() |
Wolfram Language 13.0 (December 2021) or above
This work is licensed under a Creative Commons Attribution 4.0 International License