|
|
◆ ddisna()
| void ddisna |
( |
char |
job, |
|
|
int |
m, |
|
|
int |
n, |
|
|
double |
d[], |
|
|
double |
sep[], |
|
|
int * |
info |
|
) |
| |
対称/エルミート行列の固有ベクトルあるいは一般行列の特異ベクトルの条件数
- 目的
- 本ルーチンは実対称または複素エルミート行列の固有ベクトル, あるいは, m×n一般行列の左または右特異ベクトルの条件数の逆数を求める. 条件数の逆数は, 固有値あるいは特異値とそれに最も近い他の値との「間隔」である.
求められたi番目のベクトルの誤差限界を角度(ラジアン)で表すと次のようになる.
double dlamch(char cmach) 機種パラメータ (倍精度浮動小数演算) Definition dlamch.c:79
ここで, anorm = 2-norm(A) = max(abs(d[j])) である. sep[i]は, 誤差限界の大きさを制限するために dlamch('E')*anorm より小さくてはならない.
ddisnaはまた, 一般化対称定値固有値問題の固有値の誤差限界を計算するために使用してもよい.
- 引数
-
| [in] | job | 条件数の逆数を計算する問題の種類.
= 'E': 対称/エルミート行列の固有ベクトル.
= 'L': 一般行列の左特異ベクトル.
= 'R': 一般行列の右特異ベクトル. |
| [in] | m | 行列の行数. (m >= 0) (m = 0 の場合, 処理を行わずに戻る) |
| [in] | n | job = 'L', 'R': 行列の列数. (n >= 0) (n = 0 の場合, 処理を行わずに戻る)
job = 'E': 無視される. |
| [in] | d[] | 配列 d[ld] (ld >= m (job = 'E'), ld >= min(m, n) (job = 'L'または'R'))
job = 'E': 行列の固有値(昇順または降順).
job = 'L'または'R': 行列の特異値(昇順または降順). (特異値 >= 0) |
| [out] | sep[] | 配列 sep[lsep] (lsep >= m (job = 'E'), lsep >= min(m, n) (job = 'L'または'R'))
job = 'E': 固有ベクトルの条件数の逆数.
job = 'L'または'R': 特異値ベクトルの条件数の逆数. |
| [out] | info | = 0: 正常終了
= -1: 入力パラメータ job の誤り (job != 'E', 'L'および'R')
= -2: 入力パラメータ m の誤り (m < 0)
= -3: 入力パラメータ n の誤り (n < 0)
= -4: 入力パラメータ d の誤り (昇順または降順でない) |
- 出典
- LAPACK
|