aboutsummaryrefslogtreecommitdiff
path: root/src/GeneralizedPolynomial-Uniform/Lagrange-maximum-degree/3d.cube.order1.smooth0.c
blob: 6b9b2e2acd05a16a45bd2a1289b714666e3ea2ad (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/fetch.h"
#include "../common/evaluate.h"
#include "../common/store.h"

/* function prototype */
#define FUNCTION_NAME	LocalInterp_U_LagrMD_3d_cube10
#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 FETCH_DATA_REAL			LocalInterp_fetch_3d_cube2_r
#define FETCH_DATA_REAL4		LocalInterp_fetch_3d_cube2_r4
#define FETCH_DATA_REAL8		LocalInterp_fetch_3d_cube2_r8
#define FETCH_DATA_REAL16		LocalInterp_fetch_3d_cube2_r16
#define FETCH_DATA_COMPLEX		LocalInterp_fetch_3d_cube2_c
#define FETCH_DATA_COMPLEX8		LocalInterp_fetch_3d_cube2_c8
#define FETCH_DATA_COMPLEX16		LocalInterp_fetch_3d_cube2_c16
#define FETCH_DATA_COMPLEX32		LocalInterp_fetch_3d_cube2_c32

#define EVALUATE_MOLECULE		LocalInterp_eval_3d_cube2

#define STORE_COEFFS			LocalInterp_store_3d_cube2

/* 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"