aboutsummaryrefslogtreecommitdiff
path: root/ML_BSSN
diff options
context:
space:
mode:
authorErik Schnetter <schnetter@cct.lsu.edu>2010-02-13 15:27:22 -0600
committerErik Schnetter <schnetter@cct.lsu.edu>2010-02-13 15:27:22 -0600
commit9eea7b4930f6f85e477139187eb93e4cef2bef3d (patch)
tree5a1283291ceed40abbeece2695535b707814e0ce /ML_BSSN
parent76d87a0dd9b19a671d422fcefc17c7aabd223c08 (diff)
Update auto-generated code
Diffstat (limited to 'ML_BSSN')
-rw-r--r--ML_BSSN/interface.ccl2
-rw-r--r--ML_BSSN/param.ccl40
-rw-r--r--ML_BSSN/schedule.ccl19
-rw-r--r--ML_BSSN/src/Differencing.h36
-rw-r--r--ML_BSSN/src/ML_BSSN_Minkowski.c166
-rw-r--r--ML_BSSN/src/ML_BSSN_RHS.c1102
-rw-r--r--ML_BSSN/src/ML_BSSN_RHS1.c560
-rw-r--r--ML_BSSN/src/ML_BSSN_RHS2.c878
-rw-r--r--ML_BSSN/src/ML_BSSN_RHSRadiativeBoundary.c296
-rw-r--r--ML_BSSN/src/ML_BSSN_RHSStaticBoundary.c162
-rw-r--r--ML_BSSN/src/ML_BSSN_boundary.c162
-rw-r--r--ML_BSSN/src/ML_BSSN_constraints.c846
-rw-r--r--ML_BSSN/src/ML_BSSN_constraints_boundary.c106
-rw-r--r--ML_BSSN/src/ML_BSSN_convertFromADMBase.c261
-rw-r--r--ML_BSSN/src/ML_BSSN_convertFromADMBaseGamma.c329
-rw-r--r--ML_BSSN/src/ML_BSSN_convertToADMBase.c236
-rw-r--r--ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShift.c146
-rw-r--r--ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShiftBoundary.c130
-rw-r--r--ML_BSSN/src/ML_BSSN_convertToADMBaseFakeDtLapseShift.c130
-rw-r--r--ML_BSSN/src/ML_BSSN_enforce.c177
-rw-r--r--ML_BSSN/src/ML_BSSN_enforce2.c164
-rw-r--r--ML_BSSN/src/ML_BSSN_setBetaDriver.c103
-rw-r--r--ML_BSSN/src/make.code.defn2
23 files changed, 3889 insertions, 2164 deletions
diff --git a/ML_BSSN/interface.ccl b/ML_BSSN/interface.ccl
index d31bcd8..a0d38b5 100644
--- a/ML_BSSN/interface.ccl
+++ b/ML_BSSN/interface.ccl
@@ -2,7 +2,7 @@
implements: ML_BSSN
-inherits: ADMBase Grid GenericFD Boundary
+inherits: ADMBase TmunuBase Grid GenericFD Boundary
diff --git a/ML_BSSN/param.ccl b/ML_BSSN/param.ccl
index 8e791df..2324c01 100644
--- a/ML_BSSN/param.ccl
+++ b/ML_BSSN/param.ccl
@@ -124,7 +124,7 @@ restricted:
CCTK_INT useMatter "Add matter terms"
{
*:* :: ""
-} 0
+} 1
private:
KEYWORD my_initial_data "my_initial_data"
@@ -186,7 +186,7 @@ restricted:
CCTK_INT timelevels "Number of active timelevels"
{
0:4 :: ""
-} 4
+} 3
restricted:
CCTK_INT rhs_timelevels "Number of active RHS timelevels"
@@ -225,6 +225,18 @@ CCTK_INT ML_BSSN_RHS_calc_every "ML_BSSN_RHS_calc_every"
} 1
restricted:
+CCTK_INT ML_BSSN_RHS1_calc_every "ML_BSSN_RHS1_calc_every"
+{
+ *:* :: ""
+} 1
+
+restricted:
+CCTK_INT ML_BSSN_RHS2_calc_every "ML_BSSN_RHS2_calc_every"
+{
+ *:* :: ""
+} 1
+
+restricted:
CCTK_INT ML_BSSN_RHSStaticBoundary_calc_every "ML_BSSN_RHSStaticBoundary_calc_every"
{
*:* :: ""
@@ -243,6 +255,12 @@ CCTK_INT ML_BSSN_enforce_calc_every "ML_BSSN_enforce_calc_every"
} 1
restricted:
+CCTK_INT ML_BSSN_enforce2_calc_every "ML_BSSN_enforce2_calc_every"
+{
+ *:* :: ""
+} 1
+
+restricted:
CCTK_INT ML_BSSN_boundary_calc_every "ML_BSSN_boundary_calc_every"
{
*:* :: ""
@@ -315,6 +333,18 @@ CCTK_INT ML_BSSN_RHS_calc_offset "ML_BSSN_RHS_calc_offset"
} 0
restricted:
+CCTK_INT ML_BSSN_RHS1_calc_offset "ML_BSSN_RHS1_calc_offset"
+{
+ *:* :: ""
+} 0
+
+restricted:
+CCTK_INT ML_BSSN_RHS2_calc_offset "ML_BSSN_RHS2_calc_offset"
+{
+ *:* :: ""
+} 0
+
+restricted:
CCTK_INT ML_BSSN_RHSStaticBoundary_calc_offset "ML_BSSN_RHSStaticBoundary_calc_offset"
{
*:* :: ""
@@ -333,6 +363,12 @@ CCTK_INT ML_BSSN_enforce_calc_offset "ML_BSSN_enforce_calc_offset"
} 0
restricted:
+CCTK_INT ML_BSSN_enforce2_calc_offset "ML_BSSN_enforce2_calc_offset"
+{
+ *:* :: ""
+} 0
+
+restricted:
CCTK_INT ML_BSSN_boundary_calc_offset "ML_BSSN_boundary_calc_offset"
{
*:* :: ""
diff --git a/ML_BSSN/schedule.ccl b/ML_BSSN/schedule.ccl
index f8a7f3b..d8422cd 100644
--- a/ML_BSSN/schedule.ccl
+++ b/ML_BSSN/schedule.ccl
@@ -376,11 +376,21 @@ if (CCTK_EQUALS(UseSpatialBetaDriver, "yes"))
} "ML_BSSN_setBetaDriver"
}
-schedule ML_BSSN_RHS IN ML_BSSN_evolCalcGroup
+schedule ML_BSSN_RHS IN NoSuchGroup
{
LANG: C
} "ML_BSSN_RHS"
+schedule ML_BSSN_RHS1 IN ML_BSSN_evolCalcGroup
+{
+ LANG: C
+} "ML_BSSN_RHS1"
+
+schedule ML_BSSN_RHS2 IN ML_BSSN_evolCalcGroup
+{
+ LANG: C
+} "ML_BSSN_RHS2"
+
if (CCTK_EQUALS(my_rhs_boundary_condition, "static"))
{
@@ -399,11 +409,16 @@ if (CCTK_EQUALS(my_rhs_boundary_condition, "radiative"))
} "ML_BSSN_RHSRadiativeBoundary"
}
-schedule ML_BSSN_enforce IN MoL_PostStep BEFORE ML_BSSN_BoundConds
+schedule ML_BSSN_enforce IN MoL_PostStep BEFORE ML_BSSN_SelectBoundConds
{
LANG: C
} "ML_BSSN_enforce"
+schedule ML_BSSN_enforce2 IN MoL_PostStep AFTER ML_BSSN_enforce BEFORE ML_BSSN_SelectBoundConds
+{
+ LANG: C
+} "ML_BSSN_enforce2"
+
if (CCTK_EQUALS(my_boundary_condition, "Minkowski"))
{
diff --git a/ML_BSSN/src/Differencing.h b/ML_BSSN/src/Differencing.h
index 414cf95..1cdce99 100644
--- a/ML_BSSN/src/Differencing.h
+++ b/ML_BSSN/src/Differencing.h
@@ -1,18 +1,18 @@
-#define PDstandardNth1(u,i,j,k) (p1o12dx*(-8*(u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(k))] + 8*(u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(k))]))
-#define PDstandardNth2(u,i,j,k) (p1o12dy*(-8*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(k))] + 8*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(k))]))
-#define PDstandardNth3(u,i,j,k) (p1o12dz*(-8*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(-1 + k))] + 8*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(-2 + k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(2 + k))]))
-#define PDstandardNth11(u,i,j,k) (pm1o12dx2*(-16*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(k))]) + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(k))] + 30*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k))]))
-#define PDstandardNth22(u,i,j,k) (pm1o12dy2*(-16*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(k))]) + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(k))] + 30*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k))]))
-#define PDstandardNth33(u,i,j,k) (pm1o12dz2*(-16*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(-1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(1 + k))]) + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(2 + k))] + 30*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k))]))
-#define PDstandardNth12(u,i,j,k) (p1o144dxdy*(-64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(-1 + j),(int)(k))]) + 64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(-1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(1 + j),(int)(k))]) + 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(-2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(-1 + j),(int)(k))]) - 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(-2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(-1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(1 + j),(int)(k))]) + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(-2 + j),(int)(k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(2 + j),(int)(k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(-2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(2 + j),(int)(k))]))
-#define PDstandardNth13(u,i,j,k) (p1o144dxdz*(-64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(-1 + k))]) + 64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(-1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(1 + k))]) + 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(-1 + k))]) - 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(-1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(1 + k))]) + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(-2 + k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(2 + k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(2 + k))]))
-#define PDstandardNth21(u,i,j,k) (p1o144dxdy*(-64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(-1 + j),(int)(k))]) + 64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(-1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(1 + j),(int)(k))]) + 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(-2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(-1 + j),(int)(k))]) - 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(-2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(-1 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(1 + j),(int)(k))]) + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(-2 + j),(int)(k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(2 + j),(int)(k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(-2 + j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(2 + j),(int)(k))]))
-#define PDstandardNth23(u,i,j,k) (p1o144dydz*(-64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(-1 + k))]) + 64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(-1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(1 + k))]) + 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(-1 + k))]) - 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(-1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(1 + k))]) + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(-2 + k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(2 + k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(2 + k))]))
-#define PDstandardNth31(u,i,j,k) (p1o144dxdz*(-64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(-1 + k))]) + 64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(-1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(1 + k))]) + 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(-1 + k))]) - 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(-1 + i),(int)(j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(1 + i),(int)(j),(int)(2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(-1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(1 + k))]) + (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(-2 + k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(-2 + i),(int)(j),(int)(2 + k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(2 + i),(int)(j),(int)(2 + k))]))
-#define PDstandardNth32(u,i,j,k) (p1o144dydz*(-64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(-1 + k))]) + 64*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(-1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(1 + k))]) + 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(-1 + k))]) - 8*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-1 + j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(1 + j),(int)(2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(-1 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(1 + k))]) + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(-2 + k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(-2 + j),(int)(2 + k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(-2 + k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(2 + j),(int)(2 + k))]))
-#define PDupwindNth1(u,i,j,k) (p1o12dx*(-6*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i + 2*dir1),(int)(j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i + 3*dir1),(int)(j),(int)(k))] - 3*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i - dir1),(int)(j),(int)(k))] + 18*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i + dir1),(int)(j),(int)(k))] - 10*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k))])*dir1)
-#define PDupwindNth2(u,i,j,k) (p1o12dy*(-6*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j + 2*dir2),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j + 3*dir2),(int)(k))] - 3*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j - dir2),(int)(k))] + 18*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j + dir2),(int)(k))] - 10*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k))])*dir2)
-#define PDupwindNth3(u,i,j,k) (p1o12dz*(-10*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k))] - 6*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k + 2*dir3))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k + 3*dir3))] - 3*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k - dir3))] + 18*(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k + dir3))])*dir3)
-#define PDonesided1(u,i,j,k) (p1odx*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i + dir1),(int)(j),(int)(k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k))])*dir1)
-#define PDonesided2(u,i,j,k) (p1ody*((u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j + dir2),(int)(k))] - (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k))])*dir2)
-#define PDonesided3(u,i,j,k) (p1odz*(-(u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k))] + (u)[CCTK_GFINDEX3D(cctkGH,(int)(i),(int)(j),(int)(k + dir3))])*dir3)
+#define PDstandardNth1(u,i,j,k) (p1o12dx*(-8*(u)[index+di*(-1)+dj*(0)+dk*(0)] + 8*(u)[index+di*(1)+dj*(0)+dk*(0)] + (u)[index+di*(-2)+dj*(0)+dk*(0)] - (u)[index+di*(2)+dj*(0)+dk*(0)]))
+#define PDstandardNth2(u,i,j,k) (p1o12dy*(-8*(u)[index+di*(0)+dj*(-1)+dk*(0)] + 8*(u)[index+di*(0)+dj*(1)+dk*(0)] + (u)[index+di*(0)+dj*(-2)+dk*(0)] - (u)[index+di*(0)+dj*(2)+dk*(0)]))
+#define PDstandardNth3(u,i,j,k) (p1o12dz*(-8*(u)[index+di*(0)+dj*(0)+dk*(-1)] + 8*(u)[index+di*(0)+dj*(0)+dk*(1)] + (u)[index+di*(0)+dj*(0)+dk*(-2)] - (u)[index+di*(0)+dj*(0)+dk*(2)]))
+#define PDstandardNth11(u,i,j,k) (pm1o12dx2*(30*(u)[index+di*(0)+dj*(0)+dk*(0)] - 16*((u)[index+di*(-1)+dj*(0)+dk*(0)] + (u)[index+di*(1)+dj*(0)+dk*(0)]) + (u)[index+di*(-2)+dj*(0)+dk*(0)] + (u)[index+di*(2)+dj*(0)+dk*(0)]))
+#define PDstandardNth22(u,i,j,k) (pm1o12dy2*(30*(u)[index+di*(0)+dj*(0)+dk*(0)] - 16*((u)[index+di*(0)+dj*(-1)+dk*(0)] + (u)[index+di*(0)+dj*(1)+dk*(0)]) + (u)[index+di*(0)+dj*(-2)+dk*(0)] + (u)[index+di*(0)+dj*(2)+dk*(0)]))
+#define PDstandardNth33(u,i,j,k) (pm1o12dz2*(30*(u)[index+di*(0)+dj*(0)+dk*(0)] - 16*((u)[index+di*(0)+dj*(0)+dk*(-1)] + (u)[index+di*(0)+dj*(0)+dk*(1)]) + (u)[index+di*(0)+dj*(0)+dk*(-2)] + (u)[index+di*(0)+dj*(0)+dk*(2)]))
+#define PDstandardNth12(u,i,j,k) (p1o144dxdy*(-64*((u)[index+di*(-1)+dj*(1)+dk*(0)] + (u)[index+di*(1)+dj*(-1)+dk*(0)]) + 64*((u)[index+di*(-1)+dj*(-1)+dk*(0)] + (u)[index+di*(1)+dj*(1)+dk*(0)]) + 8*((u)[index+di*(-1)+dj*(2)+dk*(0)] + (u)[index+di*(1)+dj*(-2)+dk*(0)] + (u)[index+di*(-2)+dj*(1)+dk*(0)] + (u)[index+di*(2)+dj*(-1)+dk*(0)]) - 8*((u)[index+di*(-1)+dj*(-2)+dk*(0)] + (u)[index+di*(1)+dj*(2)+dk*(0)] + (u)[index+di*(-2)+dj*(-1)+dk*(0)] + (u)[index+di*(2)+dj*(1)+dk*(0)]) + (u)[index+di*(-2)+dj*(-2)+dk*(0)] - (u)[index+di*(-2)+dj*(2)+dk*(0)] - (u)[index+di*(2)+dj*(-2)+dk*(0)] + (u)[index+di*(2)+dj*(2)+dk*(0)]))
+#define PDstandardNth13(u,i,j,k) (p1o144dxdz*(-64*((u)[index+di*(-1)+dj*(0)+dk*(1)] + (u)[index+di*(1)+dj*(0)+dk*(-1)]) + 64*((u)[index+di*(-1)+dj*(0)+dk*(-1)] + (u)[index+di*(1)+dj*(0)+dk*(1)]) + 8*((u)[index+di*(-1)+dj*(0)+dk*(2)] + (u)[index+di*(1)+dj*(0)+dk*(-2)] + (u)[index+di*(-2)+dj*(0)+dk*(1)] + (u)[index+di*(2)+dj*(0)+dk*(-1)]) - 8*((u)[index+di*(-1)+dj*(0)+dk*(-2)] + (u)[index+di*(1)+dj*(0)+dk*(2)] + (u)[index+di*(-2)+dj*(0)+dk*(-1)] + (u)[index+di*(2)+dj*(0)+dk*(1)]) + (u)[index+di*(-2)+dj*(0)+dk*(-2)] - (u)[index+di*(-2)+dj*(0)+dk*(2)] - (u)[index+di*(2)+dj*(0)+dk*(-2)] + (u)[index+di*(2)+dj*(0)+dk*(2)]))
+#define PDstandardNth21(u,i,j,k) (p1o144dxdy*(-64*((u)[index+di*(-1)+dj*(1)+dk*(0)] + (u)[index+di*(1)+dj*(-1)+dk*(0)]) + 64*((u)[index+di*(-1)+dj*(-1)+dk*(0)] + (u)[index+di*(1)+dj*(1)+dk*(0)]) + 8*((u)[index+di*(-1)+dj*(2)+dk*(0)] + (u)[index+di*(1)+dj*(-2)+dk*(0)] + (u)[index+di*(-2)+dj*(1)+dk*(0)] + (u)[index+di*(2)+dj*(-1)+dk*(0)]) - 8*((u)[index+di*(-1)+dj*(-2)+dk*(0)] + (u)[index+di*(1)+dj*(2)+dk*(0)] + (u)[index+di*(-2)+dj*(-1)+dk*(0)] + (u)[index+di*(2)+dj*(1)+dk*(0)]) + (u)[index+di*(-2)+dj*(-2)+dk*(0)] - (u)[index+di*(-2)+dj*(2)+dk*(0)] - (u)[index+di*(2)+dj*(-2)+dk*(0)] + (u)[index+di*(2)+dj*(2)+dk*(0)]))
+#define PDstandardNth23(u,i,j,k) (p1o144dydz*(-64*((u)[index+di*(0)+dj*(-1)+dk*(1)] + (u)[index+di*(0)+dj*(1)+dk*(-1)]) + 64*((u)[index+di*(0)+dj*(-1)+dk*(-1)] + (u)[index+di*(0)+dj*(1)+dk*(1)]) + 8*((u)[index+di*(0)+dj*(-1)+dk*(2)] + (u)[index+di*(0)+dj*(1)+dk*(-2)] + (u)[index+di*(0)+dj*(-2)+dk*(1)] + (u)[index+di*(0)+dj*(2)+dk*(-1)]) - 8*((u)[index+di*(0)+dj*(-1)+dk*(-2)] + (u)[index+di*(0)+dj*(1)+dk*(2)] + (u)[index+di*(0)+dj*(-2)+dk*(-1)] + (u)[index+di*(0)+dj*(2)+dk*(1)]) + (u)[index+di*(0)+dj*(-2)+dk*(-2)] - (u)[index+di*(0)+dj*(-2)+dk*(2)] - (u)[index+di*(0)+dj*(2)+dk*(-2)] + (u)[index+di*(0)+dj*(2)+dk*(2)]))
+#define PDstandardNth31(u,i,j,k) (p1o144dxdz*(-64*((u)[index+di*(-1)+dj*(0)+dk*(1)] + (u)[index+di*(1)+dj*(0)+dk*(-1)]) + 64*((u)[index+di*(-1)+dj*(0)+dk*(-1)] + (u)[index+di*(1)+dj*(0)+dk*(1)]) + 8*((u)[index+di*(-1)+dj*(0)+dk*(2)] + (u)[index+di*(1)+dj*(0)+dk*(-2)] + (u)[index+di*(-2)+dj*(0)+dk*(1)] + (u)[index+di*(2)+dj*(0)+dk*(-1)]) - 8*((u)[index+di*(-1)+dj*(0)+dk*(-2)] + (u)[index+di*(1)+dj*(0)+dk*(2)] + (u)[index+di*(-2)+dj*(0)+dk*(-1)] + (u)[index+di*(2)+dj*(0)+dk*(1)]) + (u)[index+di*(-2)+dj*(0)+dk*(-2)] - (u)[index+di*(-2)+dj*(0)+dk*(2)] - (u)[index+di*(2)+dj*(0)+dk*(-2)] + (u)[index+di*(2)+dj*(0)+dk*(2)]))
+#define PDstandardNth32(u,i,j,k) (p1o144dydz*(-64*((u)[index+di*(0)+dj*(-1)+dk*(1)] + (u)[index+di*(0)+dj*(1)+dk*(-1)]) + 64*((u)[index+di*(0)+dj*(-1)+dk*(-1)] + (u)[index+di*(0)+dj*(1)+dk*(1)]) + 8*((u)[index+di*(0)+dj*(-1)+dk*(2)] + (u)[index+di*(0)+dj*(1)+dk*(-2)] + (u)[index+di*(0)+dj*(-2)+dk*(1)] + (u)[index+di*(0)+dj*(2)+dk*(-1)]) - 8*((u)[index+di*(0)+dj*(-1)+dk*(-2)] + (u)[index+di*(0)+dj*(1)+dk*(2)] + (u)[index+di*(0)+dj*(-2)+dk*(-1)] + (u)[index+di*(0)+dj*(2)+dk*(1)]) + (u)[index+di*(0)+dj*(-2)+dk*(-2)] - (u)[index+di*(0)+dj*(-2)+dk*(2)] - (u)[index+di*(0)+dj*(2)+dk*(-2)] + (u)[index+di*(0)+dj*(2)+dk*(2)]))
+#define PDupwindNth1(u,i,j,k) (p1o12dx*(-10*(u)[index+di*(0)+dj*(0)+dk*(0)] - 6*(u)[index+di*(2*dir1)+dj*(0)+dk*(0)] + (u)[index+di*(3*dir1)+dj*(0)+dk*(0)] - 3*(u)[index+di*(-dir1)+dj*(0)+dk*(0)] + 18*(u)[index+di*(dir1)+dj*(0)+dk*(0)])*dir1)
+#define PDupwindNth2(u,i,j,k) (p1o12dy*(-10*(u)[index+di*(0)+dj*(0)+dk*(0)] - 6*(u)[index+di*(0)+dj*(2*dir2)+dk*(0)] + (u)[index+di*(0)+dj*(3*dir2)+dk*(0)] - 3*(u)[index+di*(0)+dj*(-dir2)+dk*(0)] + 18*(u)[index+di*(0)+dj*(dir2)+dk*(0)])*dir2)
+#define PDupwindNth3(u,i,j,k) (p1o12dz*(-10*(u)[index+di*(0)+dj*(0)+dk*(0)] - 6*(u)[index+di*(0)+dj*(0)+dk*(2*dir3)] + (u)[index+di*(0)+dj*(0)+dk*(3*dir3)] - 3*(u)[index+di*(0)+dj*(0)+dk*(-dir3)] + 18*(u)[index+di*(0)+dj*(0)+dk*(dir3)])*dir3)
+#define PDonesided1(u,i,j,k) (p1odx*(-(u)[index+di*(0)+dj*(0)+dk*(0)] + (u)[index+di*(dir1)+dj*(0)+dk*(0)])*dir1)
+#define PDonesided2(u,i,j,k) (p1ody*(-(u)[index+di*(0)+dj*(0)+dk*(0)] + (u)[index+di*(0)+dj*(dir2)+dk*(0)])*dir2)
+#define PDonesided3(u,i,j,k) (p1odz*(-(u)[index+di*(0)+dj*(0)+dk*(0)] + (u)[index+di*(0)+dj*(0)+dk*(dir3)])*dir3)
diff --git a/ML_BSSN/src/ML_BSSN_Minkowski.c b/ML_BSSN/src/ML_BSSN_Minkowski.c
index 759310a..c467955 100644
--- a/ML_BSSN/src/ML_BSSN_Minkowski.c
+++ b/ML_BSSN/src/ML_BSSN_Minkowski.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_Minkowski_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_Minkowski_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_Minkowski_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_I
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,24 +93,24 @@ void ML_BSSN_Minkowski_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_I
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
/* Declare local copies of grid functions */
- CCTK_REAL AL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE;
- CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
- CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
- CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
- CCTK_REAL etaL = INITVALUE;
- CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
- CCTK_REAL phiL = INITVALUE;
- CCTK_REAL trKL = INITVALUE;
- CCTK_REAL Xt1L = INITVALUE, Xt2L = INITVALUE, Xt3L = INITVALUE;
+ // CCTK_REAL AL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
+ // CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
+ // CCTK_REAL etaL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
+ // CCTK_REAL phiL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE;
+ // CCTK_REAL Xt1L = INITVALUE, Xt2L = INITVALUE, Xt3L = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
@@ -128,57 +126,57 @@ void ML_BSSN_Minkowski_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_I
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- phiL = IfThen(conformalMethod,1,0);
+ CCTK_REAL const phiL = IfThen(conformalMethod,1,0);
- gt11L = 1;
+ CCTK_REAL const gt11L = 1;
- gt12L = 0;
+ CCTK_REAL const gt12L = 0;
- gt13L = 0;
+ CCTK_REAL const gt13L = 0;
- gt22L = 1;
+ CCTK_REAL const gt22L = 1;
- gt23L = 0;
+ CCTK_REAL const gt23L = 0;
- gt33L = 1;
+ CCTK_REAL const gt33L = 1;
- trKL = 0;
+ CCTK_REAL const trKL = 0;
- At11L = 0;
+ CCTK_REAL const At11L = 0;
- At12L = 0;
+ CCTK_REAL const At12L = 0;
- At13L = 0;
+ CCTK_REAL const At13L = 0;
- At22L = 0;
+ CCTK_REAL const At22L = 0;
- At23L = 0;
+ CCTK_REAL const At23L = 0;
- At33L = 0;
+ CCTK_REAL const At33L = 0;
- Xt1L = 0;
+ CCTK_REAL const Xt1L = 0;
- Xt2L = 0;
+ CCTK_REAL const Xt2L = 0;
- Xt3L = 0;
+ CCTK_REAL const Xt3L = 0;
- alphaL = 1;
+ CCTK_REAL const alphaL = 1;
- AL = 0;
+ CCTK_REAL const AL = 0;
- beta1L = 0;
+ CCTK_REAL const beta1L = 0;
- beta2L = 0;
+ CCTK_REAL const beta2L = 0;
- beta3L = 0;
+ CCTK_REAL const beta3L = 0;
- B1L = 0;
+ CCTK_REAL const B1L = 0;
- B2L = 0;
+ CCTK_REAL const B2L = 0;
- B3L = 0;
+ CCTK_REAL const B3L = 0;
- etaL = BetaDriver;
+ CCTK_REAL const etaL = BetaDriver;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_RHS.c b/ML_BSSN/src/ML_BSSN_RHS.c
index 905b469..f207bcc 100644
--- a/ML_BSSN/src/ML_BSSN_RHS.c
+++ b/ML_BSSN/src/ML_BSSN_RHS.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_RHS_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,408 +93,429 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
- CCTK_REAL Atm11 = INITVALUE, Atm12 = INITVALUE, Atm13 = INITVALUE, Atm21 = INITVALUE, Atm22 = INITVALUE, Atm23 = INITVALUE;
- CCTK_REAL Atm31 = INITVALUE, Atm32 = INITVALUE, Atm33 = INITVALUE;
- CCTK_REAL Ats11 = INITVALUE, Ats12 = INITVALUE, Ats13 = INITVALUE, Ats22 = INITVALUE, Ats23 = INITVALUE, Ats33 = INITVALUE;
- CCTK_REAL Atu11 = INITVALUE, Atu21 = INITVALUE, Atu22 = INITVALUE, Atu31 = INITVALUE, Atu32 = INITVALUE, Atu33 = INITVALUE;
- CCTK_REAL cdphi1 = INITVALUE, cdphi2 = INITVALUE, cdphi211 = INITVALUE, cdphi212 = INITVALUE, cdphi213 = INITVALUE, cdphi222 = INITVALUE;
- CCTK_REAL cdphi223 = INITVALUE, cdphi233 = INITVALUE, cdphi3 = INITVALUE;
- CCTK_REAL detgt = INITVALUE;
- CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
- CCTK_REAL e4phi = INITVALUE;
- CCTK_REAL em4phi = INITVALUE;
- CCTK_REAL fac1 = INITVALUE, fac2 = INITVALUE;
- CCTK_REAL g11 = INITVALUE;
- CCTK_REAL G111 = INITVALUE, G112 = INITVALUE, G113 = INITVALUE;
- CCTK_REAL g12 = INITVALUE;
- CCTK_REAL G122 = INITVALUE, G123 = INITVALUE;
- CCTK_REAL g13 = INITVALUE;
- CCTK_REAL G133 = INITVALUE, G211 = INITVALUE, G212 = INITVALUE, G213 = INITVALUE;
- CCTK_REAL g22 = INITVALUE;
- CCTK_REAL G222 = INITVALUE, G223 = INITVALUE;
- CCTK_REAL g23 = INITVALUE;
- CCTK_REAL G233 = INITVALUE, G311 = INITVALUE, G312 = INITVALUE, G313 = INITVALUE, G322 = INITVALUE, G323 = INITVALUE;
- CCTK_REAL g33 = INITVALUE;
- CCTK_REAL G333 = INITVALUE;
- CCTK_REAL Gt111 = INITVALUE, Gt112 = INITVALUE, Gt113 = INITVALUE, Gt122 = INITVALUE, Gt123 = INITVALUE, Gt133 = INITVALUE;
- CCTK_REAL Gt211 = INITVALUE, Gt212 = INITVALUE, Gt213 = INITVALUE, Gt222 = INITVALUE, Gt223 = INITVALUE, Gt233 = INITVALUE;
- CCTK_REAL Gt311 = INITVALUE, Gt312 = INITVALUE, Gt313 = INITVALUE, Gt322 = INITVALUE, Gt323 = INITVALUE, Gt333 = INITVALUE;
- CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
- CCTK_REAL gu11 = INITVALUE, gu21 = INITVALUE, gu22 = INITVALUE, gu31 = INITVALUE, gu32 = INITVALUE, gu33 = INITVALUE;
- CCTK_REAL R11 = INITVALUE, R12 = INITVALUE, R13 = INITVALUE, R22 = INITVALUE, R23 = INITVALUE, R33 = INITVALUE;
- CCTK_REAL Rphi11 = INITVALUE, Rphi12 = INITVALUE, Rphi13 = INITVALUE, Rphi22 = INITVALUE, Rphi23 = INITVALUE, Rphi33 = INITVALUE;
- CCTK_REAL Rt11 = INITVALUE, Rt12 = INITVALUE, Rt13 = INITVALUE, Rt22 = INITVALUE, Rt23 = INITVALUE, Rt33 = INITVALUE;
- CCTK_REAL trAts = INITVALUE;
- CCTK_REAL Xtn1 = INITVALUE, Xtn2 = INITVALUE, Xtn3 = INITVALUE;
+ // CCTK_REAL Atm11 = INITVALUE, Atm12 = INITVALUE, Atm13 = INITVALUE, Atm21 = INITVALUE, Atm22 = INITVALUE, Atm23 = INITVALUE;
+ // CCTK_REAL Atm31 = INITVALUE, Atm32 = INITVALUE, Atm33 = INITVALUE;
+ // CCTK_REAL Ats11 = INITVALUE, Ats12 = INITVALUE, Ats13 = INITVALUE, Ats22 = INITVALUE, Ats23 = INITVALUE, Ats33 = INITVALUE;
+ // CCTK_REAL Atu11 = INITVALUE, Atu21 = INITVALUE, Atu22 = INITVALUE, Atu31 = INITVALUE, Atu32 = INITVALUE, Atu33 = INITVALUE;
+ // CCTK_REAL cdphi1 = INITVALUE, cdphi2 = INITVALUE, cdphi211 = INITVALUE, cdphi212 = INITVALUE, cdphi213 = INITVALUE, cdphi222 = INITVALUE;
+ // CCTK_REAL cdphi223 = INITVALUE, cdphi233 = INITVALUE, cdphi3 = INITVALUE;
+ // CCTK_REAL detgt = INITVALUE;
+ // CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
+ // CCTK_REAL e4phi = INITVALUE;
+ // CCTK_REAL em4phi = INITVALUE;
+ // CCTK_REAL fac1 = INITVALUE, fac2 = INITVALUE;
+ // CCTK_REAL g11 = INITVALUE;
+ // CCTK_REAL G111 = INITVALUE, G112 = INITVALUE, G113 = INITVALUE;
+ // CCTK_REAL g12 = INITVALUE;
+ // CCTK_REAL G122 = INITVALUE, G123 = INITVALUE;
+ // CCTK_REAL g13 = INITVALUE;
+ // CCTK_REAL G133 = INITVALUE, G211 = INITVALUE, G212 = INITVALUE, G213 = INITVALUE;
+ // CCTK_REAL g22 = INITVALUE;
+ // CCTK_REAL G222 = INITVALUE, G223 = INITVALUE;
+ // CCTK_REAL g23 = INITVALUE;
+ // CCTK_REAL G233 = INITVALUE, G311 = INITVALUE, G312 = INITVALUE, G313 = INITVALUE, G322 = INITVALUE, G323 = INITVALUE;
+ // CCTK_REAL g33 = INITVALUE;
+ // CCTK_REAL G333 = INITVALUE;
+ // CCTK_REAL Gt111 = INITVALUE, Gt112 = INITVALUE, Gt113 = INITVALUE, Gt122 = INITVALUE, Gt123 = INITVALUE, Gt133 = INITVALUE;
+ // CCTK_REAL Gt211 = INITVALUE, Gt212 = INITVALUE, Gt213 = INITVALUE, Gt222 = INITVALUE, Gt223 = INITVALUE, Gt233 = INITVALUE;
+ // CCTK_REAL Gt311 = INITVALUE, Gt312 = INITVALUE, Gt313 = INITVALUE, Gt322 = INITVALUE, Gt323 = INITVALUE, Gt333 = INITVALUE;
+ // CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
+ // CCTK_REAL gu11 = INITVALUE, gu21 = INITVALUE, gu22 = INITVALUE, gu31 = INITVALUE, gu32 = INITVALUE, gu33 = INITVALUE;
+ // CCTK_REAL R11 = INITVALUE, R12 = INITVALUE, R13 = INITVALUE, R22 = INITVALUE, R23 = INITVALUE, R33 = INITVALUE;
+ // CCTK_REAL rho = INITVALUE;
+ // CCTK_REAL Rphi11 = INITVALUE, Rphi12 = INITVALUE, Rphi13 = INITVALUE, Rphi22 = INITVALUE, Rphi23 = INITVALUE, Rphi33 = INITVALUE;
+ // CCTK_REAL Rt11 = INITVALUE, Rt12 = INITVALUE, Rt13 = INITVALUE, Rt22 = INITVALUE, Rt23 = INITVALUE, Rt33 = INITVALUE;
+ // CCTK_REAL S1 = INITVALUE, S2 = INITVALUE, S3 = INITVALUE;
+ // CCTK_REAL T00 = INITVALUE, T01 = INITVALUE, T02 = INITVALUE, T03 = INITVALUE, T11 = INITVALUE, T12 = INITVALUE;
+ // CCTK_REAL T13 = INITVALUE, T22 = INITVALUE, T23 = INITVALUE, T33 = INITVALUE;
+ // CCTK_REAL trAts = INITVALUE;
+ // CCTK_REAL trS = INITVALUE;
+ // CCTK_REAL Xtn1 = INITVALUE, Xtn2 = INITVALUE, Xtn3 = INITVALUE;
/* Declare local copies of grid functions */
- CCTK_REAL AL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE, alpharhsL = INITVALUE;
- CCTK_REAL ArhsL = INITVALUE;
- CCTK_REAL At11L = INITVALUE, At11rhsL = INITVALUE, At12L = INITVALUE, At12rhsL = INITVALUE, At13L = INITVALUE, At13rhsL = INITVALUE;
- CCTK_REAL At22L = INITVALUE, At22rhsL = INITVALUE, At23L = INITVALUE, At23rhsL = INITVALUE, At33L = INITVALUE, At33rhsL = INITVALUE;
- CCTK_REAL B1L = INITVALUE, B1rhsL = INITVALUE, B2L = INITVALUE, B2rhsL = INITVALUE, B3L = INITVALUE, B3rhsL = INITVALUE;
- CCTK_REAL beta1L = INITVALUE, beta1rhsL = INITVALUE, beta2L = INITVALUE, beta2rhsL = INITVALUE, beta3L = INITVALUE, beta3rhsL = INITVALUE;
- CCTK_REAL etaL = INITVALUE;
- CCTK_REAL gt11L = INITVALUE, gt11rhsL = INITVALUE, gt12L = INITVALUE, gt12rhsL = INITVALUE, gt13L = INITVALUE, gt13rhsL = INITVALUE;
- CCTK_REAL gt22L = INITVALUE, gt22rhsL = INITVALUE, gt23L = INITVALUE, gt23rhsL = INITVALUE, gt33L = INITVALUE, gt33rhsL = INITVALUE;
- CCTK_REAL phiL = INITVALUE, phirhsL = INITVALUE;
- CCTK_REAL trKL = INITVALUE, trKrhsL = INITVALUE;
- CCTK_REAL Xt1L = INITVALUE, Xt1rhsL = INITVALUE, Xt2L = INITVALUE, Xt2rhsL = INITVALUE, Xt3L = INITVALUE, Xt3rhsL = INITVALUE;
+ // CCTK_REAL AL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE, alpharhsL = INITVALUE;
+ // CCTK_REAL ArhsL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At11rhsL = INITVALUE, At12L = INITVALUE, At12rhsL = INITVALUE, At13L = INITVALUE, At13rhsL = INITVALUE;
+ // CCTK_REAL At22L = INITVALUE, At22rhsL = INITVALUE, At23L = INITVALUE, At23rhsL = INITVALUE, At33L = INITVALUE, At33rhsL = INITVALUE;
+ // CCTK_REAL B1L = INITVALUE, B1rhsL = INITVALUE, B2L = INITVALUE, B2rhsL = INITVALUE, B3L = INITVALUE, B3rhsL = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta1rhsL = INITVALUE, beta2L = INITVALUE, beta2rhsL = INITVALUE, beta3L = INITVALUE, beta3rhsL = INITVALUE;
+ // CCTK_REAL etaL = INITVALUE;
+ // CCTK_REAL eTttL = INITVALUE;
+ // CCTK_REAL eTtxL = INITVALUE;
+ // CCTK_REAL eTtyL = INITVALUE;
+ // CCTK_REAL eTtzL = INITVALUE;
+ // CCTK_REAL eTxxL = INITVALUE;
+ // CCTK_REAL eTxyL = INITVALUE;
+ // CCTK_REAL eTxzL = INITVALUE;
+ // CCTK_REAL eTyyL = INITVALUE;
+ // CCTK_REAL eTyzL = INITVALUE;
+ // CCTK_REAL eTzzL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt11rhsL = INITVALUE, gt12L = INITVALUE, gt12rhsL = INITVALUE, gt13L = INITVALUE, gt13rhsL = INITVALUE;
+ // CCTK_REAL gt22L = INITVALUE, gt22rhsL = INITVALUE, gt23L = INITVALUE, gt23rhsL = INITVALUE, gt33L = INITVALUE, gt33rhsL = INITVALUE;
+ // CCTK_REAL phiL = INITVALUE, phirhsL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE, trKrhsL = INITVALUE;
+ // CCTK_REAL Xt1L = INITVALUE, Xt1rhsL = INITVALUE, Xt2L = INITVALUE, Xt2rhsL = INITVALUE, Xt3L = INITVALUE, Xt3rhsL = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
- CCTK_REAL PDstandardNth1alpha = INITVALUE;
- CCTK_REAL PDstandardNth2alpha = INITVALUE;
- CCTK_REAL PDstandardNth3alpha = INITVALUE;
- CCTK_REAL PDstandardNth11alpha = INITVALUE;
- CCTK_REAL PDstandardNth22alpha = INITVALUE;
- CCTK_REAL PDstandardNth33alpha = INITVALUE;
- CCTK_REAL PDstandardNth12alpha = INITVALUE;
- CCTK_REAL PDstandardNth13alpha = INITVALUE;
- CCTK_REAL PDstandardNth23alpha = INITVALUE;
- CCTK_REAL PDstandardNth1beta1 = INITVALUE;
- CCTK_REAL PDstandardNth2beta1 = INITVALUE;
- CCTK_REAL PDstandardNth3beta1 = INITVALUE;
- CCTK_REAL PDstandardNth11beta1 = INITVALUE;
- CCTK_REAL PDstandardNth22beta1 = INITVALUE;
- CCTK_REAL PDstandardNth33beta1 = INITVALUE;
- CCTK_REAL PDstandardNth12beta1 = INITVALUE;
- CCTK_REAL PDstandardNth13beta1 = INITVALUE;
- CCTK_REAL PDstandardNth23beta1 = INITVALUE;
- CCTK_REAL PDstandardNth1beta2 = INITVALUE;
- CCTK_REAL PDstandardNth2beta2 = INITVALUE;
- CCTK_REAL PDstandardNth3beta2 = INITVALUE;
- CCTK_REAL PDstandardNth11beta2 = INITVALUE;
- CCTK_REAL PDstandardNth22beta2 = INITVALUE;
- CCTK_REAL PDstandardNth33beta2 = INITVALUE;
- CCTK_REAL PDstandardNth12beta2 = INITVALUE;
- CCTK_REAL PDstandardNth13beta2 = INITVALUE;
- CCTK_REAL PDstandardNth23beta2 = INITVALUE;
- CCTK_REAL PDstandardNth1beta3 = INITVALUE;
- CCTK_REAL PDstandardNth2beta3 = INITVALUE;
- CCTK_REAL PDstandardNth3beta3 = INITVALUE;
- CCTK_REAL PDstandardNth11beta3 = INITVALUE;
- CCTK_REAL PDstandardNth22beta3 = INITVALUE;
- CCTK_REAL PDstandardNth33beta3 = INITVALUE;
- CCTK_REAL PDstandardNth12beta3 = INITVALUE;
- CCTK_REAL PDstandardNth13beta3 = INITVALUE;
- CCTK_REAL PDstandardNth23beta3 = INITVALUE;
- CCTK_REAL PDstandardNth1gt11 = INITVALUE;
- CCTK_REAL PDstandardNth2gt11 = INITVALUE;
- CCTK_REAL PDstandardNth3gt11 = INITVALUE;
- CCTK_REAL PDstandardNth11gt11 = INITVALUE;
- CCTK_REAL PDstandardNth22gt11 = INITVALUE;
- CCTK_REAL PDstandardNth33gt11 = INITVALUE;
- CCTK_REAL PDstandardNth12gt11 = INITVALUE;
- CCTK_REAL PDstandardNth13gt11 = INITVALUE;
- CCTK_REAL PDstandardNth23gt11 = INITVALUE;
- CCTK_REAL PDstandardNth1gt12 = INITVALUE;
- CCTK_REAL PDstandardNth2gt12 = INITVALUE;
- CCTK_REAL PDstandardNth3gt12 = INITVALUE;
- CCTK_REAL PDstandardNth11gt12 = INITVALUE;
- CCTK_REAL PDstandardNth22gt12 = INITVALUE;
- CCTK_REAL PDstandardNth33gt12 = INITVALUE;
- CCTK_REAL PDstandardNth12gt12 = INITVALUE;
- CCTK_REAL PDstandardNth13gt12 = INITVALUE;
- CCTK_REAL PDstandardNth23gt12 = INITVALUE;
- CCTK_REAL PDstandardNth1gt13 = INITVALUE;
- CCTK_REAL PDstandardNth2gt13 = INITVALUE;
- CCTK_REAL PDstandardNth3gt13 = INITVALUE;
- CCTK_REAL PDstandardNth11gt13 = INITVALUE;
- CCTK_REAL PDstandardNth22gt13 = INITVALUE;
- CCTK_REAL PDstandardNth33gt13 = INITVALUE;
- CCTK_REAL PDstandardNth12gt13 = INITVALUE;
- CCTK_REAL PDstandardNth13gt13 = INITVALUE;
- CCTK_REAL PDstandardNth23gt13 = INITVALUE;
- CCTK_REAL PDstandardNth1gt22 = INITVALUE;
- CCTK_REAL PDstandardNth2gt22 = INITVALUE;
- CCTK_REAL PDstandardNth3gt22 = INITVALUE;
- CCTK_REAL PDstandardNth11gt22 = INITVALUE;
- CCTK_REAL PDstandardNth22gt22 = INITVALUE;
- CCTK_REAL PDstandardNth33gt22 = INITVALUE;
- CCTK_REAL PDstandardNth12gt22 = INITVALUE;
- CCTK_REAL PDstandardNth13gt22 = INITVALUE;
- CCTK_REAL PDstandardNth23gt22 = INITVALUE;
- CCTK_REAL PDstandardNth1gt23 = INITVALUE;
- CCTK_REAL PDstandardNth2gt23 = INITVALUE;
- CCTK_REAL PDstandardNth3gt23 = INITVALUE;
- CCTK_REAL PDstandardNth11gt23 = INITVALUE;
- CCTK_REAL PDstandardNth22gt23 = INITVALUE;
- CCTK_REAL PDstandardNth33gt23 = INITVALUE;
- CCTK_REAL PDstandardNth12gt23 = INITVALUE;
- CCTK_REAL PDstandardNth13gt23 = INITVALUE;
- CCTK_REAL PDstandardNth23gt23 = INITVALUE;
- CCTK_REAL PDstandardNth1gt33 = INITVALUE;
- CCTK_REAL PDstandardNth2gt33 = INITVALUE;
- CCTK_REAL PDstandardNth3gt33 = INITVALUE;
- CCTK_REAL PDstandardNth11gt33 = INITVALUE;
- CCTK_REAL PDstandardNth22gt33 = INITVALUE;
- CCTK_REAL PDstandardNth33gt33 = INITVALUE;
- CCTK_REAL PDstandardNth12gt33 = INITVALUE;
- CCTK_REAL PDstandardNth13gt33 = INITVALUE;
- CCTK_REAL PDstandardNth23gt33 = INITVALUE;
- CCTK_REAL PDstandardNth1phi = INITVALUE;
- CCTK_REAL PDstandardNth2phi = INITVALUE;
- CCTK_REAL PDstandardNth3phi = INITVALUE;
- CCTK_REAL PDstandardNth11phi = INITVALUE;
- CCTK_REAL PDstandardNth22phi = INITVALUE;
- CCTK_REAL PDstandardNth33phi = INITVALUE;
- CCTK_REAL PDstandardNth12phi = INITVALUE;
- CCTK_REAL PDstandardNth13phi = INITVALUE;
- CCTK_REAL PDstandardNth23phi = INITVALUE;
- CCTK_REAL PDstandardNth1trK = INITVALUE;
- CCTK_REAL PDstandardNth2trK = INITVALUE;
- CCTK_REAL PDstandardNth3trK = INITVALUE;
- CCTK_REAL PDstandardNth1Xt1 = INITVALUE;
- CCTK_REAL PDstandardNth2Xt1 = INITVALUE;
- CCTK_REAL PDstandardNth3Xt1 = INITVALUE;
- CCTK_REAL PDstandardNth1Xt2 = INITVALUE;
- CCTK_REAL PDstandardNth2Xt2 = INITVALUE;
- CCTK_REAL PDstandardNth3Xt2 = INITVALUE;
- CCTK_REAL PDstandardNth1Xt3 = INITVALUE;
- CCTK_REAL PDstandardNth2Xt3 = INITVALUE;
- CCTK_REAL PDstandardNth3Xt3 = INITVALUE;
+ // CCTK_REAL PDstandardNth1alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth2alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth3alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth11alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth22alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth33alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth12alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth13alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth23alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth1beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth2beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth3beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth11beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth22beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth33beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth12beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth13beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth23beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth1beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth2beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth3beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth11beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth22beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth33beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth12beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth13beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth23beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth1beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth2beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth3beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth11beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth22beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth33beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth12beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth13beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth23beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth1phi = INITVALUE;
+ // CCTK_REAL PDstandardNth2phi = INITVALUE;
+ // CCTK_REAL PDstandardNth3phi = INITVALUE;
+ // CCTK_REAL PDstandardNth11phi = INITVALUE;
+ // CCTK_REAL PDstandardNth22phi = INITVALUE;
+ // CCTK_REAL PDstandardNth33phi = INITVALUE;
+ // CCTK_REAL PDstandardNth12phi = INITVALUE;
+ // CCTK_REAL PDstandardNth13phi = INITVALUE;
+ // CCTK_REAL PDstandardNth23phi = INITVALUE;
+ // CCTK_REAL PDstandardNth1trK = INITVALUE;
+ // CCTK_REAL PDstandardNth2trK = INITVALUE;
+ // CCTK_REAL PDstandardNth3trK = INITVALUE;
+ // CCTK_REAL PDstandardNth1Xt1 = INITVALUE;
+ // CCTK_REAL PDstandardNth2Xt1 = INITVALUE;
+ // CCTK_REAL PDstandardNth3Xt1 = INITVALUE;
+ // CCTK_REAL PDstandardNth1Xt2 = INITVALUE;
+ // CCTK_REAL PDstandardNth2Xt2 = INITVALUE;
+ // CCTK_REAL PDstandardNth3Xt2 = INITVALUE;
+ // CCTK_REAL PDstandardNth1Xt3 = INITVALUE;
+ // CCTK_REAL PDstandardNth2Xt3 = INITVALUE;
+ // CCTK_REAL PDstandardNth3Xt3 = INITVALUE;
/* Assign local copies of grid functions */
- AL = A[index];
- alphaL = alpha[index];
- At11L = At11[index];
- At12L = At12[index];
- At13L = At13[index];
- At22L = At22[index];
- At23L = At23[index];
- At33L = At33[index];
- B1L = B1[index];
- B2L = B2[index];
- B3L = B3[index];
- beta1L = beta1[index];
- beta2L = beta2[index];
- beta3L = beta3[index];
- etaL = eta[index];
- gt11L = gt11[index];
- gt12L = gt12[index];
- gt13L = gt13[index];
- gt22L = gt22[index];
- gt23L = gt23[index];
- gt33L = gt33[index];
- phiL = phi[index];
- trKL = trK[index];
- trKrhsL = trKrhs[index];
- Xt1L = Xt1[index];
- Xt1rhsL = Xt1rhs[index];
- Xt2L = Xt2[index];
- Xt2rhsL = Xt2rhs[index];
- Xt3L = Xt3[index];
- Xt3rhsL = Xt3rhs[index];
+ CCTK_REAL const AL = A[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const At11L = At11[index];
+ CCTK_REAL const At12L = At12[index];
+ CCTK_REAL const At13L = At13[index];
+ CCTK_REAL const At22L = At22[index];
+ CCTK_REAL const At23L = At23[index];
+ CCTK_REAL const At33L = At33[index];
+ CCTK_REAL const B1L = B1[index];
+ CCTK_REAL const B2L = B2[index];
+ CCTK_REAL const B3L = B3[index];
+ CCTK_REAL const beta1L = beta1[index];
+ CCTK_REAL const beta2L = beta2[index];
+ CCTK_REAL const beta3L = beta3[index];
+ CCTK_REAL const etaL = eta[index];
+ CCTK_REAL const eTttL = (stress_energy_state) ? (eTtt[index]) : 0.0;
+ CCTK_REAL const eTtxL = (stress_energy_state) ? (eTtx[index]) : 0.0;
+ CCTK_REAL const eTtyL = (stress_energy_state) ? (eTty[index]) : 0.0;
+ CCTK_REAL const eTtzL = (stress_energy_state) ? (eTtz[index]) : 0.0;
+ CCTK_REAL const eTxxL = (stress_energy_state) ? (eTxx[index]) : 0.0;
+ CCTK_REAL const eTxyL = (stress_energy_state) ? (eTxy[index]) : 0.0;
+ CCTK_REAL const eTxzL = (stress_energy_state) ? (eTxz[index]) : 0.0;
+ CCTK_REAL const eTyyL = (stress_energy_state) ? (eTyy[index]) : 0.0;
+ CCTK_REAL const eTyzL = (stress_energy_state) ? (eTyz[index]) : 0.0;
+ CCTK_REAL const eTzzL = (stress_energy_state) ? (eTzz[index]) : 0.0;
+ CCTK_REAL const gt11L = gt11[index];
+ CCTK_REAL const gt12L = gt12[index];
+ CCTK_REAL const gt13L = gt13[index];
+ CCTK_REAL const gt22L = gt22[index];
+ CCTK_REAL const gt23L = gt23[index];
+ CCTK_REAL const gt33L = gt33[index];
+ CCTK_REAL const phiL = phi[index];
+ CCTK_REAL const trKL = trK[index];
+ CCTK_REAL const Xt1L = Xt1[index];
+ CCTK_REAL const Xt2L = Xt2[index];
+ CCTK_REAL const Xt3L = Xt3[index];
/* Assign local copies of subblock grid functions */
/* Include user supplied include files */
/* Precompute derivatives (new style) */
- PDstandardNth1alpha = PDstandardNth1(alpha, i, j, k);
- PDstandardNth2alpha = PDstandardNth2(alpha, i, j, k);
- PDstandardNth3alpha = PDstandardNth3(alpha, i, j, k);
- PDstandardNth11alpha = PDstandardNth11(alpha, i, j, k);
- PDstandardNth22alpha = PDstandardNth22(alpha, i, j, k);
- PDstandardNth33alpha = PDstandardNth33(alpha, i, j, k);
- PDstandardNth12alpha = PDstandardNth12(alpha, i, j, k);
- PDstandardNth13alpha = PDstandardNth13(alpha, i, j, k);
- PDstandardNth23alpha = PDstandardNth23(alpha, i, j, k);
- PDstandardNth1beta1 = PDstandardNth1(beta1, i, j, k);
- PDstandardNth2beta1 = PDstandardNth2(beta1, i, j, k);
- PDstandardNth3beta1 = PDstandardNth3(beta1, i, j, k);
- PDstandardNth11beta1 = PDstandardNth11(beta1, i, j, k);
- PDstandardNth22beta1 = PDstandardNth22(beta1, i, j, k);
- PDstandardNth33beta1 = PDstandardNth33(beta1, i, j, k);
- PDstandardNth12beta1 = PDstandardNth12(beta1, i, j, k);
- PDstandardNth13beta1 = PDstandardNth13(beta1, i, j, k);
- PDstandardNth23beta1 = PDstandardNth23(beta1, i, j, k);
- PDstandardNth1beta2 = PDstandardNth1(beta2, i, j, k);
- PDstandardNth2beta2 = PDstandardNth2(beta2, i, j, k);
- PDstandardNth3beta2 = PDstandardNth3(beta2, i, j, k);
- PDstandardNth11beta2 = PDstandardNth11(beta2, i, j, k);
- PDstandardNth22beta2 = PDstandardNth22(beta2, i, j, k);
- PDstandardNth33beta2 = PDstandardNth33(beta2, i, j, k);
- PDstandardNth12beta2 = PDstandardNth12(beta2, i, j, k);
- PDstandardNth13beta2 = PDstandardNth13(beta2, i, j, k);
- PDstandardNth23beta2 = PDstandardNth23(beta2, i, j, k);
- PDstandardNth1beta3 = PDstandardNth1(beta3, i, j, k);
- PDstandardNth2beta3 = PDstandardNth2(beta3, i, j, k);
- PDstandardNth3beta3 = PDstandardNth3(beta3, i, j, k);
- PDstandardNth11beta3 = PDstandardNth11(beta3, i, j, k);
- PDstandardNth22beta3 = PDstandardNth22(beta3, i, j, k);
- PDstandardNth33beta3 = PDstandardNth33(beta3, i, j, k);
- PDstandardNth12beta3 = PDstandardNth12(beta3, i, j, k);
- PDstandardNth13beta3 = PDstandardNth13(beta3, i, j, k);
- PDstandardNth23beta3 = PDstandardNth23(beta3, i, j, k);
- PDstandardNth1gt11 = PDstandardNth1(gt11, i, j, k);
- PDstandardNth2gt11 = PDstandardNth2(gt11, i, j, k);
- PDstandardNth3gt11 = PDstandardNth3(gt11, i, j, k);
- PDstandardNth11gt11 = PDstandardNth11(gt11, i, j, k);
- PDstandardNth22gt11 = PDstandardNth22(gt11, i, j, k);
- PDstandardNth33gt11 = PDstandardNth33(gt11, i, j, k);
- PDstandardNth12gt11 = PDstandardNth12(gt11, i, j, k);
- PDstandardNth13gt11 = PDstandardNth13(gt11, i, j, k);
- PDstandardNth23gt11 = PDstandardNth23(gt11, i, j, k);
- PDstandardNth1gt12 = PDstandardNth1(gt12, i, j, k);
- PDstandardNth2gt12 = PDstandardNth2(gt12, i, j, k);
- PDstandardNth3gt12 = PDstandardNth3(gt12, i, j, k);
- PDstandardNth11gt12 = PDstandardNth11(gt12, i, j, k);
- PDstandardNth22gt12 = PDstandardNth22(gt12, i, j, k);
- PDstandardNth33gt12 = PDstandardNth33(gt12, i, j, k);
- PDstandardNth12gt12 = PDstandardNth12(gt12, i, j, k);
- PDstandardNth13gt12 = PDstandardNth13(gt12, i, j, k);
- PDstandardNth23gt12 = PDstandardNth23(gt12, i, j, k);
- PDstandardNth1gt13 = PDstandardNth1(gt13, i, j, k);
- PDstandardNth2gt13 = PDstandardNth2(gt13, i, j, k);
- PDstandardNth3gt13 = PDstandardNth3(gt13, i, j, k);
- PDstandardNth11gt13 = PDstandardNth11(gt13, i, j, k);
- PDstandardNth22gt13 = PDstandardNth22(gt13, i, j, k);
- PDstandardNth33gt13 = PDstandardNth33(gt13, i, j, k);
- PDstandardNth12gt13 = PDstandardNth12(gt13, i, j, k);
- PDstandardNth13gt13 = PDstandardNth13(gt13, i, j, k);
- PDstandardNth23gt13 = PDstandardNth23(gt13, i, j, k);
- PDstandardNth1gt22 = PDstandardNth1(gt22, i, j, k);
- PDstandardNth2gt22 = PDstandardNth2(gt22, i, j, k);
- PDstandardNth3gt22 = PDstandardNth3(gt22, i, j, k);
- PDstandardNth11gt22 = PDstandardNth11(gt22, i, j, k);
- PDstandardNth22gt22 = PDstandardNth22(gt22, i, j, k);
- PDstandardNth33gt22 = PDstandardNth33(gt22, i, j, k);
- PDstandardNth12gt22 = PDstandardNth12(gt22, i, j, k);
- PDstandardNth13gt22 = PDstandardNth13(gt22, i, j, k);
- PDstandardNth23gt22 = PDstandardNth23(gt22, i, j, k);
- PDstandardNth1gt23 = PDstandardNth1(gt23, i, j, k);
- PDstandardNth2gt23 = PDstandardNth2(gt23, i, j, k);
- PDstandardNth3gt23 = PDstandardNth3(gt23, i, j, k);
- PDstandardNth11gt23 = PDstandardNth11(gt23, i, j, k);
- PDstandardNth22gt23 = PDstandardNth22(gt23, i, j, k);
- PDstandardNth33gt23 = PDstandardNth33(gt23, i, j, k);
- PDstandardNth12gt23 = PDstandardNth12(gt23, i, j, k);
- PDstandardNth13gt23 = PDstandardNth13(gt23, i, j, k);
- PDstandardNth23gt23 = PDstandardNth23(gt23, i, j, k);
- PDstandardNth1gt33 = PDstandardNth1(gt33, i, j, k);
- PDstandardNth2gt33 = PDstandardNth2(gt33, i, j, k);
- PDstandardNth3gt33 = PDstandardNth3(gt33, i, j, k);
- PDstandardNth11gt33 = PDstandardNth11(gt33, i, j, k);
- PDstandardNth22gt33 = PDstandardNth22(gt33, i, j, k);
- PDstandardNth33gt33 = PDstandardNth33(gt33, i, j, k);
- PDstandardNth12gt33 = PDstandardNth12(gt33, i, j, k);
- PDstandardNth13gt33 = PDstandardNth13(gt33, i, j, k);
- PDstandardNth23gt33 = PDstandardNth23(gt33, i, j, k);
- PDstandardNth1phi = PDstandardNth1(phi, i, j, k);
- PDstandardNth2phi = PDstandardNth2(phi, i, j, k);
- PDstandardNth3phi = PDstandardNth3(phi, i, j, k);
- PDstandardNth11phi = PDstandardNth11(phi, i, j, k);
- PDstandardNth22phi = PDstandardNth22(phi, i, j, k);
- PDstandardNth33phi = PDstandardNth33(phi, i, j, k);
- PDstandardNth12phi = PDstandardNth12(phi, i, j, k);
- PDstandardNth13phi = PDstandardNth13(phi, i, j, k);
- PDstandardNth23phi = PDstandardNth23(phi, i, j, k);
- PDstandardNth1trK = PDstandardNth1(trK, i, j, k);
- PDstandardNth2trK = PDstandardNth2(trK, i, j, k);
- PDstandardNth3trK = PDstandardNth3(trK, i, j, k);
- PDstandardNth1Xt1 = PDstandardNth1(Xt1, i, j, k);
- PDstandardNth2Xt1 = PDstandardNth2(Xt1, i, j, k);
- PDstandardNth3Xt1 = PDstandardNth3(Xt1, i, j, k);
- PDstandardNth1Xt2 = PDstandardNth1(Xt2, i, j, k);
- PDstandardNth2Xt2 = PDstandardNth2(Xt2, i, j, k);
- PDstandardNth3Xt2 = PDstandardNth3(Xt2, i, j, k);
- PDstandardNth1Xt3 = PDstandardNth1(Xt3, i, j, k);
- PDstandardNth2Xt3 = PDstandardNth2(Xt3, i, j, k);
- PDstandardNth3Xt3 = PDstandardNth3(Xt3, i, j, k);
+ CCTK_REAL const PDstandardNth1alpha = PDstandardNth1(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth2alpha = PDstandardNth2(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth3alpha = PDstandardNth3(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth11alpha = PDstandardNth11(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth22alpha = PDstandardNth22(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth33alpha = PDstandardNth33(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth12alpha = PDstandardNth12(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth13alpha = PDstandardNth13(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth23alpha = PDstandardNth23(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth1beta1 = PDstandardNth1(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth2beta1 = PDstandardNth2(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth3beta1 = PDstandardNth3(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth11beta1 = PDstandardNth11(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth22beta1 = PDstandardNth22(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth33beta1 = PDstandardNth33(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth12beta1 = PDstandardNth12(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth13beta1 = PDstandardNth13(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth23beta1 = PDstandardNth23(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth1beta2 = PDstandardNth1(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth2beta2 = PDstandardNth2(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth3beta2 = PDstandardNth3(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth11beta2 = PDstandardNth11(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth22beta2 = PDstandardNth22(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth33beta2 = PDstandardNth33(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth12beta2 = PDstandardNth12(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth13beta2 = PDstandardNth13(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth23beta2 = PDstandardNth23(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth1beta3 = PDstandardNth1(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth2beta3 = PDstandardNth2(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth3beta3 = PDstandardNth3(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth11beta3 = PDstandardNth11(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth22beta3 = PDstandardNth22(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth33beta3 = PDstandardNth33(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth12beta3 = PDstandardNth12(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth13beta3 = PDstandardNth13(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth23beta3 = PDstandardNth23(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth1gt11 = PDstandardNth1(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth2gt11 = PDstandardNth2(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth3gt11 = PDstandardNth3(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth11gt11 = PDstandardNth11(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth22gt11 = PDstandardNth22(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth33gt11 = PDstandardNth33(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth12gt11 = PDstandardNth12(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth13gt11 = PDstandardNth13(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth23gt11 = PDstandardNth23(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth1gt12 = PDstandardNth1(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth2gt12 = PDstandardNth2(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth3gt12 = PDstandardNth3(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth11gt12 = PDstandardNth11(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth22gt12 = PDstandardNth22(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth33gt12 = PDstandardNth33(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth12gt12 = PDstandardNth12(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth13gt12 = PDstandardNth13(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth23gt12 = PDstandardNth23(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth1gt13 = PDstandardNth1(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth2gt13 = PDstandardNth2(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth3gt13 = PDstandardNth3(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth11gt13 = PDstandardNth11(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth22gt13 = PDstandardNth22(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth33gt13 = PDstandardNth33(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth12gt13 = PDstandardNth12(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth13gt13 = PDstandardNth13(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth23gt13 = PDstandardNth23(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth1gt22 = PDstandardNth1(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth2gt22 = PDstandardNth2(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth3gt22 = PDstandardNth3(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth11gt22 = PDstandardNth11(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth22gt22 = PDstandardNth22(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth33gt22 = PDstandardNth33(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth12gt22 = PDstandardNth12(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth13gt22 = PDstandardNth13(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth23gt22 = PDstandardNth23(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth1gt23 = PDstandardNth1(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth2gt23 = PDstandardNth2(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth3gt23 = PDstandardNth3(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth11gt23 = PDstandardNth11(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth22gt23 = PDstandardNth22(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth33gt23 = PDstandardNth33(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth12gt23 = PDstandardNth12(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth13gt23 = PDstandardNth13(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth23gt23 = PDstandardNth23(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth1gt33 = PDstandardNth1(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth2gt33 = PDstandardNth2(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth3gt33 = PDstandardNth3(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth11gt33 = PDstandardNth11(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth22gt33 = PDstandardNth22(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth33gt33 = PDstandardNth33(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth12gt33 = PDstandardNth12(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth13gt33 = PDstandardNth13(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth23gt33 = PDstandardNth23(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth1phi = PDstandardNth1(phi, i, j, k);
+ CCTK_REAL const PDstandardNth2phi = PDstandardNth2(phi, i, j, k);
+ CCTK_REAL const PDstandardNth3phi = PDstandardNth3(phi, i, j, k);
+ CCTK_REAL const PDstandardNth11phi = PDstandardNth11(phi, i, j, k);
+ CCTK_REAL const PDstandardNth22phi = PDstandardNth22(phi, i, j, k);
+ CCTK_REAL const PDstandardNth33phi = PDstandardNth33(phi, i, j, k);
+ CCTK_REAL const PDstandardNth12phi = PDstandardNth12(phi, i, j, k);
+ CCTK_REAL const PDstandardNth13phi = PDstandardNth13(phi, i, j, k);
+ CCTK_REAL const PDstandardNth23phi = PDstandardNth23(phi, i, j, k);
+ CCTK_REAL const PDstandardNth1trK = PDstandardNth1(trK, i, j, k);
+ CCTK_REAL const PDstandardNth2trK = PDstandardNth2(trK, i, j, k);
+ CCTK_REAL const PDstandardNth3trK = PDstandardNth3(trK, i, j, k);
+ CCTK_REAL const PDstandardNth1Xt1 = PDstandardNth1(Xt1, i, j, k);
+ CCTK_REAL const PDstandardNth2Xt1 = PDstandardNth2(Xt1, i, j, k);
+ CCTK_REAL const PDstandardNth3Xt1 = PDstandardNth3(Xt1, i, j, k);
+ CCTK_REAL const PDstandardNth1Xt2 = PDstandardNth1(Xt2, i, j, k);
+ CCTK_REAL const PDstandardNth2Xt2 = PDstandardNth2(Xt2, i, j, k);
+ CCTK_REAL const PDstandardNth3Xt2 = PDstandardNth3(Xt2, i, j, k);
+ CCTK_REAL const PDstandardNth1Xt3 = PDstandardNth1(Xt3, i, j, k);
+ CCTK_REAL const PDstandardNth2Xt3 = PDstandardNth2(Xt3, i, j, k);
+ CCTK_REAL const PDstandardNth3Xt3 = PDstandardNth3(Xt3, i, j, k);
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- dir1 = Sign(beta1L);
+ int const dir1 = Sign(beta1L);
- dir2 = Sign(beta2L);
+ int const dir2 = Sign(beta2L);
- dir3 = Sign(beta3L);
+ int const dir3 = Sign(beta3L);
- detgt = 1;
+ CCTK_REAL const detgt = 1;
- gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
+ CCTK_REAL const gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
- gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
+ CCTK_REAL const gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
- gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
- gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
+ CCTK_REAL const gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
- gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
- gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
+ CCTK_REAL const gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
- Gt111 = khalf*(gtu11*PDstandardNth1gt11 + 2*(gtu21*PDstandardNth1gt12 + gtu31*PDstandardNth1gt13) -
+ CCTK_REAL const Gt111 = khalf*(gtu11*PDstandardNth1gt11 + 2*(gtu21*PDstandardNth1gt12 + gtu31*PDstandardNth1gt13) -
gtu21*PDstandardNth2gt11 - gtu31*PDstandardNth3gt11);
- Gt211 = khalf*(gtu21*PDstandardNth1gt11 + 2*(gtu22*PDstandardNth1gt12 + gtu32*PDstandardNth1gt13) -
+ CCTK_REAL const Gt211 = khalf*(gtu21*PDstandardNth1gt11 + 2*(gtu22*PDstandardNth1gt12 + gtu32*PDstandardNth1gt13) -
gtu22*PDstandardNth2gt11 - gtu32*PDstandardNth3gt11);
- Gt311 = khalf*(gtu31*PDstandardNth1gt11 + 2*(gtu32*PDstandardNth1gt12 + gtu33*PDstandardNth1gt13) -
+ CCTK_REAL const Gt311 = khalf*(gtu31*PDstandardNth1gt11 + 2*(gtu32*PDstandardNth1gt12 + gtu33*PDstandardNth1gt13) -
gtu32*PDstandardNth2gt11 - gtu33*PDstandardNth3gt11);
- Gt112 = khalf*(gtu21*PDstandardNth1gt22 + gtu11*PDstandardNth2gt11 +
+ CCTK_REAL const Gt112 = khalf*(gtu21*PDstandardNth1gt22 + gtu11*PDstandardNth2gt11 +
gtu31*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
- Gt212 = khalf*(gtu22*PDstandardNth1gt22 + gtu21*PDstandardNth2gt11 +
+ CCTK_REAL const Gt212 = khalf*(gtu22*PDstandardNth1gt22 + gtu21*PDstandardNth2gt11 +
gtu32*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
- Gt312 = khalf*(gtu32*PDstandardNth1gt22 + gtu31*PDstandardNth2gt11 +
+ CCTK_REAL const Gt312 = khalf*(gtu32*PDstandardNth1gt22 + gtu31*PDstandardNth2gt11 +
gtu33*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
- Gt113 = khalf*(gtu31*PDstandardNth1gt33 + gtu11*PDstandardNth3gt11 +
+ CCTK_REAL const Gt113 = khalf*(gtu31*PDstandardNth1gt33 + gtu11*PDstandardNth3gt11 +
gtu21*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
- Gt213 = khalf*(gtu32*PDstandardNth1gt33 + gtu21*PDstandardNth3gt11 +
+ CCTK_REAL const Gt213 = khalf*(gtu32*PDstandardNth1gt33 + gtu21*PDstandardNth3gt11 +
gtu22*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
- Gt313 = khalf*(gtu33*PDstandardNth1gt33 + gtu31*PDstandardNth3gt11 +
+ CCTK_REAL const Gt313 = khalf*(gtu33*PDstandardNth1gt33 + gtu31*PDstandardNth3gt11 +
gtu32*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
- Gt122 = khalf*(gtu11*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu21*PDstandardNth2gt22 +
+ CCTK_REAL const Gt122 = khalf*(gtu11*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu21*PDstandardNth2gt22 +
gtu31*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
- Gt222 = khalf*(gtu21*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu22*PDstandardNth2gt22 +
+ CCTK_REAL const Gt222 = khalf*(gtu21*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu22*PDstandardNth2gt22 +
gtu32*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
- Gt322 = khalf*(gtu31*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu32*PDstandardNth2gt22 +
+ CCTK_REAL const Gt322 = khalf*(gtu31*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu32*PDstandardNth2gt22 +
gtu33*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
- Gt123 = khalf*(gtu31*PDstandardNth2gt33 + gtu11*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ CCTK_REAL const Gt123 = khalf*(gtu31*PDstandardNth2gt33 + gtu11*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
gtu21*PDstandardNth3gt22);
- Gt223 = khalf*(gtu32*PDstandardNth2gt33 + gtu21*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ CCTK_REAL const Gt223 = khalf*(gtu32*PDstandardNth2gt33 + gtu21*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
gtu22*PDstandardNth3gt22);
- Gt323 = khalf*(gtu33*PDstandardNth2gt33 + gtu31*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ CCTK_REAL const Gt323 = khalf*(gtu33*PDstandardNth2gt33 + gtu31*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
gtu32*PDstandardNth3gt22);
- Gt133 = khalf*(-(gtu11*PDstandardNth1gt33) - gtu21*PDstandardNth2gt33 + 2*gtu11*PDstandardNth3gt13 +
+ CCTK_REAL const Gt133 = khalf*(-(gtu11*PDstandardNth1gt33) - gtu21*PDstandardNth2gt33 + 2*gtu11*PDstandardNth3gt13 +
2*gtu21*PDstandardNth3gt23 + gtu31*PDstandardNth3gt33);
- Gt233 = khalf*(-(gtu21*PDstandardNth1gt33) - gtu22*PDstandardNth2gt33 + 2*gtu21*PDstandardNth3gt13 +
+ CCTK_REAL const Gt233 = khalf*(-(gtu21*PDstandardNth1gt33) - gtu22*PDstandardNth2gt33 + 2*gtu21*PDstandardNth3gt13 +
2*gtu22*PDstandardNth3gt23 + gtu32*PDstandardNth3gt33);
- Gt333 = khalf*(-(gtu31*PDstandardNth1gt33) - gtu32*PDstandardNth2gt33 + 2*gtu31*PDstandardNth3gt13 +
+ CCTK_REAL const Gt333 = khalf*(-(gtu31*PDstandardNth1gt33) - gtu32*PDstandardNth2gt33 + 2*gtu31*PDstandardNth3gt13 +
2*gtu32*PDstandardNth3gt23 + gtu33*PDstandardNth3gt33);
- Xtn1 = Gt111*gtu11 + Gt122*gtu22 + 2*(Gt112*gtu21 + Gt113*gtu31 + Gt123*gtu32) + Gt133*gtu33;
+ CCTK_REAL const Xtn1 = Gt111*gtu11 + Gt122*gtu22 + 2*(Gt112*gtu21 + Gt113*gtu31 + Gt123*gtu32) + Gt133*gtu33;
- Xtn2 = Gt211*gtu11 + Gt222*gtu22 + 2*(Gt212*gtu21 + Gt213*gtu31 + Gt223*gtu32) + Gt233*gtu33;
+ CCTK_REAL const Xtn2 = Gt211*gtu11 + Gt222*gtu22 + 2*(Gt212*gtu21 + Gt213*gtu31 + Gt223*gtu32) + Gt233*gtu33;
- Xtn3 = Gt311*gtu11 + Gt322*gtu22 + 2*(Gt312*gtu21 + Gt313*gtu31 + Gt323*gtu32) + Gt333*gtu33;
+ CCTK_REAL const Xtn3 = Gt311*gtu11 + Gt322*gtu22 + 2*(Gt312*gtu21 + Gt313*gtu31 + Gt323*gtu32) + Gt333*gtu33;
- Rt11 = -(gtu11*khalf*PDstandardNth11gt11) + gtu21*
+ CCTK_REAL const Rt11 = -(gtu11*khalf*PDstandardNth11gt11) + gtu21*
(2*Gt211*Gt212*gt22L + 4*Gt112*gt13L*Gt311 + 2*Gt113*gt11L*Gt312 + 2*gt13L*Gt312*Gt313 + 2*gt13L*Gt211*Gt322 +
2*gt13L*Gt311*Gt323 + 2*Gt311*Gt312*gt33L - PDstandardNth12gt11) - gtu31*PDstandardNth13gt11 +
gt11L*PDstandardNth1Xt1 + gt12L*(4*Gt111*Gt212*gtu21 + 2*Gt211*Gt222*gtu21 + 2*Gt212*Gt222*gtu22 +
@@ -528,7 +547,7 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
gt12L*gtu21*SQR(Gt212)) + gt22L*gtu33*SQR(Gt213) + gt33L*gtu11*SQR(Gt311) + gt33L*gtu22*SQR(Gt312) +
2*gt13L*gtu31*SQR(Gt313) + gt33L*gtu33*SQR(Gt313);
- Rt12 = khalf*(-(gtu11*PDstandardNth11gt12) - 2*gtu21*PDstandardNth12gt12 - 2*gtu31*PDstandardNth13gt12 +
+ CCTK_REAL const Rt12 = khalf*(-(gtu11*PDstandardNth11gt12) - 2*gtu21*PDstandardNth12gt12 - 2*gtu31*PDstandardNth13gt12 +
gt12L*PDstandardNth1Xt1 + gt22L*PDstandardNth1Xt2 + gt23L*PDstandardNth1Xt3 - gtu22*PDstandardNth22gt12 -
2*gtu32*PDstandardNth23gt12 + gt11L*PDstandardNth2Xt1 + gt12L*PDstandardNth2Xt2 + gt13L*PDstandardNth2Xt3 -
gtu33*PDstandardNth33gt12 + (Gt111*gt12L + Gt211*gt22L + gt23L*Gt311)*Xtn1 +
@@ -580,7 +599,7 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
Gt112*(2*gt11L*Gt123 + Gt113*gt12L + gt12L*Gt223 + gt13L*Gt323) +
gt12L*(Gt122*Gt213 + Gt123*(2*Gt212 + Gt313) + Gt223*(Gt222 + Gt323)) + Gt312*Gt323*gt33L + gt13L*SQR(Gt323)));
- Rt13 = khalf*(-(gtu11*PDstandardNth11gt13) - 2*gtu21*PDstandardNth12gt13 - 2*gtu31*PDstandardNth13gt13 +
+ CCTK_REAL const Rt13 = khalf*(-(gtu11*PDstandardNth11gt13) - 2*gtu21*PDstandardNth12gt13 - 2*gtu31*PDstandardNth13gt13 +
gt13L*PDstandardNth1Xt1 + gt23L*PDstandardNth1Xt2 + gt33L*PDstandardNth1Xt3 - gtu22*PDstandardNth22gt13 -
2*gtu32*PDstandardNth23gt13 - gtu33*PDstandardNth33gt13 + gt11L*PDstandardNth3Xt1 + gt12L*PDstandardNth3Xt2 +
gt13L*PDstandardNth3Xt3 + (Gt113*gt11L + gt12L*Gt213 + gt13L*Gt313)*Xtn1 +
@@ -632,7 +651,7 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
Gt113*(2*gt11L*Gt133 + gt12L*Gt233 + Gt213*gt23L + gt13L*Gt333 + Gt313*gt33L) + gt13L*SQR(Gt113) +
gt13L*SQR(Gt333)));
- Rt22 = 4*(Gt122*gt12L*Gt212*gtu21 + Gt112*gt12L*Gt222*gtu21 + Gt122*gt12L*Gt222*gtu22 + Gt123*gt12L*Gt212*gtu31 +
+ CCTK_REAL const Rt22 = 4*(Gt122*gt12L*Gt212*gtu21 + Gt112*gt12L*Gt222*gtu21 + Gt122*gt12L*Gt222*gtu22 + Gt123*gt12L*Gt212*gtu31 +
Gt123*gt12L*Gt222*gtu32 + Gt123*gt12L*Gt223*gtu33) - gtu11*khalf*PDstandardNth11gt22 +
gtu21*(6*Gt212*Gt222*gt22L + 2*Gt122*gt23L*Gt311 + 2*Gt122*gt13L*Gt312 + 4*Gt222*gt23L*Gt312 +
2*Gt113*gt12L*Gt322 + 2*gt23L*Gt312*Gt323 + 2*Gt312*Gt322*gt33L - PDstandardNth12gt22) +
@@ -662,7 +681,7 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
3*gt22L*gtu11*SQR(Gt212) + 3*gt22L*gtu22*SQR(Gt222) + 3*gt22L*gtu33*SQR(Gt223) + gt33L*gtu11*SQR(Gt312) +
gt33L*gtu22*SQR(Gt322) + 2*gt23L*gtu32*SQR(Gt323) + gt33L*gtu33*SQR(Gt323);
- Rt23 = khalf*(-(gtu11*PDstandardNth11gt23) - 2*gtu21*PDstandardNth12gt23 - 2*gtu31*PDstandardNth13gt23 -
+ CCTK_REAL const Rt23 = khalf*(-(gtu11*PDstandardNth11gt23) - 2*gtu21*PDstandardNth12gt23 - 2*gtu31*PDstandardNth13gt23 -
gtu22*PDstandardNth22gt23 - 2*gtu32*PDstandardNth23gt23 + gt13L*PDstandardNth2Xt1 + gt23L*PDstandardNth2Xt2 +
gt33L*PDstandardNth2Xt3 - gtu33*PDstandardNth33gt23 + gt12L*PDstandardNth3Xt1 + gt22L*PDstandardNth3Xt2 +
gt23L*PDstandardNth3Xt3 + (Gt113*gt12L + Gt213*gt22L + gt23L*Gt313)*Xtn1 +
@@ -713,7 +732,7 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
gt22L*Gt233*Gt333 + Gt223*gt23L*Gt333 + Gt123*Gt313*gt33L + Gt223*Gt323*gt33L + 2*Gt323*Gt333*gt33L +
gt23L*SQR(Gt223) + gt23L*SQR(Gt333)));
- Rt33 = 4*(Gt123*gt13L*Gt323*gtu22 + Gt223*gt23L*Gt323*gtu22 + Gt133*gt13L*Gt313*gtu31 + Gt233*gt23L*Gt313*gtu31 +
+ CCTK_REAL const Rt33 = 4*(Gt123*gt13L*Gt323*gtu22 + Gt223*gt23L*Gt323*gtu22 + Gt133*gt13L*Gt313*gtu31 + Gt233*gt23L*Gt313*gtu31 +
Gt113*gt13L*Gt333*gtu31 + Gt133*gt13L*Gt323*gtu32 + Gt233*gt23L*Gt323*gtu32 + Gt123*gt13L*Gt333*gtu32 +
Gt133*gt13L*Gt333*gtu33) + gtu21*(2*Gt212*Gt223*gt23L + 4*Gt123*gt13L*Gt313 + 4*Gt223*gt23L*Gt313 +
4*Gt113*gt13L*Gt323 + 4*Gt213*gt23L*Gt323 + 2*Gt123*Gt311*gt33L - PDstandardNth12gt33) +
@@ -743,199 +762,231 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
gt11L*gtu33*SQR(Gt133) + gt22L*gtu11*SQR(Gt213) + gt22L*gtu22*SQR(Gt223) + 2*gt23L*gtu32*SQR(Gt223) +
gt22L*gtu33*SQR(Gt233) + 3*gt33L*gtu11*SQR(Gt313) + 3*gt33L*gtu22*SQR(Gt323) + 3*gt33L*gtu33*SQR(Gt333);
- fac1 = IfThen(conformalMethod,-(khalf*INV(phiL)),1);
+ CCTK_REAL const fac1 = IfThen(conformalMethod,-(khalf*INV(phiL)),1);
- cdphi1 = fac1*PDstandardNth1phi;
+ CCTK_REAL const cdphi1 = fac1*PDstandardNth1phi;
- cdphi2 = fac1*PDstandardNth2phi;
+ CCTK_REAL const cdphi2 = fac1*PDstandardNth2phi;
- cdphi3 = fac1*PDstandardNth3phi;
+ CCTK_REAL const cdphi3 = fac1*PDstandardNth3phi;
- fac2 = IfThen(conformalMethod,khalf*pow(phiL,-2),0);
+ CCTK_REAL const fac2 = IfThen(conformalMethod,khalf*pow(phiL,-2),0);
- cdphi211 = -(fac1*(-PDstandardNth11phi + Gt111*PDstandardNth1phi + Gt211*PDstandardNth2phi +
+ CCTK_REAL const cdphi211 = -(fac1*(-PDstandardNth11phi + Gt111*PDstandardNth1phi + Gt211*PDstandardNth2phi +
Gt311*PDstandardNth3phi)) + fac2*SQR(PDstandardNth1phi);
- cdphi212 = fac2*PDstandardNth1phi*PDstandardNth2phi -
+ CCTK_REAL const cdphi212 = fac2*PDstandardNth1phi*PDstandardNth2phi -
fac1*(-PDstandardNth12phi + Gt112*PDstandardNth1phi + Gt212*PDstandardNth2phi + Gt312*PDstandardNth3phi);
- cdphi213 = fac2*PDstandardNth1phi*PDstandardNth3phi -
+ CCTK_REAL const cdphi213 = fac2*PDstandardNth1phi*PDstandardNth3phi -
fac1*(-PDstandardNth13phi + Gt113*PDstandardNth1phi + Gt213*PDstandardNth2phi + Gt313*PDstandardNth3phi);
- cdphi222 = -(fac1*(Gt122*PDstandardNth1phi - PDstandardNth22phi + Gt222*PDstandardNth2phi +
+ CCTK_REAL const cdphi222 = -(fac1*(Gt122*PDstandardNth1phi - PDstandardNth22phi + Gt222*PDstandardNth2phi +
Gt322*PDstandardNth3phi)) + fac2*SQR(PDstandardNth2phi);
- cdphi223 = fac2*PDstandardNth2phi*PDstandardNth3phi -
+ CCTK_REAL const cdphi223 = fac2*PDstandardNth2phi*PDstandardNth3phi -
fac1*(Gt123*PDstandardNth1phi - PDstandardNth23phi + Gt223*PDstandardNth2phi + Gt323*PDstandardNth3phi);
- cdphi233 = -(fac1*(Gt133*PDstandardNth1phi + Gt233*PDstandardNth2phi - PDstandardNth33phi +
+ CCTK_REAL const cdphi233 = -(fac1*(Gt133*PDstandardNth1phi + Gt233*PDstandardNth2phi - PDstandardNth33phi +
Gt333*PDstandardNth3phi)) + fac2*SQR(PDstandardNth3phi);
- Rphi11 = -2*(cdphi211 + 2*(-1 + gt11L*gtu11)*SQR(cdphi1) +
+ CCTK_REAL const Rphi11 = -2*(cdphi211 + 2*(-1 + gt11L*gtu11)*SQR(cdphi1) +
gt11L*(cdphi211*gtu11 + 4*(cdphi1*(cdphi2*gtu21 + cdphi3*gtu31) + cdphi2*cdphi3*gtu32) + cdphi233*gtu33 +
gtu22*(cdphi222 + 2*SQR(cdphi2)) + 2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu33*SQR(cdphi3))));
- Rphi12 = -2*(cdphi212 + cdphi1*(cdphi2*(-2 + 4*gt12L*gtu21) + 4*cdphi3*gt12L*gtu31) +
+ CCTK_REAL const Rphi12 = -2*(cdphi212 + cdphi1*(cdphi2*(-2 + 4*gt12L*gtu21) + 4*cdphi3*gt12L*gtu31) +
gt12L*(cdphi211*gtu11 + 4*cdphi2*cdphi3*gtu32 +
2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu11*SQR(cdphi1)) + gtu22*(cdphi222 + 2*SQR(cdphi2)) +
gtu33*(cdphi233 + 2*SQR(cdphi3))));
- Rphi13 = -2*(cdphi213 + cdphi1*(4*cdphi2*gt13L*gtu21 + cdphi3*(-2 + 4*gt13L*gtu31)) +
+ CCTK_REAL const Rphi13 = -2*(cdphi213 + cdphi1*(4*cdphi2*gt13L*gtu21 + cdphi3*(-2 + 4*gt13L*gtu31)) +
gt13L*(cdphi211*gtu11 + 4*cdphi2*cdphi3*gtu32 +
2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu11*SQR(cdphi1)) + gtu22*(cdphi222 + 2*SQR(cdphi2)) +
gtu33*(cdphi233 + 2*SQR(cdphi3))));
- Rphi22 = -2*(cdphi222 + 2*(-1 + gt22L*gtu22)*SQR(cdphi2) +
+ CCTK_REAL const Rphi22 = -2*(cdphi222 + 2*(-1 + gt22L*gtu22)*SQR(cdphi2) +
gt22L*(cdphi222*gtu22 + 4*(cdphi1*cdphi3*gtu31 + cdphi2*(cdphi1*gtu21 + cdphi3*gtu32)) + cdphi233*gtu33 +
gtu11*(cdphi211 + 2*SQR(cdphi1)) + 2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu33*SQR(cdphi3))));
- Rphi23 = -2*(cdphi223 + cdphi2*(4*cdphi1*gt23L*gtu21 + cdphi3*(-2 + 4*gt23L*gtu32)) +
+ CCTK_REAL const Rphi23 = -2*(cdphi223 + cdphi2*(4*cdphi1*gt23L*gtu21 + cdphi3*(-2 + 4*gt23L*gtu32)) +
gt23L*(cdphi222*gtu22 + 4*cdphi1*cdphi3*gtu31 + gtu11*(cdphi211 + 2*SQR(cdphi1)) +
2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu22*SQR(cdphi2)) + gtu33*(cdphi233 + 2*SQR(cdphi3))));
- Rphi33 = -2*(cdphi233 + gt33L*((4*cdphi1*cdphi2 + 2*cdphi212)*gtu21 + 4*cdphi3*(cdphi1*gtu31 + cdphi2*gtu32) +
+ CCTK_REAL const Rphi33 = -2*(cdphi233 + gt33L*((4*cdphi1*cdphi2 + 2*cdphi212)*gtu21 + 4*cdphi3*(cdphi1*gtu31 + cdphi2*gtu32) +
2*(cdphi213*gtu31 + cdphi223*gtu32) + cdphi233*gtu33 + gtu11*(cdphi211 + 2*SQR(cdphi1)) +
gtu22*(cdphi222 + 2*SQR(cdphi2))) + 2*(-1 + gt33L*gtu33)*SQR(cdphi3));
- Atm11 = At11L*gtu11 + At12L*gtu21 + At13L*gtu31;
+ CCTK_REAL const Atm11 = At11L*gtu11 + At12L*gtu21 + At13L*gtu31;
+
+ CCTK_REAL const Atm21 = At11L*gtu21 + At12L*gtu22 + At13L*gtu32;
+
+ CCTK_REAL const Atm31 = At11L*gtu31 + At12L*gtu32 + At13L*gtu33;
+
+ CCTK_REAL const Atm12 = At12L*gtu11 + At22L*gtu21 + At23L*gtu31;
+
+ CCTK_REAL const Atm22 = At12L*gtu21 + At22L*gtu22 + At23L*gtu32;
+
+ CCTK_REAL const Atm32 = At12L*gtu31 + At22L*gtu32 + At23L*gtu33;
+
+ CCTK_REAL const Atm13 = At13L*gtu11 + At23L*gtu21 + At33L*gtu31;
+
+ CCTK_REAL const Atm23 = At13L*gtu21 + At23L*gtu22 + At33L*gtu32;
+
+ CCTK_REAL const Atm33 = At13L*gtu31 + At23L*gtu32 + At33L*gtu33;
+
+ CCTK_REAL const Atu11 = Atm11*gtu11 + Atm12*gtu21 + Atm13*gtu31;
- Atm21 = At11L*gtu21 + At12L*gtu22 + At13L*gtu32;
+ CCTK_REAL const Atu21 = Atm11*gtu21 + Atm12*gtu22 + Atm13*gtu32;
- Atm31 = At11L*gtu31 + At12L*gtu32 + At13L*gtu33;
+ CCTK_REAL const Atu31 = Atm11*gtu31 + Atm12*gtu32 + Atm13*gtu33;
- Atm12 = At12L*gtu11 + At22L*gtu21 + At23L*gtu31;
+ CCTK_REAL const Atu22 = Atm21*gtu21 + Atm22*gtu22 + Atm23*gtu32;
- Atm22 = At12L*gtu21 + At22L*gtu22 + At23L*gtu32;
+ CCTK_REAL const Atu32 = Atm21*gtu31 + Atm22*gtu32 + Atm23*gtu33;
- Atm32 = At12L*gtu31 + At22L*gtu32 + At23L*gtu33;
+ CCTK_REAL const Atu33 = Atm31*gtu31 + Atm32*gtu32 + Atm33*gtu33;
- Atm13 = At13L*gtu11 + At23L*gtu21 + At33L*gtu31;
+ CCTK_REAL const e4phi = IfThen(conformalMethod,pow(phiL,-2),exp(4*phiL));
- Atm23 = At13L*gtu21 + At23L*gtu22 + At33L*gtu32;
+ CCTK_REAL const em4phi = INV(e4phi);
- Atm33 = At13L*gtu31 + At23L*gtu32 + At33L*gtu33;
+ CCTK_REAL const g11 = e4phi*gt11L;
- Atu11 = Atm11*gtu11 + Atm12*gtu21 + Atm13*gtu31;
+ CCTK_REAL const g12 = e4phi*gt12L;
- Atu21 = Atm11*gtu21 + Atm12*gtu22 + Atm13*gtu32;
+ CCTK_REAL const g13 = e4phi*gt13L;
- Atu31 = Atm11*gtu31 + Atm12*gtu32 + Atm13*gtu33;
+ CCTK_REAL const g22 = e4phi*gt22L;
- Atu22 = Atm21*gtu21 + Atm22*gtu22 + Atm23*gtu32;
+ CCTK_REAL const g23 = e4phi*gt23L;
- Atu32 = Atm21*gtu31 + Atm22*gtu32 + Atm23*gtu33;
+ CCTK_REAL const g33 = e4phi*gt33L;
- Atu33 = Atm31*gtu31 + Atm32*gtu32 + Atm33*gtu33;
+ CCTK_REAL const gu11 = em4phi*gtu11;
- e4phi = IfThen(conformalMethod,pow(phiL,-2),exp(4*phiL));
+ CCTK_REAL const gu21 = em4phi*gtu21;
- em4phi = INV(e4phi);
+ CCTK_REAL const gu31 = em4phi*gtu31;
- g11 = e4phi*gt11L;
+ CCTK_REAL const gu22 = em4phi*gtu22;
- g12 = e4phi*gt12L;
+ CCTK_REAL const gu32 = em4phi*gtu32;
- g13 = e4phi*gt13L;
+ CCTK_REAL const gu33 = em4phi*gtu33;
- g22 = e4phi*gt22L;
+ CCTK_REAL const G111 = Gt111 + cdphi1*(4 - 2*gt11L*gtu11) - 2*gt11L*(cdphi2*gtu21 + cdphi3*gtu31);
- g23 = e4phi*gt23L;
+ CCTK_REAL const G211 = Gt211 - 2*gt11L*(cdphi1*gtu21 + cdphi2*gtu22 + cdphi3*gtu32);
- g33 = e4phi*gt33L;
+ CCTK_REAL const G311 = Gt311 - 2*gt11L*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33);
- gu11 = em4phi*gtu11;
+ CCTK_REAL const G112 = Gt112 + cdphi2*(2 - 2*gt12L*gtu21) - 2*gt12L*(cdphi1*gtu11 + cdphi3*gtu31);
- gu21 = em4phi*gtu21;
+ CCTK_REAL const G212 = Gt212 + cdphi1*(2 - 2*gt12L*gtu21) - 2*gt12L*(cdphi2*gtu22 + cdphi3*gtu32);
- gu31 = em4phi*gtu31;
+ CCTK_REAL const G312 = Gt312 - 2*gt12L*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33);
- gu22 = em4phi*gtu22;
+ CCTK_REAL const G113 = Gt113 - 2*gt13L*(cdphi1*gtu11 + cdphi2*gtu21) + cdphi3*(2 - 2*gt13L*gtu31);
- gu32 = em4phi*gtu32;
+ CCTK_REAL const G213 = Gt213 - 2*gt13L*(cdphi1*gtu21 + cdphi2*gtu22 + cdphi3*gtu32);
- gu33 = em4phi*gtu33;
+ CCTK_REAL const G313 = Gt313 + cdphi1*(2 - 2*gt13L*gtu31) - 2*gt13L*(cdphi2*gtu32 + cdphi3*gtu33);
- G111 = Gt111 + cdphi1*(4 - 2*gt11L*gtu11) - 2*gt11L*(cdphi2*gtu21 + cdphi3*gtu31);
+ CCTK_REAL const G122 = Gt122 - 2*gt22L*(cdphi1*gtu11 + cdphi2*gtu21 + cdphi3*gtu31);
- G211 = Gt211 - 2*gt11L*(cdphi1*gtu21 + cdphi2*gtu22 + cdphi3*gtu32);
+ CCTK_REAL const G222 = Gt222 + cdphi2*(4 - 2*gt22L*gtu22) - 2*gt22L*(cdphi1*gtu21 + cdphi3*gtu32);
- G311 = Gt311 - 2*gt11L*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33);
+ CCTK_REAL const G322 = Gt322 - 2*gt22L*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33);
- G112 = Gt112 + cdphi2*(2 - 2*gt12L*gtu21) - 2*gt12L*(cdphi1*gtu11 + cdphi3*gtu31);
+ CCTK_REAL const G123 = Gt123 - 2*gt23L*(cdphi1*gtu11 + cdphi2*gtu21 + cdphi3*gtu31);
- G212 = Gt212 + cdphi1*(2 - 2*gt12L*gtu21) - 2*gt12L*(cdphi2*gtu22 + cdphi3*gtu32);
+ CCTK_REAL const G223 = Gt223 - 2*gt23L*(cdphi1*gtu21 + cdphi2*gtu22) + cdphi3*(2 - 2*gt23L*gtu32);
- G312 = Gt312 - 2*gt12L*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33);
+ CCTK_REAL const G323 = Gt323 + cdphi2*(2 - 2*gt23L*gtu32) - 2*gt23L*(cdphi1*gtu31 + cdphi3*gtu33);
- G113 = Gt113 - 2*gt13L*(cdphi1*gtu11 + cdphi2*gtu21) + cdphi3*(2 - 2*gt13L*gtu31);
+ CCTK_REAL const G133 = Gt133 - 2*gt33L*(cdphi1*gtu11 + cdphi2*gtu21 + cdphi3*gtu31);
- G213 = Gt213 - 2*gt13L*(cdphi1*gtu21 + cdphi2*gtu22 + cdphi3*gtu32);
+ CCTK_REAL const G233 = Gt233 - 2*gt33L*(cdphi1*gtu21 + cdphi2*gtu22 + cdphi3*gtu32);
- G313 = Gt313 + cdphi1*(2 - 2*gt13L*gtu31) - 2*gt13L*(cdphi2*gtu32 + cdphi3*gtu33);
+ CCTK_REAL const G333 = Gt333 - 2*gt33L*(cdphi1*gtu31 + cdphi2*gtu32) + cdphi3*(4 - 2*gt33L*gtu33);
- G122 = Gt122 - 2*gt22L*(cdphi1*gtu11 + cdphi2*gtu21 + cdphi3*gtu31);
+ CCTK_REAL const R11 = Rphi11 + Rt11;
- G222 = Gt222 + cdphi2*(4 - 2*gt22L*gtu22) - 2*gt22L*(cdphi1*gtu21 + cdphi3*gtu32);
+ CCTK_REAL const R12 = Rphi12 + Rt12;
- G322 = Gt322 - 2*gt22L*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33);
+ CCTK_REAL const R13 = Rphi13 + Rt13;
- G123 = Gt123 - 2*gt23L*(cdphi1*gtu11 + cdphi2*gtu21 + cdphi3*gtu31);
+ CCTK_REAL const R22 = Rphi22 + Rt22;
- G223 = Gt223 - 2*gt23L*(cdphi1*gtu21 + cdphi2*gtu22) + cdphi3*(2 - 2*gt23L*gtu32);
+ CCTK_REAL const R23 = Rphi23 + Rt23;
- G323 = Gt323 + cdphi2*(2 - 2*gt23L*gtu32) - 2*gt23L*(cdphi1*gtu31 + cdphi3*gtu33);
+ CCTK_REAL const R33 = Rphi33 + Rt33;
- G133 = Gt133 - 2*gt33L*(cdphi1*gtu11 + cdphi2*gtu21 + cdphi3*gtu31);
+ CCTK_REAL const T00 = eTttL;
- G233 = Gt233 - 2*gt33L*(cdphi1*gtu21 + cdphi2*gtu22 + cdphi3*gtu32);
+ CCTK_REAL const T01 = eTtxL;
- G333 = Gt333 - 2*gt33L*(cdphi1*gtu31 + cdphi2*gtu32) + cdphi3*(4 - 2*gt33L*gtu33);
+ CCTK_REAL const T02 = eTtyL;
- R11 = Rphi11 + Rt11;
+ CCTK_REAL const T03 = eTtzL;
- R12 = Rphi12 + Rt12;
+ CCTK_REAL const T11 = eTxxL;
- R13 = Rphi13 + Rt13;
+ CCTK_REAL const T12 = eTxyL;
- R22 = Rphi22 + Rt22;
+ CCTK_REAL const T13 = eTxzL;
- R23 = Rphi23 + Rt23;
+ CCTK_REAL const T22 = eTyyL;
- R33 = Rphi33 + Rt33;
+ CCTK_REAL const T23 = eTyzL;
- phirhsL = PDupwindNth1(phi, i, j, k)*beta1L + PDupwindNth2(phi, i, j, k)*beta2L +
+ CCTK_REAL const T33 = eTzzL;
+
+ CCTK_REAL const rho = pow(alphaL,-2)*(T00 - 2*(beta2L*T02 + beta3L*T03) +
+ 2*(beta1L*(-T01 + beta2L*T12 + beta3L*T13) + beta2L*beta3L*T23) + T11*SQR(beta1L) + T22*SQR(beta2L) +
+ T33*SQR(beta3L));
+
+ CCTK_REAL const S1 = (-T01 + beta1L*T11 + beta2L*T12 + beta3L*T13)*INV(alphaL);
+
+ CCTK_REAL const S2 = (-T02 + beta1L*T12 + beta2L*T22 + beta3L*T23)*INV(alphaL);
+
+ CCTK_REAL const S3 = (-T03 + beta1L*T13 + beta2L*T23 + beta3L*T33)*INV(alphaL);
+
+ CCTK_REAL const trS = gu11*T11 + gu22*T22 + 2*(gu21*T12 + gu31*T13 + gu32*T23) + gu33*T33;
+
+ CCTK_REAL const phirhsL = PDupwindNth1(phi, i, j, k)*beta1L + PDupwindNth2(phi, i, j, k)*beta2L +
PDupwindNth3(phi, i, j, k)*beta3L + (PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3)*
IfThen(conformalMethod,-(kthird*phiL),0.16666666666666666) +
alphaL*trKL*IfThen(conformalMethod,kthird*phiL,-0.16666666666666666);
- gt11rhsL = -2*alphaL*At11L + PDupwindNth1(gt11, i, j, k)*beta1L + PDupwindNth2(gt11, i, j, k)*beta2L +
+ CCTK_REAL const gt11rhsL = -2*alphaL*At11L + PDupwindNth1(gt11, i, j, k)*beta1L + PDupwindNth2(gt11, i, j, k)*beta2L +
PDupwindNth3(gt11, i, j, k)*beta3L + 2*(gt12L*PDstandardNth1beta2 + gt13L*PDstandardNth1beta3) +
gt11L*(kfourthird*PDstandardNth1beta1 - ktwothird*PDstandardNth2beta2 - ktwothird*PDstandardNth3beta3);
- gt12rhsL = -2*alphaL*At12L + PDupwindNth1(gt12, i, j, k)*beta1L + PDupwindNth2(gt12, i, j, k)*beta2L +
+ CCTK_REAL const gt12rhsL = -2*alphaL*At12L + PDupwindNth1(gt12, i, j, k)*beta1L + PDupwindNth2(gt12, i, j, k)*beta2L +
PDupwindNth3(gt12, i, j, k)*beta3L + gt22L*PDstandardNth1beta2 + gt23L*PDstandardNth1beta3 +
gt11L*PDstandardNth2beta1 + gt13L*PDstandardNth2beta3 +
gt12L*(kthird*(PDstandardNth1beta1 + PDstandardNth2beta2) - ktwothird*PDstandardNth3beta3);
- gt13rhsL = -2*alphaL*At13L + PDupwindNth1(gt13, i, j, k)*beta1L + PDupwindNth2(gt13, i, j, k)*beta2L +
+ CCTK_REAL const gt13rhsL = -2*alphaL*At13L + PDupwindNth1(gt13, i, j, k)*beta1L + PDupwindNth2(gt13, i, j, k)*beta2L +
PDupwindNth3(gt13, i, j, k)*beta3L + gt23L*PDstandardNth1beta2 + gt33L*PDstandardNth1beta3 +
gt11L*PDstandardNth3beta1 + gt12L*PDstandardNth3beta2 +
gt13L*(-(ktwothird*PDstandardNth2beta2) + kthird*(PDstandardNth1beta1 + PDstandardNth3beta3));
- gt22rhsL = -2*alphaL*At22L + PDupwindNth1(gt22, i, j, k)*beta1L + PDupwindNth2(gt22, i, j, k)*beta2L +
+ CCTK_REAL const gt22rhsL = -2*alphaL*At22L + PDupwindNth1(gt22, i, j, k)*beta1L + PDupwindNth2(gt22, i, j, k)*beta2L +
PDupwindNth3(gt22, i, j, k)*beta3L + 2*(gt12L*PDstandardNth2beta1 + gt23L*PDstandardNth2beta3) +
gt22L*(-(ktwothird*PDstandardNth1beta1) + kfourthird*PDstandardNth2beta2 - ktwothird*PDstandardNth3beta3);
- gt23rhsL = -2*alphaL*At23L + PDupwindNth1(gt23, i, j, k)*beta1L + PDupwindNth2(gt23, i, j, k)*beta2L +
+ CCTK_REAL const gt23rhsL = -2*alphaL*At23L + PDupwindNth1(gt23, i, j, k)*beta1L + PDupwindNth2(gt23, i, j, k)*beta2L +
PDupwindNth3(gt23, i, j, k)*beta3L + gt13L*PDstandardNth2beta1 + gt33L*PDstandardNth2beta3 +
gt12L*PDstandardNth3beta1 + gt22L*PDstandardNth3beta2 +
gt23L*(-(ktwothird*PDstandardNth1beta1) + kthird*(PDstandardNth2beta2 + PDstandardNth3beta3));
- gt33rhsL = -2*alphaL*At33L + PDupwindNth1(gt33, i, j, k)*beta1L + PDupwindNth2(gt33, i, j, k)*beta2L +
+ CCTK_REAL const gt33rhsL = -2*alphaL*At33L + PDupwindNth1(gt33, i, j, k)*beta1L + PDupwindNth2(gt33, i, j, k)*beta2L +
PDupwindNth3(gt33, i, j, k)*beta3L - gt33L*ktwothird*PDstandardNth1beta1 - gt33L*ktwothird*PDstandardNth2beta2 +
2*gt13L*PDstandardNth3beta1 + 2*gt23L*PDstandardNth3beta2 + gt33L*kfourthird*PDstandardNth3beta3;
- Xt1rhsL = kthird*(7*(gtu21*PDstandardNth12beta1 + gtu31*PDstandardNth13beta1) +
+ CCTK_REAL const Xt1rhsL = kthird*(7*(gtu21*PDstandardNth12beta1 + gtu31*PDstandardNth13beta1) +
gtu11*(4*PDstandardNth11beta1 + PDstandardNth12beta2 + PDstandardNth13beta3) +
gtu21*(PDstandardNth22beta2 + PDstandardNth23beta3) +
3*(PDupwindNth1(Xt1, i, j, k)*beta1L + PDupwindNth2(Xt1, i, j, k)*beta2L +
@@ -944,11 +995,12 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
6*(Atu11*PDstandardNth1alpha + Atu21*PDstandardNth2alpha + Atu31*PDstandardNth3alpha) +
6*(gtu32*PDstandardNth23beta1 + alphaL*(6*(Atu11*cdphi1 + Atu21*cdphi2 + Atu31*cdphi3) + Atu11*Gt111 +
Atu22*Gt122 + 2*(Atu21*Gt112 + Atu31*Gt113 + Atu32*Gt123) + Atu33*Gt133 -
- ktwothird*(gtu11*PDstandardNth1trK + gtu21*PDstandardNth2trK + gtu31*PDstandardNth3trK))) +
+ ktwothird*(gtu11*PDstandardNth1trK + gtu21*PDstandardNth2trK + gtu31*PDstandardNth3trK))) -
+ 150.7964473723100754462068823974161384415*alphaL*(gtu11*S1 + gtu21*S2 + gtu31*S3) +
(-3*PDstandardNth1beta1 + 2*(PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3))*Xtn1 -
3*(PDstandardNth2beta1*Xtn2 + PDstandardNth3beta1*Xtn3));
- Xt2rhsL = kthird*(gtu21*(PDstandardNth11beta1 + 7*PDstandardNth12beta2 + PDstandardNth13beta3) +
+ CCTK_REAL const Xt2rhsL = kthird*(gtu21*(PDstandardNth11beta1 + 7*PDstandardNth12beta2 + PDstandardNth13beta3) +
gtu22*(PDstandardNth12beta1 + 4*PDstandardNth22beta2 + PDstandardNth23beta3) +
3*(PDupwindNth1(Xt2, i, j, k)*beta1L + PDupwindNth2(Xt2, i, j, k)*beta2L +
PDupwindNth3(Xt2, i, j, k)*beta3L + gtu11*PDstandardNth11beta2 + gtu33*PDstandardNth33beta2) +
@@ -956,11 +1008,12 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
6*(Atu21*PDstandardNth1alpha + Atu22*PDstandardNth2alpha + Atu32*PDstandardNth3alpha) +
6*(gtu31*PDstandardNth13beta2 + alphaL*(6*(Atu21*cdphi1 + Atu22*cdphi2 + Atu32*cdphi3) + Atu11*Gt211 +
Atu22*Gt222 + 2*(Atu21*Gt212 + Atu31*Gt213 + Atu32*Gt223) + Atu33*Gt233 -
- ktwothird*(gtu21*PDstandardNth1trK + gtu22*PDstandardNth2trK + gtu32*PDstandardNth3trK))) +
+ ktwothird*(gtu21*PDstandardNth1trK + gtu22*PDstandardNth2trK + gtu32*PDstandardNth3trK))) -
+ 150.7964473723100754462068823974161384415*alphaL*(gtu21*S1 + gtu22*S2 + gtu32*S3) +
2*(PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3)*Xtn2 -
3*(PDstandardNth1beta2*Xtn1 + PDstandardNth2beta2*Xtn2 + PDstandardNth3beta2*Xtn3));
- Xt3rhsL = kthird*(gtu31*(PDstandardNth11beta1 + PDstandardNth12beta2 + 7*PDstandardNth13beta3) +
+ CCTK_REAL const Xt3rhsL = kthird*(gtu31*(PDstandardNth11beta1 + PDstandardNth12beta2 + 7*PDstandardNth13beta3) +
3*(PDupwindNth1(Xt3, i, j, k)*beta1L + PDupwindNth2(Xt3, i, j, k)*beta2L +
PDupwindNth3(Xt3, i, j, k)*beta3L + gtu11*PDstandardNth11beta3 + gtu22*PDstandardNth22beta3) +
gtu32*(PDstandardNth12beta1 + PDstandardNth22beta2 + 7*PDstandardNth23beta3) +
@@ -968,98 +1021,113 @@ void ML_BSSN_RHS_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT con
6*(Atu31*PDstandardNth1alpha + Atu32*PDstandardNth2alpha + Atu33*PDstandardNth3alpha) +
6*(gtu21*PDstandardNth12beta3 + alphaL*(6*(Atu31*cdphi1 + Atu32*cdphi2 + Atu33*cdphi3) + Atu11*Gt311 +
Atu22*Gt322 + 2*(Atu21*Gt312 + Atu31*Gt313 + Atu32*Gt323) + Atu33*Gt333 -
- ktwothird*(gtu31*PDstandardNth1trK + gtu32*PDstandardNth2trK + gtu33*PDstandardNth3trK))) +
+ ktwothird*(gtu31*PDstandardNth1trK + gtu32*PDstandardNth2trK + gtu33*PDstandardNth3trK))) -
+ 150.7964473723100754462068823974161384415*alphaL*(gtu31*S1 + gtu32*S2 + gtu33*S3) +
2*(PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3)*Xtn3 -
3*(PDstandardNth1beta3*Xtn1 + PDstandardNth2beta3*Xtn2 + PDstandardNth3beta3*Xtn3));
- trKrhsL = PDupwindNth1(trK, i, j, k)*beta1L + PDupwindNth2(trK, i, j, k)*beta2L +
- PDupwindNth3(trK, i, j, k)*beta3L - gu11*PDstandardNth11alpha - 2*gu21*PDstandardNth12alpha -
- 2*gu31*PDstandardNth13alpha + (G111*gu11 + 2*G112*gu21 + G122*gu22 + 2*G113*gu31 + 2*G123*gu32 + G133*gu33)*
- PDstandardNth1alpha - gu22*PDstandardNth22alpha - 2*gu32*PDstandardNth23alpha +
- (G211*gu11 + 2*G212*gu21 + G222*gu22 + 2*G213*gu31 + 2*G223*gu32 + G233*gu33)*PDstandardNth2alpha -
- gu33*PDstandardNth33alpha + G311*gu11*PDstandardNth3alpha + G322*gu22*PDstandardNth3alpha +
- 2*G313*gu31*PDstandardNth3alpha + 2*G323*gu32*PDstandardNth3alpha + G333*gu33*PDstandardNth3alpha +
- 2*(alphaL*Atm12*Atm21 + alphaL*Atm13*Atm31 + alphaL*Atm23*Atm32 + G312*gu21*PDstandardNth3alpha) +
- alphaL*SQR(Atm11) + alphaL*SQR(Atm22) + alphaL*SQR(Atm33) + alphaL*kthird*SQR(trKL);
-
- Ats11 = -PDstandardNth11alpha + G111*PDstandardNth1alpha + G211*PDstandardNth2alpha + G311*PDstandardNth3alpha +
+ CCTK_REAL const trKrhsL = PDupwindNth1(trK, i, j, k)*beta1L + PDupwindNth2(trK, i, j, k)*beta2L +
+ PDupwindNth3(trK, i, j, k)*beta3L + (G111*gu11 + G122*gu22 + 2.*(G112*gu21 + G113*gu31 + G123*gu32) + G133*gu33)*
+ PDstandardNth1alpha - 2.*(gu21*PDstandardNth12alpha + gu31*PDstandardNth13alpha + gu32*PDstandardNth23alpha) +
+ (G211*gu11 + G222*gu22 + 2.*(G212*gu21 + G213*gu31 + G223*gu32) + G233*gu33)*PDstandardNth2alpha -
+ 1.*(gu11*PDstandardNth11alpha + gu22*PDstandardNth22alpha + gu33*PDstandardNth33alpha) +
+ (G311*gu11 + G322*gu22 + 2.*(G313*gu31 + G323*gu32) + G333*gu33)*PDstandardNth3alpha +
+ 2.*(alphaL*(Atm12*Atm21 + Atm13*Atm31 + Atm23*Atm32) + G312*gu21*PDstandardNth3alpha) +
+ alphaL*(12.56637061435917295385057353311801153679*(rho + trS) + SQR(Atm11) + SQR(Atm22) + SQR(Atm33) +
+ 0.3333333333333333333333333333333333333333*SQR(trKL));
+
+ CCTK_REAL const Ats11 = -PDstandardNth11alpha + G111*PDstandardNth1alpha + G211*PDstandardNth2alpha + G311*PDstandardNth3alpha +
alphaL*R11;
- Ats12 = -PDstandardNth12alpha + G112*PDstandardNth1alpha + G212*PDstandardNth2alpha + G312*PDstandardNth3alpha +
+ CCTK_REAL const Ats12 = -PDstandardNth12alpha + G112*PDstandardNth1alpha + G212*PDstandardNth2alpha + G312*PDstandardNth3alpha +
alphaL*R12;
- Ats13 = -PDstandardNth13alpha + G113*PDstandardNth1alpha + G213*PDstandardNth2alpha + G313*PDstandardNth3alpha +
+ CCTK_REAL const Ats13 = -PDstandardNth13alpha + G113*PDstandardNth1alpha + G213*PDstandardNth2alpha + G313*PDstandardNth3alpha +
alphaL*R13;
- Ats22 = G122*PDstandardNth1alpha - PDstandardNth22alpha + G222*PDstandardNth2alpha + G322*PDstandardNth3alpha +
+ CCTK_REAL const Ats22 = G122*PDstandardNth1alpha - PDstandardNth22alpha + G222*PDstandardNth2alpha + G322*PDstandardNth3alpha +
alphaL*R22;
- Ats23 = G123*PDstandardNth1alpha - PDstandardNth23alpha + G223*PDstandardNth2alpha + G323*PDstandardNth3alpha +
+ CCTK_REAL const Ats23 = G123*PDstandardNth1alpha - PDstandardNth23alpha + G223*PDstandardNth2alpha + G323*PDstandardNth3alpha +
alphaL*R23;
- Ats33 = G133*PDstandardNth1alpha + G233*PDstandardNth2alpha - PDstandardNth33alpha + G333*PDstandardNth3alpha +
+ CCTK_REAL const Ats33 = G133*PDstandardNth1alpha + G233*PDstandardNth2alpha - PDstandardNth33alpha + G333*PDstandardNth3alpha +
alphaL*R33;
- trAts = Ats11*gu11 + Ats22*gu22 + 2*(Ats12*gu21 + Ats13*gu31 + Ats23*gu32) + Ats33*gu33;
+ CCTK_REAL const trAts = Ats11*gu11 + Ats22*gu22 + 2*(Ats12*gu21 + Ats13*gu31 + Ats23*gu32) + Ats33*gu33;
- At11rhsL = PDupwindNth1(At11, i, j, k)*beta1L + PDupwindNth2(At11, i, j, k)*beta2L +
- PDupwindNth3(At11, i, j, k)*beta3L + 2*(At11L*PDstandardNth1beta1 + At12L*PDstandardNth1beta2 +
- At13L*PDstandardNth1beta3) - At11L*ktwothird*(PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3) +
- em4phi*(Ats11 - g11*kthird*trAts) + alphaL*(-2*(At11L*Atm11 + At12L*Atm21 + At13L*Atm31) + At11L*trKL);
+ CCTK_REAL const At11rhsL = -2.*alphaL*(At11L*Atm11 + At12L*Atm21 + At13L*Atm31) + PDupwindNth1(At11, i, j, k)*beta1L +
+ PDupwindNth2(At11, i, j, k)*beta2L + PDupwindNth3(At11, i, j, k)*beta3L +
+ 2.*(At12L*PDstandardNth1beta2 + At13L*PDstandardNth1beta3) +
+ At11L*(1.333333333333333333333333333333333333333*PDstandardNth1beta1 -
+ 0.6666666666666666666666666666666666666667*(PDstandardNth2beta2 + PDstandardNth3beta3) + alphaL*trKL) +
+ em4phi*(Ats11 - 0.3333333333333333333333333333333333333333*g11*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T11 + 8.377580409572781969233715688745341024526*g11*trS));
- At12rhsL = -2*alphaL*(At11L*Atm12 + At12L*Atm22 + At13L*Atm32) + PDupwindNth1(At12, i, j, k)*beta1L +
+ CCTK_REAL const At12rhsL = -2.*alphaL*(At11L*Atm12 + At12L*Atm22 + At13L*Atm32) + PDupwindNth1(At12, i, j, k)*beta1L +
PDupwindNth2(At12, i, j, k)*beta2L + PDupwindNth3(At12, i, j, k)*beta3L + At22L*PDstandardNth1beta2 +
At23L*PDstandardNth1beta3 + At11L*PDstandardNth2beta1 + At13L*PDstandardNth2beta3 +
- em4phi*(Ats12 - g12*kthird*trAts) + At12L*(kthird*(PDstandardNth1beta1 + PDstandardNth2beta2) -
- ktwothird*PDstandardNth3beta3 + alphaL*trKL);
+ At12L*(0.3333333333333333333333333333333333333333*(PDstandardNth1beta1 + PDstandardNth2beta2) -
+ 0.6666666666666666666666666666666666666667*PDstandardNth3beta3 + alphaL*trKL) +
+ em4phi*(Ats12 - 0.3333333333333333333333333333333333333333*g12*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T12 + 8.377580409572781969233715688745341024526*g12*trS));
- At13rhsL = -2*alphaL*(At11L*Atm13 + At12L*Atm23 + At13L*Atm33) + PDupwindNth1(At13, i, j, k)*beta1L +
+ CCTK_REAL const At13rhsL = -2.*alphaL*(At11L*Atm13 + At12L*Atm23 + At13L*Atm33) + PDupwindNth1(At13, i, j, k)*beta1L +
PDupwindNth2(At13, i, j, k)*beta2L + PDupwindNth3(At13, i, j, k)*beta3L + At23L*PDstandardNth1beta2 +
At33L*PDstandardNth1beta3 + At11L*PDstandardNth3beta1 + At12L*PDstandardNth3beta2 +
- em4phi*(Ats13 - g13*kthird*trAts) + At13L*(-(ktwothird*PDstandardNth2beta2) +
- kthird*(PDstandardNth1beta1 + PDstandardNth3beta3) + alphaL*trKL);
-
- At22rhsL = PDupwindNth1(At22, i, j, k)*beta1L + PDupwindNth2(At22, i, j, k)*beta2L +
- PDupwindNth3(At22, i, j, k)*beta3L + 2*(At12L*PDstandardNth2beta1 + At22L*PDstandardNth2beta2 +
- At23L*PDstandardNth2beta3) - At22L*ktwothird*(PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3) +
- em4phi*(Ats22 - g22*kthird*trAts) + alphaL*(-2*(At12L*Atm12 + At22L*Atm22 + At23L*Atm32) + At22L*trKL);
-
- At23rhsL = -2*alphaL*(At12L*Atm13 + At22L*Atm23 + At23L*Atm33) + PDupwindNth1(At23, i, j, k)*beta1L +
+ At13L*(-0.6666666666666666666666666666666666666667*PDstandardNth2beta2 +
+ 0.3333333333333333333333333333333333333333*(PDstandardNth1beta1 + PDstandardNth3beta3) + alphaL*trKL) +
+ em4phi*(Ats13 - 0.3333333333333333333333333333333333333333*g13*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T13 + 8.377580409572781969233715688745341024526*g13*trS));
+
+ CCTK_REAL const At22rhsL = -2.*alphaL*(At12L*Atm12 + At22L*Atm22 + At23L*Atm32) + PDupwindNth1(At22, i, j, k)*beta1L +
+ PDupwindNth2(At22, i, j, k)*beta2L + PDupwindNth3(At22, i, j, k)*beta3L +
+ 2.*(At12L*PDstandardNth2beta1 + At23L*PDstandardNth2beta3) +
+ At22L*(1.333333333333333333333333333333333333333*PDstandardNth2beta2 -
+ 0.6666666666666666666666666666666666666667*(PDstandardNth1beta1 + PDstandardNth3beta3) + alphaL*trKL) +
+ em4phi*(Ats22 - 0.3333333333333333333333333333333333333333*g22*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T22 + 8.377580409572781969233715688745341024526*g22*trS));
+
+ CCTK_REAL const At23rhsL = -2.*alphaL*(At12L*Atm13 + At22L*Atm23 + At23L*Atm33) + PDupwindNth1(At23, i, j, k)*beta1L +
PDupwindNth2(At23, i, j, k)*beta2L + PDupwindNth3(At23, i, j, k)*beta3L + At13L*PDstandardNth2beta1 +
At33L*PDstandardNth2beta3 + At12L*PDstandardNth3beta1 + At22L*PDstandardNth3beta2 +
- em4phi*(Ats23 - g23*kthird*trAts) + At23L*(-(ktwothird*PDstandardNth1beta1) +
- kthird*(PDstandardNth2beta2 + PDstandardNth3beta3) + alphaL*trKL);
-
- At33rhsL = PDupwindNth1(At33, i, j, k)*beta1L + PDupwindNth2(At33, i, j, k)*beta2L +
- PDupwindNth3(At33, i, j, k)*beta3L - At33L*ktwothird*
- (PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3) +
- 2*(At13L*PDstandardNth3beta1 + At23L*PDstandardNth3beta2 + At33L*PDstandardNth3beta3) +
- em4phi*(Ats33 - g33*kthird*trAts) + alphaL*(-2*(At13L*Atm13 + At23L*Atm23 + At33L*Atm33) + At33L*trKL);
-
- alpharhsL = (PDupwindNth1(alpha, i, j, k)*beta1L + PDupwindNth2(alpha, i, j, k)*beta2L +
+ At23L*(-0.6666666666666666666666666666666666666667*PDstandardNth1beta1 +
+ 0.3333333333333333333333333333333333333333*(PDstandardNth2beta2 + PDstandardNth3beta3) + alphaL*trKL) +
+ em4phi*(Ats23 - 0.3333333333333333333333333333333333333333*g23*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T23 + 8.377580409572781969233715688745341024526*g23*trS));
+
+ CCTK_REAL const At33rhsL = -2.*alphaL*(At13L*Atm13 + At23L*Atm23 + At33L*Atm33) + PDupwindNth1(At33, i, j, k)*beta1L +
+ PDupwindNth2(At33, i, j, k)*beta2L + PDupwindNth3(At33, i, j, k)*beta3L +
+ 2.*(At13L*PDstandardNth3beta1 + At23L*PDstandardNth3beta2) +
+ At33L*(-0.6666666666666666666666666666666666666667*(PDstandardNth1beta1 + PDstandardNth2beta2) +
+ 1.333333333333333333333333333333333333333*PDstandardNth3beta3 + alphaL*trKL) +
+ em4phi*(Ats33 - 0.3333333333333333333333333333333333333333*g33*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T33 + 8.377580409572781969233715688745341024526*g33*trS));
+
+ CCTK_REAL const alpharhsL = (PDupwindNth1(alpha, i, j, k)*beta1L + PDupwindNth2(alpha, i, j, k)*beta2L +
PDupwindNth3(alpha, i, j, k)*beta3L)*LapseAdvectionCoeff +
harmonicF*(AL*(-1 + LapseAdvectionCoeff) - LapseAdvectionCoeff*trKL)*pow(alphaL,harmonicN);
- ArhsL = (-1 + LapseAdvectionCoeff)*(AL*AlphaDriver - trKrhsL);
+ CCTK_REAL const ArhsL = (-1 + LapseAdvectionCoeff)*(AL*AlphaDriver - trKrhsL);
- beta1rhsL = (PDupwindNth1(beta1, i, j, k)*beta1L + PDupwindNth2(beta1, i, j, k)*beta2L +
+ CCTK_REAL const beta1rhsL = (PDupwindNth1(beta1, i, j, k)*beta1L + PDupwindNth2(beta1, i, j, k)*beta2L +
PDupwindNth3(beta1, i, j, k)*beta3L)*ShiftAdvectionCoeff + B1L*ShiftGammaCoeff;
- beta2rhsL = (PDupwindNth1(beta2, i, j, k)*beta1L + PDupwindNth2(beta2, i, j, k)*beta2L +
+ CCTK_REAL const beta2rhsL = (PDupwindNth1(beta2, i, j, k)*beta1L + PDupwindNth2(beta2, i, j, k)*beta2L +
PDupwindNth3(beta2, i, j, k)*beta3L)*ShiftAdvectionCoeff + B2L*ShiftGammaCoeff;
- beta3rhsL = (PDupwindNth1(beta3, i, j, k)*beta1L + PDupwindNth2(beta3, i, j, k)*beta2L +
+ CCTK_REAL const beta3rhsL = (PDupwindNth1(beta3, i, j, k)*beta1L + PDupwindNth2(beta3, i, j, k)*beta2L +
PDupwindNth3(beta3, i, j, k)*beta3L)*ShiftAdvectionCoeff + B3L*ShiftGammaCoeff;
- B1rhsL = -(B1L*etaL) + ((PDupwindNth1(B1, i, j, k) - PDupwindNth1(Xt1, i, j, k))*beta1L +
+ CCTK_REAL const B1rhsL = -(B1L*etaL) + ((PDupwindNth1(B1, i, j, k) - PDupwindNth1(Xt1, i, j, k))*beta1L +
(PDupwindNth2(B1, i, j, k) - PDupwindNth2(Xt1, i, j, k))*beta2L +
(PDupwindNth3(B1, i, j, k) - PDupwindNth3(Xt1, i, j, k))*beta3L)*ShiftAdvectionCoeff + Xt1rhsL;
- B2rhsL = -(B2L*etaL) + ((PDupwindNth1(B2, i, j, k) - PDupwindNth1(Xt2, i, j, k))*beta1L +
+ CCTK_REAL const B2rhsL = -(B2L*etaL) + ((PDupwindNth1(B2, i, j, k) - PDupwindNth1(Xt2, i, j, k))*beta1L +
(PDupwindNth2(B2, i, j, k) - PDupwindNth2(Xt2, i, j, k))*beta2L +
(PDupwindNth3(B2, i, j, k) - PDupwindNth3(Xt2, i, j, k))*beta3L)*ShiftAdvectionCoeff + Xt2rhsL;
- B3rhsL = -(B3L*etaL) + ((PDupwindNth1(B3, i, j, k) - PDupwindNth1(Xt3, i, j, k))*beta1L +
+ CCTK_REAL const B3rhsL = -(B3L*etaL) + ((PDupwindNth1(B3, i, j, k) - PDupwindNth1(Xt3, i, j, k))*beta1L +
(PDupwindNth2(B3, i, j, k) - PDupwindNth2(Xt3, i, j, k))*beta2L +
(PDupwindNth3(B3, i, j, k) - PDupwindNth3(Xt3, i, j, k))*beta3L)*ShiftAdvectionCoeff + Xt3rhsL;
diff --git a/ML_BSSN/src/ML_BSSN_RHS1.c b/ML_BSSN/src/ML_BSSN_RHS1.c
new file mode 100644
index 0000000..71e93dc
--- /dev/null
+++ b/ML_BSSN/src/ML_BSSN_RHS1.c
@@ -0,0 +1,560 @@
+/* File produced by Kranc */
+
+#define KRANC_C
+
+#include <assert.h>
+#include <math.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include "cctk.h"
+#include "cctk_Arguments.h"
+#include "cctk_Parameters.h"
+#include "GenericFD.h"
+#include "Differencing.h"
+#include "loopcontrol.h"
+
+/* Define macros used in calculations */
+#define INITVALUE (42)
+#define INV(x) ((1.0) / (x))
+#define SQR(x) ((x) * (x))
+#define CUB(x) ((x) * (x) * (x))
+#define QAD(x) ((x) * (x) * (x) * (x))
+
+void ML_BSSN_RHS1_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
+{
+ DECLARE_CCTK_ARGUMENTS;
+ DECLARE_CCTK_PARAMETERS;
+
+
+ /* Declare finite differencing variables */
+
+ /* Declare predefined quantities */
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
+
+ if (verbose > 1)
+ {
+ CCTK_VInfo(CCTK_THORNSTRING,"Entering ML_BSSN_RHS1_Body");
+ }
+
+ if (cctk_iteration % ML_BSSN_RHS1_calc_every != ML_BSSN_RHS1_calc_offset)
+ {
+ return;
+ }
+
+ /* Include user-supplied include files */
+
+ /* Initialise finite differencing variables */
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
+
+ /* Initialize predefined quantities */
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
+
+ /* Loop over the grid points */
+ #pragma omp parallel
+ LC_LOOP3 (ML_BSSN_RHS1,
+ i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
+ cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
+ {
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+
+ /* Declare shorthands */
+ // CCTK_REAL Atm11 = INITVALUE, Atm12 = INITVALUE, Atm13 = INITVALUE, Atm21 = INITVALUE, Atm22 = INITVALUE, Atm23 = INITVALUE;
+ // CCTK_REAL Atm31 = INITVALUE, Atm32 = INITVALUE, Atm33 = INITVALUE;
+ // CCTK_REAL Atu11 = INITVALUE, Atu21 = INITVALUE, Atu22 = INITVALUE, Atu31 = INITVALUE, Atu32 = INITVALUE, Atu33 = INITVALUE;
+ // CCTK_REAL cdphi1 = INITVALUE, cdphi2 = INITVALUE, cdphi3 = INITVALUE;
+ // CCTK_REAL detgt = INITVALUE;
+ // CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
+ // CCTK_REAL fac1 = INITVALUE;
+ // CCTK_REAL Gt111 = INITVALUE, Gt112 = INITVALUE, Gt113 = INITVALUE, Gt122 = INITVALUE, Gt123 = INITVALUE, Gt133 = INITVALUE;
+ // CCTK_REAL Gt211 = INITVALUE, Gt212 = INITVALUE, Gt213 = INITVALUE, Gt222 = INITVALUE, Gt223 = INITVALUE, Gt233 = INITVALUE;
+ // CCTK_REAL Gt311 = INITVALUE, Gt312 = INITVALUE, Gt313 = INITVALUE, Gt322 = INITVALUE, Gt323 = INITVALUE, Gt333 = INITVALUE;
+ // CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
+ // CCTK_REAL S1 = INITVALUE, S2 = INITVALUE, S3 = INITVALUE;
+ // CCTK_REAL T01 = INITVALUE, T02 = INITVALUE, T03 = INITVALUE, T11 = INITVALUE, T12 = INITVALUE, T13 = INITVALUE;
+ // CCTK_REAL T22 = INITVALUE, T23 = INITVALUE, T33 = INITVALUE;
+ // CCTK_REAL Xtn1 = INITVALUE, Xtn2 = INITVALUE, Xtn3 = INITVALUE;
+
+ /* Declare local copies of grid functions */
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
+ // CCTK_REAL B1L = INITVALUE, B1rhsL = INITVALUE, B2L = INITVALUE, B2rhsL = INITVALUE, B3L = INITVALUE, B3rhsL = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta1rhsL = INITVALUE, beta2L = INITVALUE, beta2rhsL = INITVALUE, beta3L = INITVALUE, beta3rhsL = INITVALUE;
+ // CCTK_REAL etaL = INITVALUE;
+ // CCTK_REAL eTtxL = INITVALUE;
+ // CCTK_REAL eTtyL = INITVALUE;
+ // CCTK_REAL eTtzL = INITVALUE;
+ // CCTK_REAL eTxxL = INITVALUE;
+ // CCTK_REAL eTxyL = INITVALUE;
+ // CCTK_REAL eTxzL = INITVALUE;
+ // CCTK_REAL eTyyL = INITVALUE;
+ // CCTK_REAL eTyzL = INITVALUE;
+ // CCTK_REAL eTzzL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt11rhsL = INITVALUE, gt12L = INITVALUE, gt12rhsL = INITVALUE, gt13L = INITVALUE, gt13rhsL = INITVALUE;
+ // CCTK_REAL gt22L = INITVALUE, gt22rhsL = INITVALUE, gt23L = INITVALUE, gt23rhsL = INITVALUE, gt33L = INITVALUE, gt33rhsL = INITVALUE;
+ // CCTK_REAL phiL = INITVALUE, phirhsL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE;
+ // CCTK_REAL Xt1L = INITVALUE, Xt1rhsL = INITVALUE, Xt2L = INITVALUE, Xt2rhsL = INITVALUE, Xt3L = INITVALUE, Xt3rhsL = INITVALUE;
+ /* Declare precomputed derivatives*/
+
+ /* Declare derivatives */
+ // CCTK_REAL PDstandardNth1alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth2alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth3alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth1beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth2beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth3beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth11beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth22beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth33beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth12beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth13beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth23beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth1beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth2beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth3beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth11beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth22beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth33beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth12beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth13beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth23beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth1beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth2beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth3beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth11beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth22beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth33beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth12beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth13beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth23beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth1phi = INITVALUE;
+ // CCTK_REAL PDstandardNth2phi = INITVALUE;
+ // CCTK_REAL PDstandardNth3phi = INITVALUE;
+ // CCTK_REAL PDstandardNth1trK = INITVALUE;
+ // CCTK_REAL PDstandardNth2trK = INITVALUE;
+ // CCTK_REAL PDstandardNth3trK = INITVALUE;
+
+ /* Assign local copies of grid functions */
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const At11L = At11[index];
+ CCTK_REAL const At12L = At12[index];
+ CCTK_REAL const At13L = At13[index];
+ CCTK_REAL const At22L = At22[index];
+ CCTK_REAL const At23L = At23[index];
+ CCTK_REAL const At33L = At33[index];
+ CCTK_REAL const B1L = B1[index];
+ CCTK_REAL const B2L = B2[index];
+ CCTK_REAL const B3L = B3[index];
+ CCTK_REAL const beta1L = beta1[index];
+ CCTK_REAL const beta2L = beta2[index];
+ CCTK_REAL const beta3L = beta3[index];
+ CCTK_REAL const etaL = eta[index];
+ CCTK_REAL const eTtxL = (stress_energy_state) ? (eTtx[index]) : 0.0;
+ CCTK_REAL const eTtyL = (stress_energy_state) ? (eTty[index]) : 0.0;
+ CCTK_REAL const eTtzL = (stress_energy_state) ? (eTtz[index]) : 0.0;
+ CCTK_REAL const eTxxL = (stress_energy_state) ? (eTxx[index]) : 0.0;
+ CCTK_REAL const eTxyL = (stress_energy_state) ? (eTxy[index]) : 0.0;
+ CCTK_REAL const eTxzL = (stress_energy_state) ? (eTxz[index]) : 0.0;
+ CCTK_REAL const eTyyL = (stress_energy_state) ? (eTyy[index]) : 0.0;
+ CCTK_REAL const eTyzL = (stress_energy_state) ? (eTyz[index]) : 0.0;
+ CCTK_REAL const eTzzL = (stress_energy_state) ? (eTzz[index]) : 0.0;
+ CCTK_REAL const gt11L = gt11[index];
+ CCTK_REAL const gt12L = gt12[index];
+ CCTK_REAL const gt13L = gt13[index];
+ CCTK_REAL const gt22L = gt22[index];
+ CCTK_REAL const gt23L = gt23[index];
+ CCTK_REAL const gt33L = gt33[index];
+ CCTK_REAL const phiL = phi[index];
+ CCTK_REAL const trKL = trK[index];
+ CCTK_REAL const Xt1L = Xt1[index];
+ CCTK_REAL const Xt2L = Xt2[index];
+ CCTK_REAL const Xt3L = Xt3[index];
+
+ /* Assign local copies of subblock grid functions */
+
+ /* Include user supplied include files */
+
+ /* Precompute derivatives (new style) */
+ CCTK_REAL const PDstandardNth1alpha = PDstandardNth1(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth2alpha = PDstandardNth2(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth3alpha = PDstandardNth3(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth1beta1 = PDstandardNth1(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth2beta1 = PDstandardNth2(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth3beta1 = PDstandardNth3(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth11beta1 = PDstandardNth11(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth22beta1 = PDstandardNth22(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth33beta1 = PDstandardNth33(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth12beta1 = PDstandardNth12(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth13beta1 = PDstandardNth13(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth23beta1 = PDstandardNth23(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth1beta2 = PDstandardNth1(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth2beta2 = PDstandardNth2(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth3beta2 = PDstandardNth3(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth11beta2 = PDstandardNth11(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth22beta2 = PDstandardNth22(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth33beta2 = PDstandardNth33(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth12beta2 = PDstandardNth12(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth13beta2 = PDstandardNth13(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth23beta2 = PDstandardNth23(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth1beta3 = PDstandardNth1(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth2beta3 = PDstandardNth2(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth3beta3 = PDstandardNth3(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth11beta3 = PDstandardNth11(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth22beta3 = PDstandardNth22(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth33beta3 = PDstandardNth33(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth12beta3 = PDstandardNth12(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth13beta3 = PDstandardNth13(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth23beta3 = PDstandardNth23(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth1gt11 = PDstandardNth1(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth2gt11 = PDstandardNth2(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth3gt11 = PDstandardNth3(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth1gt12 = PDstandardNth1(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth2gt12 = PDstandardNth2(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth3gt12 = PDstandardNth3(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth1gt13 = PDstandardNth1(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth2gt13 = PDstandardNth2(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth3gt13 = PDstandardNth3(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth1gt22 = PDstandardNth1(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth2gt22 = PDstandardNth2(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth3gt22 = PDstandardNth3(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth1gt23 = PDstandardNth1(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth2gt23 = PDstandardNth2(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth3gt23 = PDstandardNth3(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth1gt33 = PDstandardNth1(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth2gt33 = PDstandardNth2(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth3gt33 = PDstandardNth3(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth1phi = PDstandardNth1(phi, i, j, k);
+ CCTK_REAL const PDstandardNth2phi = PDstandardNth2(phi, i, j, k);
+ CCTK_REAL const PDstandardNth3phi = PDstandardNth3(phi, i, j, k);
+ CCTK_REAL const PDstandardNth1trK = PDstandardNth1(trK, i, j, k);
+ CCTK_REAL const PDstandardNth2trK = PDstandardNth2(trK, i, j, k);
+ CCTK_REAL const PDstandardNth3trK = PDstandardNth3(trK, i, j, k);
+
+ /* Precompute derivatives (old style) */
+
+ /* Calculate temporaries and grid functions */
+ int const dir1 = Sign(beta1L);
+
+ int const dir2 = Sign(beta2L);
+
+ int const dir3 = Sign(beta3L);
+
+ CCTK_REAL const detgt = 1;
+
+ CCTK_REAL const gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
+
+ CCTK_REAL const gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
+
+ CCTK_REAL const gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
+
+ CCTK_REAL const gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
+
+ CCTK_REAL const gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
+
+ CCTK_REAL const gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
+
+ CCTK_REAL const Gt111 = khalf*(gtu11*PDstandardNth1gt11 + 2*(gtu21*PDstandardNth1gt12 + gtu31*PDstandardNth1gt13) -
+ gtu21*PDstandardNth2gt11 - gtu31*PDstandardNth3gt11);
+
+ CCTK_REAL const Gt211 = khalf*(gtu21*PDstandardNth1gt11 + 2*(gtu22*PDstandardNth1gt12 + gtu32*PDstandardNth1gt13) -
+ gtu22*PDstandardNth2gt11 - gtu32*PDstandardNth3gt11);
+
+ CCTK_REAL const Gt311 = khalf*(gtu31*PDstandardNth1gt11 + 2*(gtu32*PDstandardNth1gt12 + gtu33*PDstandardNth1gt13) -
+ gtu32*PDstandardNth2gt11 - gtu33*PDstandardNth3gt11);
+
+ CCTK_REAL const Gt112 = khalf*(gtu21*PDstandardNth1gt22 + gtu11*PDstandardNth2gt11 +
+ gtu31*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
+
+ CCTK_REAL const Gt212 = khalf*(gtu22*PDstandardNth1gt22 + gtu21*PDstandardNth2gt11 +
+ gtu32*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
+
+ CCTK_REAL const Gt312 = khalf*(gtu32*PDstandardNth1gt22 + gtu31*PDstandardNth2gt11 +
+ gtu33*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
+
+ CCTK_REAL const Gt113 = khalf*(gtu31*PDstandardNth1gt33 + gtu11*PDstandardNth3gt11 +
+ gtu21*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
+
+ CCTK_REAL const Gt213 = khalf*(gtu32*PDstandardNth1gt33 + gtu21*PDstandardNth3gt11 +
+ gtu22*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
+
+ CCTK_REAL const Gt313 = khalf*(gtu33*PDstandardNth1gt33 + gtu31*PDstandardNth3gt11 +
+ gtu32*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
+
+ CCTK_REAL const Gt122 = khalf*(gtu11*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu21*PDstandardNth2gt22 +
+ gtu31*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
+
+ CCTK_REAL const Gt222 = khalf*(gtu21*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu22*PDstandardNth2gt22 +
+ gtu32*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
+
+ CCTK_REAL const Gt322 = khalf*(gtu31*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu32*PDstandardNth2gt22 +
+ gtu33*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
+
+ CCTK_REAL const Gt123 = khalf*(gtu31*PDstandardNth2gt33 + gtu11*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ gtu21*PDstandardNth3gt22);
+
+ CCTK_REAL const Gt223 = khalf*(gtu32*PDstandardNth2gt33 + gtu21*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ gtu22*PDstandardNth3gt22);
+
+ CCTK_REAL const Gt323 = khalf*(gtu33*PDstandardNth2gt33 + gtu31*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ gtu32*PDstandardNth3gt22);
+
+ CCTK_REAL const Gt133 = khalf*(-(gtu11*PDstandardNth1gt33) - gtu21*PDstandardNth2gt33 + 2*gtu11*PDstandardNth3gt13 +
+ 2*gtu21*PDstandardNth3gt23 + gtu31*PDstandardNth3gt33);
+
+ CCTK_REAL const Gt233 = khalf*(-(gtu21*PDstandardNth1gt33) - gtu22*PDstandardNth2gt33 + 2*gtu21*PDstandardNth3gt13 +
+ 2*gtu22*PDstandardNth3gt23 + gtu32*PDstandardNth3gt33);
+
+ CCTK_REAL const Gt333 = khalf*(-(gtu31*PDstandardNth1gt33) - gtu32*PDstandardNth2gt33 + 2*gtu31*PDstandardNth3gt13 +
+ 2*gtu32*PDstandardNth3gt23 + gtu33*PDstandardNth3gt33);
+
+ CCTK_REAL const Xtn1 = Gt111*gtu11 + Gt122*gtu22 + 2*(Gt112*gtu21 + Gt113*gtu31 + Gt123*gtu32) + Gt133*gtu33;
+
+ CCTK_REAL const Xtn2 = Gt211*gtu11 + Gt222*gtu22 + 2*(Gt212*gtu21 + Gt213*gtu31 + Gt223*gtu32) + Gt233*gtu33;
+
+ CCTK_REAL const Xtn3 = Gt311*gtu11 + Gt322*gtu22 + 2*(Gt312*gtu21 + Gt313*gtu31 + Gt323*gtu32) + Gt333*gtu33;
+
+ CCTK_REAL const fac1 = IfThen(conformalMethod,-(khalf*INV(phiL)),1);
+
+ CCTK_REAL const cdphi1 = fac1*PDstandardNth1phi;
+
+ CCTK_REAL const cdphi2 = fac1*PDstandardNth2phi;
+
+ CCTK_REAL const cdphi3 = fac1*PDstandardNth3phi;
+
+ CCTK_REAL const Atm11 = At11L*gtu11 + At12L*gtu21 + At13L*gtu31;
+
+ CCTK_REAL const Atm21 = At11L*gtu21 + At12L*gtu22 + At13L*gtu32;
+
+ CCTK_REAL const Atm31 = At11L*gtu31 + At12L*gtu32 + At13L*gtu33;
+
+ CCTK_REAL const Atm12 = At12L*gtu11 + At22L*gtu21 + At23L*gtu31;
+
+ CCTK_REAL const Atm22 = At12L*gtu21 + At22L*gtu22 + At23L*gtu32;
+
+ CCTK_REAL const Atm32 = At12L*gtu31 + At22L*gtu32 + At23L*gtu33;
+
+ CCTK_REAL const Atm13 = At13L*gtu11 + At23L*gtu21 + At33L*gtu31;
+
+ CCTK_REAL const Atm23 = At13L*gtu21 + At23L*gtu22 + At33L*gtu32;
+
+ CCTK_REAL const Atm33 = At13L*gtu31 + At23L*gtu32 + At33L*gtu33;
+
+ CCTK_REAL const Atu11 = Atm11*gtu11 + Atm12*gtu21 + Atm13*gtu31;
+
+ CCTK_REAL const Atu21 = Atm11*gtu21 + Atm12*gtu22 + Atm13*gtu32;
+
+ CCTK_REAL const Atu31 = Atm11*gtu31 + Atm12*gtu32 + Atm13*gtu33;
+
+ CCTK_REAL const Atu22 = Atm21*gtu21 + Atm22*gtu22 + Atm23*gtu32;
+
+ CCTK_REAL const Atu32 = Atm21*gtu31 + Atm22*gtu32 + Atm23*gtu33;
+
+ CCTK_REAL const Atu33 = Atm31*gtu31 + Atm32*gtu32 + Atm33*gtu33;
+
+ CCTK_REAL const T01 = eTtxL;
+
+ CCTK_REAL const T02 = eTtyL;
+
+ CCTK_REAL const T03 = eTtzL;
+
+ CCTK_REAL const T11 = eTxxL;
+
+ CCTK_REAL const T12 = eTxyL;
+
+ CCTK_REAL const T13 = eTxzL;
+
+ CCTK_REAL const T22 = eTyyL;
+
+ CCTK_REAL const T23 = eTyzL;
+
+ CCTK_REAL const T33 = eTzzL;
+
+ CCTK_REAL const S1 = (-T01 + beta1L*T11 + beta2L*T12 + beta3L*T13)*INV(alphaL);
+
+ CCTK_REAL const S2 = (-T02 + beta1L*T12 + beta2L*T22 + beta3L*T23)*INV(alphaL);
+
+ CCTK_REAL const S3 = (-T03 + beta1L*T13 + beta2L*T23 + beta3L*T33)*INV(alphaL);
+
+ CCTK_REAL const phirhsL = PDupwindNth1(phi, i, j, k)*beta1L + PDupwindNth2(phi, i, j, k)*beta2L +
+ PDupwindNth3(phi, i, j, k)*beta3L + (PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3)*
+ IfThen(conformalMethod,-(kthird*phiL),0.16666666666666666) +
+ alphaL*trKL*IfThen(conformalMethod,kthird*phiL,-0.16666666666666666);
+
+ CCTK_REAL const gt11rhsL = -2*alphaL*At11L + PDupwindNth1(gt11, i, j, k)*beta1L + PDupwindNth2(gt11, i, j, k)*beta2L +
+ PDupwindNth3(gt11, i, j, k)*beta3L + 2*(gt12L*PDstandardNth1beta2 + gt13L*PDstandardNth1beta3) +
+ gt11L*(kfourthird*PDstandardNth1beta1 - ktwothird*PDstandardNth2beta2 - ktwothird*PDstandardNth3beta3);
+
+ CCTK_REAL const gt12rhsL = -2*alphaL*At12L + PDupwindNth1(gt12, i, j, k)*beta1L + PDupwindNth2(gt12, i, j, k)*beta2L +
+ PDupwindNth3(gt12, i, j, k)*beta3L + gt22L*PDstandardNth1beta2 + gt23L*PDstandardNth1beta3 +
+ gt11L*PDstandardNth2beta1 + gt13L*PDstandardNth2beta3 +
+ gt12L*(kthird*(PDstandardNth1beta1 + PDstandardNth2beta2) - ktwothird*PDstandardNth3beta3);
+
+ CCTK_REAL const gt13rhsL = -2*alphaL*At13L + PDupwindNth1(gt13, i, j, k)*beta1L + PDupwindNth2(gt13, i, j, k)*beta2L +
+ PDupwindNth3(gt13, i, j, k)*beta3L + gt23L*PDstandardNth1beta2 + gt33L*PDstandardNth1beta3 +
+ gt11L*PDstandardNth3beta1 + gt12L*PDstandardNth3beta2 +
+ gt13L*(-(ktwothird*PDstandardNth2beta2) + kthird*(PDstandardNth1beta1 + PDstandardNth3beta3));
+
+ CCTK_REAL const gt22rhsL = -2*alphaL*At22L + PDupwindNth1(gt22, i, j, k)*beta1L + PDupwindNth2(gt22, i, j, k)*beta2L +
+ PDupwindNth3(gt22, i, j, k)*beta3L + 2*(gt12L*PDstandardNth2beta1 + gt23L*PDstandardNth2beta3) +
+ gt22L*(-(ktwothird*PDstandardNth1beta1) + kfourthird*PDstandardNth2beta2 - ktwothird*PDstandardNth3beta3);
+
+ CCTK_REAL const gt23rhsL = -2*alphaL*At23L + PDupwindNth1(gt23, i, j, k)*beta1L + PDupwindNth2(gt23, i, j, k)*beta2L +
+ PDupwindNth3(gt23, i, j, k)*beta3L + gt13L*PDstandardNth2beta1 + gt33L*PDstandardNth2beta3 +
+ gt12L*PDstandardNth3beta1 + gt22L*PDstandardNth3beta2 +
+ gt23L*(-(ktwothird*PDstandardNth1beta1) + kthird*(PDstandardNth2beta2 + PDstandardNth3beta3));
+
+ CCTK_REAL const gt33rhsL = -2*alphaL*At33L + PDupwindNth1(gt33, i, j, k)*beta1L + PDupwindNth2(gt33, i, j, k)*beta2L +
+ PDupwindNth3(gt33, i, j, k)*beta3L - gt33L*ktwothird*PDstandardNth1beta1 - gt33L*ktwothird*PDstandardNth2beta2 +
+ 2*gt13L*PDstandardNth3beta1 + 2*gt23L*PDstandardNth3beta2 + gt33L*kfourthird*PDstandardNth3beta3;
+
+ CCTK_REAL const Xt1rhsL = kthird*(7*(gtu21*PDstandardNth12beta1 + gtu31*PDstandardNth13beta1) +
+ gtu11*(4*PDstandardNth11beta1 + PDstandardNth12beta2 + PDstandardNth13beta3) +
+ gtu21*(PDstandardNth22beta2 + PDstandardNth23beta3) +
+ 3*(PDupwindNth1(Xt1, i, j, k)*beta1L + PDupwindNth2(Xt1, i, j, k)*beta2L +
+ PDupwindNth3(Xt1, i, j, k)*beta3L + gtu22*PDstandardNth22beta1 + gtu33*PDstandardNth33beta1) +
+ gtu31*(PDstandardNth23beta2 + PDstandardNth33beta3) -
+ 6*(Atu11*PDstandardNth1alpha + Atu21*PDstandardNth2alpha + Atu31*PDstandardNth3alpha) +
+ 6*(gtu32*PDstandardNth23beta1 + alphaL*(6*(Atu11*cdphi1 + Atu21*cdphi2 + Atu31*cdphi3) + Atu11*Gt111 +
+ Atu22*Gt122 + 2*(Atu21*Gt112 + Atu31*Gt113 + Atu32*Gt123) + Atu33*Gt133 -
+ ktwothird*(gtu11*PDstandardNth1trK + gtu21*PDstandardNth2trK + gtu31*PDstandardNth3trK))) -
+ 150.7964473723100754462068823974161384415*alphaL*(gtu11*S1 + gtu21*S2 + gtu31*S3) +
+ (-3*PDstandardNth1beta1 + 2*(PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3))*Xtn1 -
+ 3*(PDstandardNth2beta1*Xtn2 + PDstandardNth3beta1*Xtn3));
+
+ CCTK_REAL const Xt2rhsL = kthird*(gtu21*(PDstandardNth11beta1 + 7*PDstandardNth12beta2 + PDstandardNth13beta3) +
+ gtu22*(PDstandardNth12beta1 + 4*PDstandardNth22beta2 + PDstandardNth23beta3) +
+ 3*(PDupwindNth1(Xt2, i, j, k)*beta1L + PDupwindNth2(Xt2, i, j, k)*beta2L +
+ PDupwindNth3(Xt2, i, j, k)*beta3L + gtu11*PDstandardNth11beta2 + gtu33*PDstandardNth33beta2) +
+ gtu32*(PDstandardNth13beta1 + 7*PDstandardNth23beta2 + PDstandardNth33beta3) -
+ 6*(Atu21*PDstandardNth1alpha + Atu22*PDstandardNth2alpha + Atu32*PDstandardNth3alpha) +
+ 6*(gtu31*PDstandardNth13beta2 + alphaL*(6*(Atu21*cdphi1 + Atu22*cdphi2 + Atu32*cdphi3) + Atu11*Gt211 +
+ Atu22*Gt222 + 2*(Atu21*Gt212 + Atu31*Gt213 + Atu32*Gt223) + Atu33*Gt233 -
+ ktwothird*(gtu21*PDstandardNth1trK + gtu22*PDstandardNth2trK + gtu32*PDstandardNth3trK))) -
+ 150.7964473723100754462068823974161384415*alphaL*(gtu21*S1 + gtu22*S2 + gtu32*S3) +
+ 2*(PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3)*Xtn2 -
+ 3*(PDstandardNth1beta2*Xtn1 + PDstandardNth2beta2*Xtn2 + PDstandardNth3beta2*Xtn3));
+
+ CCTK_REAL const Xt3rhsL = kthird*(gtu31*(PDstandardNth11beta1 + PDstandardNth12beta2 + 7*PDstandardNth13beta3) +
+ 3*(PDupwindNth1(Xt3, i, j, k)*beta1L + PDupwindNth2(Xt3, i, j, k)*beta2L +
+ PDupwindNth3(Xt3, i, j, k)*beta3L + gtu11*PDstandardNth11beta3 + gtu22*PDstandardNth22beta3) +
+ gtu32*(PDstandardNth12beta1 + PDstandardNth22beta2 + 7*PDstandardNth23beta3) +
+ gtu33*(PDstandardNth13beta1 + PDstandardNth23beta2 + 4*PDstandardNth33beta3) -
+ 6*(Atu31*PDstandardNth1alpha + Atu32*PDstandardNth2alpha + Atu33*PDstandardNth3alpha) +
+ 6*(gtu21*PDstandardNth12beta3 + alphaL*(6*(Atu31*cdphi1 + Atu32*cdphi2 + Atu33*cdphi3) + Atu11*Gt311 +
+ Atu22*Gt322 + 2*(Atu21*Gt312 + Atu31*Gt313 + Atu32*Gt323) + Atu33*Gt333 -
+ ktwothird*(gtu31*PDstandardNth1trK + gtu32*PDstandardNth2trK + gtu33*PDstandardNth3trK))) -
+ 150.7964473723100754462068823974161384415*alphaL*(gtu31*S1 + gtu32*S2 + gtu33*S3) +
+ 2*(PDstandardNth1beta1 + PDstandardNth2beta2 + PDstandardNth3beta3)*Xtn3 -
+ 3*(PDstandardNth1beta3*Xtn1 + PDstandardNth2beta3*Xtn2 + PDstandardNth3beta3*Xtn3));
+
+ CCTK_REAL const beta1rhsL = (PDupwindNth1(beta1, i, j, k)*beta1L + PDupwindNth2(beta1, i, j, k)*beta2L +
+ PDupwindNth3(beta1, i, j, k)*beta3L)*ShiftAdvectionCoeff + B1L*ShiftGammaCoeff;
+
+ CCTK_REAL const beta2rhsL = (PDupwindNth1(beta2, i, j, k)*beta1L + PDupwindNth2(beta2, i, j, k)*beta2L +
+ PDupwindNth3(beta2, i, j, k)*beta3L)*ShiftAdvectionCoeff + B2L*ShiftGammaCoeff;
+
+ CCTK_REAL const beta3rhsL = (PDupwindNth1(beta3, i, j, k)*beta1L + PDupwindNth2(beta3, i, j, k)*beta2L +
+ PDupwindNth3(beta3, i, j, k)*beta3L)*ShiftAdvectionCoeff + B3L*ShiftGammaCoeff;
+
+ CCTK_REAL const B1rhsL = -(B1L*etaL) + ((PDupwindNth1(B1, i, j, k) - PDupwindNth1(Xt1, i, j, k))*beta1L +
+ (PDupwindNth2(B1, i, j, k) - PDupwindNth2(Xt1, i, j, k))*beta2L +
+ (PDupwindNth3(B1, i, j, k) - PDupwindNth3(Xt1, i, j, k))*beta3L)*ShiftAdvectionCoeff + Xt1rhsL;
+
+ CCTK_REAL const B2rhsL = -(B2L*etaL) + ((PDupwindNth1(B2, i, j, k) - PDupwindNth1(Xt2, i, j, k))*beta1L +
+ (PDupwindNth2(B2, i, j, k) - PDupwindNth2(Xt2, i, j, k))*beta2L +
+ (PDupwindNth3(B2, i, j, k) - PDupwindNth3(Xt2, i, j, k))*beta3L)*ShiftAdvectionCoeff + Xt2rhsL;
+
+ CCTK_REAL const B3rhsL = -(B3L*etaL) + ((PDupwindNth1(B3, i, j, k) - PDupwindNth1(Xt3, i, j, k))*beta1L +
+ (PDupwindNth2(B3, i, j, k) - PDupwindNth2(Xt3, i, j, k))*beta2L +
+ (PDupwindNth3(B3, i, j, k) - PDupwindNth3(Xt3, i, j, k))*beta3L)*ShiftAdvectionCoeff + Xt3rhsL;
+
+
+ /* Copy local copies back to grid functions */
+ B1rhs[index] = B1rhsL;
+ B2rhs[index] = B2rhsL;
+ B3rhs[index] = B3rhsL;
+ beta1rhs[index] = beta1rhsL;
+ beta2rhs[index] = beta2rhsL;
+ beta3rhs[index] = beta3rhsL;
+ gt11rhs[index] = gt11rhsL;
+ gt12rhs[index] = gt12rhsL;
+ gt13rhs[index] = gt13rhsL;
+ gt22rhs[index] = gt22rhsL;
+ gt23rhs[index] = gt23rhsL;
+ gt33rhs[index] = gt33rhsL;
+ phirhs[index] = phirhsL;
+ Xt1rhs[index] = Xt1rhsL;
+ Xt2rhs[index] = Xt2rhsL;
+ Xt3rhs[index] = Xt3rhsL;
+
+ /* Copy local copies back to subblock grid functions */
+ }
+ LC_ENDLOOP3 (ML_BSSN_RHS1);
+}
+
+void ML_BSSN_RHS1(CCTK_ARGUMENTS)
+{
+ DECLARE_CCTK_ARGUMENTS;
+ DECLARE_CCTK_PARAMETERS;
+
+ GenericFD_LoopOverInterior(cctkGH, &ML_BSSN_RHS1_Body);
+}
diff --git a/ML_BSSN/src/ML_BSSN_RHS2.c b/ML_BSSN/src/ML_BSSN_RHS2.c
new file mode 100644
index 0000000..a8ff2dc
--- /dev/null
+++ b/ML_BSSN/src/ML_BSSN_RHS2.c
@@ -0,0 +1,878 @@
+/* File produced by Kranc */
+
+#define KRANC_C
+
+#include <assert.h>
+#include <math.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include "cctk.h"
+#include "cctk_Arguments.h"
+#include "cctk_Parameters.h"
+#include "GenericFD.h"
+#include "Differencing.h"
+#include "loopcontrol.h"
+
+/* Define macros used in calculations */
+#define INITVALUE (42)
+#define INV(x) ((1.0) / (x))
+#define SQR(x) ((x) * (x))
+#define CUB(x) ((x) * (x) * (x))
+#define QAD(x) ((x) * (x) * (x) * (x))
+
+void ML_BSSN_RHS2_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
+{
+ DECLARE_CCTK_ARGUMENTS;
+ DECLARE_CCTK_PARAMETERS;
+
+
+ /* Declare finite differencing variables */
+
+ /* Declare predefined quantities */
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
+
+ if (verbose > 1)
+ {
+ CCTK_VInfo(CCTK_THORNSTRING,"Entering ML_BSSN_RHS2_Body");
+ }
+
+ if (cctk_iteration % ML_BSSN_RHS2_calc_every != ML_BSSN_RHS2_calc_offset)
+ {
+ return;
+ }
+
+ /* Include user-supplied include files */
+
+ /* Initialise finite differencing variables */
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
+
+ /* Initialize predefined quantities */
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
+
+ /* Loop over the grid points */
+ #pragma omp parallel
+ LC_LOOP3 (ML_BSSN_RHS2,
+ i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
+ cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
+ {
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+
+ /* Declare shorthands */
+ // CCTK_REAL Atm11 = INITVALUE, Atm12 = INITVALUE, Atm13 = INITVALUE, Atm21 = INITVALUE, Atm22 = INITVALUE, Atm23 = INITVALUE;
+ // CCTK_REAL Atm31 = INITVALUE, Atm32 = INITVALUE, Atm33 = INITVALUE;
+ // CCTK_REAL Ats11 = INITVALUE, Ats12 = INITVALUE, Ats13 = INITVALUE, Ats22 = INITVALUE, Ats23 = INITVALUE, Ats33 = INITVALUE;
+ // CCTK_REAL cdphi1 = INITVALUE, cdphi2 = INITVALUE, cdphi211 = INITVALUE, cdphi212 = INITVALUE, cdphi213 = INITVALUE, cdphi222 = INITVALUE;
+ // CCTK_REAL cdphi223 = INITVALUE, cdphi233 = INITVALUE, cdphi3 = INITVALUE;
+ // CCTK_REAL detgt = INITVALUE;
+ // CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
+ // CCTK_REAL e4phi = INITVALUE;
+ // CCTK_REAL em4phi = INITVALUE;
+ // CCTK_REAL fac1 = INITVALUE, fac2 = INITVALUE;
+ // CCTK_REAL g11 = INITVALUE;
+ // CCTK_REAL G111 = INITVALUE, G112 = INITVALUE, G113 = INITVALUE;
+ // CCTK_REAL g12 = INITVALUE;
+ // CCTK_REAL G122 = INITVALUE, G123 = INITVALUE;
+ // CCTK_REAL g13 = INITVALUE;
+ // CCTK_REAL G133 = INITVALUE, G211 = INITVALUE, G212 = INITVALUE, G213 = INITVALUE;
+ // CCTK_REAL g22 = INITVALUE;
+ // CCTK_REAL G222 = INITVALUE, G223 = INITVALUE;
+ // CCTK_REAL g23 = INITVALUE;
+ // CCTK_REAL G233 = INITVALUE, G311 = INITVALUE, G312 = INITVALUE, G313 = INITVALUE, G322 = INITVALUE, G323 = INITVALUE;
+ // CCTK_REAL g33 = INITVALUE;
+ // CCTK_REAL G333 = INITVALUE;
+ // CCTK_REAL Gt111 = INITVALUE, Gt112 = INITVALUE, Gt113 = INITVALUE, Gt122 = INITVALUE, Gt123 = INITVALUE, Gt133 = INITVALUE;
+ // CCTK_REAL Gt211 = INITVALUE, Gt212 = INITVALUE, Gt213 = INITVALUE, Gt222 = INITVALUE, Gt223 = INITVALUE, Gt233 = INITVALUE;
+ // CCTK_REAL Gt311 = INITVALUE, Gt312 = INITVALUE, Gt313 = INITVALUE, Gt322 = INITVALUE, Gt323 = INITVALUE, Gt333 = INITVALUE;
+ // CCTK_REAL Gtl111 = INITVALUE, Gtl112 = INITVALUE, Gtl113 = INITVALUE, Gtl122 = INITVALUE, Gtl123 = INITVALUE, Gtl133 = INITVALUE;
+ // CCTK_REAL Gtl211 = INITVALUE, Gtl212 = INITVALUE, Gtl213 = INITVALUE, Gtl222 = INITVALUE, Gtl223 = INITVALUE, Gtl233 = INITVALUE;
+ // CCTK_REAL Gtl311 = INITVALUE, Gtl312 = INITVALUE, Gtl313 = INITVALUE, Gtl322 = INITVALUE, Gtl323 = INITVALUE, Gtl333 = INITVALUE;
+ // CCTK_REAL Gtlu111 = INITVALUE, Gtlu112 = INITVALUE, Gtlu113 = INITVALUE, Gtlu121 = INITVALUE, Gtlu122 = INITVALUE, Gtlu123 = INITVALUE;
+ // CCTK_REAL Gtlu131 = INITVALUE, Gtlu132 = INITVALUE, Gtlu133 = INITVALUE, Gtlu211 = INITVALUE, Gtlu212 = INITVALUE, Gtlu213 = INITVALUE;
+ // CCTK_REAL Gtlu221 = INITVALUE, Gtlu222 = INITVALUE, Gtlu223 = INITVALUE, Gtlu231 = INITVALUE, Gtlu232 = INITVALUE, Gtlu233 = INITVALUE;
+ // CCTK_REAL Gtlu311 = INITVALUE, Gtlu312 = INITVALUE, Gtlu313 = INITVALUE, Gtlu321 = INITVALUE, Gtlu322 = INITVALUE, Gtlu323 = INITVALUE;
+ // CCTK_REAL Gtlu331 = INITVALUE, Gtlu332 = INITVALUE, Gtlu333 = INITVALUE;
+ // CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
+ // CCTK_REAL gu11 = INITVALUE, gu21 = INITVALUE, gu22 = INITVALUE, gu31 = INITVALUE, gu32 = INITVALUE, gu33 = INITVALUE;
+ // CCTK_REAL R11 = INITVALUE, R12 = INITVALUE, R13 = INITVALUE, R22 = INITVALUE, R23 = INITVALUE, R33 = INITVALUE;
+ // CCTK_REAL rho = INITVALUE;
+ // CCTK_REAL Rphi11 = INITVALUE, Rphi12 = INITVALUE, Rphi13 = INITVALUE, Rphi22 = INITVALUE, Rphi23 = INITVALUE, Rphi33 = INITVALUE;
+ // CCTK_REAL Rt11 = INITVALUE, Rt12 = INITVALUE, Rt13 = INITVALUE, Rt22 = INITVALUE, Rt23 = INITVALUE, Rt33 = INITVALUE;
+ // CCTK_REAL T00 = INITVALUE, T01 = INITVALUE, T02 = INITVALUE, T03 = INITVALUE, T11 = INITVALUE, T12 = INITVALUE;
+ // CCTK_REAL T13 = INITVALUE, T22 = INITVALUE, T23 = INITVALUE, T33 = INITVALUE;
+ // CCTK_REAL trAts = INITVALUE;
+ // CCTK_REAL trS = INITVALUE;
+ // CCTK_REAL Xtn1 = INITVALUE, Xtn2 = INITVALUE, Xtn3 = INITVALUE;
+
+ /* Declare local copies of grid functions */
+ // CCTK_REAL AL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE, alpharhsL = INITVALUE;
+ // CCTK_REAL ArhsL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At11rhsL = INITVALUE, At12L = INITVALUE, At12rhsL = INITVALUE, At13L = INITVALUE, At13rhsL = INITVALUE;
+ // CCTK_REAL At22L = INITVALUE, At22rhsL = INITVALUE, At23L = INITVALUE, At23rhsL = INITVALUE, At33L = INITVALUE, At33rhsL = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
+ // CCTK_REAL eTttL = INITVALUE;
+ // CCTK_REAL eTtxL = INITVALUE;
+ // CCTK_REAL eTtyL = INITVALUE;
+ // CCTK_REAL eTtzL = INITVALUE;
+ // CCTK_REAL eTxxL = INITVALUE;
+ // CCTK_REAL eTxyL = INITVALUE;
+ // CCTK_REAL eTxzL = INITVALUE;
+ // CCTK_REAL eTyyL = INITVALUE;
+ // CCTK_REAL eTyzL = INITVALUE;
+ // CCTK_REAL eTzzL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
+ // CCTK_REAL phiL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE, trKrhsL = INITVALUE;
+ // CCTK_REAL Xt1L = INITVALUE, Xt2L = INITVALUE, Xt3L = INITVALUE;
+ /* Declare precomputed derivatives*/
+
+ /* Declare derivatives */
+ // CCTK_REAL PDstandardNth1alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth2alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth3alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth11alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth22alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth33alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth12alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth13alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth23alpha = INITVALUE;
+ // CCTK_REAL PDstandardNth1beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth2beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth3beta1 = INITVALUE;
+ // CCTK_REAL PDstandardNth1beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth2beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth3beta2 = INITVALUE;
+ // CCTK_REAL PDstandardNth1beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth2beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth3beta3 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth1phi = INITVALUE;
+ // CCTK_REAL PDstandardNth2phi = INITVALUE;
+ // CCTK_REAL PDstandardNth3phi = INITVALUE;
+ // CCTK_REAL PDstandardNth11phi = INITVALUE;
+ // CCTK_REAL PDstandardNth22phi = INITVALUE;
+ // CCTK_REAL PDstandardNth33phi = INITVALUE;
+ // CCTK_REAL PDstandardNth12phi = INITVALUE;
+ // CCTK_REAL PDstandardNth13phi = INITVALUE;
+ // CCTK_REAL PDstandardNth23phi = INITVALUE;
+ // CCTK_REAL PDstandardNth1Xt1 = INITVALUE;
+ // CCTK_REAL PDstandardNth2Xt1 = INITVALUE;
+ // CCTK_REAL PDstandardNth3Xt1 = INITVALUE;
+ // CCTK_REAL PDstandardNth1Xt2 = INITVALUE;
+ // CCTK_REAL PDstandardNth2Xt2 = INITVALUE;
+ // CCTK_REAL PDstandardNth3Xt2 = INITVALUE;
+ // CCTK_REAL PDstandardNth1Xt3 = INITVALUE;
+ // CCTK_REAL PDstandardNth2Xt3 = INITVALUE;
+ // CCTK_REAL PDstandardNth3Xt3 = INITVALUE;
+
+ /* Assign local copies of grid functions */
+ CCTK_REAL const AL = A[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const At11L = At11[index];
+ CCTK_REAL const At12L = At12[index];
+ CCTK_REAL const At13L = At13[index];
+ CCTK_REAL const At22L = At22[index];
+ CCTK_REAL const At23L = At23[index];
+ CCTK_REAL const At33L = At33[index];
+ CCTK_REAL const beta1L = beta1[index];
+ CCTK_REAL const beta2L = beta2[index];
+ CCTK_REAL const beta3L = beta3[index];
+ CCTK_REAL const eTttL = (stress_energy_state) ? (eTtt[index]) : 0.0;
+ CCTK_REAL const eTtxL = (stress_energy_state) ? (eTtx[index]) : 0.0;
+ CCTK_REAL const eTtyL = (stress_energy_state) ? (eTty[index]) : 0.0;
+ CCTK_REAL const eTtzL = (stress_energy_state) ? (eTtz[index]) : 0.0;
+ CCTK_REAL const eTxxL = (stress_energy_state) ? (eTxx[index]) : 0.0;
+ CCTK_REAL const eTxyL = (stress_energy_state) ? (eTxy[index]) : 0.0;
+ CCTK_REAL const eTxzL = (stress_energy_state) ? (eTxz[index]) : 0.0;
+ CCTK_REAL const eTyyL = (stress_energy_state) ? (eTyy[index]) : 0.0;
+ CCTK_REAL const eTyzL = (stress_energy_state) ? (eTyz[index]) : 0.0;
+ CCTK_REAL const eTzzL = (stress_energy_state) ? (eTzz[index]) : 0.0;
+ CCTK_REAL const gt11L = gt11[index];
+ CCTK_REAL const gt12L = gt12[index];
+ CCTK_REAL const gt13L = gt13[index];
+ CCTK_REAL const gt22L = gt22[index];
+ CCTK_REAL const gt23L = gt23[index];
+ CCTK_REAL const gt33L = gt33[index];
+ CCTK_REAL const phiL = phi[index];
+ CCTK_REAL const trKL = trK[index];
+ CCTK_REAL const Xt1L = Xt1[index];
+ CCTK_REAL const Xt2L = Xt2[index];
+ CCTK_REAL const Xt3L = Xt3[index];
+
+ /* Assign local copies of subblock grid functions */
+
+ /* Include user supplied include files */
+
+ /* Precompute derivatives (new style) */
+ CCTK_REAL const PDstandardNth1alpha = PDstandardNth1(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth2alpha = PDstandardNth2(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth3alpha = PDstandardNth3(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth11alpha = PDstandardNth11(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth22alpha = PDstandardNth22(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth33alpha = PDstandardNth33(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth12alpha = PDstandardNth12(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth13alpha = PDstandardNth13(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth23alpha = PDstandardNth23(alpha, i, j, k);
+ CCTK_REAL const PDstandardNth1beta1 = PDstandardNth1(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth2beta1 = PDstandardNth2(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth3beta1 = PDstandardNth3(beta1, i, j, k);
+ CCTK_REAL const PDstandardNth1beta2 = PDstandardNth1(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth2beta2 = PDstandardNth2(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth3beta2 = PDstandardNth3(beta2, i, j, k);
+ CCTK_REAL const PDstandardNth1beta3 = PDstandardNth1(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth2beta3 = PDstandardNth2(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth3beta3 = PDstandardNth3(beta3, i, j, k);
+ CCTK_REAL const PDstandardNth1gt11 = PDstandardNth1(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth2gt11 = PDstandardNth2(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth3gt11 = PDstandardNth3(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth11gt11 = PDstandardNth11(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth22gt11 = PDstandardNth22(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth33gt11 = PDstandardNth33(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth12gt11 = PDstandardNth12(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth13gt11 = PDstandardNth13(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth23gt11 = PDstandardNth23(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth1gt12 = PDstandardNth1(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth2gt12 = PDstandardNth2(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth3gt12 = PDstandardNth3(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth11gt12 = PDstandardNth11(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth22gt12 = PDstandardNth22(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth33gt12 = PDstandardNth33(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth12gt12 = PDstandardNth12(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth13gt12 = PDstandardNth13(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth23gt12 = PDstandardNth23(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth1gt13 = PDstandardNth1(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth2gt13 = PDstandardNth2(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth3gt13 = PDstandardNth3(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth11gt13 = PDstandardNth11(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth22gt13 = PDstandardNth22(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth33gt13 = PDstandardNth33(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth12gt13 = PDstandardNth12(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth13gt13 = PDstandardNth13(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth23gt13 = PDstandardNth23(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth1gt22 = PDstandardNth1(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth2gt22 = PDstandardNth2(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth3gt22 = PDstandardNth3(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth11gt22 = PDstandardNth11(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth22gt22 = PDstandardNth22(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth33gt22 = PDstandardNth33(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth12gt22 = PDstandardNth12(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth13gt22 = PDstandardNth13(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth23gt22 = PDstandardNth23(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth1gt23 = PDstandardNth1(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth2gt23 = PDstandardNth2(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth3gt23 = PDstandardNth3(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth11gt23 = PDstandardNth11(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth22gt23 = PDstandardNth22(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth33gt23 = PDstandardNth33(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth12gt23 = PDstandardNth12(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth13gt23 = PDstandardNth13(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth23gt23 = PDstandardNth23(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth1gt33 = PDstandardNth1(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth2gt33 = PDstandardNth2(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth3gt33 = PDstandardNth3(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth11gt33 = PDstandardNth11(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth22gt33 = PDstandardNth22(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth33gt33 = PDstandardNth33(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth12gt33 = PDstandardNth12(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth13gt33 = PDstandardNth13(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth23gt33 = PDstandardNth23(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth1phi = PDstandardNth1(phi, i, j, k);
+ CCTK_REAL const PDstandardNth2phi = PDstandardNth2(phi, i, j, k);
+ CCTK_REAL const PDstandardNth3phi = PDstandardNth3(phi, i, j, k);
+ CCTK_REAL const PDstandardNth11phi = PDstandardNth11(phi, i, j, k);
+ CCTK_REAL const PDstandardNth22phi = PDstandardNth22(phi, i, j, k);
+ CCTK_REAL const PDstandardNth33phi = PDstandardNth33(phi, i, j, k);
+ CCTK_REAL const PDstandardNth12phi = PDstandardNth12(phi, i, j, k);
+ CCTK_REAL const PDstandardNth13phi = PDstandardNth13(phi, i, j, k);
+ CCTK_REAL const PDstandardNth23phi = PDstandardNth23(phi, i, j, k);
+ CCTK_REAL const PDstandardNth1Xt1 = PDstandardNth1(Xt1, i, j, k);
+ CCTK_REAL const PDstandardNth2Xt1 = PDstandardNth2(Xt1, i, j, k);
+ CCTK_REAL const PDstandardNth3Xt1 = PDstandardNth3(Xt1, i, j, k);
+ CCTK_REAL const PDstandardNth1Xt2 = PDstandardNth1(Xt2, i, j, k);
+ CCTK_REAL const PDstandardNth2Xt2 = PDstandardNth2(Xt2, i, j, k);
+ CCTK_REAL const PDstandardNth3Xt2 = PDstandardNth3(Xt2, i, j, k);
+ CCTK_REAL const PDstandardNth1Xt3 = PDstandardNth1(Xt3, i, j, k);
+ CCTK_REAL const PDstandardNth2Xt3 = PDstandardNth2(Xt3, i, j, k);
+ CCTK_REAL const PDstandardNth3Xt3 = PDstandardNth3(Xt3, i, j, k);
+
+ /* Precompute derivatives (old style) */
+
+ /* Calculate temporaries and grid functions */
+ int const dir1 = Sign(beta1L);
+
+ int const dir2 = Sign(beta2L);
+
+ int const dir3 = Sign(beta3L);
+
+ CCTK_REAL const detgt = 1;
+
+ CCTK_REAL const gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
+
+ CCTK_REAL const gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
+
+ CCTK_REAL const gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
+
+ CCTK_REAL const gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
+
+ CCTK_REAL const gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
+
+ CCTK_REAL const gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
+
+ CCTK_REAL const Gtl111 = khalf*PDstandardNth1gt11;
+
+ CCTK_REAL const Gtl112 = khalf*PDstandardNth2gt11;
+
+ CCTK_REAL const Gtl113 = khalf*PDstandardNth3gt11;
+
+ CCTK_REAL const Gtl122 = -(khalf*PDstandardNth1gt22) + PDstandardNth2gt12;
+
+ CCTK_REAL const Gtl123 = khalf*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12);
+
+ CCTK_REAL const Gtl133 = -(khalf*PDstandardNth1gt33) + PDstandardNth3gt13;
+
+ CCTK_REAL const Gtl211 = PDstandardNth1gt12 - khalf*PDstandardNth2gt11;
+
+ CCTK_REAL const Gtl212 = khalf*PDstandardNth1gt22;
+
+ CCTK_REAL const Gtl213 = khalf*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12);
+
+ CCTK_REAL const Gtl222 = khalf*PDstandardNth2gt22;
+
+ CCTK_REAL const Gtl223 = khalf*PDstandardNth3gt22;
+
+ CCTK_REAL const Gtl233 = -(khalf*PDstandardNth2gt33) + PDstandardNth3gt23;
+
+ CCTK_REAL const Gtl311 = PDstandardNth1gt13 - khalf*PDstandardNth3gt11;
+
+ CCTK_REAL const Gtl312 = khalf*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12);
+
+ CCTK_REAL const Gtl313 = khalf*PDstandardNth1gt33;
+
+ CCTK_REAL const Gtl322 = PDstandardNth2gt23 - khalf*PDstandardNth3gt22;
+
+ CCTK_REAL const Gtl323 = khalf*PDstandardNth2gt33;
+
+ CCTK_REAL const Gtl333 = khalf*PDstandardNth3gt33;
+
+ CCTK_REAL const Gtlu111 = Gtl111*gtu11 + Gtl112*gtu21 + Gtl113*gtu31;
+
+ CCTK_REAL const Gtlu112 = Gtl111*gtu21 + Gtl112*gtu22 + Gtl113*gtu32;
+
+ CCTK_REAL const Gtlu113 = Gtl111*gtu31 + Gtl112*gtu32 + Gtl113*gtu33;
+
+ CCTK_REAL const Gtlu121 = Gtl112*gtu11 + Gtl122*gtu21 + Gtl123*gtu31;
+
+ CCTK_REAL const Gtlu122 = Gtl112*gtu21 + Gtl122*gtu22 + Gtl123*gtu32;
+
+ CCTK_REAL const Gtlu123 = Gtl112*gtu31 + Gtl122*gtu32 + Gtl123*gtu33;
+
+ CCTK_REAL const Gtlu131 = Gtl113*gtu11 + Gtl123*gtu21 + Gtl133*gtu31;
+
+ CCTK_REAL const Gtlu132 = Gtl113*gtu21 + Gtl123*gtu22 + Gtl133*gtu32;
+
+ CCTK_REAL const Gtlu133 = Gtl113*gtu31 + Gtl123*gtu32 + Gtl133*gtu33;
+
+ CCTK_REAL const Gtlu211 = Gtl211*gtu11 + Gtl212*gtu21 + Gtl213*gtu31;
+
+ CCTK_REAL const Gtlu212 = Gtl211*gtu21 + Gtl212*gtu22 + Gtl213*gtu32;
+
+ CCTK_REAL const Gtlu213 = Gtl211*gtu31 + Gtl212*gtu32 + Gtl213*gtu33;
+
+ CCTK_REAL const Gtlu221 = Gtl212*gtu11 + Gtl222*gtu21 + Gtl223*gtu31;
+
+ CCTK_REAL const Gtlu222 = Gtl212*gtu21 + Gtl222*gtu22 + Gtl223*gtu32;
+
+ CCTK_REAL const Gtlu223 = Gtl212*gtu31 + Gtl222*gtu32 + Gtl223*gtu33;
+
+ CCTK_REAL const Gtlu231 = Gtl213*gtu11 + Gtl223*gtu21 + Gtl233*gtu31;
+
+ CCTK_REAL const Gtlu232 = Gtl213*gtu21 + Gtl223*gtu22 + Gtl233*gtu32;
+
+ CCTK_REAL const Gtlu233 = Gtl213*gtu31 + Gtl223*gtu32 + Gtl233*gtu33;
+
+ CCTK_REAL const Gtlu311 = Gtl311*gtu11 + Gtl312*gtu21 + Gtl313*gtu31;
+
+ CCTK_REAL const Gtlu312 = Gtl311*gtu21 + Gtl312*gtu22 + Gtl313*gtu32;
+
+ CCTK_REAL const Gtlu313 = Gtl311*gtu31 + Gtl312*gtu32 + Gtl313*gtu33;
+
+ CCTK_REAL const Gtlu321 = Gtl312*gtu11 + Gtl322*gtu21 + Gtl323*gtu31;
+
+ CCTK_REAL const Gtlu322 = Gtl312*gtu21 + Gtl322*gtu22 + Gtl323*gtu32;
+
+ CCTK_REAL const Gtlu323 = Gtl312*gtu31 + Gtl322*gtu32 + Gtl323*gtu33;
+
+ CCTK_REAL const Gtlu331 = Gtl313*gtu11 + Gtl323*gtu21 + Gtl333*gtu31;
+
+ CCTK_REAL const Gtlu332 = Gtl313*gtu21 + Gtl323*gtu22 + Gtl333*gtu32;
+
+ CCTK_REAL const Gtlu333 = Gtl313*gtu31 + Gtl323*gtu32 + Gtl333*gtu33;
+
+ CCTK_REAL const Gt111 = Gtl111*gtu11 + Gtl211*gtu21 + Gtl311*gtu31;
+
+ CCTK_REAL const Gt211 = Gtl111*gtu21 + Gtl211*gtu22 + Gtl311*gtu32;
+
+ CCTK_REAL const Gt311 = Gtl111*gtu31 + Gtl211*gtu32 + Gtl311*gtu33;
+
+ CCTK_REAL const Gt112 = Gtl112*gtu11 + Gtl212*gtu21 + Gtl312*gtu31;
+
+ CCTK_REAL const Gt212 = Gtl112*gtu21 + Gtl212*gtu22 + Gtl312*gtu32;
+
+ CCTK_REAL const Gt312 = Gtl112*gtu31 + Gtl212*gtu32 + Gtl312*gtu33;
+
+ CCTK_REAL const Gt113 = Gtl113*gtu11 + Gtl213*gtu21 + Gtl313*gtu31;
+
+ CCTK_REAL const Gt213 = Gtl113*gtu21 + Gtl213*gtu22 + Gtl313*gtu32;
+
+ CCTK_REAL const Gt313 = Gtl113*gtu31 + Gtl213*gtu32 + Gtl313*gtu33;
+
+ CCTK_REAL const Gt122 = Gtl122*gtu11 + Gtl222*gtu21 + Gtl322*gtu31;
+
+ CCTK_REAL const Gt222 = Gtl122*gtu21 + Gtl222*gtu22 + Gtl322*gtu32;
+
+ CCTK_REAL const Gt322 = Gtl122*gtu31 + Gtl222*gtu32 + Gtl322*gtu33;
+
+ CCTK_REAL const Gt123 = Gtl123*gtu11 + Gtl223*gtu21 + Gtl323*gtu31;
+
+ CCTK_REAL const Gt223 = Gtl123*gtu21 + Gtl223*gtu22 + Gtl323*gtu32;
+
+ CCTK_REAL const Gt323 = Gtl123*gtu31 + Gtl223*gtu32 + Gtl323*gtu33;
+
+ CCTK_REAL const Gt133 = Gtl133*gtu11 + Gtl233*gtu21 + Gtl333*gtu31;
+
+ CCTK_REAL const Gt233 = Gtl133*gtu21 + Gtl233*gtu22 + Gtl333*gtu32;
+
+ CCTK_REAL const Gt333 = Gtl133*gtu31 + Gtl233*gtu32 + Gtl333*gtu33;
+
+ CCTK_REAL const Xtn1 = Gt111*gtu11 + Gt122*gtu22 + 2*(Gt112*gtu21 + Gt113*gtu31 + Gt123*gtu32) + Gt133*gtu33;
+
+ CCTK_REAL const Xtn2 = Gt211*gtu11 + Gt222*gtu22 + 2*(Gt212*gtu21 + Gt213*gtu31 + Gt223*gtu32) + Gt233*gtu33;
+
+ CCTK_REAL const Xtn3 = Gt311*gtu11 + Gt322*gtu22 + 2*(Gt312*gtu21 + Gt313*gtu31 + Gt323*gtu32) + Gt333*gtu33;
+
+ CCTK_REAL const Rt11 = 3*(Gt111*Gtlu111 + Gt112*Gtlu112 + Gt113*Gtlu113) +
+ 2*(Gt211*Gtlu121 + Gt212*Gtlu122 + Gt213*Gtlu123 + Gt311*Gtlu131 + Gt312*Gtlu132 + Gt313*Gtlu133) + Gt211*Gtlu211 +
+ Gt212*Gtlu212 + Gt213*Gtlu213 + Gt311*Gtlu311 + Gt312*Gtlu312 + Gt313*Gtlu313 + gt11L*PDstandardNth1Xt1 +
+ gt12L*PDstandardNth1Xt2 + gt13L*PDstandardNth1Xt3 +
+ khalf*(-(gtu11*PDstandardNth11gt11) - 2*gtu21*PDstandardNth12gt11 - 2*gtu31*PDstandardNth13gt11 -
+ gtu22*PDstandardNth22gt11 - 2*gtu32*PDstandardNth23gt11 - gtu33*PDstandardNth33gt11) + Gtl111*Xtn1 +
+ Gtl112*Xtn2 + Gtl113*Xtn3;
+
+ CCTK_REAL const Rt12 = khalf*(4*(Gt211*Gtlu221 + Gt212*Gtlu222 + Gt213*Gtlu223) +
+ 2*(Gt112*Gtlu111 + Gt122*Gtlu112 + Gt123*Gtlu113 + Gt111*Gtlu121 + Gt212*Gtlu121 + Gt112*Gtlu122 +
+ Gt222*Gtlu122 + Gt113*Gtlu123 + Gt223*Gtlu123 + Gt312*Gtlu131 + Gt322*Gtlu132 + Gt323*Gtlu133 +
+ Gt111*Gtlu211 + Gt112*Gtlu212 + Gt113*Gtlu213 + Gt311*Gtlu231 + Gt312*Gtlu232 + Gt313*Gtlu233 +
+ Gt311*Gtlu321 + Gt312*Gtlu322 + Gt313*Gtlu323) - gtu11*PDstandardNth11gt12 - 2*gtu21*PDstandardNth12gt12 -
+ 2*gtu31*PDstandardNth13gt12 + gt12L*PDstandardNth1Xt1 + gt22L*PDstandardNth1Xt2 + gt23L*PDstandardNth1Xt3 -
+ gtu22*PDstandardNth22gt12 - 2*gtu32*PDstandardNth23gt12 + gt11L*PDstandardNth2Xt1 + gt12L*PDstandardNth2Xt2 +
+ gt13L*PDstandardNth2Xt3 - gtu33*PDstandardNth33gt12 + Gtl112*Xtn1 + Gtl211*Xtn1 + Gtl122*Xtn2 + Gtl212*Xtn2 +
+ Gtl123*Xtn3 + Gtl213*Xtn3);
+
+ CCTK_REAL const Rt13 = khalf*(2*(Gt113*Gtlu111 + Gt123*Gtlu112 + Gt133*Gtlu113 + Gt213*Gtlu121 + Gt223*Gtlu122 + Gt233*Gtlu123 +
+ Gt111*Gtlu131 + Gt313*Gtlu131 + Gt112*Gtlu132 + Gt323*Gtlu132 + Gt113*Gtlu133 + Gt333*Gtlu133 +
+ Gt211*Gtlu231 + Gt212*Gtlu232 + Gt213*Gtlu233 + Gt111*Gtlu311 + Gt112*Gtlu312 + Gt113*Gtlu313 +
+ Gt211*Gtlu321 + Gt212*Gtlu322 + Gt213*Gtlu323) + 4*(Gt311*Gtlu331 + Gt312*Gtlu332 + Gt313*Gtlu333) -
+ gtu11*PDstandardNth11gt13 - 2*gtu21*PDstandardNth12gt13 - 2*gtu31*PDstandardNth13gt13 + gt13L*PDstandardNth1Xt1 +
+ gt23L*PDstandardNth1Xt2 + gt33L*PDstandardNth1Xt3 - gtu22*PDstandardNth22gt13 - 2*gtu32*PDstandardNth23gt13 -
+ gtu33*PDstandardNth33gt13 + gt11L*PDstandardNth3Xt1 + gt12L*PDstandardNth3Xt2 + gt13L*PDstandardNth3Xt3 +
+ Gtl113*Xtn1 + Gtl311*Xtn1 + Gtl123*Xtn2 + Gtl312*Xtn2 + Gtl133*Xtn3 + Gtl313*Xtn3);
+
+ CCTK_REAL const Rt22 = Gt112*(Gtlu121 + 2*Gtlu211) + Gt122*(Gtlu122 + 2*Gtlu212) + Gt123*(Gtlu123 + 2*Gtlu213) +
+ 3*(Gt212*Gtlu221 + Gt222*Gtlu222 + Gt223*Gtlu223) + 2*(Gt312*Gtlu231 + Gt322*Gtlu232 + Gt323*Gtlu233) +
+ Gt312*Gtlu321 + Gt322*Gtlu322 + Gt323*Gtlu323 + gt12L*PDstandardNth2Xt1 + gt22L*PDstandardNth2Xt2 +
+ gt23L*PDstandardNth2Xt3 + khalf*(-(gtu11*PDstandardNth11gt22) - 2*gtu21*PDstandardNth12gt22 -
+ 2*gtu31*PDstandardNth13gt22 - gtu22*PDstandardNth22gt22 - 2*gtu32*PDstandardNth23gt22 - gtu33*PDstandardNth33gt22
+ ) + Gtl212*Xtn1 + Gtl222*Xtn2 + Gtl223*Xtn3;
+
+ CCTK_REAL const Rt23 = khalf*(2*(Gt112*Gtlu131 + Gt122*Gtlu132 + Gt123*Gtlu133 + Gt113*Gtlu211 + Gt123*Gtlu212 + Gt133*Gtlu213 +
+ Gt213*Gtlu221 + Gt223*Gtlu222 + Gt233*Gtlu223 + Gt212*Gtlu231 + Gt313*Gtlu231 + Gt222*Gtlu232 +
+ Gt323*Gtlu232 + Gt223*Gtlu233 + Gt333*Gtlu233 + Gt112*Gtlu311 + Gt122*Gtlu312 + Gt123*Gtlu313 +
+ Gt212*Gtlu321 + Gt222*Gtlu322 + Gt223*Gtlu323) + 4*(Gt312*Gtlu331 + Gt322*Gtlu332 + Gt323*Gtlu333) -
+ gtu11*PDstandardNth11gt23 - 2*gtu21*PDstandardNth12gt23 - 2*gtu31*PDstandardNth13gt23 -
+ gtu22*PDstandardNth22gt23 - 2*gtu32*PDstandardNth23gt23 + gt13L*PDstandardNth2Xt1 + gt23L*PDstandardNth2Xt2 +
+ gt33L*PDstandardNth2Xt3 - gtu33*PDstandardNth33gt23 + gt12L*PDstandardNth3Xt1 + gt22L*PDstandardNth3Xt2 +
+ gt23L*PDstandardNth3Xt3 + Gtl213*Xtn1 + Gtl312*Xtn1 + Gtl223*Xtn2 + Gtl322*Xtn2 + Gtl233*Xtn3 + Gtl323*Xtn3);
+
+ CCTK_REAL const Rt33 = Gt113*(Gtlu131 + 2*Gtlu311) + Gt123*(Gtlu132 + 2*Gtlu312) + Gt133*(Gtlu133 + 2*Gtlu313) +
+ Gt213*(Gtlu231 + 2*Gtlu321) + Gt223*(Gtlu232 + 2*Gtlu322) + Gt233*(Gtlu233 + 2*Gtlu323) +
+ 3*(Gt313*Gtlu331 + Gt323*Gtlu332 + Gt333*Gtlu333) +
+ khalf*(-(gtu11*PDstandardNth11gt33) - 2*gtu21*PDstandardNth12gt33 - 2*gtu31*PDstandardNth13gt33 -
+ gtu22*PDstandardNth22gt33 - 2*gtu32*PDstandardNth23gt33 - gtu33*PDstandardNth33gt33) + gt13L*PDstandardNth3Xt1 +
+ gt23L*PDstandardNth3Xt2 + gt33L*PDstandardNth3Xt3 + Gtl313*Xtn1 + Gtl323*Xtn2 + Gtl333*Xtn3;
+
+ CCTK_REAL const fac1 = IfThen(conformalMethod,-(khalf*INV(phiL)),1);
+
+ CCTK_REAL const cdphi1 = fac1*PDstandardNth1phi;
+
+ CCTK_REAL const cdphi2 = fac1*PDstandardNth2phi;
+
+ CCTK_REAL const cdphi3 = fac1*PDstandardNth3phi;
+
+ CCTK_REAL const fac2 = IfThen(conformalMethod,khalf*pow(phiL,-2),0);
+
+ CCTK_REAL const cdphi211 = -(fac1*(-PDstandardNth11phi + Gt111*PDstandardNth1phi + Gt211*PDstandardNth2phi +
+ Gt311*PDstandardNth3phi)) + fac2*SQR(PDstandardNth1phi);
+
+ CCTK_REAL const cdphi212 = fac2*PDstandardNth1phi*PDstandardNth2phi -
+ fac1*(-PDstandardNth12phi + Gt112*PDstandardNth1phi + Gt212*PDstandardNth2phi + Gt312*PDstandardNth3phi);
+
+ CCTK_REAL const cdphi213 = fac2*PDstandardNth1phi*PDstandardNth3phi -
+ fac1*(-PDstandardNth13phi + Gt113*PDstandardNth1phi + Gt213*PDstandardNth2phi + Gt313*PDstandardNth3phi);
+
+ CCTK_REAL const cdphi222 = -(fac1*(Gt122*PDstandardNth1phi - PDstandardNth22phi + Gt222*PDstandardNth2phi +
+ Gt322*PDstandardNth3phi)) + fac2*SQR(PDstandardNth2phi);
+
+ CCTK_REAL const cdphi223 = fac2*PDstandardNth2phi*PDstandardNth3phi -
+ fac1*(Gt123*PDstandardNth1phi - PDstandardNth23phi + Gt223*PDstandardNth2phi + Gt323*PDstandardNth3phi);
+
+ CCTK_REAL const cdphi233 = -(fac1*(Gt133*PDstandardNth1phi + Gt233*PDstandardNth2phi - PDstandardNth33phi +
+ Gt333*PDstandardNth3phi)) + fac2*SQR(PDstandardNth3phi);
+
+ CCTK_REAL const Rphi11 = -2*(cdphi211 + 2*(-1 + gt11L*gtu11)*SQR(cdphi1) +
+ gt11L*(cdphi211*gtu11 + 4*(cdphi1*(cdphi2*gtu21 + cdphi3*gtu31) + cdphi2*cdphi3*gtu32) + cdphi233*gtu33 +
+ gtu22*(cdphi222 + 2*SQR(cdphi2)) + 2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu33*SQR(cdphi3))));
+
+ CCTK_REAL const Rphi12 = -2*(cdphi212 + cdphi1*(cdphi2*(-2 + 4*gt12L*gtu21) + 4*cdphi3*gt12L*gtu31) +
+ gt12L*(cdphi211*gtu11 + 4*cdphi2*cdphi3*gtu32 +
+ 2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu11*SQR(cdphi1)) + gtu22*(cdphi222 + 2*SQR(cdphi2)) +
+ gtu33*(cdphi233 + 2*SQR(cdphi3))));
+
+ CCTK_REAL const Rphi13 = -2*(cdphi213 + cdphi1*(4*cdphi2*gt13L*gtu21 + cdphi3*(-2 + 4*gt13L*gtu31)) +
+ gt13L*(cdphi211*gtu11 + 4*cdphi2*cdphi3*gtu32 +
+ 2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu11*SQR(cdphi1)) + gtu22*(cdphi222 + 2*SQR(cdphi2)) +
+ gtu33*(cdphi233 + 2*SQR(cdphi3))));
+
+ CCTK_REAL const Rphi22 = -2*(cdphi222 + 2*(-1 + gt22L*gtu22)*SQR(cdphi2) +
+ gt22L*(cdphi222*gtu22 + 4*(cdphi1*cdphi3*gtu31 + cdphi2*(cdphi1*gtu21 + cdphi3*gtu32)) + cdphi233*gtu33 +
+ gtu11*(cdphi211 + 2*SQR(cdphi1)) + 2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu33*SQR(cdphi3))));
+
+ CCTK_REAL const Rphi23 = -2*(cdphi223 + cdphi2*(4*cdphi1*gt23L*gtu21 + cdphi3*(-2 + 4*gt23L*gtu32)) +
+ gt23L*(cdphi222*gtu22 + 4*cdphi1*cdphi3*gtu31 + gtu11*(cdphi211 + 2*SQR(cdphi1)) +
+ 2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu22*SQR(cdphi2)) + gtu33*(cdphi233 + 2*SQR(cdphi3))));
+
+ CCTK_REAL const Rphi33 = -2*(cdphi233 + gt33L*((4*cdphi1*cdphi2 + 2*cdphi212)*gtu21 + 4*cdphi3*(cdphi1*gtu31 + cdphi2*gtu32) +
+ 2*(cdphi213*gtu31 + cdphi223*gtu32) + cdphi233*gtu33 + gtu11*(cdphi211 + 2*SQR(cdphi1)) +
+ gtu22*(cdphi222 + 2*SQR(cdphi2))) + 2*(-1 + gt33L*gtu33)*SQR(cdphi3));
+
+ CCTK_REAL const Atm11 = At11L*gtu11 + At12L*gtu21 + At13L*gtu31;
+
+ CCTK_REAL const Atm21 = At11L*gtu21 + At12L*gtu22 + At13L*gtu32;
+
+ CCTK_REAL const Atm31 = At11L*gtu31 + At12L*gtu32 + At13L*gtu33;
+
+ CCTK_REAL const Atm12 = At12L*gtu11 + At22L*gtu21 + At23L*gtu31;
+
+ CCTK_REAL const Atm22 = At12L*gtu21 + At22L*gtu22 + At23L*gtu32;
+
+ CCTK_REAL const Atm32 = At12L*gtu31 + At22L*gtu32 + At23L*gtu33;
+
+ CCTK_REAL const Atm13 = At13L*gtu11 + At23L*gtu21 + At33L*gtu31;
+
+ CCTK_REAL const Atm23 = At13L*gtu21 + At23L*gtu22 + At33L*gtu32;
+
+ CCTK_REAL const Atm33 = At13L*gtu31 + At23L*gtu32 + At33L*gtu33;
+
+ CCTK_REAL const e4phi = IfThen(conformalMethod,pow(phiL,-2),exp(4*phiL));
+
+ CCTK_REAL const em4phi = INV(e4phi);
+
+ CCTK_REAL const g11 = e4phi*gt11L;
+
+ CCTK_REAL const g12 = e4phi*gt12L;
+
+ CCTK_REAL const g13 = e4phi*gt13L;
+
+ CCTK_REAL const g22 = e4phi*gt22L;
+
+ CCTK_REAL const g23 = e4phi*gt23L;
+
+ CCTK_REAL const g33 = e4phi*gt33L;
+
+ CCTK_REAL const gu11 = em4phi*gtu11;
+
+ CCTK_REAL const gu21 = em4phi*gtu21;
+
+ CCTK_REAL const gu31 = em4phi*gtu31;
+
+ CCTK_REAL const gu22 = em4phi*gtu22;
+
+ CCTK_REAL const gu32 = em4phi*gtu32;
+
+ CCTK_REAL const gu33 = em4phi*gtu33;
+
+ CCTK_REAL const G111 = Gt111 + cdphi1*(4 - 2*gt11L*gtu11) - 2*gt11L*(cdphi2*gtu21 + cdphi3*gtu31);
+
+ CCTK_REAL const G211 = Gt211 - 2*gt11L*(cdphi1*gtu21 + cdphi2*gtu22 + cdphi3*gtu32);
+
+ CCTK_REAL const G311 = Gt311 - 2*gt11L*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33);
+
+ CCTK_REAL const G112 = Gt112 + cdphi2*(2 - 2*gt12L*gtu21) - 2*gt12L*(cdphi1*gtu11 + cdphi3*gtu31);
+
+ CCTK_REAL const G212 = Gt212 + cdphi1*(2 - 2*gt12L*gtu21) - 2*gt12L*(cdphi2*gtu22 + cdphi3*gtu32);
+
+ CCTK_REAL const G312 = Gt312 - 2*gt12L*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33);
+
+ CCTK_REAL const G113 = Gt113 - 2*gt13L*(cdphi1*gtu11 + cdphi2*gtu21) + cdphi3*(2 - 2*gt13L*gtu31);
+
+ CCTK_REAL const G213 = Gt213 - 2*gt13L*(cdphi1*gtu21 + cdphi2*gtu22 + cdphi3*gtu32);
+
+ CCTK_REAL const G313 = Gt313 + cdphi1*(2 - 2*gt13L*gtu31) - 2*gt13L*(cdphi2*gtu32 + cdphi3*gtu33);
+
+ CCTK_REAL const G122 = Gt122 - 2*gt22L*(cdphi1*gtu11 + cdphi2*gtu21 + cdphi3*gtu31);
+
+ CCTK_REAL const G222 = Gt222 + cdphi2*(4 - 2*gt22L*gtu22) - 2*gt22L*(cdphi1*gtu21 + cdphi3*gtu32);
+
+ CCTK_REAL const G322 = Gt322 - 2*gt22L*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33);
+
+ CCTK_REAL const G123 = Gt123 - 2*gt23L*(cdphi1*gtu11 + cdphi2*gtu21 + cdphi3*gtu31);
+
+ CCTK_REAL const G223 = Gt223 - 2*gt23L*(cdphi1*gtu21 + cdphi2*gtu22) + cdphi3*(2 - 2*gt23L*gtu32);
+
+ CCTK_REAL const G323 = Gt323 + cdphi2*(2 - 2*gt23L*gtu32) - 2*gt23L*(cdphi1*gtu31 + cdphi3*gtu33);
+
+ CCTK_REAL const G133 = Gt133 - 2*gt33L*(cdphi1*gtu11 + cdphi2*gtu21 + cdphi3*gtu31);
+
+ CCTK_REAL const G233 = Gt233 - 2*gt33L*(cdphi1*gtu21 + cdphi2*gtu22 + cdphi3*gtu32);
+
+ CCTK_REAL const G333 = Gt333 - 2*gt33L*(cdphi1*gtu31 + cdphi2*gtu32) + cdphi3*(4 - 2*gt33L*gtu33);
+
+ CCTK_REAL const R11 = Rphi11 + Rt11;
+
+ CCTK_REAL const R12 = Rphi12 + Rt12;
+
+ CCTK_REAL const R13 = Rphi13 + Rt13;
+
+ CCTK_REAL const R22 = Rphi22 + Rt22;
+
+ CCTK_REAL const R23 = Rphi23 + Rt23;
+
+ CCTK_REAL const R33 = Rphi33 + Rt33;
+
+ CCTK_REAL const T00 = eTttL;
+
+ CCTK_REAL const T01 = eTtxL;
+
+ CCTK_REAL const T02 = eTtyL;
+
+ CCTK_REAL const T03 = eTtzL;
+
+ CCTK_REAL const T11 = eTxxL;
+
+ CCTK_REAL const T12 = eTxyL;
+
+ CCTK_REAL const T13 = eTxzL;
+
+ CCTK_REAL const T22 = eTyyL;
+
+ CCTK_REAL const T23 = eTyzL;
+
+ CCTK_REAL const T33 = eTzzL;
+
+ CCTK_REAL const rho = pow(alphaL,-2)*(T00 - 2*(beta2L*T02 + beta3L*T03) +
+ 2*(beta1L*(-T01 + beta2L*T12 + beta3L*T13) + beta2L*beta3L*T23) + T11*SQR(beta1L) + T22*SQR(beta2L) +
+ T33*SQR(beta3L));
+
+ CCTK_REAL const trS = gu11*T11 + gu22*T22 + 2*(gu21*T12 + gu31*T13 + gu32*T23) + gu33*T33;
+
+ CCTK_REAL const trKrhsL = PDupwindNth1(trK, i, j, k)*beta1L + PDupwindNth2(trK, i, j, k)*beta2L +
+ PDupwindNth3(trK, i, j, k)*beta3L + (G111*gu11 + G122*gu22 + 2.*(G112*gu21 + G113*gu31 + G123*gu32) + G133*gu33)*
+ PDstandardNth1alpha - 2.*(gu21*PDstandardNth12alpha + gu31*PDstandardNth13alpha + gu32*PDstandardNth23alpha) +
+ (G211*gu11 + G222*gu22 + 2.*(G212*gu21 + G213*gu31 + G223*gu32) + G233*gu33)*PDstandardNth2alpha -
+ 1.*(gu11*PDstandardNth11alpha + gu22*PDstandardNth22alpha + gu33*PDstandardNth33alpha) +
+ (G311*gu11 + G322*gu22 + 2.*(G313*gu31 + G323*gu32) + G333*gu33)*PDstandardNth3alpha +
+ 2.*(alphaL*(Atm12*Atm21 + Atm13*Atm31 + Atm23*Atm32) + G312*gu21*PDstandardNth3alpha) +
+ alphaL*(12.56637061435917295385057353311801153679*(rho + trS) + SQR(Atm11) + SQR(Atm22) + SQR(Atm33) +
+ 0.3333333333333333333333333333333333333333*SQR(trKL));
+
+ CCTK_REAL const Ats11 = -PDstandardNth11alpha + G111*PDstandardNth1alpha + G211*PDstandardNth2alpha + G311*PDstandardNth3alpha +
+ alphaL*R11;
+
+ CCTK_REAL const Ats12 = -PDstandardNth12alpha + G112*PDstandardNth1alpha + G212*PDstandardNth2alpha + G312*PDstandardNth3alpha +
+ alphaL*R12;
+
+ CCTK_REAL const Ats13 = -PDstandardNth13alpha + G113*PDstandardNth1alpha + G213*PDstandardNth2alpha + G313*PDstandardNth3alpha +
+ alphaL*R13;
+
+ CCTK_REAL const Ats22 = G122*PDstandardNth1alpha - PDstandardNth22alpha + G222*PDstandardNth2alpha + G322*PDstandardNth3alpha +
+ alphaL*R22;
+
+ CCTK_REAL const Ats23 = G123*PDstandardNth1alpha - PDstandardNth23alpha + G223*PDstandardNth2alpha + G323*PDstandardNth3alpha +
+ alphaL*R23;
+
+ CCTK_REAL const Ats33 = G133*PDstandardNth1alpha + G233*PDstandardNth2alpha - PDstandardNth33alpha + G333*PDstandardNth3alpha +
+ alphaL*R33;
+
+ CCTK_REAL const trAts = Ats11*gu11 + Ats22*gu22 + 2*(Ats12*gu21 + Ats13*gu31 + Ats23*gu32) + Ats33*gu33;
+
+ CCTK_REAL const At11rhsL = -2.*alphaL*(At11L*Atm11 + At12L*Atm21 + At13L*Atm31) + PDupwindNth1(At11, i, j, k)*beta1L +
+ PDupwindNth2(At11, i, j, k)*beta2L + PDupwindNth3(At11, i, j, k)*beta3L +
+ 2.*(At12L*PDstandardNth1beta2 + At13L*PDstandardNth1beta3) +
+ At11L*(1.333333333333333333333333333333333333333*PDstandardNth1beta1 -
+ 0.6666666666666666666666666666666666666667*(PDstandardNth2beta2 + PDstandardNth3beta3) + alphaL*trKL) +
+ em4phi*(Ats11 - 0.3333333333333333333333333333333333333333*g11*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T11 + 8.377580409572781969233715688745341024526*g11*trS));
+
+ CCTK_REAL const At12rhsL = -2.*alphaL*(At11L*Atm12 + At12L*Atm22 + At13L*Atm32) + PDupwindNth1(At12, i, j, k)*beta1L +
+ PDupwindNth2(At12, i, j, k)*beta2L + PDupwindNth3(At12, i, j, k)*beta3L + At22L*PDstandardNth1beta2 +
+ At23L*PDstandardNth1beta3 + At11L*PDstandardNth2beta1 + At13L*PDstandardNth2beta3 +
+ At12L*(0.3333333333333333333333333333333333333333*(PDstandardNth1beta1 + PDstandardNth2beta2) -
+ 0.6666666666666666666666666666666666666667*PDstandardNth3beta3 + alphaL*trKL) +
+ em4phi*(Ats12 - 0.3333333333333333333333333333333333333333*g12*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T12 + 8.377580409572781969233715688745341024526*g12*trS));
+
+ CCTK_REAL const At13rhsL = -2.*alphaL*(At11L*Atm13 + At12L*Atm23 + At13L*Atm33) + PDupwindNth1(At13, i, j, k)*beta1L +
+ PDupwindNth2(At13, i, j, k)*beta2L + PDupwindNth3(At13, i, j, k)*beta3L + At23L*PDstandardNth1beta2 +
+ At33L*PDstandardNth1beta3 + At11L*PDstandardNth3beta1 + At12L*PDstandardNth3beta2 +
+ At13L*(-0.6666666666666666666666666666666666666667*PDstandardNth2beta2 +
+ 0.3333333333333333333333333333333333333333*(PDstandardNth1beta1 + PDstandardNth3beta3) + alphaL*trKL) +
+ em4phi*(Ats13 - 0.3333333333333333333333333333333333333333*g13*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T13 + 8.377580409572781969233715688745341024526*g13*trS));
+
+ CCTK_REAL const At22rhsL = -2.*alphaL*(At12L*Atm12 + At22L*Atm22 + At23L*Atm32) + PDupwindNth1(At22, i, j, k)*beta1L +
+ PDupwindNth2(At22, i, j, k)*beta2L + PDupwindNth3(At22, i, j, k)*beta3L +
+ 2.*(At12L*PDstandardNth2beta1 + At23L*PDstandardNth2beta3) +
+ At22L*(1.333333333333333333333333333333333333333*PDstandardNth2beta2 -
+ 0.6666666666666666666666666666666666666667*(PDstandardNth1beta1 + PDstandardNth3beta3) + alphaL*trKL) +
+ em4phi*(Ats22 - 0.3333333333333333333333333333333333333333*g22*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T22 + 8.377580409572781969233715688745341024526*g22*trS));
+
+ CCTK_REAL const At23rhsL = -2.*alphaL*(At12L*Atm13 + At22L*Atm23 + At23L*Atm33) + PDupwindNth1(At23, i, j, k)*beta1L +
+ PDupwindNth2(At23, i, j, k)*beta2L + PDupwindNth3(At23, i, j, k)*beta3L + At13L*PDstandardNth2beta1 +
+ At33L*PDstandardNth2beta3 + At12L*PDstandardNth3beta1 + At22L*PDstandardNth3beta2 +
+ At23L*(-0.6666666666666666666666666666666666666667*PDstandardNth1beta1 +
+ 0.3333333333333333333333333333333333333333*(PDstandardNth2beta2 + PDstandardNth3beta3) + alphaL*trKL) +
+ em4phi*(Ats23 - 0.3333333333333333333333333333333333333333*g23*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T23 + 8.377580409572781969233715688745341024526*g23*trS));
+
+ CCTK_REAL const At33rhsL = -2.*alphaL*(At13L*Atm13 + At23L*Atm23 + At33L*Atm33) + PDupwindNth1(At33, i, j, k)*beta1L +
+ PDupwindNth2(At33, i, j, k)*beta2L + PDupwindNth3(At33, i, j, k)*beta3L +
+ 2.*(At13L*PDstandardNth3beta1 + At23L*PDstandardNth3beta2) +
+ At33L*(-0.6666666666666666666666666666666666666667*(PDstandardNth1beta1 + PDstandardNth2beta2) +
+ 1.333333333333333333333333333333333333333*PDstandardNth3beta3 + alphaL*trKL) +
+ em4phi*(Ats33 - 0.3333333333333333333333333333333333333333*g33*trAts +
+ alphaL*(-25.13274122871834590770114706623602307358*T33 + 8.377580409572781969233715688745341024526*g33*trS));
+
+ CCTK_REAL const alpharhsL = (PDupwindNth1(alpha, i, j, k)*beta1L + PDupwindNth2(alpha, i, j, k)*beta2L +
+ PDupwindNth3(alpha, i, j, k)*beta3L)*LapseAdvectionCoeff +
+ harmonicF*(AL*(-1 + LapseAdvectionCoeff) - LapseAdvectionCoeff*trKL)*pow(alphaL,harmonicN);
+
+ CCTK_REAL const ArhsL = (-1 + LapseAdvectionCoeff)*(AL*AlphaDriver - trKrhsL);
+
+
+ /* Copy local copies back to grid functions */
+ alpharhs[index] = alpharhsL;
+ Arhs[index] = ArhsL;
+ At11rhs[index] = At11rhsL;
+ At12rhs[index] = At12rhsL;
+ At13rhs[index] = At13rhsL;
+ At22rhs[index] = At22rhsL;
+ At23rhs[index] = At23rhsL;
+ At33rhs[index] = At33rhsL;
+ trKrhs[index] = trKrhsL;
+
+ /* Copy local copies back to subblock grid functions */
+ }
+ LC_ENDLOOP3 (ML_BSSN_RHS2);
+}
+
+void ML_BSSN_RHS2(CCTK_ARGUMENTS)
+{
+ DECLARE_CCTK_ARGUMENTS;
+ DECLARE_CCTK_PARAMETERS;
+
+ GenericFD_LoopOverInterior(cctkGH, &ML_BSSN_RHS2_Body);
+}
diff --git a/ML_BSSN/src/ML_BSSN_RHSRadiativeBoundary.c b/ML_BSSN/src/ML_BSSN_RHSRadiativeBoundary.c
index cd5b2d2..d85f2c8 100644
--- a/ML_BSSN/src/ML_BSSN_RHSRadiativeBoundary.c
+++ b/ML_BSSN/src/ML_BSSN_RHSRadiativeBoundary.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_RHSRadiativeBoundary_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_RHSRadiativeBoundary_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_RHSRadiativeBoundary_Body(cGH const * const cctkGH, CCTK_INT const
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,66 +93,66 @@ void ML_BSSN_RHSRadiativeBoundary_Body(cGH const * const cctkGH, CCTK_INT const
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
- CCTK_REAL detgt = INITVALUE;
- CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
- CCTK_REAL em4phi = INITVALUE;
- CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
- CCTK_REAL gu11 = INITVALUE, gu21 = INITVALUE, gu22 = INITVALUE, gu31 = INITVALUE, gu32 = INITVALUE, gu33 = INITVALUE;
- CCTK_REAL nlen = INITVALUE, nlen2 = INITVALUE;
- CCTK_REAL nn1 = INITVALUE, nn2 = INITVALUE, nn3 = INITVALUE;
- CCTK_REAL nu1 = INITVALUE, nu2 = INITVALUE, nu3 = INITVALUE;
- CCTK_REAL su1 = INITVALUE, su2 = INITVALUE, su3 = INITVALUE;
- CCTK_REAL vg = INITVALUE;
+ // CCTK_REAL detgt = INITVALUE;
+ // CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
+ // CCTK_REAL em4phi = INITVALUE;
+ // CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
+ // CCTK_REAL gu11 = INITVALUE, gu21 = INITVALUE, gu22 = INITVALUE, gu31 = INITVALUE, gu32 = INITVALUE, gu33 = INITVALUE;
+ // CCTK_REAL nlen = INITVALUE, nlen2 = INITVALUE;
+ // CCTK_REAL nn1 = INITVALUE, nn2 = INITVALUE, nn3 = INITVALUE;
+ // CCTK_REAL nu1 = INITVALUE, nu2 = INITVALUE, nu3 = INITVALUE;
+ // CCTK_REAL su1 = INITVALUE, su2 = INITVALUE, su3 = INITVALUE;
+ // CCTK_REAL vg = INITVALUE;
/* Declare local copies of grid functions */
- CCTK_REAL AL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE, alpharhsL = INITVALUE;
- CCTK_REAL ArhsL = INITVALUE;
- CCTK_REAL At11L = INITVALUE, At11rhsL = INITVALUE, At12L = INITVALUE, At12rhsL = INITVALUE, At13L = INITVALUE, At13rhsL = INITVALUE;
- CCTK_REAL At22L = INITVALUE, At22rhsL = INITVALUE, At23L = INITVALUE, At23rhsL = INITVALUE, At33L = INITVALUE, At33rhsL = INITVALUE;
- CCTK_REAL B1L = INITVALUE, B1rhsL = INITVALUE, B2L = INITVALUE, B2rhsL = INITVALUE, B3L = INITVALUE, B3rhsL = INITVALUE;
- CCTK_REAL beta1L = INITVALUE, beta1rhsL = INITVALUE, beta2L = INITVALUE, beta2rhsL = INITVALUE, beta3L = INITVALUE, beta3rhsL = INITVALUE;
- CCTK_REAL gt11L = INITVALUE, gt11rhsL = INITVALUE, gt12L = INITVALUE, gt12rhsL = INITVALUE, gt13L = INITVALUE, gt13rhsL = INITVALUE;
- CCTK_REAL gt22L = INITVALUE, gt22rhsL = INITVALUE, gt23L = INITVALUE, gt23rhsL = INITVALUE, gt33L = INITVALUE, gt33rhsL = INITVALUE;
- CCTK_REAL phiL = INITVALUE, phirhsL = INITVALUE;
- CCTK_REAL trKL = INITVALUE, trKrhsL = INITVALUE;
- CCTK_REAL Xt1L = INITVALUE, Xt1rhsL = INITVALUE, Xt2L = INITVALUE, Xt2rhsL = INITVALUE, Xt3L = INITVALUE, Xt3rhsL = INITVALUE;
+ // CCTK_REAL AL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE, alpharhsL = INITVALUE;
+ // CCTK_REAL ArhsL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At11rhsL = INITVALUE, At12L = INITVALUE, At12rhsL = INITVALUE, At13L = INITVALUE, At13rhsL = INITVALUE;
+ // CCTK_REAL At22L = INITVALUE, At22rhsL = INITVALUE, At23L = INITVALUE, At23rhsL = INITVALUE, At33L = INITVALUE, At33rhsL = INITVALUE;
+ // CCTK_REAL B1L = INITVALUE, B1rhsL = INITVALUE, B2L = INITVALUE, B2rhsL = INITVALUE, B3L = INITVALUE, B3rhsL = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta1rhsL = INITVALUE, beta2L = INITVALUE, beta2rhsL = INITVALUE, beta3L = INITVALUE, beta3rhsL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt11rhsL = INITVALUE, gt12L = INITVALUE, gt12rhsL = INITVALUE, gt13L = INITVALUE, gt13rhsL = INITVALUE;
+ // CCTK_REAL gt22L = INITVALUE, gt22rhsL = INITVALUE, gt23L = INITVALUE, gt23rhsL = INITVALUE, gt33L = INITVALUE, gt33rhsL = INITVALUE;
+ // CCTK_REAL phiL = INITVALUE, phirhsL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE, trKrhsL = INITVALUE;
+ // CCTK_REAL Xt1L = INITVALUE, Xt1rhsL = INITVALUE, Xt2L = INITVALUE, Xt2rhsL = INITVALUE, Xt3L = INITVALUE, Xt3rhsL = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
/* Assign local copies of grid functions */
- AL = A[index];
- alphaL = alpha[index];
- At11L = At11[index];
- At12L = At12[index];
- At13L = At13[index];
- At22L = At22[index];
- At23L = At23[index];
- At33L = At33[index];
- B1L = B1[index];
- B2L = B2[index];
- B3L = B3[index];
- beta1L = beta1[index];
- beta2L = beta2[index];
- beta3L = beta3[index];
- gt11L = gt11[index];
- gt12L = gt12[index];
- gt13L = gt13[index];
- gt22L = gt22[index];
- gt23L = gt23[index];
- gt33L = gt33[index];
- phiL = phi[index];
- trKL = trK[index];
- Xt1L = Xt1[index];
- Xt2L = Xt2[index];
- Xt3L = Xt3[index];
+ CCTK_REAL const AL = A[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const At11L = At11[index];
+ CCTK_REAL const At12L = At12[index];
+ CCTK_REAL const At13L = At13[index];
+ CCTK_REAL const At22L = At22[index];
+ CCTK_REAL const At23L = At23[index];
+ CCTK_REAL const At33L = At33[index];
+ CCTK_REAL const B1L = B1[index];
+ CCTK_REAL const B2L = B2[index];
+ CCTK_REAL const B3L = B3[index];
+ CCTK_REAL const beta1L = beta1[index];
+ CCTK_REAL const beta2L = beta2[index];
+ CCTK_REAL const beta3L = beta3[index];
+ CCTK_REAL const gt11L = gt11[index];
+ CCTK_REAL const gt12L = gt12[index];
+ CCTK_REAL const gt13L = gt13[index];
+ CCTK_REAL const gt22L = gt22[index];
+ CCTK_REAL const gt23L = gt23[index];
+ CCTK_REAL const gt33L = gt33[index];
+ CCTK_REAL const phiL = phi[index];
+ CCTK_REAL const trKL = trK[index];
+ CCTK_REAL const Xt1L = Xt1[index];
+ CCTK_REAL const Xt2L = Xt2[index];
+ CCTK_REAL const Xt3L = Xt3[index];
/* Assign local copies of subblock grid functions */
@@ -165,117 +163,117 @@ void ML_BSSN_RHSRadiativeBoundary_Body(cGH const * const cctkGH, CCTK_INT const
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- dir1 = Sign(normal[0]);
+ int const dir1 = Sign(normal[0]);
- dir2 = Sign(normal[1]);
+ int const dir2 = Sign(normal[1]);
- dir3 = Sign(normal[2]);
+ int const dir3 = Sign(normal[2]);
- detgt = 1;
+ CCTK_REAL const detgt = 1;
- gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
+ CCTK_REAL const gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
- gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
+ CCTK_REAL const gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
- gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
- gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
+ CCTK_REAL const gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
- gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
- gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
+ CCTK_REAL const gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
- em4phi = IfThen(conformalMethod,SQR(phiL),exp(-4*phiL));
+ CCTK_REAL const em4phi = IfThen(conformalMethod,SQR(phiL),exp(-4*phiL));
- gu11 = em4phi*gtu11;
+ CCTK_REAL const gu11 = em4phi*gtu11;
- gu21 = em4phi*gtu21;
+ CCTK_REAL const gu21 = em4phi*gtu21;
- gu31 = em4phi*gtu31;
+ CCTK_REAL const gu31 = em4phi*gtu31;
- gu22 = em4phi*gtu22;
+ CCTK_REAL const gu22 = em4phi*gtu22;
- gu32 = em4phi*gtu32;
+ CCTK_REAL const gu32 = em4phi*gtu32;
- gu33 = em4phi*gtu33;
+ CCTK_REAL const gu33 = em4phi*gtu33;
- nn1 = normal[0];
+ CCTK_REAL const nn1 = normal[0];
- nn2 = normal[1];
+ CCTK_REAL const nn2 = normal[1];
- nn3 = normal[2];
+ CCTK_REAL const nn3 = normal[2];
- nu1 = gu11*nn1 + gu21*nn2 + gu31*nn3;
+ CCTK_REAL const nu1 = gu11*nn1 + gu21*nn2 + gu31*nn3;
- nu2 = gu21*nn1 + gu22*nn2 + gu32*nn3;
+ CCTK_REAL const nu2 = gu21*nn1 + gu22*nn2 + gu32*nn3;
- nu3 = gu31*nn1 + gu32*nn2 + gu33*nn3;
+ CCTK_REAL const nu3 = gu31*nn1 + gu32*nn2 + gu33*nn3;
- nlen2 = nn1*nu1 + nn2*nu2 + nn3*nu3;
+ CCTK_REAL const nlen2 = nn1*nu1 + nn2*nu2 + nn3*nu3;
- nlen = pow(nlen2,0.5);
+ CCTK_REAL const nlen = pow(nlen2,0.5);
- su1 = nu1*INV(nlen);
+ CCTK_REAL const su1 = nu1*INV(nlen);
- su2 = nu2*INV(nlen);
+ CCTK_REAL const su2 = nu2*INV(nlen);
- su3 = nu3*INV(nlen);
+ CCTK_REAL const su3 = nu3*INV(nlen);
- vg = pow(harmonicF,0.5);
+ CCTK_REAL const vg = pow(harmonicF,0.5);
- phirhsL = -((PDonesided1(phi, i, j, k)*su1 + PDonesided2(phi, i, j, k)*su2 + PDonesided3(phi, i, j, k)*su3)*vg);
+ CCTK_REAL const phirhsL = -((PDonesided1(phi, i, j, k)*su1 + PDonesided2(phi, i, j, k)*su2 + PDonesided3(phi, i, j, k)*su3)*vg);
- gt11rhsL = -(PDonesided1(gt11, i, j, k)*su1) - PDonesided2(gt11, i, j, k)*su2 - PDonesided3(gt11, i, j, k)*su3;
+ CCTK_REAL const gt11rhsL = -(PDonesided1(gt11, i, j, k)*su1) - PDonesided2(gt11, i, j, k)*su2 - PDonesided3(gt11, i, j, k)*su3;
- gt12rhsL = -(PDonesided1(gt12, i, j, k)*su1) - PDonesided2(gt12, i, j, k)*su2 - PDonesided3(gt12, i, j, k)*su3;
+ CCTK_REAL const gt12rhsL = -(PDonesided1(gt12, i, j, k)*su1) - PDonesided2(gt12, i, j, k)*su2 - PDonesided3(gt12, i, j, k)*su3;
- gt13rhsL = -(PDonesided1(gt13, i, j, k)*su1) - PDonesided2(gt13, i, j, k)*su2 - PDonesided3(gt13, i, j, k)*su3;
+ CCTK_REAL const gt13rhsL = -(PDonesided1(gt13, i, j, k)*su1) - PDonesided2(gt13, i, j, k)*su2 - PDonesided3(gt13, i, j, k)*su3;
- gt22rhsL = -(PDonesided1(gt22, i, j, k)*su1) - PDonesided2(gt22, i, j, k)*su2 - PDonesided3(gt22, i, j, k)*su3;
+ CCTK_REAL const gt22rhsL = -(PDonesided1(gt22, i, j, k)*su1) - PDonesided2(gt22, i, j, k)*su2 - PDonesided3(gt22, i, j, k)*su3;
- gt23rhsL = -(PDonesided1(gt23, i, j, k)*su1) - PDonesided2(gt23, i, j, k)*su2 - PDonesided3(gt23, i, j, k)*su3;
+ CCTK_REAL const gt23rhsL = -(PDonesided1(gt23, i, j, k)*su1) - PDonesided2(gt23, i, j, k)*su2 - PDonesided3(gt23, i, j, k)*su3;
- gt33rhsL = -(PDonesided1(gt33, i, j, k)*su1) - PDonesided2(gt33, i, j, k)*su2 - PDonesided3(gt33, i, j, k)*su3;
+ CCTK_REAL const gt33rhsL = -(PDonesided1(gt33, i, j, k)*su1) - PDonesided2(gt33, i, j, k)*su2 - PDonesided3(gt33, i, j, k)*su3;
- trKrhsL = -((PDonesided1(trK, i, j, k)*su1 + PDonesided2(trK, i, j, k)*su2 + PDonesided3(trK, i, j, k)*su3)*vg);
+ CCTK_REAL const trKrhsL = -((PDonesided1(trK, i, j, k)*su1 + PDonesided2(trK, i, j, k)*su2 + PDonesided3(trK, i, j, k)*su3)*vg);
- At11rhsL = -(PDonesided1(At11, i, j, k)*su1) - PDonesided2(At11, i, j, k)*su2 - PDonesided3(At11, i, j, k)*su3;
+ CCTK_REAL const At11rhsL = -(PDonesided1(At11, i, j, k)*su1) - PDonesided2(At11, i, j, k)*su2 - PDonesided3(At11, i, j, k)*su3;
- At12rhsL = -(PDonesided1(At12, i, j, k)*su1) - PDonesided2(At12, i, j, k)*su2 - PDonesided3(At12, i, j, k)*su3;
+ CCTK_REAL const At12rhsL = -(PDonesided1(At12, i, j, k)*su1) - PDonesided2(At12, i, j, k)*su2 - PDonesided3(At12, i, j, k)*su3;
- At13rhsL = -(PDonesided1(At13, i, j, k)*su1) - PDonesided2(At13, i, j, k)*su2 - PDonesided3(At13, i, j, k)*su3;
+ CCTK_REAL const At13rhsL = -(PDonesided1(At13, i, j, k)*su1) - PDonesided2(At13, i, j, k)*su2 - PDonesided3(At13, i, j, k)*su3;
- At22rhsL = -(PDonesided1(At22, i, j, k)*su1) - PDonesided2(At22, i, j, k)*su2 - PDonesided3(At22, i, j, k)*su3;
+ CCTK_REAL const At22rhsL = -(PDonesided1(At22, i, j, k)*su1) - PDonesided2(At22, i, j, k)*su2 - PDonesided3(At22, i, j, k)*su3;
- At23rhsL = -(PDonesided1(At23, i, j, k)*su1) - PDonesided2(At23, i, j, k)*su2 - PDonesided3(At23, i, j, k)*su3;
+ CCTK_REAL const At23rhsL = -(PDonesided1(At23, i, j, k)*su1) - PDonesided2(At23, i, j, k)*su2 - PDonesided3(At23, i, j, k)*su3;
- At33rhsL = -(PDonesided1(At33, i, j, k)*su1) - PDonesided2(At33, i, j, k)*su2 - PDonesided3(At33, i, j, k)*su3;
+ CCTK_REAL const At33rhsL = -(PDonesided1(At33, i, j, k)*su1) - PDonesided2(At33, i, j, k)*su2 - PDonesided3(At33, i, j, k)*su3;
- Xt1rhsL = -(PDonesided1(Xt1, i, j, k)*su1) - PDonesided2(Xt1, i, j, k)*su2 - PDonesided3(Xt1, i, j, k)*su3;
+ CCTK_REAL const Xt1rhsL = -(PDonesided1(Xt1, i, j, k)*su1) - PDonesided2(Xt1, i, j, k)*su2 - PDonesided3(Xt1, i, j, k)*su3;
- Xt2rhsL = -(PDonesided1(Xt2, i, j, k)*su1) - PDonesided2(Xt2, i, j, k)*su2 - PDonesided3(Xt2, i, j, k)*su3;
+ CCTK_REAL const Xt2rhsL = -(PDonesided1(Xt2, i, j, k)*su1) - PDonesided2(Xt2, i, j, k)*su2 - PDonesided3(Xt2, i, j, k)*su3;
- Xt3rhsL = -(PDonesided1(Xt3, i, j, k)*su1) - PDonesided2(Xt3, i, j, k)*su2 - PDonesided3(Xt3, i, j, k)*su3;
+ CCTK_REAL const Xt3rhsL = -(PDonesided1(Xt3, i, j, k)*su1) - PDonesided2(Xt3, i, j, k)*su2 - PDonesided3(Xt3, i, j, k)*su3;
- alpharhsL = -((PDonesided1(alpha, i, j, k)*su1 + PDonesided2(alpha, i, j, k)*su2 +
+ CCTK_REAL const alpharhsL = -((PDonesided1(alpha, i, j, k)*su1 + PDonesided2(alpha, i, j, k)*su2 +
PDonesided3(alpha, i, j, k)*su3)*vg);
- ArhsL = -((PDonesided1(A, i, j, k)*su1 + PDonesided2(A, i, j, k)*su2 + PDonesided3(A, i, j, k)*su3)*vg);
+ CCTK_REAL const ArhsL = -((PDonesided1(A, i, j, k)*su1 + PDonesided2(A, i, j, k)*su2 + PDonesided3(A, i, j, k)*su3)*vg);
- beta1rhsL = -(PDonesided1(beta1, i, j, k)*su1) - PDonesided2(beta1, i, j, k)*su2 -
+ CCTK_REAL const beta1rhsL = -(PDonesided1(beta1, i, j, k)*su1) - PDonesided2(beta1, i, j, k)*su2 -
PDonesided3(beta1, i, j, k)*su3;
- beta2rhsL = -(PDonesided1(beta2, i, j, k)*su1) - PDonesided2(beta2, i, j, k)*su2 -
+ CCTK_REAL const beta2rhsL = -(PDonesided1(beta2, i, j, k)*su1) - PDonesided2(beta2, i, j, k)*su2 -
PDonesided3(beta2, i, j, k)*su3;
- beta3rhsL = -(PDonesided1(beta3, i, j, k)*su1) - PDonesided2(beta3, i, j, k)*su2 -
+ CCTK_REAL const beta3rhsL = -(PDonesided1(beta3, i, j, k)*su1) - PDonesided2(beta3, i, j, k)*su2 -
PDonesided3(beta3, i, j, k)*su3;
- B1rhsL = -(PDonesided1(B1, i, j, k)*su1) - PDonesided2(B1, i, j, k)*su2 - PDonesided3(B1, i, j, k)*su3;
+ CCTK_REAL const B1rhsL = -(PDonesided1(B1, i, j, k)*su1) - PDonesided2(B1, i, j, k)*su2 - PDonesided3(B1, i, j, k)*su3;
- B2rhsL = -(PDonesided1(B2, i, j, k)*su1) - PDonesided2(B2, i, j, k)*su2 - PDonesided3(B2, i, j, k)*su3;
+ CCTK_REAL const B2rhsL = -(PDonesided1(B2, i, j, k)*su1) - PDonesided2(B2, i, j, k)*su2 - PDonesided3(B2, i, j, k)*su3;
- B3rhsL = -(PDonesided1(B3, i, j, k)*su1) - PDonesided2(B3, i, j, k)*su2 - PDonesided3(B3, i, j, k)*su3;
+ CCTK_REAL const B3rhsL = -(PDonesided1(B3, i, j, k)*su1) - PDonesided2(B3, i, j, k)*su2 - PDonesided3(B3, i, j, k)*su3;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_RHSStaticBoundary.c b/ML_BSSN/src/ML_BSSN_RHSStaticBoundary.c
index d2c5559..f1a6c0a 100644
--- a/ML_BSSN/src/ML_BSSN_RHSStaticBoundary.c
+++ b/ML_BSSN/src/ML_BSSN_RHSStaticBoundary.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_RHSStaticBoundary_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_RHSStaticBoundary_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_RHSStaticBoundary_Body(cGH const * const cctkGH, CCTK_INT const dir
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,23 +93,23 @@ void ML_BSSN_RHSStaticBoundary_Body(cGH const * const cctkGH, CCTK_INT const dir
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
/* Declare local copies of grid functions */
- CCTK_REAL alpharhsL = INITVALUE;
- CCTK_REAL ArhsL = INITVALUE;
- CCTK_REAL At11rhsL = INITVALUE, At12rhsL = INITVALUE, At13rhsL = INITVALUE, At22rhsL = INITVALUE, At23rhsL = INITVALUE, At33rhsL = INITVALUE;
- CCTK_REAL B1rhsL = INITVALUE, B2rhsL = INITVALUE, B3rhsL = INITVALUE;
- CCTK_REAL beta1rhsL = INITVALUE, beta2rhsL = INITVALUE, beta3rhsL = INITVALUE;
- CCTK_REAL gt11rhsL = INITVALUE, gt12rhsL = INITVALUE, gt13rhsL = INITVALUE, gt22rhsL = INITVALUE, gt23rhsL = INITVALUE, gt33rhsL = INITVALUE;
- CCTK_REAL phirhsL = INITVALUE;
- CCTK_REAL trKrhsL = INITVALUE;
- CCTK_REAL Xt1rhsL = INITVALUE, Xt2rhsL = INITVALUE, Xt3rhsL = INITVALUE;
+ // CCTK_REAL alpharhsL = INITVALUE;
+ // CCTK_REAL ArhsL = INITVALUE;
+ // CCTK_REAL At11rhsL = INITVALUE, At12rhsL = INITVALUE, At13rhsL = INITVALUE, At22rhsL = INITVALUE, At23rhsL = INITVALUE, At33rhsL = INITVALUE;
+ // CCTK_REAL B1rhsL = INITVALUE, B2rhsL = INITVALUE, B3rhsL = INITVALUE;
+ // CCTK_REAL beta1rhsL = INITVALUE, beta2rhsL = INITVALUE, beta3rhsL = INITVALUE;
+ // CCTK_REAL gt11rhsL = INITVALUE, gt12rhsL = INITVALUE, gt13rhsL = INITVALUE, gt22rhsL = INITVALUE, gt23rhsL = INITVALUE, gt33rhsL = INITVALUE;
+ // CCTK_REAL phirhsL = INITVALUE;
+ // CCTK_REAL trKrhsL = INITVALUE;
+ // CCTK_REAL Xt1rhsL = INITVALUE, Xt2rhsL = INITVALUE, Xt3rhsL = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
@@ -127,55 +125,55 @@ void ML_BSSN_RHSStaticBoundary_Body(cGH const * const cctkGH, CCTK_INT const dir
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- phirhsL = 0;
+ CCTK_REAL const phirhsL = 0;
- gt11rhsL = 0;
+ CCTK_REAL const gt11rhsL = 0;
- gt12rhsL = 0;
+ CCTK_REAL const gt12rhsL = 0;
- gt13rhsL = 0;
+ CCTK_REAL const gt13rhsL = 0;
- gt22rhsL = 0;
+ CCTK_REAL const gt22rhsL = 0;
- gt23rhsL = 0;
+ CCTK_REAL const gt23rhsL = 0;
- gt33rhsL = 0;
+ CCTK_REAL const gt33rhsL = 0;
- trKrhsL = 0;
+ CCTK_REAL const trKrhsL = 0;
- At11rhsL = 0;
+ CCTK_REAL const At11rhsL = 0;
- At12rhsL = 0;
+ CCTK_REAL const At12rhsL = 0;
- At13rhsL = 0;
+ CCTK_REAL const At13rhsL = 0;
- At22rhsL = 0;
+ CCTK_REAL const At22rhsL = 0;
- At23rhsL = 0;
+ CCTK_REAL const At23rhsL = 0;
- At33rhsL = 0;
+ CCTK_REAL const At33rhsL = 0;
- Xt1rhsL = 0;
+ CCTK_REAL const Xt1rhsL = 0;
- Xt2rhsL = 0;
+ CCTK_REAL const Xt2rhsL = 0;
- Xt3rhsL = 0;
+ CCTK_REAL const Xt3rhsL = 0;
- alpharhsL = 0;
+ CCTK_REAL const alpharhsL = 0;
- ArhsL = 0;
+ CCTK_REAL const ArhsL = 0;
- beta1rhsL = 0;
+ CCTK_REAL const beta1rhsL = 0;
- beta2rhsL = 0;
+ CCTK_REAL const beta2rhsL = 0;
- beta3rhsL = 0;
+ CCTK_REAL const beta3rhsL = 0;
- B1rhsL = 0;
+ CCTK_REAL const B1rhsL = 0;
- B2rhsL = 0;
+ CCTK_REAL const B2rhsL = 0;
- B3rhsL = 0;
+ CCTK_REAL const B3rhsL = 0;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_boundary.c b/ML_BSSN/src/ML_BSSN_boundary.c
index c44bca2..a2ad643 100644
--- a/ML_BSSN/src/ML_BSSN_boundary.c
+++ b/ML_BSSN/src/ML_BSSN_boundary.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_boundary_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_boundary_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_boundary_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_IN
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,23 +93,23 @@ void ML_BSSN_boundary_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_IN
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
/* Declare local copies of grid functions */
- CCTK_REAL AL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE;
- CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
- CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
- CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
- CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
- CCTK_REAL phiL = INITVALUE;
- CCTK_REAL trKL = INITVALUE;
- CCTK_REAL Xt1L = INITVALUE, Xt2L = INITVALUE, Xt3L = INITVALUE;
+ // CCTK_REAL AL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
+ // CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
+ // CCTK_REAL phiL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE;
+ // CCTK_REAL Xt1L = INITVALUE, Xt2L = INITVALUE, Xt3L = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
@@ -127,55 +125,55 @@ void ML_BSSN_boundary_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_IN
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- phiL = IfThen(conformalMethod,1,0);
+ CCTK_REAL const phiL = IfThen(conformalMethod,1,0);
- gt11L = 1;
+ CCTK_REAL const gt11L = 1;
- gt12L = 0;
+ CCTK_REAL const gt12L = 0;
- gt13L = 0;
+ CCTK_REAL const gt13L = 0;
- gt22L = 1;
+ CCTK_REAL const gt22L = 1;
- gt23L = 0;
+ CCTK_REAL const gt23L = 0;
- gt33L = 1;
+ CCTK_REAL const gt33L = 1;
- trKL = 0;
+ CCTK_REAL const trKL = 0;
- At11L = 0;
+ CCTK_REAL const At11L = 0;
- At12L = 0;
+ CCTK_REAL const At12L = 0;
- At13L = 0;
+ CCTK_REAL const At13L = 0;
- At22L = 0;
+ CCTK_REAL const At22L = 0;
- At23L = 0;
+ CCTK_REAL const At23L = 0;
- At33L = 0;
+ CCTK_REAL const At33L = 0;
- Xt1L = 0;
+ CCTK_REAL const Xt1L = 0;
- Xt2L = 0;
+ CCTK_REAL const Xt2L = 0;
- Xt3L = 0;
+ CCTK_REAL const Xt3L = 0;
- alphaL = 1;
+ CCTK_REAL const alphaL = 1;
- AL = 0;
+ CCTK_REAL const AL = 0;
- beta1L = 0;
+ CCTK_REAL const beta1L = 0;
- beta2L = 0;
+ CCTK_REAL const beta2L = 0;
- beta3L = 0;
+ CCTK_REAL const beta3L = 0;
- B1L = 0;
+ CCTK_REAL const B1L = 0;
- B2L = 0;
+ CCTK_REAL const B2L = 0;
- B3L = 0;
+ CCTK_REAL const B3L = 0;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_constraints.c b/ML_BSSN/src/ML_BSSN_constraints.c
index bab2155..f63c3fd 100644
--- a/ML_BSSN/src/ML_BSSN_constraints.c
+++ b/ML_BSSN/src/ML_BSSN_constraints.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_constraints_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_constraints_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_constraints_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,328 +93,358 @@ void ML_BSSN_constraints_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
- CCTK_REAL Atm11 = INITVALUE, Atm12 = INITVALUE, Atm13 = INITVALUE, Atm21 = INITVALUE, Atm22 = INITVALUE, Atm23 = INITVALUE;
- CCTK_REAL Atm31 = INITVALUE, Atm32 = INITVALUE, Atm33 = INITVALUE;
- CCTK_REAL cdphi1 = INITVALUE, cdphi2 = INITVALUE, cdphi211 = INITVALUE, cdphi212 = INITVALUE, cdphi213 = INITVALUE, cdphi222 = INITVALUE;
- CCTK_REAL cdphi223 = INITVALUE, cdphi233 = INITVALUE, cdphi3 = INITVALUE;
- CCTK_REAL detgt = INITVALUE;
- CCTK_REAL e4phi = INITVALUE;
- CCTK_REAL em4phi = INITVALUE;
- CCTK_REAL fac1 = INITVALUE, fac2 = INITVALUE;
- CCTK_REAL Gt111 = INITVALUE, Gt112 = INITVALUE, Gt113 = INITVALUE, Gt122 = INITVALUE, Gt123 = INITVALUE, Gt133 = INITVALUE;
- CCTK_REAL Gt211 = INITVALUE, Gt212 = INITVALUE, Gt213 = INITVALUE, Gt222 = INITVALUE, Gt223 = INITVALUE, Gt233 = INITVALUE;
- CCTK_REAL Gt311 = INITVALUE, Gt312 = INITVALUE, Gt313 = INITVALUE, Gt322 = INITVALUE, Gt323 = INITVALUE, Gt333 = INITVALUE;
- CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
- CCTK_REAL gu11 = INITVALUE, gu21 = INITVALUE, gu22 = INITVALUE, gu31 = INITVALUE, gu32 = INITVALUE, gu33 = INITVALUE;
- CCTK_REAL R11 = INITVALUE, R12 = INITVALUE, R13 = INITVALUE, R22 = INITVALUE, R23 = INITVALUE, R33 = INITVALUE;
- CCTK_REAL Rphi11 = INITVALUE, Rphi12 = INITVALUE, Rphi13 = INITVALUE, Rphi22 = INITVALUE, Rphi23 = INITVALUE, Rphi33 = INITVALUE;
- CCTK_REAL Rt11 = INITVALUE, Rt12 = INITVALUE, Rt13 = INITVALUE, Rt22 = INITVALUE, Rt23 = INITVALUE, Rt33 = INITVALUE;
- CCTK_REAL trR = INITVALUE;
+ // CCTK_REAL Atm11 = INITVALUE, Atm12 = INITVALUE, Atm13 = INITVALUE, Atm21 = INITVALUE, Atm22 = INITVALUE, Atm23 = INITVALUE;
+ // CCTK_REAL Atm31 = INITVALUE, Atm32 = INITVALUE, Atm33 = INITVALUE;
+ // CCTK_REAL cdphi1 = INITVALUE, cdphi2 = INITVALUE, cdphi211 = INITVALUE, cdphi212 = INITVALUE, cdphi213 = INITVALUE, cdphi222 = INITVALUE;
+ // CCTK_REAL cdphi223 = INITVALUE, cdphi233 = INITVALUE, cdphi3 = INITVALUE;
+ // CCTK_REAL detgt = INITVALUE;
+ // CCTK_REAL e4phi = INITVALUE;
+ // CCTK_REAL em4phi = INITVALUE;
+ // CCTK_REAL fac1 = INITVALUE, fac2 = INITVALUE;
+ // CCTK_REAL Gt111 = INITVALUE, Gt112 = INITVALUE, Gt113 = INITVALUE, Gt122 = INITVALUE, Gt123 = INITVALUE, Gt133 = INITVALUE;
+ // CCTK_REAL Gt211 = INITVALUE, Gt212 = INITVALUE, Gt213 = INITVALUE, Gt222 = INITVALUE, Gt223 = INITVALUE, Gt233 = INITVALUE;
+ // CCTK_REAL Gt311 = INITVALUE, Gt312 = INITVALUE, Gt313 = INITVALUE, Gt322 = INITVALUE, Gt323 = INITVALUE, Gt333 = INITVALUE;
+ // CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
+ // CCTK_REAL gu11 = INITVALUE, gu21 = INITVALUE, gu22 = INITVALUE, gu31 = INITVALUE, gu32 = INITVALUE, gu33 = INITVALUE;
+ // CCTK_REAL R11 = INITVALUE, R12 = INITVALUE, R13 = INITVALUE, R22 = INITVALUE, R23 = INITVALUE, R33 = INITVALUE;
+ // CCTK_REAL rho = INITVALUE;
+ // CCTK_REAL Rphi11 = INITVALUE, Rphi12 = INITVALUE, Rphi13 = INITVALUE, Rphi22 = INITVALUE, Rphi23 = INITVALUE, Rphi33 = INITVALUE;
+ // CCTK_REAL Rt11 = INITVALUE, Rt12 = INITVALUE, Rt13 = INITVALUE, Rt22 = INITVALUE, Rt23 = INITVALUE, Rt33 = INITVALUE;
+ // CCTK_REAL S1 = INITVALUE, S2 = INITVALUE, S3 = INITVALUE;
+ // CCTK_REAL T00 = INITVALUE, T01 = INITVALUE, T02 = INITVALUE, T03 = INITVALUE, T11 = INITVALUE, T12 = INITVALUE;
+ // CCTK_REAL T13 = INITVALUE, T22 = INITVALUE, T23 = INITVALUE, T33 = INITVALUE;
+ // CCTK_REAL trR = INITVALUE;
/* Declare local copies of grid functions */
- CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
- CCTK_REAL cAL = INITVALUE;
- CCTK_REAL cSL = INITVALUE;
- CCTK_REAL cXt1L = INITVALUE, cXt2L = INITVALUE, cXt3L = INITVALUE;
- CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
- CCTK_REAL HL = INITVALUE;
- CCTK_REAL M1L = INITVALUE, M2L = INITVALUE, M3L = INITVALUE;
- CCTK_REAL phiL = INITVALUE;
- CCTK_REAL trKL = INITVALUE;
- CCTK_REAL Xt1L = INITVALUE, Xt2L = INITVALUE, Xt3L = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
+ // CCTK_REAL cAL = INITVALUE;
+ // CCTK_REAL cSL = INITVALUE;
+ // CCTK_REAL cXt1L = INITVALUE, cXt2L = INITVALUE, cXt3L = INITVALUE;
+ // CCTK_REAL eTttL = INITVALUE;
+ // CCTK_REAL eTtxL = INITVALUE;
+ // CCTK_REAL eTtyL = INITVALUE;
+ // CCTK_REAL eTtzL = INITVALUE;
+ // CCTK_REAL eTxxL = INITVALUE;
+ // CCTK_REAL eTxyL = INITVALUE;
+ // CCTK_REAL eTxzL = INITVALUE;
+ // CCTK_REAL eTyyL = INITVALUE;
+ // CCTK_REAL eTyzL = INITVALUE;
+ // CCTK_REAL eTzzL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
+ // CCTK_REAL HL = INITVALUE;
+ // CCTK_REAL M1L = INITVALUE, M2L = INITVALUE, M3L = INITVALUE;
+ // CCTK_REAL phiL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE;
+ // CCTK_REAL Xt1L = INITVALUE, Xt2L = INITVALUE, Xt3L = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
- CCTK_REAL PDstandardNth1At11 = INITVALUE;
- CCTK_REAL PDstandardNth2At11 = INITVALUE;
- CCTK_REAL PDstandardNth3At11 = INITVALUE;
- CCTK_REAL PDstandardNth1At12 = INITVALUE;
- CCTK_REAL PDstandardNth2At12 = INITVALUE;
- CCTK_REAL PDstandardNth3At12 = INITVALUE;
- CCTK_REAL PDstandardNth1At13 = INITVALUE;
- CCTK_REAL PDstandardNth2At13 = INITVALUE;
- CCTK_REAL PDstandardNth3At13 = INITVALUE;
- CCTK_REAL PDstandardNth1At22 = INITVALUE;
- CCTK_REAL PDstandardNth2At22 = INITVALUE;
- CCTK_REAL PDstandardNth3At22 = INITVALUE;
- CCTK_REAL PDstandardNth1At23 = INITVALUE;
- CCTK_REAL PDstandardNth2At23 = INITVALUE;
- CCTK_REAL PDstandardNth3At23 = INITVALUE;
- CCTK_REAL PDstandardNth1At33 = INITVALUE;
- CCTK_REAL PDstandardNth2At33 = INITVALUE;
- CCTK_REAL PDstandardNth3At33 = INITVALUE;
- CCTK_REAL PDstandardNth1gt11 = INITVALUE;
- CCTK_REAL PDstandardNth2gt11 = INITVALUE;
- CCTK_REAL PDstandardNth3gt11 = INITVALUE;
- CCTK_REAL PDstandardNth11gt11 = INITVALUE;
- CCTK_REAL PDstandardNth22gt11 = INITVALUE;
- CCTK_REAL PDstandardNth33gt11 = INITVALUE;
- CCTK_REAL PDstandardNth12gt11 = INITVALUE;
- CCTK_REAL PDstandardNth13gt11 = INITVALUE;
- CCTK_REAL PDstandardNth23gt11 = INITVALUE;
- CCTK_REAL PDstandardNth1gt12 = INITVALUE;
- CCTK_REAL PDstandardNth2gt12 = INITVALUE;
- CCTK_REAL PDstandardNth3gt12 = INITVALUE;
- CCTK_REAL PDstandardNth11gt12 = INITVALUE;
- CCTK_REAL PDstandardNth22gt12 = INITVALUE;
- CCTK_REAL PDstandardNth33gt12 = INITVALUE;
- CCTK_REAL PDstandardNth12gt12 = INITVALUE;
- CCTK_REAL PDstandardNth13gt12 = INITVALUE;
- CCTK_REAL PDstandardNth23gt12 = INITVALUE;
- CCTK_REAL PDstandardNth1gt13 = INITVALUE;
- CCTK_REAL PDstandardNth2gt13 = INITVALUE;
- CCTK_REAL PDstandardNth3gt13 = INITVALUE;
- CCTK_REAL PDstandardNth11gt13 = INITVALUE;
- CCTK_REAL PDstandardNth22gt13 = INITVALUE;
- CCTK_REAL PDstandardNth33gt13 = INITVALUE;
- CCTK_REAL PDstandardNth12gt13 = INITVALUE;
- CCTK_REAL PDstandardNth13gt13 = INITVALUE;
- CCTK_REAL PDstandardNth23gt13 = INITVALUE;
- CCTK_REAL PDstandardNth1gt22 = INITVALUE;
- CCTK_REAL PDstandardNth2gt22 = INITVALUE;
- CCTK_REAL PDstandardNth3gt22 = INITVALUE;
- CCTK_REAL PDstandardNth11gt22 = INITVALUE;
- CCTK_REAL PDstandardNth22gt22 = INITVALUE;
- CCTK_REAL PDstandardNth33gt22 = INITVALUE;
- CCTK_REAL PDstandardNth12gt22 = INITVALUE;
- CCTK_REAL PDstandardNth13gt22 = INITVALUE;
- CCTK_REAL PDstandardNth23gt22 = INITVALUE;
- CCTK_REAL PDstandardNth1gt23 = INITVALUE;
- CCTK_REAL PDstandardNth2gt23 = INITVALUE;
- CCTK_REAL PDstandardNth3gt23 = INITVALUE;
- CCTK_REAL PDstandardNth11gt23 = INITVALUE;
- CCTK_REAL PDstandardNth22gt23 = INITVALUE;
- CCTK_REAL PDstandardNth33gt23 = INITVALUE;
- CCTK_REAL PDstandardNth12gt23 = INITVALUE;
- CCTK_REAL PDstandardNth13gt23 = INITVALUE;
- CCTK_REAL PDstandardNth23gt23 = INITVALUE;
- CCTK_REAL PDstandardNth1gt33 = INITVALUE;
- CCTK_REAL PDstandardNth2gt33 = INITVALUE;
- CCTK_REAL PDstandardNth3gt33 = INITVALUE;
- CCTK_REAL PDstandardNth11gt33 = INITVALUE;
- CCTK_REAL PDstandardNth22gt33 = INITVALUE;
- CCTK_REAL PDstandardNth33gt33 = INITVALUE;
- CCTK_REAL PDstandardNth12gt33 = INITVALUE;
- CCTK_REAL PDstandardNth13gt33 = INITVALUE;
- CCTK_REAL PDstandardNth23gt33 = INITVALUE;
- CCTK_REAL PDstandardNth1phi = INITVALUE;
- CCTK_REAL PDstandardNth2phi = INITVALUE;
- CCTK_REAL PDstandardNth3phi = INITVALUE;
- CCTK_REAL PDstandardNth11phi = INITVALUE;
- CCTK_REAL PDstandardNth22phi = INITVALUE;
- CCTK_REAL PDstandardNth33phi = INITVALUE;
- CCTK_REAL PDstandardNth12phi = INITVALUE;
- CCTK_REAL PDstandardNth13phi = INITVALUE;
- CCTK_REAL PDstandardNth23phi = INITVALUE;
- CCTK_REAL PDstandardNth1trK = INITVALUE;
- CCTK_REAL PDstandardNth2trK = INITVALUE;
- CCTK_REAL PDstandardNth3trK = INITVALUE;
- CCTK_REAL PDstandardNth1Xt1 = INITVALUE;
- CCTK_REAL PDstandardNth2Xt1 = INITVALUE;
- CCTK_REAL PDstandardNth3Xt1 = INITVALUE;
- CCTK_REAL PDstandardNth1Xt2 = INITVALUE;
- CCTK_REAL PDstandardNth2Xt2 = INITVALUE;
- CCTK_REAL PDstandardNth3Xt2 = INITVALUE;
- CCTK_REAL PDstandardNth1Xt3 = INITVALUE;
- CCTK_REAL PDstandardNth2Xt3 = INITVALUE;
- CCTK_REAL PDstandardNth3Xt3 = INITVALUE;
+ // CCTK_REAL PDstandardNth1At11 = INITVALUE;
+ // CCTK_REAL PDstandardNth2At11 = INITVALUE;
+ // CCTK_REAL PDstandardNth3At11 = INITVALUE;
+ // CCTK_REAL PDstandardNth1At12 = INITVALUE;
+ // CCTK_REAL PDstandardNth2At12 = INITVALUE;
+ // CCTK_REAL PDstandardNth3At12 = INITVALUE;
+ // CCTK_REAL PDstandardNth1At13 = INITVALUE;
+ // CCTK_REAL PDstandardNth2At13 = INITVALUE;
+ // CCTK_REAL PDstandardNth3At13 = INITVALUE;
+ // CCTK_REAL PDstandardNth1At22 = INITVALUE;
+ // CCTK_REAL PDstandardNth2At22 = INITVALUE;
+ // CCTK_REAL PDstandardNth3At22 = INITVALUE;
+ // CCTK_REAL PDstandardNth1At23 = INITVALUE;
+ // CCTK_REAL PDstandardNth2At23 = INITVALUE;
+ // CCTK_REAL PDstandardNth3At23 = INITVALUE;
+ // CCTK_REAL PDstandardNth1At33 = INITVALUE;
+ // CCTK_REAL PDstandardNth2At33 = INITVALUE;
+ // CCTK_REAL PDstandardNth3At33 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth11gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth22gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth33gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth12gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth13gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth23gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth1phi = INITVALUE;
+ // CCTK_REAL PDstandardNth2phi = INITVALUE;
+ // CCTK_REAL PDstandardNth3phi = INITVALUE;
+ // CCTK_REAL PDstandardNth11phi = INITVALUE;
+ // CCTK_REAL PDstandardNth22phi = INITVALUE;
+ // CCTK_REAL PDstandardNth33phi = INITVALUE;
+ // CCTK_REAL PDstandardNth12phi = INITVALUE;
+ // CCTK_REAL PDstandardNth13phi = INITVALUE;
+ // CCTK_REAL PDstandardNth23phi = INITVALUE;
+ // CCTK_REAL PDstandardNth1trK = INITVALUE;
+ // CCTK_REAL PDstandardNth2trK = INITVALUE;
+ // CCTK_REAL PDstandardNth3trK = INITVALUE;
+ // CCTK_REAL PDstandardNth1Xt1 = INITVALUE;
+ // CCTK_REAL PDstandardNth2Xt1 = INITVALUE;
+ // CCTK_REAL PDstandardNth3Xt1 = INITVALUE;
+ // CCTK_REAL PDstandardNth1Xt2 = INITVALUE;
+ // CCTK_REAL PDstandardNth2Xt2 = INITVALUE;
+ // CCTK_REAL PDstandardNth3Xt2 = INITVALUE;
+ // CCTK_REAL PDstandardNth1Xt3 = INITVALUE;
+ // CCTK_REAL PDstandardNth2Xt3 = INITVALUE;
+ // CCTK_REAL PDstandardNth3Xt3 = INITVALUE;
/* Assign local copies of grid functions */
- At11L = At11[index];
- At12L = At12[index];
- At13L = At13[index];
- At22L = At22[index];
- At23L = At23[index];
- At33L = At33[index];
- gt11L = gt11[index];
- gt12L = gt12[index];
- gt13L = gt13[index];
- gt22L = gt22[index];
- gt23L = gt23[index];
- gt33L = gt33[index];
- phiL = phi[index];
- trKL = trK[index];
- Xt1L = Xt1[index];
- Xt2L = Xt2[index];
- Xt3L = Xt3[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const At11L = At11[index];
+ CCTK_REAL const At12L = At12[index];
+ CCTK_REAL const At13L = At13[index];
+ CCTK_REAL const At22L = At22[index];
+ CCTK_REAL const At23L = At23[index];
+ CCTK_REAL const At33L = At33[index];
+ CCTK_REAL const beta1L = beta1[index];
+ CCTK_REAL const beta2L = beta2[index];
+ CCTK_REAL const beta3L = beta3[index];
+ CCTK_REAL const eTttL = (stress_energy_state) ? (eTtt[index]) : 0.0;
+ CCTK_REAL const eTtxL = (stress_energy_state) ? (eTtx[index]) : 0.0;
+ CCTK_REAL const eTtyL = (stress_energy_state) ? (eTty[index]) : 0.0;
+ CCTK_REAL const eTtzL = (stress_energy_state) ? (eTtz[index]) : 0.0;
+ CCTK_REAL const eTxxL = (stress_energy_state) ? (eTxx[index]) : 0.0;
+ CCTK_REAL const eTxyL = (stress_energy_state) ? (eTxy[index]) : 0.0;
+ CCTK_REAL const eTxzL = (stress_energy_state) ? (eTxz[index]) : 0.0;
+ CCTK_REAL const eTyyL = (stress_energy_state) ? (eTyy[index]) : 0.0;
+ CCTK_REAL const eTyzL = (stress_energy_state) ? (eTyz[index]) : 0.0;
+ CCTK_REAL const eTzzL = (stress_energy_state) ? (eTzz[index]) : 0.0;
+ CCTK_REAL const gt11L = gt11[index];
+ CCTK_REAL const gt12L = gt12[index];
+ CCTK_REAL const gt13L = gt13[index];
+ CCTK_REAL const gt22L = gt22[index];
+ CCTK_REAL const gt23L = gt23[index];
+ CCTK_REAL const gt33L = gt33[index];
+ CCTK_REAL const phiL = phi[index];
+ CCTK_REAL const trKL = trK[index];
+ CCTK_REAL const Xt1L = Xt1[index];
+ CCTK_REAL const Xt2L = Xt2[index];
+ CCTK_REAL const Xt3L = Xt3[index];
/* Assign local copies of subblock grid functions */
/* Include user supplied include files */
/* Precompute derivatives (new style) */
- PDstandardNth1At11 = PDstandardNth1(At11, i, j, k);
- PDstandardNth2At11 = PDstandardNth2(At11, i, j, k);
- PDstandardNth3At11 = PDstandardNth3(At11, i, j, k);
- PDstandardNth1At12 = PDstandardNth1(At12, i, j, k);
- PDstandardNth2At12 = PDstandardNth2(At12, i, j, k);
- PDstandardNth3At12 = PDstandardNth3(At12, i, j, k);
- PDstandardNth1At13 = PDstandardNth1(At13, i, j, k);
- PDstandardNth2At13 = PDstandardNth2(At13, i, j, k);
- PDstandardNth3At13 = PDstandardNth3(At13, i, j, k);
- PDstandardNth1At22 = PDstandardNth1(At22, i, j, k);
- PDstandardNth2At22 = PDstandardNth2(At22, i, j, k);
- PDstandardNth3At22 = PDstandardNth3(At22, i, j, k);
- PDstandardNth1At23 = PDstandardNth1(At23, i, j, k);
- PDstandardNth2At23 = PDstandardNth2(At23, i, j, k);
- PDstandardNth3At23 = PDstandardNth3(At23, i, j, k);
- PDstandardNth1At33 = PDstandardNth1(At33, i, j, k);
- PDstandardNth2At33 = PDstandardNth2(At33, i, j, k);
- PDstandardNth3At33 = PDstandardNth3(At33, i, j, k);
- PDstandardNth1gt11 = PDstandardNth1(gt11, i, j, k);
- PDstandardNth2gt11 = PDstandardNth2(gt11, i, j, k);
- PDstandardNth3gt11 = PDstandardNth3(gt11, i, j, k);
- PDstandardNth11gt11 = PDstandardNth11(gt11, i, j, k);
- PDstandardNth22gt11 = PDstandardNth22(gt11, i, j, k);
- PDstandardNth33gt11 = PDstandardNth33(gt11, i, j, k);
- PDstandardNth12gt11 = PDstandardNth12(gt11, i, j, k);
- PDstandardNth13gt11 = PDstandardNth13(gt11, i, j, k);
- PDstandardNth23gt11 = PDstandardNth23(gt11, i, j, k);
- PDstandardNth1gt12 = PDstandardNth1(gt12, i, j, k);
- PDstandardNth2gt12 = PDstandardNth2(gt12, i, j, k);
- PDstandardNth3gt12 = PDstandardNth3(gt12, i, j, k);
- PDstandardNth11gt12 = PDstandardNth11(gt12, i, j, k);
- PDstandardNth22gt12 = PDstandardNth22(gt12, i, j, k);
- PDstandardNth33gt12 = PDstandardNth33(gt12, i, j, k);
- PDstandardNth12gt12 = PDstandardNth12(gt12, i, j, k);
- PDstandardNth13gt12 = PDstandardNth13(gt12, i, j, k);
- PDstandardNth23gt12 = PDstandardNth23(gt12, i, j, k);
- PDstandardNth1gt13 = PDstandardNth1(gt13, i, j, k);
- PDstandardNth2gt13 = PDstandardNth2(gt13, i, j, k);
- PDstandardNth3gt13 = PDstandardNth3(gt13, i, j, k);
- PDstandardNth11gt13 = PDstandardNth11(gt13, i, j, k);
- PDstandardNth22gt13 = PDstandardNth22(gt13, i, j, k);
- PDstandardNth33gt13 = PDstandardNth33(gt13, i, j, k);
- PDstandardNth12gt13 = PDstandardNth12(gt13, i, j, k);
- PDstandardNth13gt13 = PDstandardNth13(gt13, i, j, k);
- PDstandardNth23gt13 = PDstandardNth23(gt13, i, j, k);
- PDstandardNth1gt22 = PDstandardNth1(gt22, i, j, k);
- PDstandardNth2gt22 = PDstandardNth2(gt22, i, j, k);
- PDstandardNth3gt22 = PDstandardNth3(gt22, i, j, k);
- PDstandardNth11gt22 = PDstandardNth11(gt22, i, j, k);
- PDstandardNth22gt22 = PDstandardNth22(gt22, i, j, k);
- PDstandardNth33gt22 = PDstandardNth33(gt22, i, j, k);
- PDstandardNth12gt22 = PDstandardNth12(gt22, i, j, k);
- PDstandardNth13gt22 = PDstandardNth13(gt22, i, j, k);
- PDstandardNth23gt22 = PDstandardNth23(gt22, i, j, k);
- PDstandardNth1gt23 = PDstandardNth1(gt23, i, j, k);
- PDstandardNth2gt23 = PDstandardNth2(gt23, i, j, k);
- PDstandardNth3gt23 = PDstandardNth3(gt23, i, j, k);
- PDstandardNth11gt23 = PDstandardNth11(gt23, i, j, k);
- PDstandardNth22gt23 = PDstandardNth22(gt23, i, j, k);
- PDstandardNth33gt23 = PDstandardNth33(gt23, i, j, k);
- PDstandardNth12gt23 = PDstandardNth12(gt23, i, j, k);
- PDstandardNth13gt23 = PDstandardNth13(gt23, i, j, k);
- PDstandardNth23gt23 = PDstandardNth23(gt23, i, j, k);
- PDstandardNth1gt33 = PDstandardNth1(gt33, i, j, k);
- PDstandardNth2gt33 = PDstandardNth2(gt33, i, j, k);
- PDstandardNth3gt33 = PDstandardNth3(gt33, i, j, k);
- PDstandardNth11gt33 = PDstandardNth11(gt33, i, j, k);
- PDstandardNth22gt33 = PDstandardNth22(gt33, i, j, k);
- PDstandardNth33gt33 = PDstandardNth33(gt33, i, j, k);
- PDstandardNth12gt33 = PDstandardNth12(gt33, i, j, k);
- PDstandardNth13gt33 = PDstandardNth13(gt33, i, j, k);
- PDstandardNth23gt33 = PDstandardNth23(gt33, i, j, k);
- PDstandardNth1phi = PDstandardNth1(phi, i, j, k);
- PDstandardNth2phi = PDstandardNth2(phi, i, j, k);
- PDstandardNth3phi = PDstandardNth3(phi, i, j, k);
- PDstandardNth11phi = PDstandardNth11(phi, i, j, k);
- PDstandardNth22phi = PDstandardNth22(phi, i, j, k);
- PDstandardNth33phi = PDstandardNth33(phi, i, j, k);
- PDstandardNth12phi = PDstandardNth12(phi, i, j, k);
- PDstandardNth13phi = PDstandardNth13(phi, i, j, k);
- PDstandardNth23phi = PDstandardNth23(phi, i, j, k);
- PDstandardNth1trK = PDstandardNth1(trK, i, j, k);
- PDstandardNth2trK = PDstandardNth2(trK, i, j, k);
- PDstandardNth3trK = PDstandardNth3(trK, i, j, k);
- PDstandardNth1Xt1 = PDstandardNth1(Xt1, i, j, k);
- PDstandardNth2Xt1 = PDstandardNth2(Xt1, i, j, k);
- PDstandardNth3Xt1 = PDstandardNth3(Xt1, i, j, k);
- PDstandardNth1Xt2 = PDstandardNth1(Xt2, i, j, k);
- PDstandardNth2Xt2 = PDstandardNth2(Xt2, i, j, k);
- PDstandardNth3Xt2 = PDstandardNth3(Xt2, i, j, k);
- PDstandardNth1Xt3 = PDstandardNth1(Xt3, i, j, k);
- PDstandardNth2Xt3 = PDstandardNth2(Xt3, i, j, k);
- PDstandardNth3Xt3 = PDstandardNth3(Xt3, i, j, k);
+ CCTK_REAL const PDstandardNth1At11 = PDstandardNth1(At11, i, j, k);
+ CCTK_REAL const PDstandardNth2At11 = PDstandardNth2(At11, i, j, k);
+ CCTK_REAL const PDstandardNth3At11 = PDstandardNth3(At11, i, j, k);
+ CCTK_REAL const PDstandardNth1At12 = PDstandardNth1(At12, i, j, k);
+ CCTK_REAL const PDstandardNth2At12 = PDstandardNth2(At12, i, j, k);
+ CCTK_REAL const PDstandardNth3At12 = PDstandardNth3(At12, i, j, k);
+ CCTK_REAL const PDstandardNth1At13 = PDstandardNth1(At13, i, j, k);
+ CCTK_REAL const PDstandardNth2At13 = PDstandardNth2(At13, i, j, k);
+ CCTK_REAL const PDstandardNth3At13 = PDstandardNth3(At13, i, j, k);
+ CCTK_REAL const PDstandardNth1At22 = PDstandardNth1(At22, i, j, k);
+ CCTK_REAL const PDstandardNth2At22 = PDstandardNth2(At22, i, j, k);
+ CCTK_REAL const PDstandardNth3At22 = PDstandardNth3(At22, i, j, k);
+ CCTK_REAL const PDstandardNth1At23 = PDstandardNth1(At23, i, j, k);
+ CCTK_REAL const PDstandardNth2At23 = PDstandardNth2(At23, i, j, k);
+ CCTK_REAL const PDstandardNth3At23 = PDstandardNth3(At23, i, j, k);
+ CCTK_REAL const PDstandardNth1At33 = PDstandardNth1(At33, i, j, k);
+ CCTK_REAL const PDstandardNth2At33 = PDstandardNth2(At33, i, j, k);
+ CCTK_REAL const PDstandardNth3At33 = PDstandardNth3(At33, i, j, k);
+ CCTK_REAL const PDstandardNth1gt11 = PDstandardNth1(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth2gt11 = PDstandardNth2(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth3gt11 = PDstandardNth3(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth11gt11 = PDstandardNth11(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth22gt11 = PDstandardNth22(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth33gt11 = PDstandardNth33(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth12gt11 = PDstandardNth12(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth13gt11 = PDstandardNth13(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth23gt11 = PDstandardNth23(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth1gt12 = PDstandardNth1(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth2gt12 = PDstandardNth2(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth3gt12 = PDstandardNth3(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth11gt12 = PDstandardNth11(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth22gt12 = PDstandardNth22(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth33gt12 = PDstandardNth33(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth12gt12 = PDstandardNth12(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth13gt12 = PDstandardNth13(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth23gt12 = PDstandardNth23(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth1gt13 = PDstandardNth1(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth2gt13 = PDstandardNth2(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth3gt13 = PDstandardNth3(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth11gt13 = PDstandardNth11(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth22gt13 = PDstandardNth22(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth33gt13 = PDstandardNth33(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth12gt13 = PDstandardNth12(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth13gt13 = PDstandardNth13(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth23gt13 = PDstandardNth23(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth1gt22 = PDstandardNth1(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth2gt22 = PDstandardNth2(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth3gt22 = PDstandardNth3(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth11gt22 = PDstandardNth11(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth22gt22 = PDstandardNth22(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth33gt22 = PDstandardNth33(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth12gt22 = PDstandardNth12(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth13gt22 = PDstandardNth13(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth23gt22 = PDstandardNth23(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth1gt23 = PDstandardNth1(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth2gt23 = PDstandardNth2(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth3gt23 = PDstandardNth3(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth11gt23 = PDstandardNth11(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth22gt23 = PDstandardNth22(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth33gt23 = PDstandardNth33(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth12gt23 = PDstandardNth12(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth13gt23 = PDstandardNth13(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth23gt23 = PDstandardNth23(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth1gt33 = PDstandardNth1(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth2gt33 = PDstandardNth2(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth3gt33 = PDstandardNth3(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth11gt33 = PDstandardNth11(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth22gt33 = PDstandardNth22(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth33gt33 = PDstandardNth33(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth12gt33 = PDstandardNth12(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth13gt33 = PDstandardNth13(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth23gt33 = PDstandardNth23(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth1phi = PDstandardNth1(phi, i, j, k);
+ CCTK_REAL const PDstandardNth2phi = PDstandardNth2(phi, i, j, k);
+ CCTK_REAL const PDstandardNth3phi = PDstandardNth3(phi, i, j, k);
+ CCTK_REAL const PDstandardNth11phi = PDstandardNth11(phi, i, j, k);
+ CCTK_REAL const PDstandardNth22phi = PDstandardNth22(phi, i, j, k);
+ CCTK_REAL const PDstandardNth33phi = PDstandardNth33(phi, i, j, k);
+ CCTK_REAL const PDstandardNth12phi = PDstandardNth12(phi, i, j, k);
+ CCTK_REAL const PDstandardNth13phi = PDstandardNth13(phi, i, j, k);
+ CCTK_REAL const PDstandardNth23phi = PDstandardNth23(phi, i, j, k);
+ CCTK_REAL const PDstandardNth1trK = PDstandardNth1(trK, i, j, k);
+ CCTK_REAL const PDstandardNth2trK = PDstandardNth2(trK, i, j, k);
+ CCTK_REAL const PDstandardNth3trK = PDstandardNth3(trK, i, j, k);
+ CCTK_REAL const PDstandardNth1Xt1 = PDstandardNth1(Xt1, i, j, k);
+ CCTK_REAL const PDstandardNth2Xt1 = PDstandardNth2(Xt1, i, j, k);
+ CCTK_REAL const PDstandardNth3Xt1 = PDstandardNth3(Xt1, i, j, k);
+ CCTK_REAL const PDstandardNth1Xt2 = PDstandardNth1(Xt2, i, j, k);
+ CCTK_REAL const PDstandardNth2Xt2 = PDstandardNth2(Xt2, i, j, k);
+ CCTK_REAL const PDstandardNth3Xt2 = PDstandardNth3(Xt2, i, j, k);
+ CCTK_REAL const PDstandardNth1Xt3 = PDstandardNth1(Xt3, i, j, k);
+ CCTK_REAL const PDstandardNth2Xt3 = PDstandardNth2(Xt3, i, j, k);
+ CCTK_REAL const PDstandardNth3Xt3 = PDstandardNth3(Xt3, i, j, k);
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- detgt = 1;
+ CCTK_REAL const detgt = 1;
- gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
+ CCTK_REAL const gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
- gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
+ CCTK_REAL const gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
- gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
- gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
+ CCTK_REAL const gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
- gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
- gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
+ CCTK_REAL const gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
- Gt111 = khalf*(gtu11*PDstandardNth1gt11 + 2*(gtu21*PDstandardNth1gt12 + gtu31*PDstandardNth1gt13) -
+ CCTK_REAL const Gt111 = khalf*(gtu11*PDstandardNth1gt11 + 2*(gtu21*PDstandardNth1gt12 + gtu31*PDstandardNth1gt13) -
gtu21*PDstandardNth2gt11 - gtu31*PDstandardNth3gt11);
- Gt211 = khalf*(gtu21*PDstandardNth1gt11 + 2*(gtu22*PDstandardNth1gt12 + gtu32*PDstandardNth1gt13) -
+ CCTK_REAL const Gt211 = khalf*(gtu21*PDstandardNth1gt11 + 2*(gtu22*PDstandardNth1gt12 + gtu32*PDstandardNth1gt13) -
gtu22*PDstandardNth2gt11 - gtu32*PDstandardNth3gt11);
- Gt311 = khalf*(gtu31*PDstandardNth1gt11 + 2*(gtu32*PDstandardNth1gt12 + gtu33*PDstandardNth1gt13) -
+ CCTK_REAL const Gt311 = khalf*(gtu31*PDstandardNth1gt11 + 2*(gtu32*PDstandardNth1gt12 + gtu33*PDstandardNth1gt13) -
gtu32*PDstandardNth2gt11 - gtu33*PDstandardNth3gt11);
- Gt112 = khalf*(gtu21*PDstandardNth1gt22 + gtu11*PDstandardNth2gt11 +
+ CCTK_REAL const Gt112 = khalf*(gtu21*PDstandardNth1gt22 + gtu11*PDstandardNth2gt11 +
gtu31*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
- Gt212 = khalf*(gtu22*PDstandardNth1gt22 + gtu21*PDstandardNth2gt11 +
+ CCTK_REAL const Gt212 = khalf*(gtu22*PDstandardNth1gt22 + gtu21*PDstandardNth2gt11 +
gtu32*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
- Gt312 = khalf*(gtu32*PDstandardNth1gt22 + gtu31*PDstandardNth2gt11 +
+ CCTK_REAL const Gt312 = khalf*(gtu32*PDstandardNth1gt22 + gtu31*PDstandardNth2gt11 +
gtu33*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
- Gt113 = khalf*(gtu31*PDstandardNth1gt33 + gtu11*PDstandardNth3gt11 +
+ CCTK_REAL const Gt113 = khalf*(gtu31*PDstandardNth1gt33 + gtu11*PDstandardNth3gt11 +
gtu21*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
- Gt213 = khalf*(gtu32*PDstandardNth1gt33 + gtu21*PDstandardNth3gt11 +
+ CCTK_REAL const Gt213 = khalf*(gtu32*PDstandardNth1gt33 + gtu21*PDstandardNth3gt11 +
gtu22*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
- Gt313 = khalf*(gtu33*PDstandardNth1gt33 + gtu31*PDstandardNth3gt11 +
+ CCTK_REAL const Gt313 = khalf*(gtu33*PDstandardNth1gt33 + gtu31*PDstandardNth3gt11 +
gtu32*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
- Gt122 = khalf*(gtu11*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu21*PDstandardNth2gt22 +
+ CCTK_REAL const Gt122 = khalf*(gtu11*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu21*PDstandardNth2gt22 +
gtu31*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
- Gt222 = khalf*(gtu21*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu22*PDstandardNth2gt22 +
+ CCTK_REAL const Gt222 = khalf*(gtu21*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu22*PDstandardNth2gt22 +
gtu32*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
- Gt322 = khalf*(gtu31*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu32*PDstandardNth2gt22 +
+ CCTK_REAL const Gt322 = khalf*(gtu31*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu32*PDstandardNth2gt22 +
gtu33*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
- Gt123 = khalf*(gtu31*PDstandardNth2gt33 + gtu11*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ CCTK_REAL const Gt123 = khalf*(gtu31*PDstandardNth2gt33 + gtu11*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
gtu21*PDstandardNth3gt22);
- Gt223 = khalf*(gtu32*PDstandardNth2gt33 + gtu21*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ CCTK_REAL const Gt223 = khalf*(gtu32*PDstandardNth2gt33 + gtu21*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
gtu22*PDstandardNth3gt22);
- Gt323 = khalf*(gtu33*PDstandardNth2gt33 + gtu31*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ CCTK_REAL const Gt323 = khalf*(gtu33*PDstandardNth2gt33 + gtu31*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
gtu32*PDstandardNth3gt22);
- Gt133 = khalf*(-(gtu11*PDstandardNth1gt33) - gtu21*PDstandardNth2gt33 + 2*gtu11*PDstandardNth3gt13 +
+ CCTK_REAL const Gt133 = khalf*(-(gtu11*PDstandardNth1gt33) - gtu21*PDstandardNth2gt33 + 2*gtu11*PDstandardNth3gt13 +
2*gtu21*PDstandardNth3gt23 + gtu31*PDstandardNth3gt33);
- Gt233 = khalf*(-(gtu21*PDstandardNth1gt33) - gtu22*PDstandardNth2gt33 + 2*gtu21*PDstandardNth3gt13 +
+ CCTK_REAL const Gt233 = khalf*(-(gtu21*PDstandardNth1gt33) - gtu22*PDstandardNth2gt33 + 2*gtu21*PDstandardNth3gt13 +
2*gtu22*PDstandardNth3gt23 + gtu32*PDstandardNth3gt33);
- Gt333 = khalf*(-(gtu31*PDstandardNth1gt33) - gtu32*PDstandardNth2gt33 + 2*gtu31*PDstandardNth3gt13 +
+ CCTK_REAL const Gt333 = khalf*(-(gtu31*PDstandardNth1gt33) - gtu32*PDstandardNth2gt33 + 2*gtu31*PDstandardNth3gt13 +
2*gtu32*PDstandardNth3gt23 + gtu33*PDstandardNth3gt33);
- Rt11 = -(gtu11*khalf*PDstandardNth11gt11) + gtu21*
+ CCTK_REAL const Rt11 = -(gtu11*khalf*PDstandardNth11gt11) + gtu21*
(2*Gt211*Gt212*gt22L + 4*Gt112*gt13L*Gt311 + 2*Gt113*gt11L*Gt312 + 2*gt13L*Gt312*Gt313 + 2*gt13L*Gt211*Gt322 +
2*gt13L*Gt311*Gt323 + 2*Gt311*Gt312*gt33L - PDstandardNth12gt11) - gtu31*PDstandardNth13gt11 +
gt11L*PDstandardNth1Xt1 + gt12L*(4*Gt111*Gt212*gtu21 + 2*Gt211*Gt222*gtu21 + 2*Gt212*Gt222*gtu22 +
@@ -448,7 +476,7 @@ void ML_BSSN_constraints_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK
gt12L*gtu21*SQR(Gt212)) + gt22L*gtu33*SQR(Gt213) + gt33L*gtu11*SQR(Gt311) + gt33L*gtu22*SQR(Gt312) +
2*gt13L*gtu31*SQR(Gt313) + gt33L*gtu33*SQR(Gt313);
- Rt12 = khalf*(-(gtu11*PDstandardNth11gt12) - 2*gtu21*PDstandardNth12gt12 - 2*gtu31*PDstandardNth13gt12 +
+ CCTK_REAL const Rt12 = khalf*(-(gtu11*PDstandardNth11gt12) - 2*gtu21*PDstandardNth12gt12 - 2*gtu31*PDstandardNth13gt12 +
gt12L*PDstandardNth1Xt1 + gt22L*PDstandardNth1Xt2 + gt23L*PDstandardNth1Xt3 - gtu22*PDstandardNth22gt12 -
2*gtu32*PDstandardNth23gt12 + gt11L*PDstandardNth2Xt1 + gt12L*PDstandardNth2Xt2 + gt13L*PDstandardNth2Xt3 -
gtu33*PDstandardNth33gt12 + (Gt111*gt12L + Gt211*gt22L + gt23L*Gt311)*Xt1L +
@@ -500,7 +528,7 @@ void ML_BSSN_constraints_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK
Gt112*(2*gt11L*Gt123 + Gt113*gt12L + gt12L*Gt223 + gt13L*Gt323) +
gt12L*(Gt122*Gt213 + Gt123*(2*Gt212 + Gt313) + Gt223*(Gt222 + Gt323)) + Gt312*Gt323*gt33L + gt13L*SQR(Gt323)));
- Rt13 = khalf*(-(gtu11*PDstandardNth11gt13) - 2*gtu21*PDstandardNth12gt13 - 2*gtu31*PDstandardNth13gt13 +
+ CCTK_REAL const Rt13 = khalf*(-(gtu11*PDstandardNth11gt13) - 2*gtu21*PDstandardNth12gt13 - 2*gtu31*PDstandardNth13gt13 +
gt13L*PDstandardNth1Xt1 + gt23L*PDstandardNth1Xt2 + gt33L*PDstandardNth1Xt3 - gtu22*PDstandardNth22gt13 -
2*gtu32*PDstandardNth23gt13 - gtu33*PDstandardNth33gt13 + gt11L*PDstandardNth3Xt1 + gt12L*PDstandardNth3Xt2 +
gt13L*PDstandardNth3Xt3 + (Gt113*gt11L + gt12L*Gt213 + gt13L*Gt313)*Xt1L +
@@ -552,7 +580,7 @@ void ML_BSSN_constraints_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK
Gt113*(2*gt11L*Gt133 + gt12L*Gt233 + Gt213*gt23L + gt13L*Gt333 + Gt313*gt33L) + gt13L*SQR(Gt113) +
gt13L*SQR(Gt333)));
- Rt22 = 4*(Gt122*gt12L*Gt212*gtu21 + Gt112*gt12L*Gt222*gtu21 + Gt122*gt12L*Gt222*gtu22 + Gt123*gt12L*Gt212*gtu31 +
+ CCTK_REAL const Rt22 = 4*(Gt122*gt12L*Gt212*gtu21 + Gt112*gt12L*Gt222*gtu21 + Gt122*gt12L*Gt222*gtu22 + Gt123*gt12L*Gt212*gtu31 +
Gt123*gt12L*Gt222*gtu32 + Gt123*gt12L*Gt223*gtu33) - gtu11*khalf*PDstandardNth11gt22 +
gtu21*(6*Gt212*Gt222*gt22L + 2*Gt122*gt23L*Gt311 + 2*Gt122*gt13L*Gt312 + 4*Gt222*gt23L*Gt312 +
2*Gt113*gt12L*Gt322 + 2*gt23L*Gt312*Gt323 + 2*Gt312*Gt322*gt33L - PDstandardNth12gt22) +
@@ -582,7 +610,7 @@ void ML_BSSN_constraints_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK
3*gt22L*gtu11*SQR(Gt212) + 3*gt22L*gtu22*SQR(Gt222) + 3*gt22L*gtu33*SQR(Gt223) + gt33L*gtu11*SQR(Gt312) +
gt33L*gtu22*SQR(Gt322) + 2*gt23L*gtu32*SQR(Gt323) + gt33L*gtu33*SQR(Gt323);
- Rt23 = khalf*(-(gtu11*PDstandardNth11gt23) - 2*gtu21*PDstandardNth12gt23 - 2*gtu31*PDstandardNth13gt23 -
+ CCTK_REAL const Rt23 = khalf*(-(gtu11*PDstandardNth11gt23) - 2*gtu21*PDstandardNth12gt23 - 2*gtu31*PDstandardNth13gt23 -
gtu22*PDstandardNth22gt23 - 2*gtu32*PDstandardNth23gt23 + gt13L*PDstandardNth2Xt1 + gt23L*PDstandardNth2Xt2 +
gt33L*PDstandardNth2Xt3 - gtu33*PDstandardNth33gt23 + gt12L*PDstandardNth3Xt1 + gt22L*PDstandardNth3Xt2 +
gt23L*PDstandardNth3Xt3 + (Gt113*gt12L + Gt213*gt22L + gt23L*Gt313)*Xt1L +
@@ -633,7 +661,7 @@ void ML_BSSN_constraints_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK
gt22L*Gt233*Gt333 + Gt223*gt23L*Gt333 + Gt123*Gt313*gt33L + Gt223*Gt323*gt33L + 2*Gt323*Gt333*gt33L +
gt23L*SQR(Gt223) + gt23L*SQR(Gt333)));
- Rt33 = 4*(Gt123*gt13L*Gt323*gtu22 + Gt223*gt23L*Gt323*gtu22 + Gt133*gt13L*Gt313*gtu31 + Gt233*gt23L*Gt313*gtu31 +
+ CCTK_REAL const Rt33 = 4*(Gt123*gt13L*Gt323*gtu22 + Gt223*gt23L*Gt323*gtu22 + Gt133*gt13L*Gt313*gtu31 + Gt233*gt23L*Gt313*gtu31 +
Gt113*gt13L*Gt333*gtu31 + Gt133*gt13L*Gt323*gtu32 + Gt233*gt23L*Gt323*gtu32 + Gt123*gt13L*Gt333*gtu32 +
Gt133*gt13L*Gt333*gtu33) + gtu21*(2*Gt212*Gt223*gt23L + 4*Gt123*gt13L*Gt313 + 4*Gt223*gt23L*Gt313 +
4*Gt113*gt13L*Gt323 + 4*Gt213*gt23L*Gt323 + 2*Gt123*Gt311*gt33L - PDstandardNth12gt33) +
@@ -663,158 +691,192 @@ void ML_BSSN_constraints_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK
gt11L*gtu33*SQR(Gt133) + gt22L*gtu11*SQR(Gt213) + gt22L*gtu22*SQR(Gt223) + 2*gt23L*gtu32*SQR(Gt223) +
gt22L*gtu33*SQR(Gt233) + 3*gt33L*gtu11*SQR(Gt313) + 3*gt33L*gtu22*SQR(Gt323) + 3*gt33L*gtu33*SQR(Gt333);
- fac1 = IfThen(conformalMethod,-(khalf*INV(phiL)),1);
+ CCTK_REAL const fac1 = IfThen(conformalMethod,-(khalf*INV(phiL)),1);
- cdphi1 = fac1*PDstandardNth1phi;
+ CCTK_REAL const cdphi1 = fac1*PDstandardNth1phi;
- cdphi2 = fac1*PDstandardNth2phi;
+ CCTK_REAL const cdphi2 = fac1*PDstandardNth2phi;
- cdphi3 = fac1*PDstandardNth3phi;
+ CCTK_REAL const cdphi3 = fac1*PDstandardNth3phi;
- fac2 = IfThen(conformalMethod,khalf*pow(phiL,-2),0);
+ CCTK_REAL const fac2 = IfThen(conformalMethod,khalf*pow(phiL,-2),0);
- cdphi211 = -(fac1*(-PDstandardNth11phi + Gt111*PDstandardNth1phi + Gt211*PDstandardNth2phi +
+ CCTK_REAL const cdphi211 = -(fac1*(-PDstandardNth11phi + Gt111*PDstandardNth1phi + Gt211*PDstandardNth2phi +
Gt311*PDstandardNth3phi)) + fac2*SQR(PDstandardNth1phi);
- cdphi212 = fac2*PDstandardNth1phi*PDstandardNth2phi -
+ CCTK_REAL const cdphi212 = fac2*PDstandardNth1phi*PDstandardNth2phi -
fac1*(-PDstandardNth12phi + Gt112*PDstandardNth1phi + Gt212*PDstandardNth2phi + Gt312*PDstandardNth3phi);
- cdphi213 = fac2*PDstandardNth1phi*PDstandardNth3phi -
+ CCTK_REAL const cdphi213 = fac2*PDstandardNth1phi*PDstandardNth3phi -
fac1*(-PDstandardNth13phi + Gt113*PDstandardNth1phi + Gt213*PDstandardNth2phi + Gt313*PDstandardNth3phi);
- cdphi222 = -(fac1*(Gt122*PDstandardNth1phi - PDstandardNth22phi + Gt222*PDstandardNth2phi +
+ CCTK_REAL const cdphi222 = -(fac1*(Gt122*PDstandardNth1phi - PDstandardNth22phi + Gt222*PDstandardNth2phi +
Gt322*PDstandardNth3phi)) + fac2*SQR(PDstandardNth2phi);
- cdphi223 = fac2*PDstandardNth2phi*PDstandardNth3phi -
+ CCTK_REAL const cdphi223 = fac2*PDstandardNth2phi*PDstandardNth3phi -
fac1*(Gt123*PDstandardNth1phi - PDstandardNth23phi + Gt223*PDstandardNth2phi + Gt323*PDstandardNth3phi);
- cdphi233 = -(fac1*(Gt133*PDstandardNth1phi + Gt233*PDstandardNth2phi - PDstandardNth33phi +
+ CCTK_REAL const cdphi233 = -(fac1*(Gt133*PDstandardNth1phi + Gt233*PDstandardNth2phi - PDstandardNth33phi +
Gt333*PDstandardNth3phi)) + fac2*SQR(PDstandardNth3phi);
- Rphi11 = -2*(cdphi211 + 2*(-1 + gt11L*gtu11)*SQR(cdphi1) +
+ CCTK_REAL const Rphi11 = -2*(cdphi211 + 2*(-1 + gt11L*gtu11)*SQR(cdphi1) +
gt11L*(cdphi211*gtu11 + 4*(cdphi1*(cdphi2*gtu21 + cdphi3*gtu31) + cdphi2*cdphi3*gtu32) + cdphi233*gtu33 +
gtu22*(cdphi222 + 2*SQR(cdphi2)) + 2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu33*SQR(cdphi3))));
- Rphi12 = -2*(cdphi212 + cdphi1*(cdphi2*(-2 + 4*gt12L*gtu21) + 4*cdphi3*gt12L*gtu31) +
+ CCTK_REAL const Rphi12 = -2*(cdphi212 + cdphi1*(cdphi2*(-2 + 4*gt12L*gtu21) + 4*cdphi3*gt12L*gtu31) +
gt12L*(cdphi211*gtu11 + 4*cdphi2*cdphi3*gtu32 +
2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu11*SQR(cdphi1)) + gtu22*(cdphi222 + 2*SQR(cdphi2)) +
gtu33*(cdphi233 + 2*SQR(cdphi3))));
- Rphi13 = -2*(cdphi213 + cdphi1*(4*cdphi2*gt13L*gtu21 + cdphi3*(-2 + 4*gt13L*gtu31)) +
+ CCTK_REAL const Rphi13 = -2*(cdphi213 + cdphi1*(4*cdphi2*gt13L*gtu21 + cdphi3*(-2 + 4*gt13L*gtu31)) +
gt13L*(cdphi211*gtu11 + 4*cdphi2*cdphi3*gtu32 +
2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu11*SQR(cdphi1)) + gtu22*(cdphi222 + 2*SQR(cdphi2)) +
gtu33*(cdphi233 + 2*SQR(cdphi3))));
- Rphi22 = -2*(cdphi222 + 2*(-1 + gt22L*gtu22)*SQR(cdphi2) +
+ CCTK_REAL const Rphi22 = -2*(cdphi222 + 2*(-1 + gt22L*gtu22)*SQR(cdphi2) +
gt22L*(cdphi222*gtu22 + 4*(cdphi1*cdphi3*gtu31 + cdphi2*(cdphi1*gtu21 + cdphi3*gtu32)) + cdphi233*gtu33 +
gtu11*(cdphi211 + 2*SQR(cdphi1)) + 2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu33*SQR(cdphi3))));
- Rphi23 = -2*(cdphi223 + cdphi2*(4*cdphi1*gt23L*gtu21 + cdphi3*(-2 + 4*gt23L*gtu32)) +
+ CCTK_REAL const Rphi23 = -2*(cdphi223 + cdphi2*(4*cdphi1*gt23L*gtu21 + cdphi3*(-2 + 4*gt23L*gtu32)) +
gt23L*(cdphi222*gtu22 + 4*cdphi1*cdphi3*gtu31 + gtu11*(cdphi211 + 2*SQR(cdphi1)) +
2*(cdphi212*gtu21 + cdphi213*gtu31 + cdphi223*gtu32 + gtu22*SQR(cdphi2)) + gtu33*(cdphi233 + 2*SQR(cdphi3))));
- Rphi33 = -2*(cdphi233 + gt33L*((4*cdphi1*cdphi2 + 2*cdphi212)*gtu21 + 4*cdphi3*(cdphi1*gtu31 + cdphi2*gtu32) +
+ CCTK_REAL const Rphi33 = -2*(cdphi233 + gt33L*((4*cdphi1*cdphi2 + 2*cdphi212)*gtu21 + 4*cdphi3*(cdphi1*gtu31 + cdphi2*gtu32) +
2*(cdphi213*gtu31 + cdphi223*gtu32) + cdphi233*gtu33 + gtu11*(cdphi211 + 2*SQR(cdphi1)) +
gtu22*(cdphi222 + 2*SQR(cdphi2))) + 2*(-1 + gt33L*gtu33)*SQR(cdphi3));
- e4phi = IfThen(conformalMethod,pow(phiL,-2),exp(4*phiL));
+ CCTK_REAL const e4phi = IfThen(conformalMethod,pow(phiL,-2),exp(4*phiL));
+
+ CCTK_REAL const em4phi = INV(e4phi);
+
+ CCTK_REAL const gu11 = em4phi*gtu11;
+
+ CCTK_REAL const gu21 = em4phi*gtu21;
+
+ CCTK_REAL const gu31 = em4phi*gtu31;
+
+ CCTK_REAL const gu22 = em4phi*gtu22;
+
+ CCTK_REAL const gu32 = em4phi*gtu32;
+
+ CCTK_REAL const gu33 = em4phi*gtu33;
+
+ CCTK_REAL const R11 = Rphi11 + Rt11;
+
+ CCTK_REAL const R12 = Rphi12 + Rt12;
+
+ CCTK_REAL const R13 = Rphi13 + Rt13;
+
+ CCTK_REAL const R22 = Rphi22 + Rt22;
+
+ CCTK_REAL const R23 = Rphi23 + Rt23;
+
+ CCTK_REAL const R33 = Rphi33 + Rt33;
+
+ CCTK_REAL const trR = gu11*R11 + gu22*R22 + 2*(gu21*R12 + gu31*R13 + gu32*R23) + gu33*R33;
- em4phi = INV(e4phi);
+ CCTK_REAL const Atm11 = At11L*gtu11 + At12L*gtu21 + At13L*gtu31;
- gu11 = em4phi*gtu11;
+ CCTK_REAL const Atm21 = At11L*gtu21 + At12L*gtu22 + At13L*gtu32;
- gu21 = em4phi*gtu21;
+ CCTK_REAL const Atm31 = At11L*gtu31 + At12L*gtu32 + At13L*gtu33;
- gu31 = em4phi*gtu31;
+ CCTK_REAL const Atm12 = At12L*gtu11 + At22L*gtu21 + At23L*gtu31;
- gu22 = em4phi*gtu22;
+ CCTK_REAL const Atm22 = At12L*gtu21 + At22L*gtu22 + At23L*gtu32;
- gu32 = em4phi*gtu32;
+ CCTK_REAL const Atm32 = At12L*gtu31 + At22L*gtu32 + At23L*gtu33;
- gu33 = em4phi*gtu33;
+ CCTK_REAL const Atm13 = At13L*gtu11 + At23L*gtu21 + At33L*gtu31;
- R11 = Rphi11 + Rt11;
+ CCTK_REAL const Atm23 = At13L*gtu21 + At23L*gtu22 + At33L*gtu32;
- R12 = Rphi12 + Rt12;
+ CCTK_REAL const Atm33 = At13L*gtu31 + At23L*gtu32 + At33L*gtu33;
- R13 = Rphi13 + Rt13;
+ CCTK_REAL const T00 = eTttL;
- R22 = Rphi22 + Rt22;
+ CCTK_REAL const T01 = eTtxL;
- R23 = Rphi23 + Rt23;
+ CCTK_REAL const T02 = eTtyL;
- R33 = Rphi33 + Rt33;
+ CCTK_REAL const T03 = eTtzL;
- trR = gu11*R11 + gu22*R22 + 2*(gu21*R12 + gu31*R13 + gu32*R23) + gu33*R33;
+ CCTK_REAL const T11 = eTxxL;
- Atm11 = At11L*gtu11 + At12L*gtu21 + At13L*gtu31;
+ CCTK_REAL const T12 = eTxyL;
- Atm21 = At11L*gtu21 + At12L*gtu22 + At13L*gtu32;
+ CCTK_REAL const T13 = eTxzL;
- Atm31 = At11L*gtu31 + At12L*gtu32 + At13L*gtu33;
+ CCTK_REAL const T22 = eTyyL;
- Atm12 = At12L*gtu11 + At22L*gtu21 + At23L*gtu31;
+ CCTK_REAL const T23 = eTyzL;
- Atm22 = At12L*gtu21 + At22L*gtu22 + At23L*gtu32;
+ CCTK_REAL const T33 = eTzzL;
- Atm32 = At12L*gtu31 + At22L*gtu32 + At23L*gtu33;
+ CCTK_REAL const rho = pow(alphaL,-2)*(T00 - 2*(beta2L*T02 + beta3L*T03) +
+ 2*(beta1L*(-T01 + beta2L*T12 + beta3L*T13) + beta2L*beta3L*T23) + T11*SQR(beta1L) + T22*SQR(beta2L) +
+ T33*SQR(beta3L));
- Atm13 = At13L*gtu11 + At23L*gtu21 + At33L*gtu31;
+ CCTK_REAL const S1 = (-T01 + beta1L*T11 + beta2L*T12 + beta3L*T13)*INV(alphaL);
- Atm23 = At13L*gtu21 + At23L*gtu22 + At33L*gtu32;
+ CCTK_REAL const S2 = (-T02 + beta1L*T12 + beta2L*T22 + beta3L*T23)*INV(alphaL);
- Atm33 = At13L*gtu31 + At23L*gtu32 + At33L*gtu33;
+ CCTK_REAL const S3 = (-T03 + beta1L*T13 + beta2L*T23 + beta3L*T33)*INV(alphaL);
- HL = -2*(Atm12*Atm21 + Atm13*Atm31 + Atm23*Atm32) + trR - SQR(Atm11) - SQR(Atm22) - SQR(Atm33) + ktwothird*SQR(trKL);
+ CCTK_REAL const HL = -2.*(Atm12*Atm21 + Atm13*Atm31 + Atm23*Atm32) - 50.26548245743669181540229413247204614715*rho + trR -
+ 1.*(SQR(Atm11) + SQR(Atm22) + SQR(Atm33)) + 0.6666666666666666666666666666666666666667*SQR(trKL);
- M1L = -(At12L*Gt112*gtu22) - At22L*Gt212*gtu22 - At12L*Gt222*gtu22 - At23L*Gt312*gtu22 - At13L*Gt322*gtu22 +
- At12L*(6*cdphi1*gtu21 - Gt111*gtu21 + 6*cdphi2*gtu22) +
- At11L*(6*cdphi1*gtu11 - 2*Gt111*gtu11 + 6*cdphi2*gtu21 - Gt122*gtu22) + 6*At13L*cdphi1*gtu31 +
- 6*At11L*cdphi3*gtu31 - At13L*Gt111*gtu31 - 3*At11L*Gt113*gtu31 - At23L*Gt211*gtu31 - 3*At12L*Gt213*gtu31 -
- At33L*Gt311*gtu31 - 3*At13L*Gt313*gtu31 + 6*At13L*cdphi2*gtu32 + 6*At12L*cdphi3*gtu32 - At13L*Gt112*gtu32 -
- At12L*Gt113*gtu32 - At23L*Gt212*gtu32 - At22L*Gt213*gtu32 - 2*At12L*Gt223*gtu32 - At33L*Gt312*gtu32 -
- At23L*Gt313*gtu32 - 2*At13L*Gt323*gtu32 - 2*(At12L*Gt211*gtu11 + At13L*Gt311*gtu11 + At11L*Gt123*gtu32) +
- 6*At13L*cdphi3*gtu33 - At13L*Gt113*gtu33 - At11L*Gt133*gtu33 - At23L*Gt213*gtu33 - At12L*Gt233*gtu33 -
- At33L*Gt313*gtu33 - At13L*Gt333*gtu33 + gtu11*PDstandardNth1At11 +
- gtu21*(-3*At11L*Gt112 - At22L*Gt211 - 3*At12L*Gt212 - At23L*Gt311 - 3*At13L*Gt312 + PDstandardNth1At12) +
- gtu31*PDstandardNth1At13 - ktwothird*PDstandardNth1trK + gtu21*PDstandardNth2At11 + gtu22*PDstandardNth2At12 +
- gtu32*PDstandardNth2At13 + gtu31*PDstandardNth3At11 + gtu32*PDstandardNth3At12 + gtu33*PDstandardNth3At13;
+ CCTK_REAL const M1L = -2.*((At12L*Gt211 + At13L*Gt311)*gtu11 + At11L*Gt123*gtu32) +
+ At12L*((6.*cdphi1 - 1.*Gt111)*gtu21 - 3.*Gt213*gtu31 + 6.*(cdphi2*gtu22 + cdphi3*gtu32) - 1.*Gt233*gtu33) -
+ 1.*((At22L*Gt212 + At12L*(Gt112 + Gt222) + At23L*Gt312 + At13L*Gt322)*gtu22 +
+ At13L*(Gt111*gtu31 + Gt112*gtu32 + Gt113*gtu33)) +
+ At11L*((6.*cdphi1 - 2.*Gt111)*gtu11 + 6.*(cdphi2*gtu21 + cdphi3*gtu31) - 1.*(Gt122*gtu22 + Gt133*gtu33)) +
+ gtu11*PDstandardNth1At11 - 0.6666666666666666666666666666666666666667*PDstandardNth1trK +
+ gtu21*(-1.*(At22L*Gt211 + At23L*Gt311) - 3.*(At11L*Gt112 + At12L*Gt212 + At13L*Gt312) + PDstandardNth1At12 +
+ PDstandardNth2At11) + gtu22*PDstandardNth2At12 +
+ gtu31*(-3.*At11L*Gt113 - 1.*(At23L*Gt211 + At33L*Gt311) + At13L*(6.*cdphi1 - 3.*Gt313) + PDstandardNth1At13 +
+ PDstandardNth3At11) + gtu32*(-2.*At12L*Gt223 -
+ 1.*(At12L*Gt113 + At22L*Gt213 + At33L*Gt312 + At23L*(Gt212 + Gt313)) + At13L*(6.*cdphi2 - 2.*Gt323) +
+ PDstandardNth2At13 + PDstandardNth3At12) +
+ gtu33*(-1.*(At23L*Gt213 + At33L*Gt313) + At13L*(6.*cdphi3 - 1.*Gt333) + PDstandardNth3At13) -
+ 25.13274122871834590770114706623602307358*S1;
- M2L = -(At11L*Gt112*gtu11) - At22L*Gt211*gtu11 - At12L*Gt212*gtu11 - At23L*Gt311*gtu11 - At13L*Gt312*gtu11 +
- At12L*(6*cdphi1*gtu11 - Gt111*gtu11) + 6*At22L*cdphi1*gtu21 + 6*At12L*cdphi2*gtu21 - 3*At12L*Gt112*gtu21 -
- At11L*Gt122*gtu21 - 3*At22L*Gt212*gtu21 - At12L*Gt222*gtu21 - 3*At23L*Gt312*gtu21 - At13L*Gt322*gtu21 +
- 6*At22L*cdphi2*gtu22 - 2*At12L*Gt122*gtu22 - 2*At22L*Gt222*gtu22 - 2*At23L*Gt322*gtu22 + 6*At23L*cdphi1*gtu31 +
- 6*At12L*cdphi3*gtu31 - At13L*Gt112*gtu31 - 2*At12L*Gt113*gtu31 - At11L*Gt123*gtu31 - At23L*Gt212*gtu31 -
- 2*At22L*Gt213*gtu31 - At12L*Gt223*gtu31 - At33L*Gt312*gtu31 - 2*At23L*Gt313*gtu31 - At13L*Gt323*gtu31 +
- 6*At23L*cdphi2*gtu32 + 6*At22L*cdphi3*gtu32 - At13L*Gt122*gtu32 - 3*At12L*Gt123*gtu32 - At23L*Gt222*gtu32 -
- 3*At22L*Gt223*gtu32 - At33L*Gt322*gtu32 - 3*At23L*Gt323*gtu32 + 6*At23L*cdphi3*gtu33 - At13L*Gt123*gtu33 -
- At12L*Gt133*gtu33 - At23L*Gt223*gtu33 - At22L*Gt233*gtu33 - At33L*Gt323*gtu33 - At23L*Gt333*gtu33 +
- gtu11*PDstandardNth1At12 + gtu21*PDstandardNth1At22 + gtu31*PDstandardNth1At23 + gtu21*PDstandardNth2At12 +
- gtu22*PDstandardNth2At22 + gtu32*PDstandardNth2At23 - ktwothird*PDstandardNth2trK + gtu31*PDstandardNth3At12 +
- gtu32*PDstandardNth3At22 + gtu33*PDstandardNth3At23;
+ CCTK_REAL const M2L = At12L*((6.*cdphi1 - 1.*Gt111)*gtu11 - 2.*Gt122*gtu22 + 6.*(cdphi2*gtu21 + cdphi3*gtu31) - 3.*Gt123*gtu32 -
+ 1.*Gt133*gtu33) + At22L*((6.*cdphi2 - 2.*Gt222)*gtu22 - 2.*Gt213*gtu31 + 6.*cdphi3*gtu32 - 1.*Gt233*gtu33) +
+ At23L*(-2.*Gt322*gtu22 - 1.*Gt333*gtu33 + 6.*(cdphi1*gtu31 + cdphi2*gtu32 + cdphi3*gtu33)) -
+ 1.*((At11L*Gt112 + At22L*Gt211 + At12L*Gt212 + At23L*Gt311 + At13L*Gt312)*gtu11 +
+ Gt122*(At11L*gtu21 + At13L*gtu32) + (At23L*Gt223 + At33L*Gt323)*gtu33 + At13L*(Gt112*gtu31 + Gt123*gtu33)) +
+ gtu11*PDstandardNth1At12 + gtu21*(At22L*(6.*cdphi1 - 3.*Gt212) + At12L*(-3.*Gt112 - 1.*Gt222) - 3.*At23L*Gt312 -
+ 1.*At13L*Gt322 + PDstandardNth1At22 + PDstandardNth2At12) + gtu22*PDstandardNth2At22 -
+ 0.6666666666666666666666666666666666666667*PDstandardNth2trK +
+ gtu31*(At12L*(-2.*Gt113 - 1.*Gt223) - 2.*At23L*Gt313 - 1.*(At11L*Gt123 + At23L*Gt212 + At33L*Gt312 + At13L*Gt323) +
+ PDstandardNth1At23 + PDstandardNth3At12) +
+ gtu32*(-1.*(At23L*Gt222 + At33L*Gt322) - 3.*(At22L*Gt223 + At23L*Gt323) + PDstandardNth2At23 +
+ PDstandardNth3At22) + gtu33*PDstandardNth3At23 - 25.13274122871834590770114706623602307358*S2;
- M3L = -(At11L*Gt113*gtu11) - At23L*Gt211*gtu11 - At12L*Gt213*gtu11 - At33L*Gt311*gtu11 - At13L*Gt313*gtu11 +
- At13L*(6*cdphi1*gtu11 - Gt111*gtu11) + 6*At23L*cdphi1*gtu21 + 6*At13L*cdphi2*gtu21 - 2*At13L*Gt112*gtu21 -
- At12L*Gt113*gtu21 - At11L*Gt123*gtu21 - 2*At23L*Gt212*gtu21 - At22L*Gt213*gtu21 - At12L*Gt223*gtu21 -
- 2*At33L*Gt312*gtu21 - At23L*Gt313*gtu21 - At13L*Gt323*gtu21 + 6*At23L*cdphi2*gtu22 - At13L*Gt122*gtu22 -
- At12L*Gt123*gtu22 - At23L*Gt222*gtu22 - At22L*Gt223*gtu22 - At33L*Gt322*gtu22 - At23L*Gt323*gtu22 +
- 6*At33L*cdphi1*gtu31 + 6*At13L*cdphi3*gtu31 - 3*At13L*Gt113*gtu31 - At11L*Gt133*gtu31 - 3*At23L*Gt213*gtu31 -
- At12L*Gt233*gtu31 - 3*At33L*Gt313*gtu31 - At13L*Gt333*gtu31 + 6*At33L*cdphi2*gtu32 + 6*At23L*cdphi3*gtu32 -
- 3*At13L*Gt123*gtu32 - At12L*Gt133*gtu32 - 3*At23L*Gt223*gtu32 - At22L*Gt233*gtu32 - 3*At33L*Gt323*gtu32 -
- At23L*Gt333*gtu32 + 6*At33L*cdphi3*gtu33 - 2*At13L*Gt133*gtu33 - 2*At23L*Gt233*gtu33 - 2*At33L*Gt333*gtu33 +
- gtu11*PDstandardNth1At13 + gtu21*PDstandardNth1At23 + gtu31*PDstandardNth1At33 + gtu21*PDstandardNth2At13 +
- gtu22*PDstandardNth2At23 + gtu32*PDstandardNth2At33 + gtu31*PDstandardNth3At13 + gtu32*PDstandardNth3At23 +
- gtu33*PDstandardNth3At33 - ktwothird*PDstandardNth3trK;
+ CCTK_REAL const M3L = -1.*((At11L*Gt113 + At23L*Gt211 + At12L*Gt213 + At33L*Gt311)*gtu11 +
+ (At22L*Gt223 + At33L*Gt322 + At23L*Gt323)*gtu22 + At11L*Gt133*gtu31 +
+ At12L*(Gt113*gtu21 + Gt123*gtu22 + Gt133*gtu32)) +
+ At13L*((6.*cdphi1 - 1.*(Gt111 + Gt313))*gtu11 - 1.*Gt122*gtu22 + 6.*(cdphi2*gtu21 + cdphi3*gtu31) -
+ 3.*Gt123*gtu32 - 2.*Gt133*gtu33) + At23L*((6.*cdphi2 - 1.*Gt222)*gtu22 - 3.*Gt213*gtu31 + 6.*cdphi3*gtu32 -
+ 2.*Gt233*gtu33) + gtu11*PDstandardNth1At13 +
+ gtu21*(-2.*(At13L*Gt112 + At33L*Gt312) + At23L*(6.*cdphi1 - 2.*Gt212 - 1.*Gt313) -
+ 1.*(At11L*Gt123 + At22L*Gt213 + At12L*Gt223 + At13L*Gt323) + PDstandardNth1At23 + PDstandardNth2At13) +
+ gtu22*PDstandardNth2At23 + gtu31*(-1.*At12L*Gt233 + At33L*(6.*cdphi1 - 3.*Gt313) + At13L*(-3.*Gt113 - 1.*Gt333) +
+ PDstandardNth1At33 + PDstandardNth3At13) +
+ gtu32*(-1.*At22L*Gt233 + At33L*(6.*cdphi2 - 3.*Gt323) + At23L*(-3.*Gt223 - 1.*Gt333) + PDstandardNth2At33 +
+ PDstandardNth3At23) + gtu33*(At33L*(6.*cdphi3 - 2.*Gt333) + PDstandardNth3At33) -
+ 0.6666666666666666666666666666666666666667*PDstandardNth3trK - 25.13274122871834590770114706623602307358*S3;
- cSL = Log(detgt);
+ CCTK_REAL const cSL = Log(detgt);
- cXt1L = Gt111*gtu11 + Gt122*gtu22 + 2*(Gt112*gtu21 + Gt113*gtu31 + Gt123*gtu32) + Gt133*gtu33 - Xt1L;
+ CCTK_REAL const cXt1L = Gt111*gtu11 + Gt122*gtu22 + 2*(Gt112*gtu21 + Gt113*gtu31 + Gt123*gtu32) + Gt133*gtu33 - Xt1L;
- cXt2L = Gt211*gtu11 + Gt222*gtu22 + 2*(Gt212*gtu21 + Gt213*gtu31 + Gt223*gtu32) + Gt233*gtu33 - Xt2L;
+ CCTK_REAL const cXt2L = Gt211*gtu11 + Gt222*gtu22 + 2*(Gt212*gtu21 + Gt213*gtu31 + Gt223*gtu32) + Gt233*gtu33 - Xt2L;
- cXt3L = Gt311*gtu11 + Gt322*gtu22 + 2*(Gt312*gtu21 + Gt313*gtu31 + Gt323*gtu32) + Gt333*gtu33 - Xt3L;
+ CCTK_REAL const cXt3L = Gt311*gtu11 + Gt322*gtu22 + 2*(Gt312*gtu21 + Gt313*gtu31 + Gt323*gtu32) + Gt333*gtu33 - Xt3L;
- cAL = At11L*gtu11 + At22L*gtu22 + 2*(At12L*gtu21 + At13L*gtu31 + At23L*gtu32) + At33L*gtu33;
+ CCTK_REAL const cAL = At11L*gtu11 + At22L*gtu22 + 2*(At12L*gtu21 + At13L*gtu31 + At23L*gtu32) + At33L*gtu33;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_constraints_boundary.c b/ML_BSSN/src/ML_BSSN_constraints_boundary.c
index 364ac66..9a3c00a 100644
--- a/ML_BSSN/src/ML_BSSN_constraints_boundary.c
+++ b/ML_BSSN/src/ML_BSSN_constraints_boundary.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_constraints_boundary_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_constraints_boundary_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_constraints_boundary_Body(cGH const * const cctkGH, CCTK_INT const
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,16 +93,16 @@ void ML_BSSN_constraints_boundary_Body(cGH const * const cctkGH, CCTK_INT const
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
/* Declare local copies of grid functions */
- CCTK_REAL HL = INITVALUE;
- CCTK_REAL M1L = INITVALUE, M2L = INITVALUE, M3L = INITVALUE;
+ // CCTK_REAL HL = INITVALUE;
+ // CCTK_REAL M1L = INITVALUE, M2L = INITVALUE, M3L = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
@@ -120,13 +118,13 @@ void ML_BSSN_constraints_boundary_Body(cGH const * const cctkGH, CCTK_INT const
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- HL = 0;
+ CCTK_REAL const HL = 0;
- M1L = 0;
+ CCTK_REAL const M1L = 0;
- M2L = 0;
+ CCTK_REAL const M2L = 0;
- M3L = 0;
+ CCTK_REAL const M3L = 0;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_convertFromADMBase.c b/ML_BSSN/src/ML_BSSN_convertFromADMBase.c
index 3d5e687..95c7d4c 100644
--- a/ML_BSSN/src/ML_BSSN_convertFromADMBase.c
+++ b/ML_BSSN/src/ML_BSSN_convertFromADMBase.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_convertFromADMBase_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_convertFromADMBase_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_convertFromADMBase_Body(cGH const * const cctkGH, CCTK_INT const di
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,65 +93,62 @@ void ML_BSSN_convertFromADMBase_Body(cGH const * const cctkGH, CCTK_INT const di
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
- CCTK_REAL detg = INITVALUE;
- CCTK_REAL em4phi = INITVALUE;
- CCTK_REAL g11 = INITVALUE, g12 = INITVALUE, g13 = INITVALUE, g22 = INITVALUE, g23 = INITVALUE, g33 = INITVALUE;
- CCTK_REAL gu11 = INITVALUE, gu21 = INITVALUE, gu22 = INITVALUE, gu31 = INITVALUE, gu32 = INITVALUE, gu33 = INITVALUE;
- CCTK_REAL K11 = INITVALUE, K12 = INITVALUE, K13 = INITVALUE, K22 = INITVALUE, K23 = INITVALUE, K33 = INITVALUE;
+ // CCTK_REAL detg = INITVALUE;
+ // CCTK_REAL em4phi = INITVALUE;
+ // CCTK_REAL g11 = INITVALUE, g12 = INITVALUE, g13 = INITVALUE, g22 = INITVALUE, g23 = INITVALUE, g33 = INITVALUE;
+ // CCTK_REAL gu11 = INITVALUE, gu21 = INITVALUE, gu22 = INITVALUE, gu31 = INITVALUE, gu32 = INITVALUE, gu33 = INITVALUE;
/* Declare local copies of grid functions */
- CCTK_REAL alpL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE;
- CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
- CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
- CCTK_REAL betaxL = INITVALUE;
- CCTK_REAL betayL = INITVALUE;
- CCTK_REAL betazL = INITVALUE;
- CCTK_REAL etaL = INITVALUE;
- CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
- CCTK_REAL gxxL = INITVALUE;
- CCTK_REAL gxyL = INITVALUE;
- CCTK_REAL gxzL = INITVALUE;
- CCTK_REAL gyyL = INITVALUE;
- CCTK_REAL gyzL = INITVALUE;
- CCTK_REAL gzzL = INITVALUE;
- CCTK_REAL kxxL = INITVALUE;
- CCTK_REAL kxyL = INITVALUE;
- CCTK_REAL kxzL = INITVALUE;
- CCTK_REAL kyyL = INITVALUE;
- CCTK_REAL kyzL = INITVALUE;
- CCTK_REAL kzzL = INITVALUE;
- CCTK_REAL phiL = INITVALUE;
- CCTK_REAL trKL = INITVALUE;
+ // CCTK_REAL alpL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
+ // CCTK_REAL betaxL = INITVALUE;
+ // CCTK_REAL betayL = INITVALUE;
+ // CCTK_REAL betazL = INITVALUE;
+ // CCTK_REAL etaL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
+ // CCTK_REAL gxxL = INITVALUE;
+ // CCTK_REAL gxyL = INITVALUE;
+ // CCTK_REAL gxzL = INITVALUE;
+ // CCTK_REAL gyyL = INITVALUE;
+ // CCTK_REAL gyzL = INITVALUE;
+ // CCTK_REAL gzzL = INITVALUE;
+ // CCTK_REAL kxxL = INITVALUE;
+ // CCTK_REAL kxyL = INITVALUE;
+ // CCTK_REAL kxzL = INITVALUE;
+ // CCTK_REAL kyyL = INITVALUE;
+ // CCTK_REAL kyzL = INITVALUE;
+ // CCTK_REAL kzzL = INITVALUE;
+ // CCTK_REAL phiL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
/* Assign local copies of grid functions */
- alpL = alp[index];
- betaxL = betax[index];
- betayL = betay[index];
- betazL = betaz[index];
- gxxL = gxx[index];
- gxyL = gxy[index];
- gxzL = gxz[index];
- gyyL = gyy[index];
- gyzL = gyz[index];
- gzzL = gzz[index];
- kxxL = kxx[index];
- kxyL = kxy[index];
- kxzL = kxz[index];
- kyyL = kyy[index];
- kyzL = kyz[index];
- kzzL = kzz[index];
- phiL = phi[index];
- trKL = trK[index];
+ CCTK_REAL const alpL = alp[index];
+ CCTK_REAL const betaxL = betax[index];
+ CCTK_REAL const betayL = betay[index];
+ CCTK_REAL const betazL = betaz[index];
+ CCTK_REAL const gxxL = gxx[index];
+ CCTK_REAL const gxyL = gxy[index];
+ CCTK_REAL const gxzL = gxz[index];
+ CCTK_REAL const gyyL = gyy[index];
+ CCTK_REAL const gyzL = gyz[index];
+ CCTK_REAL const gzzL = gzz[index];
+ CCTK_REAL const kxxL = kxx[index];
+ CCTK_REAL const kxyL = kxy[index];
+ CCTK_REAL const kxzL = kxz[index];
+ CCTK_REAL const kyyL = kyy[index];
+ CCTK_REAL const kyzL = kyz[index];
+ CCTK_REAL const kzzL = kzz[index];
/* Assign local copies of subblock grid functions */
@@ -164,83 +159,71 @@ void ML_BSSN_convertFromADMBase_Body(cGH const * const cctkGH, CCTK_INT const di
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- g11 = gxxL;
-
- g12 = gxyL;
-
- g13 = gxzL;
-
- g22 = gyyL;
-
- g23 = gyzL;
-
- g33 = gzzL;
-
- detg = 2*g12*g13*g23 + g33*(g11*g22 - SQR(g12)) - g22*SQR(g13) - g11*SQR(g23);
+ CCTK_REAL const g11 = gxxL;
- gu11 = INV(detg)*(g22*g33 - SQR(g23));
+ CCTK_REAL const g12 = gxyL;
- gu21 = (g13*g23 - g12*g33)*INV(detg);
+ CCTK_REAL const g13 = gxzL;
- gu31 = (-(g13*g22) + g12*g23)*INV(detg);
+ CCTK_REAL const g22 = gyyL;
- gu22 = INV(detg)*(g11*g33 - SQR(g13));
+ CCTK_REAL const g23 = gyzL;
- gu32 = (g12*g13 - g11*g23)*INV(detg);
+ CCTK_REAL const g33 = gzzL;
- gu33 = INV(detg)*(g11*g22 - SQR(g12));
+ CCTK_REAL const detg = 2*g12*g13*g23 + g33*(g11*g22 - SQR(g12)) - g22*SQR(g13) - g11*SQR(g23);
- phiL = IfThen(conformalMethod,pow(detg,-0.16666666666666666),Log(detg)/12.);
+ CCTK_REAL const gu11 = INV(detg)*(g22*g33 - SQR(g23));
- em4phi = IfThen(conformalMethod,SQR(phiL),exp(-4*phiL));
+ CCTK_REAL const gu21 = (g13*g23 - g12*g33)*INV(detg);
- gt11L = em4phi*g11;
+ CCTK_REAL const gu31 = (-(g13*g22) + g12*g23)*INV(detg);
- gt12L = em4phi*g12;
+ CCTK_REAL const gu22 = INV(detg)*(g11*g33 - SQR(g13));
- gt13L = em4phi*g13;
+ CCTK_REAL const gu32 = (g12*g13 - g11*g23)*INV(detg);
- gt22L = em4phi*g22;
+ CCTK_REAL const gu33 = INV(detg)*(g11*g22 - SQR(g12));
- gt23L = em4phi*g23;
+ CCTK_REAL const phiL = IfThen(conformalMethod,pow(detg,-0.16666666666666666),Log(detg)/12.);
- gt33L = em4phi*g33;
+ CCTK_REAL const em4phi = IfThen(conformalMethod,SQR(phiL),exp(-4*phiL));
- K11 = kxxL;
+ CCTK_REAL const gt11L = em4phi*g11;
- K12 = kxyL;
+ CCTK_REAL const gt12L = em4phi*g12;
- K13 = kxzL;
+ CCTK_REAL const gt13L = em4phi*g13;
- K22 = kyyL;
+ CCTK_REAL const gt22L = em4phi*g22;
- K23 = kyzL;
+ CCTK_REAL const gt23L = em4phi*g23;
- K33 = kzzL;
+ CCTK_REAL const gt33L = em4phi*g33;
- trKL = gu11*K11 + gu22*K22 + 2*(gu21*K12 + gu31*K13 + gu32*K23) + gu33*K33;
+ CCTK_REAL const trKL = gu11*kxxL + gu22*kyyL + 2*(gu21*kxyL + gu31*kxzL + gu32*kyzL) + gu33*kzzL;
- At11L = em4phi*(K11 - g11*kthird*trKL);
+ CCTK_REAL const At11L = em4phi*(kxxL - g11*kthird*trKL);
- At12L = em4phi*(K12 - g12*kthird*trKL);
+ CCTK_REAL const At12L = em4phi*(kxyL - g12*kthird*trKL);
- At13L = em4phi*(K13 - g13*kthird*trKL);
+ CCTK_REAL const At13L = em4phi*(kxzL - g13*kthird*trKL);
- At22L = em4phi*(K22 - g22*kthird*trKL);
+ CCTK_REAL const At22L = em4phi*(kyyL - g22*kthird*trKL);
- At23L = em4phi*(K23 - g23*kthird*trKL);
+ CCTK_REAL const At23L = em4phi*(kyzL - g23*kthird*trKL);
- At33L = em4phi*(K33 - g33*kthird*trKL);
+ CCTK_REAL const At33L = em4phi*(kzzL - g33*kthird*trKL);
- alphaL = alpL;
+ CCTK_REAL const alphaL = alpL;
- beta1L = betaxL;
+ CCTK_REAL const beta1L = betaxL;
- beta2L = betayL;
+ CCTK_REAL const beta2L = betayL;
- beta3L = betazL;
+ CCTK_REAL const beta3L = betazL;
- etaL = BetaDriver;
+ CCTK_REAL const etaL = BetaDriver;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_convertFromADMBaseGamma.c b/ML_BSSN/src/ML_BSSN_convertFromADMBaseGamma.c
index 8de9e36..68a3ba7 100644
--- a/ML_BSSN/src/ML_BSSN_convertFromADMBaseGamma.c
+++ b/ML_BSSN/src/ML_BSSN_convertFromADMBaseGamma.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_convertFromADMBaseGamma_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_convertFromADMBaseGamma_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_convertFromADMBaseGamma_Body(cGH const * const cctkGH, CCTK_INT con
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,194 +93,203 @@ void ML_BSSN_convertFromADMBaseGamma_Body(cGH const * const cctkGH, CCTK_INT con
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
- CCTK_REAL detgt = INITVALUE;
- CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
- CCTK_REAL Gt111 = INITVALUE, Gt112 = INITVALUE, Gt113 = INITVALUE, Gt122 = INITVALUE, Gt123 = INITVALUE, Gt133 = INITVALUE;
- CCTK_REAL Gt211 = INITVALUE, Gt212 = INITVALUE, Gt213 = INITVALUE, Gt222 = INITVALUE, Gt223 = INITVALUE, Gt233 = INITVALUE;
- CCTK_REAL Gt311 = INITVALUE, Gt312 = INITVALUE, Gt313 = INITVALUE, Gt322 = INITVALUE, Gt323 = INITVALUE, Gt333 = INITVALUE;
- CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
+ // CCTK_REAL detgt = INITVALUE;
+ // CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
+ // CCTK_REAL Gt111 = INITVALUE, Gt112 = INITVALUE, Gt113 = INITVALUE, Gt122 = INITVALUE, Gt123 = INITVALUE, Gt133 = INITVALUE;
+ // CCTK_REAL Gt211 = INITVALUE, Gt212 = INITVALUE, Gt213 = INITVALUE, Gt222 = INITVALUE, Gt223 = INITVALUE, Gt233 = INITVALUE;
+ // CCTK_REAL Gt311 = INITVALUE, Gt312 = INITVALUE, Gt313 = INITVALUE, Gt322 = INITVALUE, Gt323 = INITVALUE, Gt333 = INITVALUE;
+ // CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
/* Declare local copies of grid functions */
- CCTK_REAL AL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE;
- CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
- CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
- CCTK_REAL dtalpL = INITVALUE;
- CCTK_REAL dtbetaxL = INITVALUE;
- CCTK_REAL dtbetayL = INITVALUE;
- CCTK_REAL dtbetazL = INITVALUE;
- CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
- CCTK_REAL Xt1L = INITVALUE, Xt2L = INITVALUE, Xt3L = INITVALUE;
+ // CCTK_REAL AL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
+ // CCTK_REAL betaxL = INITVALUE;
+ // CCTK_REAL betayL = INITVALUE;
+ // CCTK_REAL betazL = INITVALUE;
+ // CCTK_REAL dtalpL = INITVALUE;
+ // CCTK_REAL dtbetaxL = INITVALUE;
+ // CCTK_REAL dtbetayL = INITVALUE;
+ // CCTK_REAL dtbetazL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
+ // CCTK_REAL Xt1L = INITVALUE, Xt2L = INITVALUE, Xt3L = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
- CCTK_REAL PDstandardNth1gt11 = INITVALUE;
- CCTK_REAL PDstandardNth2gt11 = INITVALUE;
- CCTK_REAL PDstandardNth3gt11 = INITVALUE;
- CCTK_REAL PDstandardNth1gt12 = INITVALUE;
- CCTK_REAL PDstandardNth2gt12 = INITVALUE;
- CCTK_REAL PDstandardNth3gt12 = INITVALUE;
- CCTK_REAL PDstandardNth1gt13 = INITVALUE;
- CCTK_REAL PDstandardNth2gt13 = INITVALUE;
- CCTK_REAL PDstandardNth3gt13 = INITVALUE;
- CCTK_REAL PDstandardNth1gt22 = INITVALUE;
- CCTK_REAL PDstandardNth2gt22 = INITVALUE;
- CCTK_REAL PDstandardNth3gt22 = INITVALUE;
- CCTK_REAL PDstandardNth1gt23 = INITVALUE;
- CCTK_REAL PDstandardNth2gt23 = INITVALUE;
- CCTK_REAL PDstandardNth3gt23 = INITVALUE;
- CCTK_REAL PDstandardNth1gt33 = INITVALUE;
- CCTK_REAL PDstandardNth2gt33 = INITVALUE;
- CCTK_REAL PDstandardNth3gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt11 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt12 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt13 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt22 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt23 = INITVALUE;
+ // CCTK_REAL PDstandardNth1gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth2gt33 = INITVALUE;
+ // CCTK_REAL PDstandardNth3gt33 = INITVALUE;
/* Assign local copies of grid functions */
- alphaL = alpha[index];
- beta1L = beta1[index];
- beta2L = beta2[index];
- beta3L = beta3[index];
- dtalpL = dtalp[index];
- dtbetaxL = dtbetax[index];
- dtbetayL = dtbetay[index];
- dtbetazL = dtbetaz[index];
- gt11L = gt11[index];
- gt12L = gt12[index];
- gt13L = gt13[index];
- gt22L = gt22[index];
- gt23L = gt23[index];
- gt33L = gt33[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const beta1L = beta1[index];
+ CCTK_REAL const beta2L = beta2[index];
+ CCTK_REAL const beta3L = beta3[index];
+ CCTK_REAL const betaxL = betax[index];
+ CCTK_REAL const betayL = betay[index];
+ CCTK_REAL const betazL = betaz[index];
+ CCTK_REAL const dtalpL = dtalp[index];
+ CCTK_REAL const dtbetaxL = dtbetax[index];
+ CCTK_REAL const dtbetayL = dtbetay[index];
+ CCTK_REAL const dtbetazL = dtbetaz[index];
+ CCTK_REAL const gt11L = gt11[index];
+ CCTK_REAL const gt12L = gt12[index];
+ CCTK_REAL const gt13L = gt13[index];
+ CCTK_REAL const gt22L = gt22[index];
+ CCTK_REAL const gt23L = gt23[index];
+ CCTK_REAL const gt33L = gt33[index];
/* Assign local copies of subblock grid functions */
/* Include user supplied include files */
/* Precompute derivatives (new style) */
- PDstandardNth1gt11 = PDstandardNth1(gt11, i, j, k);
- PDstandardNth2gt11 = PDstandardNth2(gt11, i, j, k);
- PDstandardNth3gt11 = PDstandardNth3(gt11, i, j, k);
- PDstandardNth1gt12 = PDstandardNth1(gt12, i, j, k);
- PDstandardNth2gt12 = PDstandardNth2(gt12, i, j, k);
- PDstandardNth3gt12 = PDstandardNth3(gt12, i, j, k);
- PDstandardNth1gt13 = PDstandardNth1(gt13, i, j, k);
- PDstandardNth2gt13 = PDstandardNth2(gt13, i, j, k);
- PDstandardNth3gt13 = PDstandardNth3(gt13, i, j, k);
- PDstandardNth1gt22 = PDstandardNth1(gt22, i, j, k);
- PDstandardNth2gt22 = PDstandardNth2(gt22, i, j, k);
- PDstandardNth3gt22 = PDstandardNth3(gt22, i, j, k);
- PDstandardNth1gt23 = PDstandardNth1(gt23, i, j, k);
- PDstandardNth2gt23 = PDstandardNth2(gt23, i, j, k);
- PDstandardNth3gt23 = PDstandardNth3(gt23, i, j, k);
- PDstandardNth1gt33 = PDstandardNth1(gt33, i, j, k);
- PDstandardNth2gt33 = PDstandardNth2(gt33, i, j, k);
- PDstandardNth3gt33 = PDstandardNth3(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth1gt11 = PDstandardNth1(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth2gt11 = PDstandardNth2(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth3gt11 = PDstandardNth3(gt11, i, j, k);
+ CCTK_REAL const PDstandardNth1gt12 = PDstandardNth1(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth2gt12 = PDstandardNth2(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth3gt12 = PDstandardNth3(gt12, i, j, k);
+ CCTK_REAL const PDstandardNth1gt13 = PDstandardNth1(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth2gt13 = PDstandardNth2(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth3gt13 = PDstandardNth3(gt13, i, j, k);
+ CCTK_REAL const PDstandardNth1gt22 = PDstandardNth1(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth2gt22 = PDstandardNth2(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth3gt22 = PDstandardNth3(gt22, i, j, k);
+ CCTK_REAL const PDstandardNth1gt23 = PDstandardNth1(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth2gt23 = PDstandardNth2(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth3gt23 = PDstandardNth3(gt23, i, j, k);
+ CCTK_REAL const PDstandardNth1gt33 = PDstandardNth1(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth2gt33 = PDstandardNth2(gt33, i, j, k);
+ CCTK_REAL const PDstandardNth3gt33 = PDstandardNth3(gt33, i, j, k);
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- dir1 = Sign(beta1L);
+ int const dir1 = Sign(beta1L);
- dir2 = Sign(beta2L);
+ int const dir2 = Sign(beta2L);
- dir3 = Sign(beta3L);
+ int const dir3 = Sign(beta3L);
- detgt = 1;
+ CCTK_REAL const detgt = 1;
- gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
+ CCTK_REAL const gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
- gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
+ CCTK_REAL const gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
- gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
- gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
+ CCTK_REAL const gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
- gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
- gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
+ CCTK_REAL const gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
- Gt111 = khalf*(gtu11*PDstandardNth1gt11 + 2*(gtu21*PDstandardNth1gt12 + gtu31*PDstandardNth1gt13) -
+ CCTK_REAL const Gt111 = khalf*(gtu11*PDstandardNth1gt11 + 2*(gtu21*PDstandardNth1gt12 + gtu31*PDstandardNth1gt13) -
gtu21*PDstandardNth2gt11 - gtu31*PDstandardNth3gt11);
- Gt211 = khalf*(gtu21*PDstandardNth1gt11 + 2*(gtu22*PDstandardNth1gt12 + gtu32*PDstandardNth1gt13) -
+ CCTK_REAL const Gt211 = khalf*(gtu21*PDstandardNth1gt11 + 2*(gtu22*PDstandardNth1gt12 + gtu32*PDstandardNth1gt13) -
gtu22*PDstandardNth2gt11 - gtu32*PDstandardNth3gt11);
- Gt311 = khalf*(gtu31*PDstandardNth1gt11 + 2*(gtu32*PDstandardNth1gt12 + gtu33*PDstandardNth1gt13) -
+ CCTK_REAL const Gt311 = khalf*(gtu31*PDstandardNth1gt11 + 2*(gtu32*PDstandardNth1gt12 + gtu33*PDstandardNth1gt13) -
gtu32*PDstandardNth2gt11 - gtu33*PDstandardNth3gt11);
- Gt112 = khalf*(gtu21*PDstandardNth1gt22 + gtu11*PDstandardNth2gt11 +
+ CCTK_REAL const Gt112 = khalf*(gtu21*PDstandardNth1gt22 + gtu11*PDstandardNth2gt11 +
gtu31*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
- Gt212 = khalf*(gtu22*PDstandardNth1gt22 + gtu21*PDstandardNth2gt11 +
+ CCTK_REAL const Gt212 = khalf*(gtu22*PDstandardNth1gt22 + gtu21*PDstandardNth2gt11 +
gtu32*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
- Gt312 = khalf*(gtu32*PDstandardNth1gt22 + gtu31*PDstandardNth2gt11 +
+ CCTK_REAL const Gt312 = khalf*(gtu32*PDstandardNth1gt22 + gtu31*PDstandardNth2gt11 +
gtu33*(PDstandardNth1gt23 + PDstandardNth2gt13 - PDstandardNth3gt12));
- Gt113 = khalf*(gtu31*PDstandardNth1gt33 + gtu11*PDstandardNth3gt11 +
+ CCTK_REAL const Gt113 = khalf*(gtu31*PDstandardNth1gt33 + gtu11*PDstandardNth3gt11 +
gtu21*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
- Gt213 = khalf*(gtu32*PDstandardNth1gt33 + gtu21*PDstandardNth3gt11 +
+ CCTK_REAL const Gt213 = khalf*(gtu32*PDstandardNth1gt33 + gtu21*PDstandardNth3gt11 +
gtu22*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
- Gt313 = khalf*(gtu33*PDstandardNth1gt33 + gtu31*PDstandardNth3gt11 +
+ CCTK_REAL const Gt313 = khalf*(gtu33*PDstandardNth1gt33 + gtu31*PDstandardNth3gt11 +
gtu32*(PDstandardNth1gt23 - PDstandardNth2gt13 + PDstandardNth3gt12));
- Gt122 = khalf*(gtu11*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu21*PDstandardNth2gt22 +
+ CCTK_REAL const Gt122 = khalf*(gtu11*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu21*PDstandardNth2gt22 +
gtu31*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
- Gt222 = khalf*(gtu21*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu22*PDstandardNth2gt22 +
+ CCTK_REAL const Gt222 = khalf*(gtu21*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu22*PDstandardNth2gt22 +
gtu32*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
- Gt322 = khalf*(gtu31*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu32*PDstandardNth2gt22 +
+ CCTK_REAL const Gt322 = khalf*(gtu31*(-PDstandardNth1gt22 + 2*PDstandardNth2gt12) + gtu32*PDstandardNth2gt22 +
gtu33*(2*PDstandardNth2gt23 - PDstandardNth3gt22));
- Gt123 = khalf*(gtu31*PDstandardNth2gt33 + gtu11*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ CCTK_REAL const Gt123 = khalf*(gtu31*PDstandardNth2gt33 + gtu11*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
gtu21*PDstandardNth3gt22);
- Gt223 = khalf*(gtu32*PDstandardNth2gt33 + gtu21*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ CCTK_REAL const Gt223 = khalf*(gtu32*PDstandardNth2gt33 + gtu21*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
gtu22*PDstandardNth3gt22);
- Gt323 = khalf*(gtu33*PDstandardNth2gt33 + gtu31*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
+ CCTK_REAL const Gt323 = khalf*(gtu33*PDstandardNth2gt33 + gtu31*(-PDstandardNth1gt23 + PDstandardNth2gt13 + PDstandardNth3gt12) +
gtu32*PDstandardNth3gt22);
- Gt133 = khalf*(-(gtu11*PDstandardNth1gt33) - gtu21*PDstandardNth2gt33 + 2*gtu11*PDstandardNth3gt13 +
+ CCTK_REAL const Gt133 = khalf*(-(gtu11*PDstandardNth1gt33) - gtu21*PDstandardNth2gt33 + 2*gtu11*PDstandardNth3gt13 +
2*gtu21*PDstandardNth3gt23 + gtu31*PDstandardNth3gt33);
- Gt233 = khalf*(-(gtu21*PDstandardNth1gt33) - gtu22*PDstandardNth2gt33 + 2*gtu21*PDstandardNth3gt13 +
+ CCTK_REAL const Gt233 = khalf*(-(gtu21*PDstandardNth1gt33) - gtu22*PDstandardNth2gt33 + 2*gtu21*PDstandardNth3gt13 +
2*gtu22*PDstandardNth3gt23 + gtu32*PDstandardNth3gt33);
- Gt333 = khalf*(-(gtu31*PDstandardNth1gt33) - gtu32*PDstandardNth2gt33 + 2*gtu31*PDstandardNth3gt13 +
+ CCTK_REAL const Gt333 = khalf*(-(gtu31*PDstandardNth1gt33) - gtu32*PDstandardNth2gt33 + 2*gtu31*PDstandardNth3gt13 +
2*gtu32*PDstandardNth3gt23 + gtu33*PDstandardNth3gt33);
- Xt1L = Gt111*gtu11 + Gt122*gtu22 + 2*(Gt112*gtu21 + Gt113*gtu31 + Gt123*gtu32) + Gt133*gtu33;
+ CCTK_REAL const Xt1L = Gt111*gtu11 + Gt122*gtu22 + 2*(Gt112*gtu21 + Gt113*gtu31 + Gt123*gtu32) + Gt133*gtu33;
- Xt2L = Gt211*gtu11 + Gt222*gtu22 + 2*(Gt212*gtu21 + Gt213*gtu31 + Gt223*gtu32) + Gt233*gtu33;
+ CCTK_REAL const Xt2L = Gt211*gtu11 + Gt222*gtu22 + 2*(Gt212*gtu21 + Gt213*gtu31 + Gt223*gtu32) + Gt233*gtu33;
- Xt3L = Gt311*gtu11 + Gt322*gtu22 + 2*(Gt312*gtu21 + Gt313*gtu31 + Gt323*gtu32) + Gt333*gtu33;
+ CCTK_REAL const Xt3L = Gt311*gtu11 + Gt322*gtu22 + 2*(Gt312*gtu21 + Gt313*gtu31 + Gt323*gtu32) + Gt333*gtu33;
- AL = -(dtalpL*(-1 + LapseAdvectionCoeff)*INV(harmonicF)*pow(alphaL,-harmonicN));
+ CCTK_REAL const AL = -(dtalpL*(-1 + LapseAdvectionCoeff)*INV(harmonicF)*pow(alphaL,-harmonicN));
- B1L = 6*IfThen(ShiftGammaCoeff,dtbetaxL*INV(ShiftGammaCoeff),0) +
- IfThen(ShiftGammaCoeff,(dtbetaxL - PDupwindNth1(beta1, i, j, k)*beta1L*ShiftAdvectionCoeff)*INV(ShiftGammaCoeff),
- 0) + IfThen(ShiftGammaCoeff,(dtbetaxL - PDupwindNth2(beta1, i, j, k)*beta2L*ShiftAdvectionCoeff)*
- INV(ShiftGammaCoeff),0) + IfThen(ShiftGammaCoeff,
- (dtbetaxL - PDupwindNth3(beta1, i, j, k)*beta3L*ShiftAdvectionCoeff)*INV(ShiftGammaCoeff),0);
+ CCTK_REAL const B1L = 6*IfThen(ShiftGammaCoeff != 0,dtbetaxL*INV(ShiftGammaCoeff),0) +
+ IfThen(ShiftGammaCoeff != 0,(dtbetaxL - PDupwindNth1(betax, i, j, k)*beta1L*ShiftAdvectionCoeff)*
+ INV(ShiftGammaCoeff),0) + IfThen(ShiftGammaCoeff != 0,
+ (dtbetaxL - PDupwindNth2(betax, i, j, k)*beta2L*ShiftAdvectionCoeff)*INV(ShiftGammaCoeff),0) +
+ IfThen(ShiftGammaCoeff != 0,(dtbetaxL - PDupwindNth3(betax, i, j, k)*beta3L*ShiftAdvectionCoeff)*
+ INV(ShiftGammaCoeff),0);
- B2L = 6*IfThen(ShiftGammaCoeff,dtbetayL*INV(ShiftGammaCoeff),0) +
- IfThen(ShiftGammaCoeff,(dtbetayL - PDupwindNth1(beta2, i, j, k)*beta1L*ShiftAdvectionCoeff)*INV(ShiftGammaCoeff),
- 0) + IfThen(ShiftGammaCoeff,(dtbetayL - PDupwindNth2(beta2, i, j, k)*beta2L*ShiftAdvectionCoeff)*
- INV(ShiftGammaCoeff),0) + IfThen(ShiftGammaCoeff,
- (dtbetayL - PDupwindNth3(beta2, i, j, k)*beta3L*ShiftAdvectionCoeff)*INV(ShiftGammaCoeff),0);
+ CCTK_REAL const B2L = 6*IfThen(ShiftGammaCoeff != 0,dtbetayL*INV(ShiftGammaCoeff),0) +
+ IfThen(ShiftGammaCoeff != 0,(dtbetayL - PDupwindNth1(betay, i, j, k)*beta1L*ShiftAdvectionCoeff)*
+ INV(ShiftGammaCoeff),0) + IfThen(ShiftGammaCoeff != 0,
+ (dtbetayL - PDupwindNth2(betay, i, j, k)*beta2L*ShiftAdvectionCoeff)*INV(ShiftGammaCoeff),0) +
+ IfThen(ShiftGammaCoeff != 0,(dtbetayL - PDupwindNth3(betay, i, j, k)*beta3L*ShiftAdvectionCoeff)*
+ INV(ShiftGammaCoeff),0);
- B3L = 6*IfThen(ShiftGammaCoeff,dtbetazL*INV(ShiftGammaCoeff),0) +
- IfThen(ShiftGammaCoeff,(dtbetazL - PDupwindNth1(beta3, i, j, k)*beta1L*ShiftAdvectionCoeff)*INV(ShiftGammaCoeff),
- 0) + IfThen(ShiftGammaCoeff,(dtbetazL - PDupwindNth2(beta3, i, j, k)*beta2L*ShiftAdvectionCoeff)*
- INV(ShiftGammaCoeff),0) + IfThen(ShiftGammaCoeff,
- (dtbetazL - PDupwindNth3(beta3, i, j, k)*beta3L*ShiftAdvectionCoeff)*INV(ShiftGammaCoeff),0);
+ CCTK_REAL const B3L = 6*IfThen(ShiftGammaCoeff != 0,dtbetazL*INV(ShiftGammaCoeff),0) +
+ IfThen(ShiftGammaCoeff != 0,(dtbetazL - PDupwindNth1(betaz, i, j, k)*beta1L*ShiftAdvectionCoeff)*
+ INV(ShiftGammaCoeff),0) + IfThen(ShiftGammaCoeff != 0,
+ (dtbetazL - PDupwindNth2(betaz, i, j, k)*beta2L*ShiftAdvectionCoeff)*INV(ShiftGammaCoeff),0) +
+ IfThen(ShiftGammaCoeff != 0,(dtbetazL - PDupwindNth3(betaz, i, j, k)*beta3L*ShiftAdvectionCoeff)*
+ INV(ShiftGammaCoeff),0);
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_convertToADMBase.c b/ML_BSSN/src/ML_BSSN_convertToADMBase.c
index 3fb72f9..5f5bde3 100644
--- a/ML_BSSN/src/ML_BSSN_convertToADMBase.c
+++ b/ML_BSSN/src/ML_BSSN_convertToADMBase.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_convertToADMBase_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_convertToADMBase_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_convertToADMBase_Body(cGH const * const cctkGH, CCTK_INT const dir,
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,62 +93,60 @@ void ML_BSSN_convertToADMBase_Body(cGH const * const cctkGH, CCTK_INT const dir,
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
- CCTK_REAL e4phi = INITVALUE;
- CCTK_REAL g11 = INITVALUE, g12 = INITVALUE, g13 = INITVALUE, g22 = INITVALUE, g23 = INITVALUE, g33 = INITVALUE;
- CCTK_REAL K11 = INITVALUE, K12 = INITVALUE, K13 = INITVALUE, K22 = INITVALUE, K23 = INITVALUE, K33 = INITVALUE;
+ // CCTK_REAL e4phi = INITVALUE;
/* Declare local copies of grid functions */
- CCTK_REAL alpL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE;
- CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
- CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
- CCTK_REAL betaxL = INITVALUE;
- CCTK_REAL betayL = INITVALUE;
- CCTK_REAL betazL = INITVALUE;
- CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
- CCTK_REAL gxxL = INITVALUE;
- CCTK_REAL gxyL = INITVALUE;
- CCTK_REAL gxzL = INITVALUE;
- CCTK_REAL gyyL = INITVALUE;
- CCTK_REAL gyzL = INITVALUE;
- CCTK_REAL gzzL = INITVALUE;
- CCTK_REAL kxxL = INITVALUE;
- CCTK_REAL kxyL = INITVALUE;
- CCTK_REAL kxzL = INITVALUE;
- CCTK_REAL kyyL = INITVALUE;
- CCTK_REAL kyzL = INITVALUE;
- CCTK_REAL kzzL = INITVALUE;
- CCTK_REAL phiL = INITVALUE;
- CCTK_REAL trKL = INITVALUE;
+ // CCTK_REAL alpL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
+ // CCTK_REAL betaxL = INITVALUE;
+ // CCTK_REAL betayL = INITVALUE;
+ // CCTK_REAL betazL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
+ // CCTK_REAL gxxL = INITVALUE;
+ // CCTK_REAL gxyL = INITVALUE;
+ // CCTK_REAL gxzL = INITVALUE;
+ // CCTK_REAL gyyL = INITVALUE;
+ // CCTK_REAL gyzL = INITVALUE;
+ // CCTK_REAL gzzL = INITVALUE;
+ // CCTK_REAL kxxL = INITVALUE;
+ // CCTK_REAL kxyL = INITVALUE;
+ // CCTK_REAL kxzL = INITVALUE;
+ // CCTK_REAL kyyL = INITVALUE;
+ // CCTK_REAL kyzL = INITVALUE;
+ // CCTK_REAL kzzL = INITVALUE;
+ // CCTK_REAL phiL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
/* Assign local copies of grid functions */
- alphaL = alpha[index];
- At11L = At11[index];
- At12L = At12[index];
- At13L = At13[index];
- At22L = At22[index];
- At23L = At23[index];
- At33L = At33[index];
- beta1L = beta1[index];
- beta2L = beta2[index];
- beta3L = beta3[index];
- gt11L = gt11[index];
- gt12L = gt12[index];
- gt13L = gt13[index];
- gt22L = gt22[index];
- gt23L = gt23[index];
- gt33L = gt33[index];
- phiL = phi[index];
- trKL = trK[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const At11L = At11[index];
+ CCTK_REAL const At12L = At12[index];
+ CCTK_REAL const At13L = At13[index];
+ CCTK_REAL const At22L = At22[index];
+ CCTK_REAL const At23L = At23[index];
+ CCTK_REAL const At33L = At33[index];
+ CCTK_REAL const beta1L = beta1[index];
+ CCTK_REAL const beta2L = beta2[index];
+ CCTK_REAL const beta3L = beta3[index];
+ CCTK_REAL const gt11L = gt11[index];
+ CCTK_REAL const gt12L = gt12[index];
+ CCTK_REAL const gt13L = gt13[index];
+ CCTK_REAL const gt22L = gt22[index];
+ CCTK_REAL const gt23L = gt23[index];
+ CCTK_REAL const gt33L = gt33[index];
+ CCTK_REAL const phiL = phi[index];
+ CCTK_REAL const trKL = trK[index];
/* Assign local copies of subblock grid functions */
@@ -161,63 +157,39 @@ void ML_BSSN_convertToADMBase_Body(cGH const * const cctkGH, CCTK_INT const dir,
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- e4phi = IfThen(conformalMethod,pow(phiL,-2),exp(4*phiL));
-
- g11 = e4phi*gt11L;
-
- g12 = e4phi*gt12L;
-
- g13 = e4phi*gt13L;
-
- g22 = e4phi*gt22L;
-
- g23 = e4phi*gt23L;
-
- g33 = e4phi*gt33L;
-
- gxxL = g11;
-
- gxyL = g12;
-
- gxzL = g13;
-
- gyyL = g22;
-
- gyzL = g23;
-
- gzzL = g33;
+ CCTK_REAL const e4phi = IfThen(conformalMethod,pow(phiL,-2),exp(4*phiL));
- K11 = At11L*e4phi + g11*kthird*trKL;
+ CCTK_REAL const gxxL = e4phi*gt11L;
- K12 = At12L*e4phi + g12*kthird*trKL;
+ CCTK_REAL const gxyL = e4phi*gt12L;
- K13 = At13L*e4phi + g13*kthird*trKL;
+ CCTK_REAL const gxzL = e4phi*gt13L;
- K22 = At22L*e4phi + g22*kthird*trKL;
+ CCTK_REAL const gyyL = e4phi*gt22L;
- K23 = At23L*e4phi + g23*kthird*trKL;
+ CCTK_REAL const gyzL = e4phi*gt23L;
- K33 = At33L*e4phi + g33*kthird*trKL;
+ CCTK_REAL const gzzL = e4phi*gt33L;
- kxxL = K11;
+ CCTK_REAL const kxxL = At11L*e4phi + gxxL*kthird*trKL;
- kxyL = K12;
+ CCTK_REAL const kxyL = At12L*e4phi + gxyL*kthird*trKL;
- kxzL = K13;
+ CCTK_REAL const kxzL = At13L*e4phi + gxzL*kthird*trKL;
- kyyL = K22;
+ CCTK_REAL const kyyL = At22L*e4phi + gyyL*kthird*trKL;
- kyzL = K23;
+ CCTK_REAL const kyzL = At23L*e4phi + gyzL*kthird*trKL;
- kzzL = K33;
+ CCTK_REAL const kzzL = At33L*e4phi + gzzL*kthird*trKL;
- alpL = alphaL;
+ CCTK_REAL const alpL = alphaL;
- betaxL = beta1L;
+ CCTK_REAL const betaxL = beta1L;
- betayL = beta2L;
+ CCTK_REAL const betayL = beta2L;
- betazL = beta3L;
+ CCTK_REAL const betazL = beta3L;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShift.c b/ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShift.c
index 280b05e..8403ae3 100644
--- a/ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShift.c
+++ b/ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShift.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_convertToADMBaseDtLapseShift_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_convertToADMBaseDtLapseShift_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_convertToADMBaseDtLapseShift_Body(cGH const * const cctkGH, CCTK_IN
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,38 +93,38 @@ void ML_BSSN_convertToADMBaseDtLapseShift_Body(cGH const * const cctkGH, CCTK_IN
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
- CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
+ // CCTK_REAL dir1 = INITVALUE, dir2 = INITVALUE, dir3 = INITVALUE;
/* Declare local copies of grid functions */
- CCTK_REAL AL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE;
- CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
- CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
- CCTK_REAL dtalpL = INITVALUE;
- CCTK_REAL dtbetaxL = INITVALUE;
- CCTK_REAL dtbetayL = INITVALUE;
- CCTK_REAL dtbetazL = INITVALUE;
- CCTK_REAL trKL = INITVALUE;
+ // CCTK_REAL AL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
+ // CCTK_REAL beta1L = INITVALUE, beta2L = INITVALUE, beta3L = INITVALUE;
+ // CCTK_REAL dtalpL = INITVALUE;
+ // CCTK_REAL dtbetaxL = INITVALUE;
+ // CCTK_REAL dtbetayL = INITVALUE;
+ // CCTK_REAL dtbetazL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
/* Assign local copies of grid functions */
- AL = A[index];
- alphaL = alpha[index];
- B1L = B1[index];
- B2L = B2[index];
- B3L = B3[index];
- beta1L = beta1[index];
- beta2L = beta2[index];
- beta3L = beta3[index];
- trKL = trK[index];
+ CCTK_REAL const AL = A[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const B1L = B1[index];
+ CCTK_REAL const B2L = B2[index];
+ CCTK_REAL const B3L = B3[index];
+ CCTK_REAL const beta1L = beta1[index];
+ CCTK_REAL const beta2L = beta2[index];
+ CCTK_REAL const beta3L = beta3[index];
+ CCTK_REAL const trKL = trK[index];
/* Assign local copies of subblock grid functions */
@@ -137,23 +135,23 @@ void ML_BSSN_convertToADMBaseDtLapseShift_Body(cGH const * const cctkGH, CCTK_IN
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- dir1 = Sign(beta1L);
+ int const dir1 = Sign(beta1L);
- dir2 = Sign(beta2L);
+ int const dir2 = Sign(beta2L);
- dir3 = Sign(beta3L);
+ int const dir3 = Sign(beta3L);
- dtalpL = (PDupwindNth1(alpha, i, j, k)*beta1L + PDupwindNth2(alpha, i, j, k)*beta2L +
+ CCTK_REAL const dtalpL = (PDupwindNth1(alpha, i, j, k)*beta1L + PDupwindNth2(alpha, i, j, k)*beta2L +
PDupwindNth3(alpha, i, j, k)*beta3L)*LapseAdvectionCoeff +
harmonicF*(AL*(-1 + LapseAdvectionCoeff) - LapseAdvectionCoeff*trKL)*pow(alphaL,harmonicN);
- dtbetaxL = (PDupwindNth1(beta1, i, j, k)*beta1L + PDupwindNth2(beta1, i, j, k)*beta2L +
+ CCTK_REAL const dtbetaxL = (PDupwindNth1(beta1, i, j, k)*beta1L + PDupwindNth2(beta1, i, j, k)*beta2L +
PDupwindNth3(beta1, i, j, k)*beta3L)*ShiftAdvectionCoeff + B1L*ShiftGammaCoeff;
- dtbetayL = (PDupwindNth1(beta2, i, j, k)*beta1L + PDupwindNth2(beta2, i, j, k)*beta2L +
+ CCTK_REAL const dtbetayL = (PDupwindNth1(beta2, i, j, k)*beta1L + PDupwindNth2(beta2, i, j, k)*beta2L +
PDupwindNth3(beta2, i, j, k)*beta3L)*ShiftAdvectionCoeff + B2L*ShiftGammaCoeff;
- dtbetazL = (PDupwindNth1(beta3, i, j, k)*beta1L + PDupwindNth2(beta3, i, j, k)*beta2L +
+ CCTK_REAL const dtbetazL = (PDupwindNth1(beta3, i, j, k)*beta1L + PDupwindNth2(beta3, i, j, k)*beta2L +
PDupwindNth3(beta3, i, j, k)*beta3L)*ShiftAdvectionCoeff + B3L*ShiftGammaCoeff;
diff --git a/ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShiftBoundary.c b/ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShiftBoundary.c
index cad10b0..06870f4 100644
--- a/ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShiftBoundary.c
+++ b/ML_BSSN/src/ML_BSSN_convertToADMBaseDtLapseShiftBoundary.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_convertToADMBaseDtLapseShiftBoundary_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_convertToADMBaseDtLapseShiftBoundary_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_convertToADMBaseDtLapseShiftBoundary_Body(cGH const * const cctkGH,
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,33 +93,33 @@ void ML_BSSN_convertToADMBaseDtLapseShiftBoundary_Body(cGH const * const cctkGH,
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
/* Declare local copies of grid functions */
- CCTK_REAL AL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE;
- CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
- CCTK_REAL dtalpL = INITVALUE;
- CCTK_REAL dtbetaxL = INITVALUE;
- CCTK_REAL dtbetayL = INITVALUE;
- CCTK_REAL dtbetazL = INITVALUE;
- CCTK_REAL trKL = INITVALUE;
+ // CCTK_REAL AL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
+ // CCTK_REAL dtalpL = INITVALUE;
+ // CCTK_REAL dtbetaxL = INITVALUE;
+ // CCTK_REAL dtbetayL = INITVALUE;
+ // CCTK_REAL dtbetazL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
/* Assign local copies of grid functions */
- AL = A[index];
- alphaL = alpha[index];
- B1L = B1[index];
- B2L = B2[index];
- B3L = B3[index];
- trKL = trK[index];
+ CCTK_REAL const AL = A[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const B1L = B1[index];
+ CCTK_REAL const B2L = B2[index];
+ CCTK_REAL const B3L = B3[index];
+ CCTK_REAL const trKL = trK[index];
/* Assign local copies of subblock grid functions */
@@ -132,13 +130,13 @@ void ML_BSSN_convertToADMBaseDtLapseShiftBoundary_Body(cGH const * const cctkGH,
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- dtalpL = harmonicF*(AL*(-1 + LapseAdvectionCoeff) - LapseAdvectionCoeff*trKL)*pow(alphaL,harmonicN);
+ CCTK_REAL const dtalpL = harmonicF*(AL*(-1 + LapseAdvectionCoeff) - LapseAdvectionCoeff*trKL)*pow(alphaL,harmonicN);
- dtbetaxL = B1L*ShiftGammaCoeff;
+ CCTK_REAL const dtbetaxL = B1L*ShiftGammaCoeff;
- dtbetayL = B2L*ShiftGammaCoeff;
+ CCTK_REAL const dtbetayL = B2L*ShiftGammaCoeff;
- dtbetazL = B3L*ShiftGammaCoeff;
+ CCTK_REAL const dtbetazL = B3L*ShiftGammaCoeff;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_convertToADMBaseFakeDtLapseShift.c b/ML_BSSN/src/ML_BSSN_convertToADMBaseFakeDtLapseShift.c
index 835480a..cae8455 100644
--- a/ML_BSSN/src/ML_BSSN_convertToADMBaseFakeDtLapseShift.c
+++ b/ML_BSSN/src/ML_BSSN_convertToADMBaseFakeDtLapseShift.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_convertToADMBaseFakeDtLapseShift_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_convertToADMBaseFakeDtLapseShift_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_convertToADMBaseFakeDtLapseShift_Body(cGH const * const cctkGH, CCT
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,33 +93,33 @@ void ML_BSSN_convertToADMBaseFakeDtLapseShift_Body(cGH const * const cctkGH, CCT
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
/* Declare local copies of grid functions */
- CCTK_REAL AL = INITVALUE;
- CCTK_REAL alphaL = INITVALUE;
- CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
- CCTK_REAL dtalpL = INITVALUE;
- CCTK_REAL dtbetaxL = INITVALUE;
- CCTK_REAL dtbetayL = INITVALUE;
- CCTK_REAL dtbetazL = INITVALUE;
- CCTK_REAL trKL = INITVALUE;
+ // CCTK_REAL AL = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE;
+ // CCTK_REAL B1L = INITVALUE, B2L = INITVALUE, B3L = INITVALUE;
+ // CCTK_REAL dtalpL = INITVALUE;
+ // CCTK_REAL dtbetaxL = INITVALUE;
+ // CCTK_REAL dtbetayL = INITVALUE;
+ // CCTK_REAL dtbetazL = INITVALUE;
+ // CCTK_REAL trKL = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
/* Assign local copies of grid functions */
- AL = A[index];
- alphaL = alpha[index];
- B1L = B1[index];
- B2L = B2[index];
- B3L = B3[index];
- trKL = trK[index];
+ CCTK_REAL const AL = A[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const B1L = B1[index];
+ CCTK_REAL const B2L = B2[index];
+ CCTK_REAL const B3L = B3[index];
+ CCTK_REAL const trKL = trK[index];
/* Assign local copies of subblock grid functions */
@@ -132,13 +130,13 @@ void ML_BSSN_convertToADMBaseFakeDtLapseShift_Body(cGH const * const cctkGH, CCT
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- dtalpL = harmonicF*(AL*(-1 + LapseAdvectionCoeff) - LapseAdvectionCoeff*trKL)*pow(alphaL,harmonicN);
+ CCTK_REAL const dtalpL = harmonicF*(AL*(-1 + LapseAdvectionCoeff) - LapseAdvectionCoeff*trKL)*pow(alphaL,harmonicN);
- dtbetaxL = B1L*ShiftGammaCoeff;
+ CCTK_REAL const dtbetaxL = B1L*ShiftGammaCoeff;
- dtbetayL = B2L*ShiftGammaCoeff;
+ CCTK_REAL const dtbetayL = B2L*ShiftGammaCoeff;
- dtbetazL = B3L*ShiftGammaCoeff;
+ CCTK_REAL const dtbetazL = B3L*ShiftGammaCoeff;
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/ML_BSSN_enforce.c b/ML_BSSN/src/ML_BSSN_enforce.c
index eb3b430..6d58561 100644
--- a/ML_BSSN/src/ML_BSSN_enforce.c
+++ b/ML_BSSN/src/ML_BSSN_enforce.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_enforce_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_enforce_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_enforce_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,38 +93,39 @@ void ML_BSSN_enforce_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
- CCTK_REAL detgt = INITVALUE;
- CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
- CCTK_REAL trAt = INITVALUE;
+ // CCTK_REAL detgt = INITVALUE;
+ // CCTK_REAL gtu11 = INITVALUE, gtu21 = INITVALUE, gtu22 = INITVALUE, gtu31 = INITVALUE, gtu32 = INITVALUE, gtu33 = INITVALUE;
+ // CCTK_REAL trAt = INITVALUE;
/* Declare local copies of grid functions */
- CCTK_REAL alphaL = INITVALUE;
- CCTK_REAL At11L = INITVALUE, At12L = INITVALUE, At13L = INITVALUE, At22L = INITVALUE, At23L = INITVALUE, At33L = INITVALUE;
- CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
+ // CCTK_REAL alphaL = INITVALUE, alpharhsL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At11rhsL = INITVALUE, At12L = INITVALUE, At12rhsL = INITVALUE, At13L = INITVALUE, At13rhsL = INITVALUE;
+ // CCTK_REAL At22L = INITVALUE, At22rhsL = INITVALUE, At23L = INITVALUE, At23rhsL = INITVALUE, At33L = INITVALUE, At33rhsL = INITVALUE;
+ // CCTK_REAL gt11L = INITVALUE, gt12L = INITVALUE, gt13L = INITVALUE, gt22L = INITVALUE, gt23L = INITVALUE, gt33L = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
/* Assign local copies of grid functions */
- alphaL = alpha[index];
- At11L = At11[index];
- At12L = At12[index];
- At13L = At13[index];
- At22L = At22[index];
- At23L = At23[index];
- At33L = At33[index];
- gt11L = gt11[index];
- gt12L = gt12[index];
- gt13L = gt13[index];
- gt22L = gt22[index];
- gt23L = gt23[index];
- gt33L = gt33[index];
+ CCTK_REAL const alphaL = alpha[index];
+ CCTK_REAL const At11L = At11[index];
+ CCTK_REAL const At12L = At12[index];
+ CCTK_REAL const At13L = At13[index];
+ CCTK_REAL const At22L = At22[index];
+ CCTK_REAL const At23L = At23[index];
+ CCTK_REAL const At33L = At33[index];
+ CCTK_REAL const gt11L = gt11[index];
+ CCTK_REAL const gt12L = gt12[index];
+ CCTK_REAL const gt13L = gt13[index];
+ CCTK_REAL const gt22L = gt22[index];
+ CCTK_REAL const gt23L = gt23[index];
+ CCTK_REAL const gt33L = gt33[index];
/* Assign local copies of subblock grid functions */
@@ -137,45 +136,45 @@ void ML_BSSN_enforce_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- detgt = 1;
+ CCTK_REAL const detgt = 1;
- gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
+ CCTK_REAL const gtu11 = INV(detgt)*(gt22L*gt33L - SQR(gt23L));
- gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
+ CCTK_REAL const gtu21 = (gt13L*gt23L - gt12L*gt33L)*INV(detgt);
- gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu31 = (-(gt13L*gt22L) + gt12L*gt23L)*INV(detgt);
- gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
+ CCTK_REAL const gtu22 = INV(detgt)*(gt11L*gt33L - SQR(gt13L));
- gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
+ CCTK_REAL const gtu32 = (gt12L*gt13L - gt11L*gt23L)*INV(detgt);
- gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
+ CCTK_REAL const gtu33 = INV(detgt)*(gt11L*gt22L - SQR(gt12L));
- trAt = At11L*gtu11 + At22L*gtu22 + 2*(At12L*gtu21 + At13L*gtu31 + At23L*gtu32) + At33L*gtu33;
+ CCTK_REAL const trAt = At11L*gtu11 + At22L*gtu22 + 2*(At12L*gtu21 + At13L*gtu31 + At23L*gtu32) + At33L*gtu33;
- At11L = At11L - gt11L*kthird*trAt;
+ CCTK_REAL const At11rhsL = At11L - gt11L*kthird*trAt;
- At12L = At12L - gt12L*kthird*trAt;
+ CCTK_REAL const At12rhsL = At12L - gt12L*kthird*trAt;
- At13L = At13L - gt13L*kthird*trAt;
+ CCTK_REAL const At13rhsL = At13L - gt13L*kthird*trAt;
- At22L = At22L - gt22L*kthird*trAt;
+ CCTK_REAL const At22rhsL = At22L - gt22L*kthird*trAt;
- At23L = At23L - gt23L*kthird*trAt;
+ CCTK_REAL const At23rhsL = At23L - gt23L*kthird*trAt;
- At33L = At33L - gt33L*kthird*trAt;
+ CCTK_REAL const At33rhsL = At33L - gt33L*kthird*trAt;
- alphaL = fmax(alphaL,MinimumLapse);
+ CCTK_REAL const alpharhsL = fmax(alphaL,MinimumLapse);
/* Copy local copies back to grid functions */
- alpha[index] = alphaL;
- At11[index] = At11L;
- At12[index] = At12L;
- At13[index] = At13L;
- At22[index] = At22L;
- At23[index] = At23L;
- At33[index] = At33L;
+ alpharhs[index] = alpharhsL;
+ At11rhs[index] = At11rhsL;
+ At12rhs[index] = At12rhsL;
+ At13rhs[index] = At13rhsL;
+ At22rhs[index] = At22rhsL;
+ At23rhs[index] = At23rhsL;
+ At33rhs[index] = At33rhsL;
/* Copy local copies back to subblock grid functions */
}
diff --git a/ML_BSSN/src/ML_BSSN_enforce2.c b/ML_BSSN/src/ML_BSSN_enforce2.c
new file mode 100644
index 0000000..348c0da
--- /dev/null
+++ b/ML_BSSN/src/ML_BSSN_enforce2.c
@@ -0,0 +1,164 @@
+/* File produced by Kranc */
+
+#define KRANC_C
+
+#include <assert.h>
+#include <math.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include "cctk.h"
+#include "cctk_Arguments.h"
+#include "cctk_Parameters.h"
+#include "GenericFD.h"
+#include "Differencing.h"
+#include "loopcontrol.h"
+
+/* Define macros used in calculations */
+#define INITVALUE (42)
+#define INV(x) ((1.0) / (x))
+#define SQR(x) ((x) * (x))
+#define CUB(x) ((x) * (x) * (x))
+#define QAD(x) ((x) * (x) * (x) * (x))
+
+void ML_BSSN_enforce2_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
+{
+ DECLARE_CCTK_ARGUMENTS;
+ DECLARE_CCTK_PARAMETERS;
+
+
+ /* Declare finite differencing variables */
+
+ /* Declare predefined quantities */
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
+
+ if (verbose > 1)
+ {
+ CCTK_VInfo(CCTK_THORNSTRING,"Entering ML_BSSN_enforce2_Body");
+ }
+
+ if (cctk_iteration % ML_BSSN_enforce2_calc_every != ML_BSSN_enforce2_calc_offset)
+ {
+ return;
+ }
+
+ /* Include user-supplied include files */
+
+ /* Initialise finite differencing variables */
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
+
+ /* Initialize predefined quantities */
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
+
+ /* Loop over the grid points */
+ #pragma omp parallel
+ LC_LOOP3 (ML_BSSN_enforce2,
+ i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
+ cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
+ {
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+
+ /* Declare shorthands */
+
+ /* Declare local copies of grid functions */
+ // CCTK_REAL alphaL = INITVALUE, alpharhsL = INITVALUE;
+ // CCTK_REAL At11L = INITVALUE, At11rhsL = INITVALUE, At12L = INITVALUE, At12rhsL = INITVALUE, At13L = INITVALUE, At13rhsL = INITVALUE;
+ // CCTK_REAL At22L = INITVALUE, At22rhsL = INITVALUE, At23L = INITVALUE, At23rhsL = INITVALUE, At33L = INITVALUE, At33rhsL = INITVALUE;
+ /* Declare precomputed derivatives*/
+
+ /* Declare derivatives */
+
+ /* Assign local copies of grid functions */
+ CCTK_REAL const alpharhsL = alpharhs[index];
+ CCTK_REAL const At11rhsL = At11rhs[index];
+ CCTK_REAL const At12rhsL = At12rhs[index];
+ CCTK_REAL const At13rhsL = At13rhs[index];
+ CCTK_REAL const At22rhsL = At22rhs[index];
+ CCTK_REAL const At23rhsL = At23rhs[index];
+ CCTK_REAL const At33rhsL = At33rhs[index];
+
+ /* Assign local copies of subblock grid functions */
+
+ /* Include user supplied include files */
+
+ /* Precompute derivatives (new style) */
+
+ /* Precompute derivatives (old style) */
+
+ /* Calculate temporaries and grid functions */
+ CCTK_REAL const At11L = At11rhsL;
+
+ CCTK_REAL const At12L = At12rhsL;
+
+ CCTK_REAL const At13L = At13rhsL;
+
+ CCTK_REAL const At22L = At22rhsL;
+
+ CCTK_REAL const At23L = At23rhsL;
+
+ CCTK_REAL const At33L = At33rhsL;
+
+ CCTK_REAL const alphaL = alpharhsL;
+
+
+ /* Copy local copies back to grid functions */
+ alpha[index] = alphaL;
+ At11[index] = At11L;
+ At12[index] = At12L;
+ At13[index] = At13L;
+ At22[index] = At22L;
+ At23[index] = At23L;
+ At33[index] = At33L;
+
+ /* Copy local copies back to subblock grid functions */
+ }
+ LC_ENDLOOP3 (ML_BSSN_enforce2);
+}
+
+void ML_BSSN_enforce2(CCTK_ARGUMENTS)
+{
+ DECLARE_CCTK_ARGUMENTS;
+ DECLARE_CCTK_PARAMETERS;
+
+ GenericFD_LoopOverEverything(cctkGH, &ML_BSSN_enforce2_Body);
+}
diff --git a/ML_BSSN/src/ML_BSSN_setBetaDriver.c b/ML_BSSN/src/ML_BSSN_setBetaDriver.c
index 04a369a..2f6a35f 100644
--- a/ML_BSSN/src/ML_BSSN_setBetaDriver.c
+++ b/ML_BSSN/src/ML_BSSN_setBetaDriver.c
@@ -20,32 +20,27 @@
#define CUB(x) ((x) * (x) * (x))
#define QAD(x) ((x) * (x) * (x) * (x))
-void ML_BSSN_setBetaDriver_Body(cGH const * const cctkGH, CCTK_INT const dir, CCTK_INT const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], CCTK_INT const min[3], CCTK_INT const max[3], CCTK_INT const n_subblock_gfs, CCTK_REAL * const subblock_gfs[])
+void ML_BSSN_setBetaDriver_Body(cGH const * restrict const cctkGH, int const dir, int const face, CCTK_REAL const normal[3], CCTK_REAL const tangentA[3], CCTK_REAL const tangentB[3], int const min[3], int const max[3], int const n_subblock_gfs, CCTK_REAL * restrict const subblock_gfs[])
{
DECLARE_CCTK_ARGUMENTS;
DECLARE_CCTK_PARAMETERS;
/* Declare finite differencing variables */
- CCTK_REAL dx = INITVALUE, dy = INITVALUE, dz = INITVALUE;
- CCTK_REAL dxi = INITVALUE, dyi = INITVALUE, dzi = INITVALUE;
- CCTK_REAL khalf = INITVALUE, kthird = INITVALUE, ktwothird = INITVALUE, kfourthird = INITVALUE, keightthird = INITVALUE;
- CCTK_REAL hdxi = INITVALUE, hdyi = INITVALUE, hdzi = INITVALUE;
-
/* Declare predefined quantities */
- CCTK_REAL p1o12dx = INITVALUE;
- CCTK_REAL p1o12dy = INITVALUE;
- CCTK_REAL p1o12dz = INITVALUE;
- CCTK_REAL p1o144dxdy = INITVALUE;
- CCTK_REAL p1o144dxdz = INITVALUE;
- CCTK_REAL p1o144dydz = INITVALUE;
- CCTK_REAL p1odx = INITVALUE;
- CCTK_REAL p1ody = INITVALUE;
- CCTK_REAL p1odz = INITVALUE;
- CCTK_REAL pm1o12dx2 = INITVALUE;
- CCTK_REAL pm1o12dy2 = INITVALUE;
- CCTK_REAL pm1o12dz2 = INITVALUE;
+ // CCTK_REAL p1o12dx = INITVALUE;
+ // CCTK_REAL p1o12dy = INITVALUE;
+ // CCTK_REAL p1o12dz = INITVALUE;
+ // CCTK_REAL p1o144dxdy = INITVALUE;
+ // CCTK_REAL p1o144dxdz = INITVALUE;
+ // CCTK_REAL p1o144dydz = INITVALUE;
+ // CCTK_REAL p1odx = INITVALUE;
+ // CCTK_REAL p1ody = INITVALUE;
+ // CCTK_REAL p1odz = INITVALUE;
+ // CCTK_REAL pm1o12dx2 = INITVALUE;
+ // CCTK_REAL pm1o12dy2 = INITVALUE;
+ // CCTK_REAL pm1o12dz2 = INITVALUE;
if (verbose > 1)
{
@@ -60,34 +55,37 @@ void ML_BSSN_setBetaDriver_Body(cGH const * const cctkGH, CCTK_INT const dir, CC
/* Include user-supplied include files */
/* Initialise finite differencing variables */
- dx = CCTK_DELTA_SPACE(0);
- dy = CCTK_DELTA_SPACE(1);
- dz = CCTK_DELTA_SPACE(2);
- dxi = 1.0 / dx;
- dyi = 1.0 / dy;
- dzi = 1.0 / dz;
- khalf = 0.5;
- kthird = 1/3.0;
- ktwothird = 2.0/3.0;
- kfourthird = 4.0/3.0;
- keightthird = 8.0/3.0;
- hdxi = 0.5 * dxi;
- hdyi = 0.5 * dyi;
- hdzi = 0.5 * dzi;
+ CCTK_REAL const dx = CCTK_DELTA_SPACE(0);
+ CCTK_REAL const dy = CCTK_DELTA_SPACE(1);
+ CCTK_REAL const dz = CCTK_DELTA_SPACE(2);
+ int const di = 1;
+ int const dj = CCTK_GFINDEX3D(cctkGH,0,1,0) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ int const dk = CCTK_GFINDEX3D(cctkGH,0,0,1) - CCTK_GFINDEX3D(cctkGH,0,0,0);
+ CCTK_REAL const dxi = 1.0 / dx;
+ CCTK_REAL const dyi = 1.0 / dy;
+ CCTK_REAL const dzi = 1.0 / dz;
+ CCTK_REAL const khalf = 0.5;
+ CCTK_REAL const kthird = 1/3.0;
+ CCTK_REAL const ktwothird = 2.0/3.0;
+ CCTK_REAL const kfourthird = 4.0/3.0;
+ CCTK_REAL const keightthird = 8.0/3.0;
+ CCTK_REAL const hdxi = 0.5 * dxi;
+ CCTK_REAL const hdyi = 0.5 * dyi;
+ CCTK_REAL const hdzi = 0.5 * dzi;
/* Initialize predefined quantities */
- p1o12dx = INV(dx)/12.;
- p1o12dy = INV(dy)/12.;
- p1o12dz = INV(dz)/12.;
- p1o144dxdy = (INV(dx)*INV(dy))/144.;
- p1o144dxdz = (INV(dx)*INV(dz))/144.;
- p1o144dydz = (INV(dy)*INV(dz))/144.;
- p1odx = INV(dx);
- p1ody = INV(dy);
- p1odz = INV(dz);
- pm1o12dx2 = -pow(dx,-2)/12.;
- pm1o12dy2 = -pow(dy,-2)/12.;
- pm1o12dz2 = -pow(dz,-2)/12.;
+ CCTK_REAL const p1o12dx = INV(dx)/12.;
+ CCTK_REAL const p1o12dy = INV(dy)/12.;
+ CCTK_REAL const p1o12dz = INV(dz)/12.;
+ CCTK_REAL const p1o144dxdy = (INV(dx)*INV(dy))/144.;
+ CCTK_REAL const p1o144dxdz = (INV(dx)*INV(dz))/144.;
+ CCTK_REAL const p1o144dydz = (INV(dy)*INV(dz))/144.;
+ CCTK_REAL const p1odx = INV(dx);
+ CCTK_REAL const p1ody = INV(dy);
+ CCTK_REAL const p1odz = INV(dz);
+ CCTK_REAL const pm1o12dx2 = -pow(dx,-2)/12.;
+ CCTK_REAL const pm1o12dy2 = -pow(dy,-2)/12.;
+ CCTK_REAL const pm1o12dz2 = -pow(dz,-2)/12.;
/* Loop over the grid points */
#pragma omp parallel
@@ -95,23 +93,22 @@ void ML_BSSN_setBetaDriver_Body(cGH const * const cctkGH, CCTK_INT const dir, CC
i,j,k, min[0],min[1],min[2], max[0],max[1],max[2],
cctk_lsh[0],cctk_lsh[1],cctk_lsh[2])
{
- int index = INITVALUE;
- int subblock_index = INITVALUE;
- index = CCTK_GFINDEX3D(cctkGH,i,j,k);
- subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
+ // int index = INITVALUE;
+ // int subblock_index = INITVALUE;
+ int const index = CCTK_GFINDEX3D(cctkGH,i,j,k);
+ int const subblock_index = i - min[0] + (max[0] - min[0]) * (j - min[1] + (max[1]-min[1]) * (k - min[2]));
/* Declare shorthands */
/* Declare local copies of grid functions */
- CCTK_REAL etaL = INITVALUE;
- CCTK_REAL rL = INITVALUE;
+ // CCTK_REAL etaL = INITVALUE;
+ // CCTK_REAL rL = INITVALUE;
/* Declare precomputed derivatives*/
/* Declare derivatives */
/* Assign local copies of grid functions */
- etaL = eta[index];
- rL = r[index];
+ CCTK_REAL const rL = r[index];
/* Assign local copies of subblock grid functions */
@@ -122,7 +119,7 @@ void ML_BSSN_setBetaDriver_Body(cGH const * const cctkGH, CCTK_INT const dir, CC
/* Precompute derivatives (old style) */
/* Calculate temporaries and grid functions */
- etaL = etaL*IfThen(rL > SpatialBetaDriverRadius,SpatialBetaDriverRadius*INV(rL),1);
+ CCTK_REAL const etaL = BetaDriver*IfThen(rL > SpatialBetaDriverRadius,SpatialBetaDriverRadius*INV(rL),1);
/* Copy local copies back to grid functions */
diff --git a/ML_BSSN/src/make.code.defn b/ML_BSSN/src/make.code.defn
index 461adc2..dcab216 100644
--- a/ML_BSSN/src/make.code.defn
+++ b/ML_BSSN/src/make.code.defn
@@ -1,3 +1,3 @@
# File produced by Kranc
-SRCS = Startup.c RegisterMoL.c RegisterSymmetries.c ML_BSSN_Minkowski.c ML_BSSN_convertFromADMBase.c ML_BSSN_convertFromADMBaseGamma.c ML_BSSN_setBetaDriver.c ML_BSSN_RHS.c ML_BSSN_RHSStaticBoundary.c ML_BSSN_RHSRadiativeBoundary.c ML_BSSN_enforce.c ML_BSSN_boundary.c ML_BSSN_convertToADMBase.c ML_BSSN_convertToADMBaseDtLapseShift.c ML_BSSN_convertToADMBaseDtLapseShiftBoundary.c ML_BSSN_convertToADMBaseFakeDtLapseShift.c ML_BSSN_constraints.c ML_BSSN_constraints_boundary.c Boundaries.c
+SRCS = Startup.c RegisterMoL.c RegisterSymmetries.c ML_BSSN_Minkowski.c ML_BSSN_convertFromADMBase.c ML_BSSN_convertFromADMBaseGamma.c ML_BSSN_setBetaDriver.c ML_BSSN_RHS.c ML_BSSN_RHS1.c ML_BSSN_RHS2.c ML_BSSN_RHSStaticBoundary.c ML_BSSN_RHSRadiativeBoundary.c ML_BSSN_enforce.c ML_BSSN_enforce2.c ML_BSSN_boundary.c ML_BSSN_convertToADMBase.c ML_BSSN_convertToADMBaseDtLapseShift.c ML_BSSN_convertToADMBaseDtLapseShiftBoundary.c ML_BSSN_convertToADMBaseFakeDtLapseShift.c ML_BSSN_constraints.c ML_BSSN_constraints_boundary.c Boundaries.c