kml_?_spline2d_eval_extrap
这个函数返回给定点(x, y)的插值结果z。计算中使用插值对象spline,数据数组xarr,yarr和zarr以及加速器xacc和yacc。函数不检查最大值最小值越界,因此当x在xarr的区间外或y在yarr的区间外时,外推法被使用。
接口定义
float kml_float_spline2d_eval_extrap(const kml_float_spline2d *spline, const float x, const float y, kml_interp_accel *xa, kml_interp_accel *ya)
int kml_float_spline2d_eval_extrap_e(const kml_float_spline2d *spline, const float x, const float y, kml_interp_accel *xa, kml_interp_accel *ya, float *z)
double kml_double_spline2d_eval_extrap(const kml_double_spline2d *spline, const double x, const double y,
kml_interp_accel *xa, kml_interp_accel *ya);
int kml_double_spline2d_eval_extrap_e(const kml_double_spline2d *spline, const double x, const double y,
kml_interp_accel *xa, kml_interp_accel *ya, double *z);
参数
参数名  | 
类型  | 
描述  | 
输入/输出  | 
|---|---|---|---|
spline  | 
kml_float_spline2d*, kml_double_spline2d*  | 
插值对象指针  | 
输入  | 
x  | 
float, double  | 
求解点x的值  | 
输入  | 
y  | 
float, double  | 
求解点y的值  | 
输入  | 
xa  | 
kml_interp_accel *  | 
加速器对象指针  | 
输入  | 
ya  | 
kml_interp_accel *  | 
加速器对象指针  | 
输入  | 
z  | 
float *, double *  | 
插值点计算结果  | 
输出  | 
依赖
#include "kipl.h"
示例
const size_t xMin = 4;
const size_t xMax = 2048;
const size_t xSize = 4;
const size_t yMin = 4;
const size_t yMax = 2048;
const size_t ySize = 4;
const float xValLo = 1;
const float xValHi = 2;
const float yValLo = 1;
const float yValHi = 2;
float xArr[4] = {1,1.33,1.67,2};
float yArr[4] = {1,1.33,1.67,2};
float* zArr = (float*)malloc(xSize * ySize * sizeof(float));
float x = 1;
float y = 1;
float z = 0;
kml_float_spline2d *spline = kml_float_spline2d_alloc(kml_float_interp2d_bicubic, xSize, ySize);
kml_interp_accel *xacc = kml_interp_accel_alloc();
kml_interp_accel *yacc = kml_interp_accel_alloc();
kml_float_spline2d_init(spline, xArr, yArr, zArr, xSize, ySize);
z = kml_float_spline2d_eval_extrap(spline, xArr, yArr, zArr, x, y, xacc, yacc);