--- MITgcm/model/inc/CPP_OPTIONS.h 2007/07/22 23:51:15 1.41 +++ MITgcm/model/inc/CPP_OPTIONS.h 2012/08/01 14:02:11 1.49 @@ -1,4 +1,4 @@ -C $Header: /home/ubuntu/mnt/e9_copy/MITgcm/model/inc/CPP_OPTIONS.h,v 1.41 2007/07/22 23:51:15 dimitri Exp $ +C $Header: /home/ubuntu/mnt/e9_copy/MITgcm/model/inc/CPP_OPTIONS.h,v 1.49 2012/08/01 14:02:11 jmc Exp $ C $Name: $ #ifndef CPP_OPTIONS_H @@ -10,9 +10,6 @@ C Note: this should be a run-time option #undef SHORTWAVE_HEATING -C o Include/exclude Duffy et al. (GRL 1999) salt plume scheme -#undef ALLOW_SALT_PLUME - C o Include/exclude phi_hyd calculation code #define INCLUDE_PHIHYD_CALCULATION_CODE @@ -25,26 +22,35 @@ C o Allow latitudinally varying BryanLewis79 vertical diffusivity #undef ALLOW_BL79_LAT_VARY -C o Allow full 3D specification of vertical diffusivity -#undef ALLOW_3D_DIFFKR - C o Include/exclude Implicit vertical advection code #define INCLUDE_IMPLVERTADV_CODE C o Include/exclude AdamsBashforth-3rd-Order code #undef ALLOW_ADAMSBASHFORTH_3 +C o Include/exclude code for single reduction Conjugate-Gradient solver +#define ALLOW_SRCG + C o Include/exclude nonHydrostatic code #undef ALLOW_NONHYDROSTATIC C o Include pressure loading code #define ATMOSPHERIC_LOADING -C o exclude/allow external forcing-fields load +C o exclude/allow external forcing-fields load C this allows to read & do simple linear time interpolation of oceanic C forcing fields, if no specific pkg (e.g., EXF) is used to compute them. #undef EXCLUDE_FFIELDS_LOAD +C o Include/exclude balancing surface forcing fluxes code +#undef ALLOW_BALANCE_FLUXES + +C o Include/exclude balancing surface forcing relaxation code +#undef ALLOW_BALANCE_RELAX + +C o Include/exclude GM-like eddy stress in momentum code +#undef ALLOW_EDDYPSI + C o Use "Exact Convervation" of fluid in Free-Surface formulation C so that d/dt(eta) is exactly equal to - Div.Transport #define EXACT_CONSERV @@ -53,6 +59,16 @@ C this implies that surface thickness (hFactors) vary with time #undef NONLIN_FRSURF +C o Allow mass source or sink of Fluid in the interior +C (3-D generalisation of oceanic real-fresh water flux) +#undef ALLOW_ADDFLUID + +C o Choices for implicit solver routines solve_*diagonal.F +C The following has low memory footprint, but not suitable for AD +#undef SOLVE_DIAGONAL_LOWMEMORY +C The following one suitable for AD but does not vectorize +#undef SOLVE_DIAGONAL_KINNER + C o ALLOW isotropic scaling of harmonic and bi-harmonic terms when C using an locally isotropic spherical grid with (dlambda) x (dphi*cos(phi)) C *only for use on a lat-lon grid* @@ -89,15 +105,23 @@ C o Execution environment support options #include "CPP_EEOPTIONS.h" -C o Include/exclude code specific to the ECCO/SEALION version. -C AUTODIFF or EXF package. -C Currently controled by a single header file -C For this to work, PACKAGES_CONFIG.h needs to be included! -cph#if (defined (ALLOW_AUTODIFF) || \ -cph defined (ALLOW_ECCO) || \ -cph defined (ALLOW_EXF)) -cph# include "ECCO_CPPOPTIONS.h" -cph#endif +C o Include/exclude single header file containing multiple packages options +C (AUTODIFF, COST, CTRL, ECCO, EXF ...) instead of the standard way where +C each of the above pkg get its own options from its specific option file. +C Although this method, inherited from ECCO setup, has been traditionally +C used for all adjoint built, the alternative standard way is currently +C going through rehabilitation. +c#include "ECCO_CPPOPTIONS.h" + +C o Allow full 3D specification of vertical diffusivity +#ifdef ALLOW_DIFFKR_CONTROL +C - Need to be defined if using DIFFKR_CONTROL +C (alternatively, could have put this in ECCO_CPPOPTIONS) +#define ALLOW_3D_DIFFKR +#else +C - otherwise, can be turned on or off hereafter: +#undef ALLOW_3D_DIFFKR +#endif /* ALLOW_DIFFKR_CONTROL */ #endif /* CPP_OPTIONS_H */