|
Calling Sequence
|
|
Ordinal(c)
Ordinal([[e1,c1], [e2,c2], ...])
omega
type(a, ordinal)
|
|
Parameters
|
|
c, c1, c2, ...
|
-
|
non-negative integers or polynomials with positive integer coefficients
|
e1, e2, ...
|
-
|
ordinals or non-negative integers
|
a
|
-
|
any expression
|
|
|
|
|
Returns
|
|
•
|
The Ordinal calling sequences return either a non-negative integer, a polynomial with positive integer coefficients, or an ordinal data structure.
|
•
|
The omega calling sequence returns the ordinal data structure ORDINAL([[1,1]]) representing the natural numbers.
|
•
|
The type(a, ordinal) calling sequence returns either true or false.
|
|
|
Description
|
|
•
|
A (non-parametric) ordinal number is represented either by a non-negative integer or by an ordinal data structure in Cantor normal form. The second option is of the form:
|
|
where ORDINAL is a literal keyword, e1,e2,... are non-negative integers or themselves ordinal data structures, recursively, and c1,c2,... are positive integers. This represents the ordinal number:
|
|
where is the ordinal representing the natural numbers equipped with their standard ordering.
|
•
|
Moreover, the exponents are sorted, that is, , where is the (strict) ordering of ordinals.
|
•
|
Finally, there must be at least one term [e1,c1], and e1 cannot be zero - an ordinal that is actually a non-negative integer is represented as such and not by an ordinal data structure.
|
•
|
The Ordinal command constructs such an ordinal data structure. It is recommended to always use this constructor and not form the data structure directly using the ORDINAL keyword. It is safer to use the Ordinal command because it ensures that the result is a valid ordinal data structure.
|
•
|
The omega calling sequence creates and returns an ordinal data structure, namely, ORDINAL([[1,1]]), for itself.
|
•
|
The type(a, ordinal) calling sequence checks whether a is an ordinal data structure of the form described above, and if so, returns true, and otherwise false. In particular, the return value is false if a is a non-negative integer.
|
•
|
The Ordinals package can only handle (and the Ordinal constructor can only form) ordinal numbers smaller than , that is, ordinal numbers that can be constructed from and positive integers in a finite number of steps by ordinal addition, multiplication, and exponentiation.
|
•
|
In addition to the non-parametric ordinals described earlier, the Ordinals package can also handle parametric ordinals. These are ordinals where the coefficients ci may contain parameters, that is, names, such as or , occurring polynomially and with positive integer coefficients. The Ordinal command allows the construction of a parametric ordinal.
|
•
|
All parameters are implicitly assumed to represent non-negative integers.
|
•
|
A parametric coefficient ci in an ordinal data structure is always in expanded form.
|
•
|
Currently the exponents ei cannot be parametric, and if they are themselves ordinals, their coefficients cannot contain parameters, either.
|
•
|
The type(a, ordinal) calling sequence checks if a is a valid (possibly parametric) ordinal data structure, and returns true if that is the case and false otherwise. If a is an integer or a polynomial with positive integer coefficients, the result is false.
|
•
|
If the argument to the Ordinal command represents an ordinal smaller than , that is, a non-negative integer, then the return value is not an ordinal data structure but either a non-negative integer, if there are no parameters, or a polynomial in the parameters with positive integer coefficients. In particular, when the Ordinal(c) calling sequence is used, where c is a non-negative integer or a polynomial with positive integer coefficients, then the return value is c.
|
|
|
Examples
|
|
| (1) |
>
|
|
| (2) |
ORDINAL([[2, 2], [1, 3], [0, 4]])
| |
Coefficients that are are removed automatically.
>
|
|
Terms out of order are removed as well; smaller terms from the left are absorbed by larger terms from the right.
>
|
|
After removal of out-of-order terms, the coefficients of neighboring terms with the same exponents are combined additively.
>
|
|
| (6) |
If, after all of the above simplifications, what remains represents a non-negative integer, it will be converted into one.
>
|
|
Exponents can be ordinals themselves.
>
|
|
| (11) |
>
|
|
| (12) |
>
|
|
ORDINAL([[ORDINAL([[ORDINAL([[4, 3], [3, 7], [2, 3], [0, 5]]), 3], [2, 1], [1, 4]]), 1], [ORDINAL([[4, 3], [3, 7], [2, 3], [0, 5]]), 2], [1, 3], [0, 4]])
| |
An ordinal with two parameters.
>
|
|
| (14) |
Neither coefficients nor exponents can be negative.
>
|
|
>
|
|
>
|
|
Exponents cannot contain parameters.
>
|
|
|
|
Compatibility
|
|
•
|
The Ordinals[Ordinal], Ordinals[omega] and type/ordinal commands were introduced in Maple 2015.
|
|
|
|