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

◆ Zgebal()

Sub Zgebal ( Job As  String,
N As  Long,
A() As  Complex,
Ilo As  Long,
Ihi As  Long,
Scal() As  Double,
Info As  Long 
)

一般行列の均衡化 (複素行列)

目的
本ルーチンは一般複素行列 A の均衡化を行う. 最初に, 先頭の 1〜Ilo-1 および末尾の Ihi+1〜N 番目の対角要素に固有値を分離するために相似変換により A の置換を行う. 次に, 行と列のノルムができるだけ同じになるように対角相似変換を行および列 Ilo〜Ihi に適用する. これらを行うかどうかはどちらも選択可能である.

均衡化によって, 行列の1ノルムを減少させ求められる固有値および固有ベクトルの精度を改善させることが期待できる.
引数
[in]JobA に施す処理を指定する.
= "N": なし: 単純に Ilo = 1, Ihi = N, Scal(i) = 1.0 (i = 0, ..., N-1) と設定する.
= "P": 置換のみ.
= "S": スケーリングのみ.
= "B": 置換とスケーリングの両方.
[in]N行列 A の行および列数. (N >= 0) (N = 0 の場合, 処理を行わずに戻る)
[in,out]A()配列 A(LA1 - 1, LA2 - 1) (LA1 >= N, LA2 >= N)
[in] 入力行列 A.
[out] A() は均衡化された行列で上書きされる. Job = "N" の場合, A() は参照されない. 「詳細」を参照せよ.
[out]Ilo
[out]Ihi終了時 Ilo および Ihi は次のような整数値に設定される.
Aij = 0 (i > j かつ j = 1, ..., Ilo-1 および i = Ihi+1, ..., N).
Job = "N" または "S" の場合, Ilo = 1 および Ihi = N.
[out]Scal()配列 Scal(LScal - 1) (LScal >= N) A に適用される置換の詳細とスケール係数. 行および列 j との入替を行った行および列のインデックスを P(j), 行および列 j に適用されたスケーリングの係数を D(j) とすると, 次のようになる.
Scal(j-1) = P(j) (j = 1, ..., Ilo-1)
= D(j) (j = Ilo, ..., Ihi)
= P(j) (j = Ihi+1, ..., N)
入替が行われる順序は N から Ihi+1, そして 1 から Ilo-1 である.
[out]Info= 0: 正常終了.
= -1: パラメータ Job の誤り. (Job <> "N", "P", "S" および "B")
= -2: パラメータ N の誤り. (N < 0)
= -3: パラメータ A() の誤り.
= -6: パラメータ Scal() の誤り.
詳細
置換は行および列の入替からなり, 行列は次のような形になる.
( T1 X Y )
P A P = ( 0 B Z )
( 0 0 T2 )
ここで, T1 および T2 は上三角行列で対角要素はその固有値になる. 列インデックス lio および Ihi は小行列 B の開始列および終了列を表す.

均衡化は, B の各行およびそれに対応する列の1ノルムがほぼ等しくなるように対角相似変換 inv(D) * B * D を施す. 出力行列は次のようになる.
( T1 X*D Y )
( 0 inv(D)*B*D inv(D)*Z ).
( 0 0 T2 )
置換 P および対角行列 D に関する情報はベクトル Scal() に返される.

本サブルーチンは EISPACK ルーチンの BALANC に基づいており, Tzu-Yi Chen, Computer Science Division, University of California at Berkeley, USA により修正されたものである.
出典
LAPACK