hankel
Hankel matrix
Description
returns a
square Hankel Matrix where
H
= hankel(c
)c
defines the first column of the matrix, and the elements are zero
below the main anti-diagonal.
Examples
Create Symmetric Hankel Matrix
Create a symmetric Hankel matrix.
c = [1 2 3 4]; hankel(c)
ans = 4×4
1 2 3 4
2 3 4 0
3 4 0 0
4 0 0 0
Create Nonsymmetric Hankel Matrix
Create a nonsymmetric Hankel matrix with specified column and row vectors.
c = [2 4 6]; r = [6 5 4 3 2 1]; hankel(c,r)
ans = 3×6
2 4 6 5 4 3
4 6 5 4 3 2
6 5 4 3 2 1
Create another nonsymmetric Hankel matrix. If the last element of the column vector does not match the first element of the row vector, hankel
issues a warning and uses the last element of the column for the anti-diagonal element.
c = [1 2 3]; r = [4 5 7 9]; hankel(c,r)
Warning: Last element of input column does not match first element of input row. Column wins anti-diagonal conflict.
ans = 3×4
1 2 3 5
2 3 5 7
3 5 7 9
Create Hankel Matrix with Complex Elements
Create a Hankel matrix with complex row and column vectors.
c = [1+2i 2-4i -1+3i]; r = [-1+3i 3-1i 1-2i]; hankel(c,r)
ans = 3×3 complex
1.0000 + 2.0000i 2.0000 - 4.0000i -1.0000 + 3.0000i
2.0000 - 4.0000i -1.0000 + 3.0000i 3.0000 - 1.0000i
-1.0000 + 3.0000i 3.0000 - 1.0000i 1.0000 - 2.0000i
Input Arguments
c
— First column of Hankel matrix
scalar | vector
First column of Hankel matrix, specified as a scalar or a vector.
Data Types: single
| double
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
Complex Number Support: Yes
r
— Last row of Hankel matrix
scalar | vector
Last row of Hankel matrix, specified as a scalar or a vector. If the last element
of c
differs from the first element of r
, then
hankel
uses the last element of c
for the
anti-diagonal.
Data Types: single
| double
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
Complex Number Support: Yes
More About
Hankel Matrix
A Hankel matrix is a matrix in which the elements along each anti-diagonal are equal:
If c
is the first column of the Hankel matrix and
r
is the last row of the Hankel matrix, then p = [c
r(2:end)]
completely determines all elements of the Hankel matrix using the
mapping
Hi,j = pi+j-1.
All square Hankel matrices are symmetric.
Extended Capabilities
C/C++ Code Generation
Generate C and C++ code using MATLAB® Coder™.
Thread-Based Environment
Run code in the background using MATLAB® backgroundPool
or accelerate code with Parallel Computing Toolbox™ ThreadPool
.
This function fully supports thread-based environments. For more information, see Run MATLAB Functions in Thread-Based Environment.
GPU Arrays
Accelerate code by running on a graphics processing unit (GPU) using Parallel Computing Toolbox™.
The hankel
function
fully supports GPU arrays. To run the function on a GPU, specify the input data as a gpuArray
(Parallel Computing Toolbox). For more information, see Run MATLAB Functions on a GPU (Parallel Computing Toolbox).
Distributed Arrays
Partition large arrays across the combined memory of your cluster using Parallel Computing Toolbox™.
This function fully supports distributed arrays. For more information, see Run MATLAB Functions with Distributed Arrays (Parallel Computing Toolbox).
Version History
Introduced before R2006a
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: United States.
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
Asia Pacific
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)