aboutsummaryrefslogtreecommitdiff
path: root/src/call_derivs2.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/call_derivs2.c')
-rw-r--r--src/call_derivs2.c44
1 files changed, 34 insertions, 10 deletions
diff --git a/src/call_derivs2.c b/src/call_derivs2.c
index 23a5899..cf193c6 100644
--- a/src/call_derivs2.c
+++ b/src/call_derivs2.c
@@ -41,6 +41,15 @@ void DiffGv2 ( const CCTK_POINTER_TO_CONST cctkGH_, const CCTK_INT dir,
const CCTK_INT *gsize,
const CCTK_REAL *delta,
CCTK_REAL *dvar2);
+ void CCTK_FCALL CCTK_FNAME(deriv2_gf_4_2_opt)(const CCTK_REAL *var,
+ const CCTK_INT *ni,
+ const CCTK_INT *nj,
+ const CCTK_INT *nk,
+ const CCTK_INT *dir,
+ const CCTK_INT *bb,
+ const CCTK_INT *gsize,
+ const CCTK_REAL *delta,
+ CCTK_REAL *dvar2);
ni = cctk_lsh[0]; nj = cctk_lsh[1]; nk = cctk_lsh[2];
@@ -85,17 +94,32 @@ void DiffGv2 ( const CCTK_POINTER_TO_CONST cctkGH_, const CCTK_INT dir,
}
if ( CCTK_Equals(norm_type,"Diagonal") ) {
- switch(loc_order) {
- case 2: {
- CCTK_FNAME(deriv2_gf_2_1)(var,&ni,&nj,&nk,&dir,bb,&gsize,&delta,dvar2);
- break;
- }
- case 4: {
- CCTK_FNAME(deriv2_gf_4_2)(var,&ni,&nj,&nk,&dir,bb,&gsize,&delta,dvar2);
- break;
- }
- default:
+ if ( CCTK_Equals(operator_type,"Minimal Bandwidth") ) {
+ switch(loc_order) {
+ case 2: {
+ CCTK_FNAME(deriv2_gf_2_1)(var,&ni,&nj,&nk,&dir,bb,&gsize,&delta,dvar2);
+ break;
+ }
+ case 4: {
+ CCTK_FNAME(deriv2_gf_4_2)(var,&ni,&nj,&nk,&dir,bb,&gsize,&delta,dvar2);
+ break;
+ }
+ default:
CCTK_WARN (0, "Unknown 2nd derivative stencil specified");
+ }
+ } else {
+ switch(loc_order) {
+ case 2: {
+ CCTK_FNAME(deriv2_gf_2_1)(var,&ni,&nj,&nk,&dir,bb,&gsize,&delta,dvar2);
+ break;
+ }
+ case 4: {
+ CCTK_FNAME(deriv2_gf_4_2_opt)(var,&ni,&nj,&nk,&dir,bb,&gsize,&delta,dvar2);
+ break;
+ }
+ default:
+ CCTK_WARN (0, "Unknown stencil specified");
+ }
}
} else {
switch(loc_order) {