KmlIssGcrAxpyP
计算GCR算法中的。
接口定义
C Interface:
int KmlIssGcrAxpyP(float *r, float *p, const double *b, const int *m, const int *mt, const int *xl, const int *xr, const int *yl, const int *yr, const int *zl, const int *zr, const int *ybegin, const int *yend, const int *zbegin, const int *zend);
参数
参数名 |
类型 |
描述 |
输入/输出 |
---|---|---|---|
r |
float * |
GCR算法残差向量r,按(z,x,y)方向存储。 |
输入/输出 |
p |
float * |
GCR算法中间变量p,按(z,x,y)方向存储。 |
输入/输出 |
b |
const double * |
GCR算法中间变量beta。 |
输入 |
m |
const int * |
GCR算法中间变量j。 |
输入 |
mt |
const int * |
GCR算法中间变量p存储位置,一般为j+1。 |
输入 |
xl |
const int * |
求解空间x方向起始位置。 |
输入 |
xr |
const int * |
求解空间x方向结束位置。 |
输入 |
yl |
const int * |
求解空间y方向起始位置。 |
输入 |
yr |
const int * |
求解空间y方向结束位置。 |
输入 |
zl |
const int * |
求解空间z方向起始位置。 |
输入 |
zr |
const int * |
求解空间z方向结束位置。 |
输入 |
ybegin |
const int * |
辅助求解空间y方向起始位置。 |
输入 |
yend |
const int * |
辅助求解空间y方向结束位置。 |
输入 |
zbegin |
const int * |
辅助求解空间z方向起始位置。 |
输入 |
zend |
const int * |
辅助求解空间z方向结束位置。 |
输入 |
返回值
返回值 |
类型 |
描述 |
---|---|---|
KMLSS_NO_ERROR |
int |
正常执行。 |
KMLSS_NULL_ARGUMENT |
int |
输入中存在空指针。 |
KMLSS_BAD_DATA |
int |
求解空间相关参数为无效参数。 |
依赖
#include "kml_gcr_specific.h"
示例
int xl = 5; int yl = 5; int zl = 5; int xr = 6; int yr = 6; int zr = 6; int ybegin = yl; int yend = yr; int zbegin = zl; int zend = zr; int m = 1; int mt = 2; int n = 64; float *r = (float*)malloc(sizeof(float) * 64); float *p = (float*)malloc(sizeof(float) * 256); double *b = (double*)malloc(sizeof(double) * 2); for (int i=0; i<64; i++) { r[i] = rand(); } for (int i=0; i<256; i++) { p[i] = rand(); } for (int i=0; i<2; i++) { b[i] = 1.0; } KmlIssGcrAxpyP(r, p, b, &m, &mt, &xl, &xr, &yl, &yr, &zl, &zr, &ybegin, ¥d, &zbegin, &zend);