linalg[hermite] - Hermite Normal Form (reduced row echelon form)
|
Calling Sequence
|
|
hermite(A, x)
hermite(A, x, U)
|
|
Parameters
|
|
A
|
-
|
rectangular matrix of polynomials in x
|
x
|
-
|
name
|
U
|
-
|
name
|
|
|
|
|
Description
|
|
•
|
The function hermite computes the Hermite Normal Form (reduced row echelon form) of an m by n rectangular matrix of univariate polynomials in x over the field of rational numbers Q, or rational expressions over Q.
|
•
|
In principle this should work for polynomials in x over any field F, i.e. the Euclidean domain F[x], but in practice the code is only as powerful as Maple's normal function.
|
•
|
The Hermite normal form is obtained by doing elementary row operations on A. This includes interchanging rows, multiplying through a row by a unit, and subtracting a multiple of one row from another.
|
•
|
One can use transposes to obtain the column form of the Hermite Normal Form of a matrix.
|
•
|
In the case of three arguments, the third argument U will be assigned the transformation matrix on output, such that the following holds: hermite(A) = U &* A.
|
•
|
The command with(linalg,hermite) allows the use of the abbreviated form of this command.
|
|
|
Examples
|
|
Important: The linalg package has been deprecated. Use the superseding packages, LinearAlgebra and VectorCalculus, instead.
>
|
|
>
|
|
| (1) |
>
|
|
| (2) |
>
|
|
| (3) |
>
|
|
| (4) |
To obtain the column form of HNF for H do
>
|
|
| (5) |
>
|
|
>
|
|
| (6) |
>
|
|
| (7) |
>
|
|
| (8) |
|
|