KmlIssGcrAxpyR
计算GCR算法中的
。
接口定义
C Interface:
int KmlIssGcrAxpyR(float *r, const float *ap, double *d, const double *ac, const int *xl, const int *xr, const int *yl, const int *zl, const int *ylT, const int *yrT, const int *zlT, const int *ybegin, const int *yend, const int *zbegin, const int *zend);
参数
参数名 |
类型 |
描述 |
输入/输出 |
|---|---|---|---|
r |
float * |
GCR算法中间变量r,按(z,x,y)方向存储。 |
输入/输出 |
ap |
float * |
GCR算法中间变量ap,按(z,x,y)方向存储。 |
输入 |
d |
double * |
GCR算法中间变量d。 |
输入/输出 |
ac |
const double * |
GCR算法中间变量alpha。 |
输入 |
xl |
const int * |
求解空间x方向起始位置。 |
输入 |
xr |
const int * |
求解空间x方向结束位置。 |
输入 |
yl |
const int * |
求解空间y方向起始位置。 |
输入 |
zl |
const int * |
求解空间z方向起始位置。 |
输入 |
ylT |
const int * |
求解空间yT方向起始位置。 |
输入 |
yrT |
const int * |
求解空间yT方向结束位置。 |
输入 |
zlT |
const int * |
求解空间zT方向起始位置。 |
输入 |
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 = 5;
int yend = 6;
int zbegin = 5;
int zend = 6;
int ylm = 4;
int yrm = 7;
int zlm = 4;
float *r = (float*)malloc(sizeof(float) * 45);
float *ap = (float*)malloc(sizeof(float) * 45);
double ac = rand();
double d = 0.0;
for (int i=0; i<45; i++) {
r[i] = rand();
ap[i] = rand();
}
KmlIssGcrAxpyR(r, ap, &d, &ac, &xl, &xr, &ylm, &zlm, &yl, &yr, &zl, &ybegin, ¥d, &zbegin, &zend);