C $Header: /u/gcmpack/MITgcm/pkg/autodiff/autodiff_init_varia.F,v 1.2 2015/12/28 17:00:13 gforget Exp $ C $Name: $ #include "AUTODIFF_OPTIONS.h" #ifdef ALLOW_CTRL # include "CTRL_OPTIONS.h" #endif CBOP C !ROUTINE: AUTODIFF_INIT_VARIA C !INTERFACE: SUBROUTINE AUTODIFF_INIT_VARIA( myThid ) C !DESCRIPTION: \bv C *==========================================================* C | SUBROUTINE AUTODIFF_INIT_VARIA C | o Initialise to zero some active arrays C *==========================================================* C \ev C !USES: IMPLICIT NONE C === Global variables === #include "SIZE.h" #include "EEPARAMS.h" #include "PARAMS.h" #include "FFIELDS.h" #include "SURFACE.h" C !INPUT/OUTPUT PARAMETERS: C == Routine arguments == C myThid :: My Thread Id number INTEGER myThid #ifdef ALLOW_AUTODIFF C !LOCAL VARIABLES: C == Local variables == C bi,bj :: tile indices C i,j,k :: Loop counters INTEGER bi, bj INTEGER i, j, k CEOP C-- Scalar fields TsurfCor = 0. _d 0 SsurfCor = 0. _d 0 C-- Over all tiles DO bj = myByLo(myThid), myByHi(myThid) DO bi = myBxLo(myThid), myBxHi(myThid) C- 3D arrays #ifdef ALLOW_EP_FLUX DO k=1,Nr DO j=1-Oly,sNy+Oly DO i=1-Olx,sNx+Olx EfluxY(i,j,k,bi,bj) = 0. EfluxP(i,j,k,bi,bj) = 0. ENDDO ENDDO ENDDO #endif #if (defined (ALLOW_AUTODIFF_INIT_OLD) && defined (ECCO_CTRL_DEPRECATED)) C- 2D arrays DO j=1-Oly,sNy+Oly DO i=1-Olx,sNx+Olx #ifdef EXACT_CONSERV dEtaHdt(i,j,bi,bj) = 0. _d 0 PmEpR(i,j,bi,bj) = 0. _d 0 cph hDivFlow(i,j,bi,bj) = 0. _d 0 #endif #ifdef ALLOW_EXF EmPmR(i,j,bi,bj) = 0. _d 0 #endif ENDDO ENDDO #endif ENDDO ENDDO #endif /* ALLOW_AUTODIFF */ RETURN END