aboutsummaryrefslogtreecommitdiff
path: root/src/Lagrange-maximum-degree/3d.cube.order1.smooth0.c
blob: 3c0275c929d7a9e9091c20c0950c6e8254013518 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/* $Header$ */

#include <math.h>
#include <limits.h>
#include <stdlib.h>
#include <string.h>
#include <stdio.h>

#include "util_ErrorCodes.h"
#include "cctk.h"
#include "../InterpLocalUniform.h"
#include "../common/structs.h"
#include "../common/load.h"
#include "../common/evaluate.h"
#include "../common/store.h"

/* function prototype */
#define FUNCTION_NAME			AEILocalInterp_U_LagMD_3cube_10
#include "../template.h"

#define N_DIMS				3
#define MOLECULE_MIN_M			0
#define MOLECULE_MAX_M			1
#define MOLECULE_SIZE			2

/* which derivative ops do we support? */
#define HAVE_OP_I
#define HAVE_OP_DX
#define HAVE_OP_DY
#define HAVE_OP_DZ
/* n.b. no 2nd derivatives for linear interpolation! */

#define XYZ				x, y, z
#define FP_XYZ				fp x, fp y, fp z
#define STRIDE_IJK			stride_i, stride_j, stride_k
#define JACOBIAN_MIJK_STRIDE		Jacobian_mi_stride, Jacobian_mj_stride, Jacobian_mk_stride

#define DATA_STRUCT			data_struct_3d_cube_size2
#define COEFFS_STRUCT			coeffs_struct_3d_cube_size2

#define LOAD_DATA_REAL			AEILocalInterp_load_3dcube2_r
#define LOAD_DATA_REAL4			AEILocalInterp_load_3dcube2_r4
#define LOAD_DATA_REAL8			AEILocalInterp_load_3dcube2_r8
#define LOAD_DATA_REAL16		AEILocalInterp_load_3dcube2_r16
#define LOAD_DATA_COMPLEX		AEILocalInterp_load_3dcube2_c
#define LOAD_DATA_COMPLEX8		AEILocalInterp_load_3dcube2_c8
#define LOAD_DATA_COMPLEX16		AEILocalInterp_load_3dcube2_c16
#define LOAD_DATA_COMPLEX32		AEILocalInterp_load_3dcube2_c32

#define EVALUATE_MOLECULE		AEILocalInterp_eval_3dcube2

#define STORE_COEFFS			AEILocalInterp_store_3dcube2

/* note pathnames are all relative to "../template.c" */
#define COEFFS_I_COMPUTE_FILE_NAME	"Lagrange-maximum-degree/3d.coeffs/3d.cube.order1.smooth0/coeffs-I.compute.c"
#define COEFFS_DX_COMPUTE_FILE_NAME	"Lagrange-maximum-degree/3d.coeffs/3d.cube.order1.smooth0/coeffs-dx.compute.c"
#define COEFFS_DY_COMPUTE_FILE_NAME	"Lagrange-maximum-degree/3d.coeffs/3d.cube.order1.smooth0/coeffs-dy.compute.c"
#define COEFFS_DZ_COMPUTE_FILE_NAME	"Lagrange-maximum-degree/3d.coeffs/3d.cube.order1.smooth0/coeffs-dz.compute.c"

/* actual code */
#include "../template.c"