The Ordering of Definitions
When you make a sequence of definitions in Mathematica
, some may be more general than others. Mathematica
follows the principle of trying to put more general definitions after more specific ones. This means that special cases of rules are typically tried before more general cases.
This behavior is crucial to the factorial function example given in "Making Definitions for Functions"
. Regardless of the order in which you entered them, Mathematica
will always put the rule for the special case f
ahead of the rule for the general case f[n_]
. This means that when Mathematica
looks for the value of an expression of the form f[n]
, it tries the special case f
first, and only if this does not apply, it tries the general case f[n_]
. As a result, when you ask for f
will keep on using the general rule until the "end condition" rule for f
|• Mathematica tries to put specific definitions before more general definitions.|
Treatment of definitions in Mathematica.
did not follow the principle of putting special rules before more general ones, then the special rules would always be "shadowed" by more general ones. In the factorial example, if the rule for f[n_]
was ahead of the rule for f
, then even when Mathematica
tried to evaluate f
, it would use the general f[n_]
rule, and it would never find the special f
Here is a general definition for f[n_]
Here is a definition for the special case f
puts the special case before the general one.
In the factorial function example used above, it is clear which rule is more general. Often, however, there is no definite ordering in generality of the rules you give. In such cases, Mathematica
simply tries the rules in the order you give them.
These rules have no definite ordering in generality.
stores the rules in the order you gave them.
This rule is a special case of the rule for log[x_y_]
puts the special rule before the more general one.
Although in many practical cases, Mathematica
can recognize when one rule is more general than another, you should realize that this is not always possible. For example, if two rules both contain complicated /;
conditions, it may not be possible to work out which is more general, and, in fact, there may not be a definite ordering. Whenever the appropriate ordering is not clear, Mathematica
stores rules in the order you give them.