ASCOT5
Loading...
Searching...
No Matches
interp.h
Go to the documentation of this file.
1
27#ifndef INTERP_H
28#define INTERP_H
29#include "../ascot5.h"
30#include "../offload.h"
31#include "../error.h"
32
40
45 NSIZE_COMP1D = 2,
46 NSIZE_COMP2D = 4,
47 NSIZE_COMP3D = 8,
48 NSIZE_EXPL1D = 4,
49 NSIZE_EXPL2D = 16,
50 NSIZE_EXPL3D = 64
51};
52
64
81
103
105 int n_x, int bc_x,
106 real x_min, real x_max);
107
109 int n_x, int n_y, int bc_x, int bc_y,
110 real x_min, real x_max,
111 real y_min, real y_max);
112
114 int n_x, int n_y, int n_z,
115 int bc_x, int bc_y, int bc_z,
116 real x_min, real x_max,
117 real y_min, real y_max,
118 real z_min, real z_max);
119
121 int n_x, int bc_x,
122 real x_min, real x_max);
123
125 int n_x, int n_y, int bc_x, int bc_y,
126 real x_min, real x_max,
127 real y_min, real y_max);
128
130 int n_x, int n_y, int n_z,
131 int bc_x, int bc_y, int bc_z,
132 real x_min, real x_max,
133 real y_min, real y_max,
134 real z_min, real z_max);
135
137 int n_x, int bc_x,
138 real x_min, real x_max);
139
141 int n_x, int n_y, int bc_x, int bc_y,
142 real x_min, real x_max,
143 real y_min, real y_max);
144
146 int n_x, int n_y, int n_z,
147 int bc_x, int bc_y, int bc_z,
148 real x_min, real x_max,
149 real y_min, real y_max,
150 real z_min, real z_max);
151
153 int n_x, int bc_x,
154 real x_min, real x_max);
155
157 int n_x, int n_y, int bc_x, int bc_y,
158 real x_min, real x_max,
159 real y_min, real y_max);
160
162 int n_x, int n_y, int n_z,
163 int bc_x, int bc_y, int bc_z,
164 real x_min, real x_max,
165 real y_min, real y_max,
166 real z_min, real z_max);
167
168int interp1Dcomp_setup(interp1D_data* str, real* f, int n_x, int bc_x,
169 real x_min, real x_max);
170
171int interp2Dcomp_setup(interp2D_data* str, real* f, int n_x, int n_y,
172 int bc_x, int bc_y, real x_min, real x_max,
173 real y_min, real y_max);
174
176 int n_x, int n_y, int n_z, int bc_x, int bc_y, int bc_z,
177 real x_min, real x_max, real y_min, real y_max,
178 real z_min, real z_max);
179
180GPU_DECLARE_TARGET_SIMD_UNIFORM(str)
182DECLARE_TARGET_END
183GPU_DECLARE_TARGET_SIMD_UNIFORM(str)
185DECLARE_TARGET_END
186GPU_DECLARE_TARGET_SIMD_UNIFORM(str)
188 real x, real y, real z);
189DECLARE_TARGET_END
190
191DECLARE_TARGET_SIMD_UNIFORM(str)
193DECLARE_TARGET_SIMD_UNIFORM(str)
195DECLARE_TARGET_SIMD_UNIFORM(str)
197 real x, real y, real z);
198
199GPU_DECLARE_TARGET_SIMD_UNIFORM(str)
201DECLARE_TARGET_END
202GPU_DECLARE_TARGET_SIMD_UNIFORM(str)
204DECLARE_TARGET_END
205GPU_DECLARE_TARGET_SIMD_UNIFORM(str)
207 real x, real y, real z);
208DECLARE_TARGET_END
209
210DECLARE_TARGET_SIMD_UNIFORM(str)
212DECLARE_TARGET_SIMD_UNIFORM(str)
214DECLARE_TARGET_SIMD_UNIFORM(str)
216 real x, real y, real z);
217#endif
Main header file for ASCOT5.
double real
Definition ascot5.h:85
Error module for ASCOT5.
unsigned long int a5err
Simulation error flag.
Definition error.h:17
DECLARE_TARGET_END a5err interp3Dcomp_eval_f(real *f, interp3D_data *str, real x, real y, real z)
Evaluate interpolated value of 3D scalar field.
void interp1Dexpl_init_spline(interp1D_data *str, real *c, int n_x, int bc_x, real x_min, real x_max)
Initialize a cubic spline.
int interp3Dcomp_setup(interp3D_data *str, real *f, int n_x, int n_y, int n_z, int bc_x, int bc_y, int bc_z, real x_min, real x_max, real y_min, real y_max, real z_min, real z_max)
Set up splines to interpolate 3D scalar data.
int interp2Dcomp_setup(interp2D_data *str, real *f, int n_x, int n_y, int bc_x, int bc_y, real x_min, real x_max, real y_min, real y_max)
Set up splines to interpolate 2D scalar data.
int interp3Dcomp_init_coeff(real *c, real *f, int n_x, int n_y, int n_z, int bc_x, int bc_y, int bc_z, real x_min, real x_max, real y_min, real y_max, real z_min, real z_max)
Calculate tricubic spline interpolation coefficients for 3D data.
int interp3Dexpl_init_coeff(real *c, real *f, int n_x, int n_y, int n_z, int bc_x, int bc_y, int bc_z, real x_min, real x_max, real y_min, real y_max, real z_min, real z_max)
Calculate tricubic spline interpolation coefficients for 3D data.
boundaryCondition
Boundary conditions for the spline interpolation.
Definition interp.h:36
@ NATURALBC
Definition interp.h:37
@ PERIODICBC
Definition interp.h:38
int interp1Dcomp_init_coeff(real *c, real *f, int n_x, int bc_x, real x_min, real x_max)
Calculate cubic spline interpolation coefficients for scalar 1D data.
DECLARE_TARGET_END a5err interp2Dcomp_eval_df(real *f_df, interp2D_data *str, real x, real y)
Evaluate interpolated value and 1st and 2nd derivatives of 2D field.
int interp2Dcomp_init_coeff(real *c, real *f, int n_x, int n_y, int bc_x, int bc_y, real x_min, real x_max, real y_min, real y_max)
Calculate bicubic spline interpolation coefficients for scalar 2D data.
a5err interp1Dcomp_eval_f(real *f, interp1D_data *str, real x)
Evaluate interpolated value of 1D scalar field.
a5err interp2Dexpl_eval_f(real *f, interp2D_data *str, real x, real y)
Evaluate interpolated value of 2D scalar field.
a5err interp3Dexpl_eval_df(real *f_df, interp3D_data *str, real x, real y, real z)
Evaluate interpolated value of 3D field and 1st and 2nd derivatives.
int interp1Dcomp_setup(interp1D_data *str, real *f, int n_x, int bc_x, real x_min, real x_max)
Set up splines to interpolate 1D scalar data.
DECLARE_TARGET_END a5err interp1Dexpl_eval_df(real *f_df, interp1D_data *str, real x)
Evaluate interpolated value of 1D and its 1st and 2nd derivatives.
a5err interp3Dexpl_eval_f(real *f, interp3D_data *str, real x, real y, real z)
Evaluate interpolated value of 3D scalar field.
void interp3Dcomp_init_spline(interp3D_data *str, real *c, int n_x, int n_y, int n_z, int bc_x, int bc_y, int bc_z, real x_min, real x_max, real y_min, real y_max, real z_min, real z_max)
Initialize a tricubic spline.
void interp3Dexpl_init_spline(interp3D_data *str, real *c, int n_x, int n_y, int n_z, int bc_x, int bc_y, int bc_z, real x_min, real x_max, real y_min, real y_max, real z_min, real z_max)
Initialize a tricubic spline.
a5err interp2Dexpl_eval_df(real *f_df, interp2D_data *str, real x, real y)
Evaluate interpolated value and 1st and 2nd derivatives of 2D field.
void interp2Dexpl_init_spline(interp2D_data *str, real *c, int n_x, int n_y, int bc_x, int bc_y, real x_min, real x_max, real y_min, real y_max)
Initialize a bicubic spline.
a5err interp1Dcomp_eval_df(real *f_df, interp1D_data *str, real x)
Evaluate interpolated value of 1D and its 1st and 2nd derivatives.
int interp1Dexpl_init_coeff(real *c, real *f, int n_x, int bc_x, real x_min, real x_max)
Calculate cubic spline interpolation coefficients for scalar 1D data.
DECLARE_TARGET_END a5err interp3Dcomp_eval_df(real *f_df, interp3D_data *str, real x, real y, real z)
Evaluate interpolated value of 3D field and 1st and 2nd derivatives.
void interp2Dcomp_init_spline(interp2D_data *str, real *c, int n_x, int n_y, int bc_x, int bc_y, real x_min, real x_max, real y_min, real y_max)
Initialize a bicubic spline.
DECLARE_TARGET_END a5err interp1Dexpl_eval_f(real *f, interp1D_data *str, real x)
Evaluate interpolated value of 1D scalar field.
int interp2Dexpl_init_coeff(real *c, real *f, int n_x, int n_y, int bc_x, int bc_y, real x_min, real x_max, real y_min, real y_max)
Calculate bicubic spline interpolation coefficients for scalar 2D data.
void interp1Dcomp_init_spline(interp1D_data *str, real *c, int n_x, int bc_x, real x_min, real x_max)
Initialize a cubic spline.
DECLARE_TARGET_END a5err interp2Dcomp_eval_f(real *f, interp2D_data *str, real x, real y)
Evaluate interpolated value of a 2D field.
splinesize
Number of coefficients stored for each data point.
Definition interp.h:44
Cubic interpolation struct.
Definition interp.h:56
real x_min
Definition interp.h:59
real x_max
Definition interp.h:60
real x_grid
Definition interp.h:61
real * c
Definition interp.h:62
Bicubic interpolation struct.
Definition interp.h:68
real y_min
Definition interp.h:76
real y_grid
Definition interp.h:78
real x_grid
Definition interp.h:75
real x_min
Definition interp.h:73
real y_max
Definition interp.h:77
real x_max
Definition interp.h:74
real * c
Definition interp.h:79
Tricubic interpolation struct.
Definition interp.h:85
real z_max
Definition interp.h:99
real z_min
Definition interp.h:98
real z_grid
Definition interp.h:100
real x_min
Definition interp.h:92
real y_max
Definition interp.h:96
real y_grid
Definition interp.h:97
real * c
Definition interp.h:101
real x_grid
Definition interp.h:94
real x_max
Definition interp.h:93
real y_min
Definition interp.h:95