?HERK_
List
cherk_ | 単精度複素数エルミート行列の階数nの更新 |
zherk_ | 倍精度複素数エルミート行列の階数nの更新 |
概略
任意の大きさの行列(正方行列でなくてもよい)とその共役転置をした行列をかけ算します。結果を別途渡したエルミート行列にスカラ倍したものを加算します(詳しくは計算式参照)これによってランクnの更新になります。計算上、返ってくるのは必ずエルミート行列になることに注意してください。
計算式
C := alpha * A conjg(A) + beta * C特に、trans="C"とすると
C := alpha * conjg(A) A + beta * C
プロトタイプ宣言
void cherk_(char *uplo, char *trans, int *n, int *k, float *alpha, complex *A, int *ldA,float *beta , complex *C, int *ldC);
void zherk_(char *uplo, char *trans, int *n, int *k, double *aplha, doublecomplex *A, int *ldA,
double *beta , doublecomplex *C, int *ldC);
引数/戻り値
変数名 | 型 | 概要 |
uplo | char* | 行列Aのどの部分を使うか指定 ("L"(下三角),"U"(上三角)から選択) |
trans | char* | 行列Aの転置を指定 ("N"(そのまま),"C"(共役転置)から選択) |
n | int* | 行列Cの行数・列数 |
k | int* | 行列Aの列数 |
alpha | double* | スカラーalpha |
A | doublecomplex* | 行列Aの先頭ポインタ |
ldA | int* | Aのleading dimension (通常は行数を指定すれば良い) |
beta | double* | スカラーbeta |
C | doublecomplex* | 行列Cの先頭ポインタ |
ldC | int* | Cのleading dimension (通常は行数を指定すれば良い) |
戻り値 | void |