HANKEL Function
generates a Hankel matrix
- HANKEL( matrix)
where
matrix is a numeric matrix or literal.
The HANKEL function generates a Hankel matrix from
a vector, or a block Hankel matrix from a matrix.
A block Hankel matrix has the property that all
matrices on the reverse diagonals are the same.
The argument matrix is an
data:image/s3,"s3://crabby-images/83476/8347647c25049994c583c40c8fcddc0f085b3741" alt="(np) x p"
or
data:image/s3,"s3://crabby-images/296b2/296b26eaa8132ead0cbe973a73d569f4caf7ba41" alt="p x (np)"
matrix; the value returned is the
data:image/s3,"s3://crabby-images/e72b2/e72b2d6f627b7284370c432514a79b9166f30709" alt="(np) x (np)"
result.
The Hankel function uses the first
data:image/s3,"s3://crabby-images/86a2b/86a2babde4e662c165bf674e46644a6326e41333" alt="p x p"
submatrix
data:image/s3,"s3://crabby-images/bbd17/bbd17d5ab02143a2940c3ca8bf10b746220f7362" alt="a_1"
of the argument matrix
as the blocks of the first reverse diagonal.
The second
data:image/s3,"s3://crabby-images/86a2b/86a2babde4e662c165bf674e46644a6326e41333" alt="p x p"
submatrix
data:image/s3,"s3://crabby-images/4fcda/4fcda9f55a24a1ea986327a85d5cc1a02f6d28a1" alt="a_2"
of the
argument matrix forms the second reverse diagonal.
The remaining reverse diagonals are formed accordingly.
After the values in the argument matrix have all been
placed, the rest of the matrix is filled in with 0.
If
data:image/s3,"s3://crabby-images/c9139/c9139fba30f584bed9b468d27b6c26f4cabb8556" alt="a"
is
data:image/s3,"s3://crabby-images/83476/8347647c25049994c583c40c8fcddc0f085b3741" alt="(np) x p"
, then the first
data:image/s3,"s3://crabby-images/ff118/ff11898ef82fe915b329b8409951888f15995bb2" alt="p"
columns of
the returned matrix,
data:image/s3,"s3://crabby-images/adf3d/adf3d714980839b1e3db6fd573fbcd908333cfed" alt="r"
, are the same as
data:image/s3,"s3://crabby-images/c9139/c9139fba30f584bed9b468d27b6c26f4cabb8556" alt="a"
.
If
data:image/s3,"s3://crabby-images/c9139/c9139fba30f584bed9b468d27b6c26f4cabb8556" alt="a"
is
data:image/s3,"s3://crabby-images/296b2/296b26eaa8132ead0cbe973a73d569f4caf7ba41" alt="p x (np)"
, then the first
data:image/s3,"s3://crabby-images/ff118/ff11898ef82fe915b329b8409951888f15995bb2" alt="p"
rows of
data:image/s3,"s3://crabby-images/adf3d/adf3d714980839b1e3db6fd573fbcd908333cfed" alt="r"
are the same as
data:image/s3,"s3://crabby-images/c9139/c9139fba30f584bed9b468d27b6c26f4cabb8556" alt="a"
.
The HANKEL function is especially useful in time series
applications, where the covariance matrix of a set
of variables representing the present and past and
a set of variables representing the present and
future is often assumed to be a block Hankel matrix.
If
![a = [ a_1|{a}_2|{a}_3| ... |{a}_n ]](images/langref_langrefeq405.gif)
and if
data:image/s3,"s3://crabby-images/adf3d/adf3d714980839b1e3db6fd573fbcd908333cfed" alt="r"
is the matrix formed by the HANKEL function, then
![r = [ a_1 & | & a_2 & | & a_3 & | & ... & | & a_n \ a_2 & | & a_3 & | & a_4 ... ... | & 0 \ \vdots & & & & & & & & \ a_n & | & 0 & | & 0 & | & ... & | & 0 ]](images/langref_langrefeq406.gif)
If
![a = [ a_1 \ a_2 \ \vdots \ a_n \ ]](images/langref_langrefeq407.gif)
and if
data:image/s3,"s3://crabby-images/adf3d/adf3d714980839b1e3db6fd573fbcd908333cfed" alt="r"
is the matrix formed by the HANKEL function, then
![r = [ a_1 & | & a_2 & | & a_3 & | & ... & | & a_n \ a_2 & | & a_3 & | & a_4 & | & ... & | & 0 \ \vdots \ a_n & | & 0 & | & 0 & | & ... & | & 0 \ ]](images/langref_langrefeq408.gif)
For example, consider the following IML code:
r=hankel({1 2 3 4 5});
This code produces the following output:
R 5 rows 5 cols (numeric)
1 2 3 4 5
2 3 4 5 0
3 4 5 0 0
4 5 0 0 0
5 0 0 0 0
The following statement returns the matrix
data:image/s3,"s3://crabby-images/adf3d/adf3d714980839b1e3db6fd573fbcd908333cfed" alt="r"
, as shown:
r=hankel({1 2 ,
3 4 ,
5 6 ,
7 8});
R 4 rows 4 cols (numeric)
1 2 5 6
3 4 7 8
5 6 0 0
7 8 0 0
The following statement returns a different matrix
data:image/s3,"s3://crabby-images/adf3d/adf3d714980839b1e3db6fd573fbcd908333cfed" alt="r"
, as shown:
r=hankel({1 2 3 4 ,
5 6 7 8});
R 4 rows 4 cols (numeric)
1 2 3 4
5 6 7 8
3 4 0 0
7 8 0 0