中文
注册
我要评分
文档获取效率
文档正确性
内容完整性
文档易理解
在线提单
论坛求助
鲲鹏小智

KmlIssGcrDotprodAlpha

计算GCR算法中的

接口定义

C Interface:

int KmlIssGcrDotprodAlpha(const float *r, const float *ap, double *c, const int *xl, const int *xr, const int *yl, const int *yr, const int *zl, 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)方向存储。

输入

c

double *

计算结果,c[0]为分子,c[1]为分母。

输入/输出

xl

const int *

求解空间x方向起始位置。

输入

xr

const int *

求解空间x方向结束位置。

输入

yl

const int *

求解空间y方向起始位置。

输入

zl

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"

示例

C Interface:
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;
float *r = (float*)malloc(sizeof(float) * 9);
float *ap = (float*)malloc(sizeof(float) * 36);
double *c=(double*)malloc(sizeof(double) * 2);
for (int i=0; i<9; i++) {
    r[i] = rand();
}
for (int i=0; i<36; i++) {
    ap[i] = rand();
}
for (int i=0; i<2; i++) {
    c[i] = 0.0;
}

KmlIssGcrDotprodAlpha(r, ap, c, &xl, &xr, &yl, &yr, &zl, &ybegin, &yend, &zbegin, &zend);