diff options
Diffstat (limited to 'src/Lagrange-tensor-product/2d.cube.order2.smooth0.c')
-rw-r--r-- | src/Lagrange-tensor-product/2d.cube.order2.smooth0.c | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/src/Lagrange-tensor-product/2d.cube.order2.smooth0.c b/src/Lagrange-tensor-product/2d.cube.order2.smooth0.c new file mode 100644 index 0000000..a3041d1 --- /dev/null +++ b/src/Lagrange-tensor-product/2d.cube.order2.smooth0.c @@ -0,0 +1,64 @@ +/* $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_LagTP_2cube_20 +#include "../template.h" + +#define N_DIMS 2 +#define MOLECULE_MIN_M -1 +#define MOLECULE_MAX_M 1 +#define MOLECULE_SIZE 3 + +/* which derivative ops do we support? */ +#define HAVE_OP_I +#define HAVE_OP_DX +#define HAVE_OP_DY +#define HAVE_OP_DXX +#define HAVE_OP_DXY +#define HAVE_OP_DYY + +#define XYZ x, y +#define FP_XYZ fp x, fp y +#define STRIDE_IJK stride_i, stride_j +#define JACOBIAN_MIJK_STRIDE Jacobian_mi_stride, Jacobian_mj_stride + +#define DATA_STRUCT data_struct_2d_cube_size3 +#define COEFFS_STRUCT coeffs_struct_2d_cube_size3 + +#define LOAD_DATA_REAL AEILocalInterp_load_2dcube3_r +#define LOAD_DATA_REAL4 AEILocalInterp_load_2dcube3_r4 +#define LOAD_DATA_REAL8 AEILocalInterp_load_2dcube3_r8 +#define LOAD_DATA_REAL16 AEILocalInterp_load_2dcube3_r16 +#define LOAD_DATA_COMPLEX AEILocalInterp_load_2dcube3_c +#define LOAD_DATA_COMPLEX8 AEILocalInterp_load_2dcube3_c8 +#define LOAD_DATA_COMPLEX16 AEILocalInterp_load_2dcube3_c16 +#define LOAD_DATA_COMPLEX32 AEILocalInterp_load_2dcube3_c32 + +#define EVALUATE_MOLECULE AEILocalInterp_eval_2dcube3 + +#define STORE_COEFFS AEILocalInterp_store_2dcube3 + +/* note pathnames are all relative to "../template.c" */ +#define COEFFS_I_COMPUTE_FILE_NAME "Lagrange-tensor-product/2d.coeffs/2d.cube.order2.smooth0/coeffs-I.compute.c" +#define COEFFS_DX_COMPUTE_FILE_NAME "Lagrange-tensor-product/2d.coeffs/2d.cube.order2.smooth0/coeffs-dx.compute.c" +#define COEFFS_DY_COMPUTE_FILE_NAME "Lagrange-tensor-product/2d.coeffs/2d.cube.order2.smooth0/coeffs-dy.compute.c" +#define COEFFS_DXX_COMPUTE_FILE_NAME "Lagrange-tensor-product/2d.coeffs/2d.cube.order2.smooth0/coeffs-dxx.compute.c" +#define COEFFS_DXY_COMPUTE_FILE_NAME "Lagrange-tensor-product/2d.coeffs/2d.cube.order2.smooth0/coeffs-dxy.compute.c" +#define COEFFS_DYY_COMPUTE_FILE_NAME "Lagrange-tensor-product/2d.coeffs/2d.cube.order2.smooth0/coeffs-dyy.compute.c" + +/* actual code */ +#include "../template.c" |