aboutsummaryrefslogtreecommitdiff
path: root/src/GeneralizedPolynomial-Uniform/Hermite/3d.maple
diff options
context:
space:
mode:
Diffstat (limited to 'src/GeneralizedPolynomial-Uniform/Hermite/3d.maple')
-rw-r--r--src/GeneralizedPolynomial-Uniform/Hermite/3d.maple170
1 files changed, 170 insertions, 0 deletions
diff --git a/src/GeneralizedPolynomial-Uniform/Hermite/3d.maple b/src/GeneralizedPolynomial-Uniform/Hermite/3d.maple
new file mode 100644
index 0000000..ae52a9f
--- /dev/null
+++ b/src/GeneralizedPolynomial-Uniform/Hermite/3d.maple
@@ -0,0 +1,170 @@
+# 3d.maple -- compute Hermite interpolation coefficients in 3-D
+# $Header$
+
+################################################################################
+
+#
+# 3d, cube, polynomial order=3, derivatives via 3-point order=2 formula
+# ==> overall order=2, 4-point molecule
+#
+
+# interpolating polynomial
+interp_3d_cube_order2
+ := Hermite_polynomial_interpolant(fn_3d_order3,
+ coeff_set_3d_order3,
+ [x,y,z],
+ {
+ {x} = deriv_3d_dx_3point,
+ {y} = deriv_3d_dy_3point,
+ {z} = deriv_3d_dz_3point,
+ {x,y} = deriv_3d_dxy_3point,
+ {x,z} = deriv_3d_dxz_3point,
+ {y,z} = deriv_3d_dyz_3point,
+ {x,y,z} = deriv_3d_dxyz_3point
+ },
+ {op(posn_list_3d_size2)},
+ {op(posn_list_3d_size2)});
+
+# I
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_I_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-I.compute.c");
+
+# d/dx
+simplify( diff(interp_3d_cube_order2,x) );
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_dx_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-dx.compute.c");
+
+# d/dy
+simplify( diff(interp_3d_cube_order2,y) );
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_dy_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-dy.compute.c");
+
+# d/dz
+simplify( diff(interp_3d_cube_order2,z) );
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_dz_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-dz.compute.c");
+
+# d^2/dx^2
+simplify( diff(interp_3d_cube_order2,x,x) );
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_dxx_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-dxx.compute.c");
+
+# d^2/dxdy
+simplify( diff(interp_3d_cube_order2,x,y) );
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_dxy_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-dxy.compute.c");
+
+# d^2/dxdz
+simplify( diff(interp_3d_cube_order2,x,z) );
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_dxz_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-dxz.compute.c");
+
+# d^2/dy^2
+simplify( diff(interp_3d_cube_order2,y,y) );
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_dyy_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-dyy.compute.c");
+
+# d^2/dydz
+simplify( diff(interp_3d_cube_order2,y,z) );
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_dyz_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-dyz.compute.c");
+
+# d^2/dz^2
+simplify( diff(interp_3d_cube_order2,z,z) );
+coeff_as_lc_of_data(%, posn_list_3d_size4);
+print_coeff__lc_of_data(%, "coeff_dzz_", "fp",
+ "3d.coeffs/3d.cube.order2/coeff-dzz.compute.c");
+
+################################################################################
+
+#
+# 3d, cube, polynomial order=3, derivatives via 5-point order=4 formula
+# ==> overall order=3, 6-point molecule
+#
+
+# interpolating polynomial
+interp_3d_cube_order3
+ := Hermite_polynomial_interpolant(fn_3d_order3,
+ coeff_set_3d_order3,
+ [x,y,z],
+ {
+ {x} = deriv_3d_dx_5point,
+ {y} = deriv_3d_dy_5point,
+ {z} = deriv_3d_dz_5point,
+ {x,y} = deriv_3d_dxy_5point,
+ {x,z} = deriv_3d_dxz_5point,
+ {y,z} = deriv_3d_dyz_5point,
+ {x,y,z} = deriv_3d_dxyz_5point
+ },
+ {op(posn_list_3d_size2)},
+ {op(posn_list_3d_size2)});
+
+# I
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_I_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-I.compute.c");
+
+# d/dx
+simplify( diff(interp_3d_cube_order3,x) );
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_dx_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-dx.compute.c");
+
+# d/dy
+simplify( diff(interp_3d_cube_order3,y) );
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_dy_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-dy.compute.c");
+
+# d/dz
+simplify( diff(interp_3d_cube_order3,z) );
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_dz_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-dz.compute.c");
+
+# d^2/dx^2
+simplify( diff(interp_3d_cube_order3,x,x) );
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_dxx_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-dxx.compute.c");
+
+# d^2/dxdy
+simplify( diff(interp_3d_cube_order3,x,y) );
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_dxy_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-dxy.compute.c");
+
+# d^2/dxdz
+simplify( diff(interp_3d_cube_order3,x,z) );
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_dxz_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-dxz.compute.c");
+
+# d^2/dy^2
+simplify( diff(interp_3d_cube_order3,y,y) );
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_dyy_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-dyy.compute.c");
+
+# d^2/dydz
+simplify( diff(interp_3d_cube_order3,y,z) );
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_dyz_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-dyz.compute.c");
+
+# d^2/dz^2
+simplify( diff(interp_3d_cube_order3,z,z) );
+coeff_as_lc_of_data(%, posn_list_3d_size6);
+print_coeff__lc_of_data(%, "coeff_dzz_", "fp",
+ "3d.coeffs/3d.cube.order3/coeff-dzz.compute.c");
+
+################################################################################