XLPack 6.1
Excel VBA 数値計算ライブラリ・リファレンスマニュアル
読み取り中…
検索中…
一致する文字列を見つけられません

◆ Zhpevd()

Sub Zhpevd ( Jobz As  String,
Uplo As  String,
N As  Long,
Ap() As  Complex,
W() As  Double,
Z() As  Complex,
Info As  Long 
)

(分割統治法ドライバ) 固有値・固有ベクトル (エルミート行列) (圧縮形式)

目的
本ルーチンは圧縮形式のエルミート行列 A のすべての固有値, および, 必要により固有ベクトルを求める. 固有値のみ求める場合, QL法またはQR法を使用する. 固有ベクトルも求める場合, 分割統治法を使用する.
引数
[in]Jobz= "N": 固有値のみ求める.
= "V": 固有値と固有ベクトルを求める.
[in]Uplo= "U": A の上三角部分を格納する.
= "L": A の下三角部分を格納する.
[in]N行列Aの行および列数. (N >= 0) (N = 0 の場合, 処理を行わずに戻る)
[in,out]Ap()配列 Ap(LAp - 1) (LAp >= N(N + 1)/2)
[in] エルミート行列 A の上または下三角部分. 1次元配列に列ごとに圧縮されており, A のj列が配列 Ap() に次のように格納される
Uplo = "U": Ap(i + j*(j + 1)/2) = Aij. ただし, 0 <= i <= j <= N - 1.
Uplo = "L": Ap((i + j*(2*N - j - 1)/2) = Aij. ただし, 0 <= j < = i <= N - 1.
[out] Ap()は三重対角形への変換中に生成される値で上書きされる. Uplo = "U" の場合, 三重対角行列 T の対角要素および上副対角要素により A の対応する要素を上書きする. Uplo = "L" の場合, T の対角要素および下副対角要素により A の対応する要素を上書きする.
[out]W()配列 W(LW - 1) (LW >= N)
Info = 0の場合, 求められた固有値(昇順).
[out]Z()配列 Z(LZ1 - 1, LZ2 - 1) (LZ1 >= N, LZ2 >= N)
Jobz = "V": Info = 0 の場合, Z()に正規直交固有ベクトルが入る. W(i)に関連する固有ベクトルが i 列に入る.
Jobz = "N": Z() は参照されない.
[out]Info= 0: 正常終了
= -1: パラメータ Jobz の誤り. (Jobz <> "V" および "N")
= -2: パラメータ Uplo の誤り. (Uplo <> "U" および "L")
= -3: パラメータ N の誤り. (N < 0)
= -4: パラメータ Ap() の誤り.
= -5: パラメータ W() の誤り.
= -6: パラメータ Z() の誤り.
= i > 0: 収束しなかった. 中間結果の3重対角形の非対角要素のうち i 個が 0 に収束しなかった.
出典
LAPACK
使用例
エルミート行列Aの固有値・固有ベクトルを求める. ただし,
( 0.20 -0.11+0.93i 0.81-0.37i )
A = ( -0.11-0.93i -0.32 -0.80+0.92i )
( 0.81+0.37i -0.80-0.92i -0.29 )
とする.
Sub Ex_Zhpevd()
Const N = 3
Dim Ap(N * (N + 1) / 2) As Complex, W(N - 1) As Double, Z(N - 1, N - 1) As Complex
Dim Info As Long
Ap(0) = Cmplx(0.2, 0)
Ap(1) = Cmplx(-0.11, -0.93): Ap(3) = Cmplx(-0.32, 0)
Ap(2) = Cmplx(0.81, 0.37): Ap(4) = Cmplx(-0.8, -0.92): Ap(5) = Cmplx(-0.29, 0)
Call Zhpevd("V", "L", N, Ap(), W(), Z(), Info)
Debug.Print "Eigenvalues =", W(0), W(1), W(2)
Debug.Print "Eigenvectors ="
Debug.Print Creal(Z(0, 0)), Cimag(Z(0, 0)), Creal(Z(0, 1)), Cimag(Z(0, 1))
Debug.Print Creal(Z(1, 0)), Cimag(Z(1, 0)), Creal(Z(1, 1)), Cimag(Z(1, 1))
Debug.Print Creal(Z(2, 0)), Cimag(Z(2, 0)), Creal(Z(2, 1)), Cimag(Z(2, 1))
Debug.Print Creal(Z(0, 2)), Cimag(Z(0, 2))
Debug.Print Creal(Z(1, 2)), Cimag(Z(1, 2))
Debug.Print Creal(Z(2, 2)), Cimag(Z(2, 2))
Debug.Print "Info =", Info
End Sub
実行結果
Eigenvalues = -2.05348849668514 0.124622388617308 1.51886610806783
Eigenvectors =
-0.449276526719113 -0 0.654793596518192 0
0.227247885813611 -0.597641779578735 0.519997178670921 -3.19846835072552E-02
0.621236109316912 -5.83009495222983E-02 0.204907317474214 -0.507777757881847
-0.607779522934083 0
0.392237107311198 0.407323787101333
-0.23846608290599 -0.503959683819116
Info = 0