New URL for NEMO forge!   http://forge.nemo-ocean.eu

Since March 2022 along with NEMO 4.2 release, the code development moved to a self-hosted GitLab.
This present forge is now archived and remained online for history.
Changeset 6060 for branches/2015/dev_merge_2015/NEMOGCM/NEMO/OPA_SRC/DYN/dynhpg.F90 – NEMO

Ignore:
Timestamp:
2015-12-16T10:25:22+01:00 (8 years ago)
Author:
timgraham
Message:

Merged dev_r5836_noc2_VVL_BY_DEFAULT into branch

File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/2015/dev_merge_2015/NEMOGCM/NEMO/OPA_SRC/DYN/dynhpg.F90

    r5930 r6060  
    5252   PUBLIC   dyn_hpg_init   ! routine called by opa module 
    5353 
    54    !                                    !!* Namelist namdyn_hpg : hydrostatic pressure gradient 
    55    LOGICAL , PUBLIC ::   ln_hpg_zco      !: z-coordinate - full steps 
    56    LOGICAL , PUBLIC ::   ln_hpg_zps      !: z-coordinate - partial steps (interpolation) 
    57    LOGICAL , PUBLIC ::   ln_hpg_sco      !: s-coordinate (standard jacobian formulation) 
    58    LOGICAL , PUBLIC ::   ln_hpg_djc      !: s-coordinate (Density Jacobian with Cubic polynomial) 
    59    LOGICAL , PUBLIC ::   ln_hpg_prj      !: s-coordinate (Pressure Jacobian scheme) 
    60    LOGICAL , PUBLIC ::   ln_hpg_isf      !: s-coordinate similar to sco modify for isf 
     54   !                                 !!* Namelist namdyn_hpg : hydrostatic pressure gradient 
     55   LOGICAL , PUBLIC ::   ln_hpg_zco   !: z-coordinate - full steps 
     56   LOGICAL , PUBLIC ::   ln_hpg_zps   !: z-coordinate - partial steps (interpolation) 
     57   LOGICAL , PUBLIC ::   ln_hpg_sco   !: s-coordinate (standard jacobian formulation) 
     58   LOGICAL , PUBLIC ::   ln_hpg_djc   !: s-coordinate (Density Jacobian with Cubic polynomial) 
     59   LOGICAL , PUBLIC ::   ln_hpg_prj   !: s-coordinate (Pressure Jacobian scheme) 
     60   LOGICAL , PUBLIC ::   ln_hpg_isf   !: s-coordinate similar to sco modify for isf 
    6161 
    6262   INTEGER , PUBLIC ::   nhpg  =  0   ! = 0 to 7, type of pressure gradient scheme used ! (deduced from ln_hpg_... flags) (PUBLIC for TAM) 
    6363 
    6464   !! * Substitutions 
    65 #  include "domzgr_substitute.h90" 
    6665#  include "vectopt_loop_substitute.h90" 
    6766   !!---------------------------------------------------------------------- 
     
    137136      REWIND( numnam_ref )              ! Namelist namdyn_hpg in reference namelist : Hydrostatic pressure gradient 
    138137      READ  ( numnam_ref, namdyn_hpg, IOSTAT = ios, ERR = 901) 
    139 901   IF( ios /= 0 ) CALL ctl_nam ( ios , 'namdyn_hpg in reference namelist', lwp ) 
    140  
     138901   IF( ios /= 0 )   CALL ctl_nam ( ios , 'namdyn_hpg in reference namelist', lwp ) 
     139      ! 
    141140      REWIND( numnam_cfg )              ! Namelist namdyn_hpg in configuration namelist : Hydrostatic pressure gradient 
    142141      READ  ( numnam_cfg, namdyn_hpg, IOSTAT = ios, ERR = 902 ) 
    143 902   IF( ios /= 0 ) CALL ctl_nam ( ios , 'namdyn_hpg in configuration namelist', lwp ) 
     142902   IF( ios /= 0 )   CALL ctl_nam ( ios , 'namdyn_hpg in configuration namelist', lwp ) 
    144143      IF(lwm) WRITE ( numond, namdyn_hpg ) 
    145144      ! 
     
    162161                           & either  ln_hpg_sco or  ln_hpg_prj instead') 
    163162      ! 
    164       IF( lk_vvl .AND. .NOT. (ln_hpg_sco.OR.ln_hpg_prj.OR.ln_hpg_isf) )   & 
    165          &   CALL ctl_stop('dyn_hpg_init : variable volume key_vvl requires:& 
    166                            & the standard jacobian formulation hpg_sco or & 
    167                            & the pressure jacobian formulation hpg_prj') 
     163      IF( .NOT.ln_linssh .AND. .NOT.(ln_hpg_sco.OR.ln_hpg_prj.OR.ln_hpg_isf) )        & 
     164         &   CALL ctl_stop('dyn_hpg_init : non-linear free surface requires either ', & 
     165         &                 '   the standard jacobian formulation hpg_sco    or '    , & 
     166         &                 '   the pressure jacobian formulation hpg_prj'            ) 
    168167 
    169168      IF(       ln_hpg_isf .AND. .NOT. ln_isfcav )   & 
     
    213212      !!---------------------------------------------------------------------- 
    214213      INTEGER, INTENT(in) ::   kt    ! ocean time-step index 
    215       !! 
     214      ! 
    216215      INTEGER  ::   ji, jj, jk       ! dummy loop indices 
    217216      REAL(wp) ::   zcoef0, zcoef1   ! temporary scalars 
     
    219218      !!---------------------------------------------------------------------- 
    220219      ! 
    221       CALL wrk_alloc( jpi,jpj,jpk, zhpi, zhpj ) 
     220      CALL wrk_alloc( jpi,jpj,jpk,   zhpi, zhpj ) 
    222221      ! 
    223222      IF( kt == nit000 ) THEN 
     
    232231      DO jj = 2, jpjm1 
    233232         DO ji = fs_2, fs_jpim1   ! vector opt. 
    234             zcoef1 = zcoef0 * fse3w(ji,jj,1) 
     233            zcoef1 = zcoef0 * e3w_n(ji,jj,1) 
    235234            ! hydrostatic pressure gradient 
    236             zhpi(ji,jj,1) = zcoef1 * ( rhd(ji+1,jj,1) - rhd(ji,jj,1) ) / e1u(ji,jj) 
    237             zhpj(ji,jj,1) = zcoef1 * ( rhd(ji,jj+1,1) - rhd(ji,jj,1) ) / e2v(ji,jj) 
     235            zhpi(ji,jj,1) = zcoef1 * ( rhd(ji+1,jj,1) - rhd(ji,jj,1) ) * r1_e1u(ji,jj) 
     236            zhpj(ji,jj,1) = zcoef1 * ( rhd(ji,jj+1,1) - rhd(ji,jj,1) ) * r1_e2v(ji,jj) 
    238237            ! add to the general momentum trend 
    239238            ua(ji,jj,1) = ua(ji,jj,1) + zhpi(ji,jj,1) 
     
    247246         DO jj = 2, jpjm1 
    248247            DO ji = fs_2, fs_jpim1   ! vector opt. 
    249                zcoef1 = zcoef0 * fse3w(ji,jj,jk) 
     248               zcoef1 = zcoef0 * e3w_n(ji,jj,jk) 
    250249               ! hydrostatic pressure gradient 
    251250               zhpi(ji,jj,jk) = zhpi(ji,jj,jk-1)   & 
    252                   &           + zcoef1 * (  ( rhd(ji+1,jj,jk)+rhd(ji+1,jj,jk-1) )   & 
    253                   &                       - ( rhd(ji  ,jj,jk)+rhd(ji  ,jj,jk-1) )  ) / e1u(ji,jj) 
     251                  &           + zcoef1 * (  ( rhd(ji+1,jj,jk)+rhd(ji+1,jj,jk-1) )    & 
     252                  &                       - ( rhd(ji  ,jj,jk)+rhd(ji  ,jj,jk-1) )  ) * r1_e1u(ji,jj) 
    254253 
    255254               zhpj(ji,jj,jk) = zhpj(ji,jj,jk-1)   & 
    256                   &           + zcoef1 * (  ( rhd(ji,jj+1,jk)+rhd(ji,jj+1,jk-1) )   & 
    257                   &                       - ( rhd(ji,jj,  jk)+rhd(ji,jj  ,jk-1) )  ) / e2v(ji,jj) 
     255                  &           + zcoef1 * (  ( rhd(ji,jj+1,jk)+rhd(ji,jj+1,jk-1) )    & 
     256                  &                       - ( rhd(ji,jj,  jk)+rhd(ji,jj  ,jk-1) )  ) * r1_e2v(ji,jj) 
    258257               ! add to the general momentum trend 
    259258               ua(ji,jj,jk) = ua(ji,jj,jk) + zhpi(ji,jj,jk) 
     
    263262      END DO 
    264263      ! 
    265       CALL wrk_dealloc( jpi,jpj,jpk, zhpi, zhpj ) 
     264      CALL wrk_dealloc( jpi,jpj,jpk,   zhpi, zhpj ) 
    266265      ! 
    267266   END SUBROUTINE hpg_zco 
     
    284283      !!---------------------------------------------------------------------- 
    285284      ! 
    286       CALL wrk_alloc( jpi,jpj,jpk, zhpi, zhpj ) 
     285      CALL wrk_alloc( jpi,jpj,jpk,   zhpi, zhpj ) 
    287286      ! 
    288287      IF( kt == nit000 ) THEN 
     
    301300      DO jj = 2, jpjm1 
    302301         DO ji = fs_2, fs_jpim1   ! vector opt. 
    303             zcoef1 = zcoef0 * fse3w(ji,jj,1) 
     302            zcoef1 = zcoef0 * e3w_n(ji,jj,1) 
    304303            ! hydrostatic pressure gradient 
    305             zhpi(ji,jj,1) = zcoef1 * ( rhd(ji+1,jj  ,1) - rhd(ji,jj,1) ) / e1u(ji,jj) 
    306             zhpj(ji,jj,1) = zcoef1 * ( rhd(ji  ,jj+1,1) - rhd(ji,jj,1) ) / e2v(ji,jj) 
     304            zhpi(ji,jj,1) = zcoef1 * ( rhd(ji+1,jj  ,1) - rhd(ji,jj,1) ) * r1_e1u(ji,jj) 
     305            zhpj(ji,jj,1) = zcoef1 * ( rhd(ji  ,jj+1,1) - rhd(ji,jj,1) ) * r1_e2v(ji,jj) 
    307306            ! add to the general momentum trend 
    308307            ua(ji,jj,1) = ua(ji,jj,1) + zhpi(ji,jj,1) 
     
    310309         END DO 
    311310      END DO 
    312  
    313311 
    314312      ! interior value (2=<jk=<jpkm1) 
     
    316314         DO jj = 2, jpjm1 
    317315            DO ji = fs_2, fs_jpim1   ! vector opt. 
    318                zcoef1 = zcoef0 * fse3w(ji,jj,jk) 
     316               zcoef1 = zcoef0 * e3w_n(ji,jj,jk) 
    319317               ! hydrostatic pressure gradient 
    320318               zhpi(ji,jj,jk) = zhpi(ji,jj,jk-1)   & 
    321319                  &           + zcoef1 * (  ( rhd(ji+1,jj,jk) + rhd(ji+1,jj,jk-1) )   & 
    322                   &                       - ( rhd(ji  ,jj,jk) + rhd(ji  ,jj,jk-1) )  ) / e1u(ji,jj) 
     320                  &                       - ( rhd(ji  ,jj,jk) + rhd(ji  ,jj,jk-1) )  ) * r1_e1u(ji,jj) 
    323321 
    324322               zhpj(ji,jj,jk) = zhpj(ji,jj,jk-1)   & 
    325323                  &           + zcoef1 * (  ( rhd(ji,jj+1,jk) + rhd(ji,jj+1,jk-1) )   & 
    326                   &                       - ( rhd(ji,jj,  jk) + rhd(ji,jj  ,jk-1) )  ) / e2v(ji,jj) 
     324                  &                       - ( rhd(ji,jj,  jk) + rhd(ji,jj  ,jk-1) )  ) * r1_e2v(ji,jj) 
    327325               ! add to the general momentum trend 
    328326               ua(ji,jj,jk) = ua(ji,jj,jk) + zhpi(ji,jj,jk) 
     
    331329         END DO 
    332330      END DO 
    333  
    334331 
    335332      ! partial steps correction at the last level  (use gru & grv computed in zpshde.F90) 
     
    338335            iku = mbku(ji,jj) 
    339336            ikv = mbkv(ji,jj) 
    340             zcoef2 = zcoef0 * MIN( fse3w(ji,jj,iku), fse3w(ji+1,jj  ,iku) ) 
    341             zcoef3 = zcoef0 * MIN( fse3w(ji,jj,ikv), fse3w(ji  ,jj+1,ikv) ) 
     337            zcoef2 = zcoef0 * MIN( e3w_n(ji,jj,iku), e3w_n(ji+1,jj  ,iku) ) 
     338            zcoef3 = zcoef0 * MIN( e3w_n(ji,jj,ikv), e3w_n(ji  ,jj+1,ikv) ) 
    342339            IF( iku > 1 ) THEN            ! on i-direction (level 2 or more) 
    343340               ua  (ji,jj,iku) = ua(ji,jj,iku) - zhpi(ji,jj,iku)         ! subtract old value 
    344341               zhpi(ji,jj,iku) = zhpi(ji,jj,iku-1)                   &   ! compute the new one 
    345                   &            + zcoef2 * ( rhd(ji+1,jj,iku-1) - rhd(ji,jj,iku-1) + gru(ji,jj) ) / e1u(ji,jj) 
     342                  &            + zcoef2 * ( rhd(ji+1,jj,iku-1) - rhd(ji,jj,iku-1) + gru(ji,jj) ) * r1_e1u(ji,jj) 
    346343               ua  (ji,jj,iku) = ua(ji,jj,iku) + zhpi(ji,jj,iku)         ! add the new one to the general momentum trend 
    347344            ENDIF 
     
    349346               va  (ji,jj,ikv) = va(ji,jj,ikv) - zhpj(ji,jj,ikv)         ! subtract old value 
    350347               zhpj(ji,jj,ikv) = zhpj(ji,jj,ikv-1)                   &   ! compute the new one 
    351                   &            + zcoef3 * ( rhd(ji,jj+1,ikv-1) - rhd(ji,jj,ikv-1) + grv(ji,jj) ) / e2v(ji,jj) 
     348                  &            + zcoef3 * ( rhd(ji,jj+1,ikv-1) - rhd(ji,jj,ikv-1) + grv(ji,jj) ) * r1_e2v(ji,jj) 
    352349               va  (ji,jj,ikv) = va(ji,jj,ikv) + zhpj(ji,jj,ikv)         ! add the new one to the general momentum trend 
    353350            ENDIF 
     
    355352      END DO 
    356353      ! 
    357       CALL wrk_dealloc( jpi,jpj,jpk, zhpi, zhpj ) 
     354      CALL wrk_dealloc( jpi,jpj,jpk,   zhpi, zhpj ) 
    358355      ! 
    359356   END SUBROUTINE hpg_zps 
     357 
    360358 
    361359   SUBROUTINE hpg_sco( kt ) 
     
    391389         IF(lwp) WRITE(numout,*) '~~~~~~~~~~~   s-coordinate case, OPA original scheme used' 
    392390      ENDIF 
    393  
    394       ! Local constant initialization 
     391      ! 
    395392      zcoef0 = - grav * 0.5_wp 
    396       ! To use density and not density anomaly 
    397       IF ( lk_vvl ) THEN   ;     znad = 1._wp          ! Variable volume 
    398       ELSE                 ;     znad = 0._wp         ! Fixed volume 
     393      IF ( ln_linssh ) THEN   ;   znad = 0._wp         ! Fixed    volume: density anomaly 
     394      ELSE                    ;   znad = 1._wp         ! Variable volume: density 
    399395      ENDIF 
    400  
     396      ! 
    401397      ! Surface value 
    402398      DO jj = 2, jpjm1 
    403399         DO ji = fs_2, fs_jpim1   ! vector opt. 
    404400            ! hydrostatic pressure gradient along s-surfaces 
    405             zhpi(ji,jj,1) = zcoef0 / e1u(ji,jj) * ( fse3w(ji+1,jj  ,1) * ( znad + rhd(ji+1,jj  ,1) )   & 
    406                &                                  - fse3w(ji  ,jj  ,1) * ( znad + rhd(ji  ,jj  ,1) ) ) 
    407             zhpj(ji,jj,1) = zcoef0 / e2v(ji,jj) * ( fse3w(ji  ,jj+1,1) * ( znad + rhd(ji  ,jj+1,1) )   & 
    408                &                                  - fse3w(ji  ,jj  ,1) * ( znad + rhd(ji  ,jj  ,1) ) ) 
     401            zhpi(ji,jj,1) = zcoef0 * (  e3w_n(ji+1,jj  ,1) * ( znad + rhd(ji+1,jj  ,1) )    & 
     402               &                      - e3w_n(ji  ,jj  ,1) * ( znad + rhd(ji  ,jj  ,1) )  ) * r1_e1u(ji,jj) 
     403            zhpj(ji,jj,1) = zcoef0 * (  e3w_n(ji  ,jj+1,1) * ( znad + rhd(ji  ,jj+1,1) )    & 
     404               &                      - e3w_n(ji  ,jj  ,1) * ( znad + rhd(ji  ,jj  ,1) )  ) * r1_e2v(ji,jj) 
    409405            ! s-coordinate pressure gradient correction 
    410             zuap = -zcoef0 * ( rhd   (ji+1,jj,1) + rhd   (ji,jj,1) + 2._wp * znad )   & 
    411                &           * ( fsde3w(ji+1,jj,1) - fsde3w(ji,jj,1) ) / e1u(ji,jj) 
    412             zvap = -zcoef0 * ( rhd   (ji,jj+1,1) + rhd   (ji,jj,1) + 2._wp * znad )   & 
    413                &           * ( fsde3w(ji,jj+1,1) - fsde3w(ji,jj,1) ) / e2v(ji,jj) 
     406            zuap = -zcoef0 * ( rhd    (ji+1,jj,1) + rhd    (ji,jj,1) + 2._wp * znad )   & 
     407               &           * ( gde3w_n(ji+1,jj,1) - gde3w_n(ji,jj,1) ) * r1_e1u(ji,jj) 
     408            zvap = -zcoef0 * ( rhd    (ji,jj+1,1) + rhd    (ji,jj,1) + 2._wp * znad )   & 
     409               &           * ( gde3w_n(ji,jj+1,1) - gde3w_n(ji,jj,1) ) * r1_e2v(ji,jj) 
    414410            ! add to the general momentum trend 
    415411            ua(ji,jj,1) = ua(ji,jj,1) + zhpi(ji,jj,1) + zuap 
     
    423419            DO ji = fs_2, fs_jpim1   ! vector opt. 
    424420               ! hydrostatic pressure gradient along s-surfaces 
    425                zhpi(ji,jj,jk) = zhpi(ji,jj,jk-1) + zcoef0 / e1u(ji,jj)   & 
    426                   &           * (  fse3w(ji+1,jj,jk) * ( rhd(ji+1,jj,jk) + rhd(ji+1,jj,jk-1) + 2*znad )   & 
    427                   &              - fse3w(ji  ,jj,jk) * ( rhd(ji  ,jj,jk) + rhd(ji  ,jj,jk-1) + 2*znad )  ) 
    428                zhpj(ji,jj,jk) = zhpj(ji,jj,jk-1) + zcoef0 / e2v(ji,jj)   & 
    429                   &           * (  fse3w(ji,jj+1,jk) * ( rhd(ji,jj+1,jk) + rhd(ji,jj+1,jk-1) + 2*znad )   & 
    430                   &              - fse3w(ji,jj  ,jk) * ( rhd(ji,jj,  jk) + rhd(ji,jj  ,jk-1) + 2*znad )  ) 
     421               zhpi(ji,jj,jk) = zhpi(ji,jj,jk-1) + zcoef0 * r1_e1u(ji,jj)   & 
     422                  &           * (  e3w_n(ji+1,jj,jk) * ( rhd(ji+1,jj,jk) + rhd(ji+1,jj,jk-1) + 2*znad )   & 
     423                  &              - e3w_n(ji  ,jj,jk) * ( rhd(ji  ,jj,jk) + rhd(ji  ,jj,jk-1) + 2*znad )  ) 
     424               zhpj(ji,jj,jk) = zhpj(ji,jj,jk-1) + zcoef0 * r1_e2v(ji,jj)   & 
     425                  &           * (  e3w_n(ji,jj+1,jk) * ( rhd(ji,jj+1,jk) + rhd(ji,jj+1,jk-1) + 2*znad )   & 
     426                  &              - e3w_n(ji,jj  ,jk) * ( rhd(ji,jj,  jk) + rhd(ji,jj  ,jk-1) + 2*znad )  ) 
    431427               ! s-coordinate pressure gradient correction 
    432                zuap = -zcoef0 * ( rhd   (ji+1,jj  ,jk) + rhd   (ji,jj,jk) + 2._wp * znad )   & 
    433                   &           * ( fsde3w(ji+1,jj  ,jk) - fsde3w(ji,jj,jk) ) / e1u(ji,jj) 
    434                zvap = -zcoef0 * ( rhd   (ji  ,jj+1,jk) + rhd   (ji,jj,jk) + 2._wp * znad )   & 
    435                   &           * ( fsde3w(ji  ,jj+1,jk) - fsde3w(ji,jj,jk) ) / e2v(ji,jj) 
     428               zuap = -zcoef0 * ( rhd    (ji+1,jj  ,jk) + rhd    (ji,jj,jk) + 2._wp * znad )   & 
     429                  &           * ( gde3w_n(ji+1,jj  ,jk) - gde3w_n(ji,jj,jk) ) * r1_e1u(ji,jj) 
     430               zvap = -zcoef0 * ( rhd    (ji  ,jj+1,jk) + rhd    (ji,jj,jk) + 2._wp * znad )   & 
     431                  &           * ( gde3w_n(ji  ,jj+1,jk) - gde3w_n(ji,jj,jk) ) * r1_e2v(ji,jj) 
    436432               ! add to the general momentum trend 
    437433               ua(ji,jj,jk) = ua(ji,jj,jk) + zhpi(ji,jj,jk) + zuap 
     
    444440      ! 
    445441   END SUBROUTINE hpg_sco 
     442 
    446443 
    447444   SUBROUTINE hpg_isf( kt ) 
     
    473470      !!---------------------------------------------------------------------- 
    474471      ! 
    475       CALL wrk_alloc( jpi,jpj, 2, ztstop)  
    476       CALL wrk_alloc( jpi,jpj,jpk, zhpi, zhpj, zrhd) 
    477       CALL wrk_alloc( jpi,jpj, ze3w, zp, zrhdtop_isf, zrhdtop_oce, ziceload, zdept, zpshpi, zpshpj)  
    478       ! 
    479      IF( kt == nit000 ) THEN 
     472      CALL wrk_alloc( jpi,jpj,  2,   ztstop )  
     473      CALL wrk_alloc( jpi,jpj,jpk,   zhpi, zhpj, zrhd) 
     474      CALL wrk_alloc( jpi,jpj,       ze3w, zp, zrhdtop_isf, zrhdtop_oce, ziceload, zdept, zpshpi, zpshpj )  
     475      ! 
     476      IF( kt == nit000 ) THEN 
    480477         IF(lwp) WRITE(numout,*) 
    481478         IF(lwp) WRITE(numout,*) 'dyn:hpg_isf : hydrostatic pressure gradient trend for ice shelf' 
    482479         IF(lwp) WRITE(numout,*) '~~~~~~~~~~~   s-coordinate case, OPA original scheme used' 
    483480      ENDIF 
    484  
    485       ! Local constant initialization 
     481      ! 
    486482      zcoef0 = - grav * 0.5_wp 
    487       ! To use density and not density anomaly 
    488 !      IF ( lk_vvl ) THEN   ;     znad = 1._wp          ! Variable volume 
    489 !      ELSE                 ;     znad = 0._wp         ! Fixed volume 
    490 !      ENDIF 
    491       znad=1._wp 
    492       ! iniitialised to 0. zhpi zhpi  
    493       zhpi(:,:,:)=0._wp ; zhpj(:,:,:)=0._wp 
    494  
    495       ! Partial steps: top & bottom before horizontal gradient 
    496 !jc      CALL zps_hde_isf( kt, jpts, tsn, gtsu, gtsv, gtui, gtvi,   &  
    497 !jc               &       rhd, gru , grv , aru , arv , gzu , gzv , ge3ru , ge3rv ,   & 
    498 !jc               &      grui, grvi, arui, arvi, gzui, gzvi, ge3rui, ge3rvi  ) 
     483      IF( ln_linssh ) THEN   ;   znad = 0._wp      ! Fixed    volume: density anomaly 
     484      ELSE                   ;   znad = 1._wp      ! Variable volume: density 
     485      ENDIF 
     486      zhpi(:,:,:) = 0._wp 
     487      zhpj(:,:,:) = 0._wp 
    499488 
    500489!==================================================================================      
     
    503492 
    504493      ! assume water displaced by the ice shelf is at T=-1.9 and S=34.4 (rude) 
    505       ztstop(:,:,1)=-1.9_wp ; ztstop(:,:,2)=34.4_wp 
     494      ztstop(:,:,jp_tem) = -1.9_wp 
     495      ztstop(:,:,jp_sal) = 34.4_wp 
     496 
     497!!gm I have the feeling that a much simplier and faster computation can be performed... 
     498!!gm     ====>>>>   We have to discuss ! 
     499 
     500!!gm below, faster to compute the ISF density in zrhd and remplace rhd value where tmask=0 
     501!!gm        furthermore, this calculation does not depends on time :  do it at the first time-step only.... 
    506502 
    507503      ! compute density of the water displaced by the ice shelf  
    508       zrhd = rhd ! save rhd 
     504      zrhd(:,:,:) = rhd(:,:,:)    ! save rhd 
    509505      DO jk = 1, jpk 
    510            zdept(:,:)=gdept_1d(jk) 
    511            CALL eos(ztstop(:,:,:),zdept(:,:),rhd(:,:,jk)) 
    512       END DO 
    513       WHERE ( tmask(:,:,:) == 1._wp) 
     506         zdept(:,:) = gdept_1d(jk) 
     507         CALL eos( ztstop(:,:,:), zdept(:,:), rhd(:,:,jk) ) 
     508      END DO 
     509      WHERE( tmask(:,:,:) == 1._wp ) 
    514510        rhd(:,:,:) = zrhd(:,:,:) ! replace wet cell by the saved rhd 
    515511      END WHERE 
    516512       
    517513      ! compute rhd at the ice/oce interface (ice shelf side) 
    518       CALL eos(ztstop,risfdep,zrhdtop_isf) 
     514      CALL eos( ztstop, risfdep, zrhdtop_isf ) 
    519515 
    520516      ! compute rhd at the ice/oce interface (ocean side) 
    521       DO ji=1,jpi 
    522         DO jj=1,jpj 
    523           ikt=mikt(ji,jj) 
    524           ztstop(ji,jj,1)=tsn(ji,jj,ikt,1) 
    525           ztstop(ji,jj,2)=tsn(ji,jj,ikt,2) 
     517      DO ji = 1, jpi 
     518        DO jj = 1, jpj 
     519          ikt = mikt(ji,jj) 
     520          ztstop(ji,jj,jp_tem) = tsn(ji,jj,ikt,jp_tem) 
     521          ztstop(ji,jj,jp_sal) = tsn(ji,jj,ikt,jp_sal) 
    526522        END DO 
    527523      END DO 
    528       CALL eos(ztstop,risfdep,zrhdtop_oce) 
     524      CALL eos( ztstop, risfdep, zrhdtop_oce ) 
    529525      ! 
    530526      ! Surface value + ice shelf gradient 
     
    533529      DO jj = 1, jpj 
    534530         DO ji = 1, jpi   ! vector opt. 
    535             ikt=mikt(ji,jj) 
    536             ziceload(ji,jj) = ziceload(ji,jj) + (znad + rhd(ji,jj,1) ) * fse3w(ji,jj,1) * (1._wp - tmask(ji,jj,1)) 
    537             DO jk=2,ikt-1 
    538                ziceload(ji,jj) = ziceload(ji,jj) + (2._wp * znad + rhd(ji,jj,jk-1) + rhd(ji,jj,jk)) * fse3w(ji,jj,jk) & 
     531            ikt = mikt(ji,jj) 
     532            ziceload(ji,jj) = ziceload(ji,jj) + (znad + rhd(ji,jj,1) ) * e3w_n(ji,jj,1) * (1._wp - tmask(ji,jj,1)) 
     533            DO jk = 2, ikt-1 
     534               ziceload(ji,jj) = ziceload(ji,jj) + (2._wp * znad + rhd(ji,jj,jk-1) + rhd(ji,jj,jk)) * e3w_n(ji,jj,jk) & 
    539535                  &                              * (1._wp - tmask(ji,jj,jk)) 
    540536            END DO 
    541             IF (ikt .GE. 2) ziceload(ji,jj) = ziceload(ji,jj) + (2._wp * znad + zrhdtop_isf(ji,jj) + rhd(ji,jj,ikt-1)) & 
    542                                &                              * ( risfdep(ji,jj) - gdept_1d(ikt-1) ) 
    543          END DO 
    544       END DO 
    545       riceload(:,:) = 0.0_wp ; riceload(:,:)=ziceload(:,:)  ! need to be saved for diaar5 
     537            IF( ikt >= 2 )  ziceload(ji,jj) = ziceload(ji,jj) + (2._wp * znad + zrhdtop_isf(ji,jj) + rhd(ji,jj,ikt-1)) & 
     538               &                                               * ( risfdep(ji,jj) - gdept_1d(ikt-1) ) 
     539         END DO 
     540      END DO 
     541      riceload(:,:) = 0._wp   ;   riceload(:,:) = ziceload(:,:)   ! need to be saved for diaar5 
    546542      ! compute zp from z=0 to first T wet point (correction due to zps not yet applied) 
    547543      DO jj = 2, jpjm1 
    548544         DO ji = fs_2, fs_jpim1   ! vector opt. 
    549             ikt=mikt(ji,jj) ; iktp1i=mikt(ji+1,jj); iktp1j=mikt(ji,jj+1) 
     545            ikt    = mikt(ji,jj) 
     546            iktp1i = mikt(ji+1,jj) 
     547            iktp1j = mikt(ji,jj+1) 
    550548            ! hydrostatic pressure gradient along s-surfaces and ice shelf pressure 
    551549            ! we assume ISF is in isostatic equilibrium 
    552             zhpi(ji,jj,1) = zcoef0 / e1u(ji,jj) * ( 0.5_wp * fse3w(ji+1,jj  ,iktp1i)                                    & 
    553                &                                  * ( 2._wp * znad + rhd(ji+1,jj  ,iktp1i) + zrhdtop_oce(ji+1,jj  ) )   & 
    554                &                                  - 0.5_wp * fse3w(ji  ,jj  ,ikt   )                                    & 
    555                &                                  * ( 2._wp * znad + rhd(ji  ,jj  ,ikt   ) + zrhdtop_oce(ji  ,jj  ) )   & 
    556                &                                  + ( ziceload(ji+1,jj) - ziceload(ji,jj))                              )  
    557             zhpj(ji,jj,1) = zcoef0 / e2v(ji,jj) * ( 0.5_wp * fse3w(ji  ,jj+1,iktp1j)                                    & 
    558                &                                  * ( 2._wp * znad + rhd(ji  ,jj+1,iktp1j) + zrhdtop_oce(ji  ,jj+1) )   & 
    559                &                                  - 0.5_wp * fse3w(ji  ,jj  ,ikt   )                                    &  
    560                &                                  * ( 2._wp * znad + rhd(ji  ,jj  ,ikt   ) + zrhdtop_oce(ji  ,jj  ) )   & 
    561                &                                  + ( ziceload(ji,jj+1) - ziceload(ji,jj) )                             )  
     550            zhpi(ji,jj,1) = zcoef0 * (                                    & 
     551               &            0.5_wp * e3w_n(ji+1,jj,iktp1i) * ( 2._wp * znad + rhd(ji+1,jj,iktp1i) + zrhdtop_oce(ji+1,jj) )   & 
     552               &          - 0.5_wp * e3w_n(ji  ,jj,ikt   ) * ( 2._wp * znad + rhd(ji  ,jj,ikt   ) + zrhdtop_oce(ji  ,jj) )   & 
     553               &          + ( ziceload(ji+1,jj) - ziceload(ji,jj) )       ) * r1_e1u(ji,jj) 
     554            zhpj(ji,jj,1) = zcoef0 * (                                    & 
     555               &            0.5_wp * e3w_n(ji,jj+1,iktp1j) * ( 2._wp * znad + rhd(ji,jj+1,iktp1j) + zrhdtop_oce(ji,jj+1) )   & 
     556               &          - 0.5_wp * e3w_n(ji,jj  ,ikt   ) * ( 2._wp * znad + rhd(ji,jj  ,ikt   ) + zrhdtop_oce(ji,jj  ) )   & 
     557               &          + ( ziceload(ji,jj+1) - ziceload(ji,jj) )       ) * r1_e2v(ji,jj) 
    562558            ! s-coordinate pressure gradient correction (=0 if z coordinate) 
    563             zuap = -zcoef0 * ( rhd   (ji+1,jj,1) + rhd   (ji,jj,1) + 2._wp * znad )   & 
    564                &           * ( fsde3w(ji+1,jj,1) - fsde3w(ji,jj,1) ) / e1u(ji,jj) 
    565             zvap = -zcoef0 * ( rhd   (ji,jj+1,1) + rhd   (ji,jj,1) + 2._wp * znad )   & 
    566                &           * ( fsde3w(ji,jj+1,1) - fsde3w(ji,jj,1) ) / e2v(ji,jj) 
     559            zuap = -zcoef0 * ( rhd    (ji+1,jj,1) + rhd    (ji,jj,1) + 2._wp * znad )   & 
     560               &           * ( gde3w_n(ji+1,jj,1) - gde3w_n(ji,jj,1) ) * r1_e1u(ji,jj) 
     561            zvap = -zcoef0 * ( rhd    (ji,jj+1,1) + rhd    (ji,jj,1) + 2._wp * znad )   & 
     562               &           * ( gde3w_n(ji,jj+1,1) - gde3w_n(ji,jj,1) ) * r1_e2v(ji,jj) 
    567563            ! add to the general momentum trend 
    568564            ua(ji,jj,1) = ua(ji,jj,1) + (zhpi(ji,jj,1) + zuap) * umask(ji,jj,1) 
     
    575571      DO jj = 2, jpjm1 
    576572         DO ji = fs_2, fs_jpim1   ! vector opt. 
    577             iku = miku(ji,jj) ;  
    578             zpshpi(ji,jj)=0.0_wp ; zpshpj(ji,jj)=0.0_wp 
     573            iku = miku(ji,jj) 
     574            zpshpi(ji,jj) = 0._wp 
     575            zpshpj(ji,jj) = 0._wp 
    579576            ze3wu  = (gdepw_0(ji+1,jj,iku+1) - gdept_0(ji+1,jj,iku)) - (gdepw_0(ji,jj,iku+1) - gdept_0(ji,jj,iku)) 
    580577            ! u direction 
    581             IF ( iku .GT. 1 ) THEN 
     578            IF( iku > 1 ) THEN 
    582579               ! case iku 
    583                zhpi(ji,jj,iku)   =  zcoef0 / e1u(ji,jj) * ze3wu                                            & 
    584                       &                                 * ( rhd    (ji+1,jj,iku) + rhd   (ji,jj,iku)       & 
    585                       &                                   + SIGN(1._wp,ze3wu) * grui(ji,jj) + 2._wp * znad ) 
     580               zhpi(ji,jj,iku) = zcoef0 * r1_e1u(ji,jj) * ze3wu                             & 
     581                  &                     * ( rhd(ji+1,jj,iku) + rhd(ji,jj,iku)               & 
     582                  &                        + SIGN(1._wp,ze3wu) * grui(ji,jj) + 2._wp * znad ) 
    586583               ! corrective term ( = 0 if z coordinate ) 
    587                zuap              = -zcoef0 * ( arui(ji,jj) + 2._wp * znad ) * gzui(ji,jj) / e1u(ji,jj) 
     584               zuap = -zcoef0 * ( arui(ji,jj) + 2._wp * znad ) * gzui(ji,jj) * r1_e1u(ji,jj) 
    588585               ! zhpi will be added in interior loop 
    589                ua(ji,jj,iku)     = ua(ji,jj,iku) + zuap 
     586               ua(ji,jj,iku) = ua(ji,jj,iku) + zuap 
    590587               ! in case of 2 cell water column, need to save the pressure gradient to compute the bottom pressure   
    591                IF (mbku(ji,jj) == iku + 1) zpshpi(ji,jj) = zhpi(ji,jj,iku) 
     588               IF( mbku(ji,jj) == iku + 1 )   zpshpi(ji,jj) = zhpi(ji,jj,iku) 
    592589 
    593590               ! case iku + 1 (remove the zphi term added in the interior loop and compute the one corrected for zps) 
    594                zhpiint        =  zcoef0 / e1u(ji,jj)                                                               &     
    595                   &           * (  fse3w(ji+1,jj  ,iku+1) * ( (rhd(ji+1,jj,iku+1) + znad)                          & 
    596                   &                                         + (rhd(ji+1,jj,iku  ) + znad) ) * tmask(ji+1,jj,iku)   & 
    597                   &              - fse3w(ji  ,jj  ,iku+1) * ( (rhd(ji  ,jj,iku+1) + znad)                          & 
    598                   &                                         + (rhd(ji  ,jj,iku  ) + znad) ) * tmask(ji  ,jj,iku)   ) 
    599                zhpi(ji,jj,iku+1) =  zcoef0 / e1u(ji,jj) * ge3rui(ji,jj) - zhpiint  
     591               zhpiint = zcoef0 * r1_e1u(ji,jj)                                                              &     
     592                  &    * (  e3w_n(ji+1,jj  ,iku+1) * ( (rhd(ji+1,jj,iku+1) + znad)                          & 
     593                  &                                   + (rhd(ji+1,jj,iku  ) + znad) ) * tmask(ji+1,jj,iku)   & 
     594                  &       - e3w_n(ji  ,jj  ,iku+1) * ( (rhd(ji  ,jj,iku+1) + znad)                          & 
     595                  &                                   + (rhd(ji  ,jj,iku  ) + znad) ) * tmask(ji  ,jj,iku)   ) 
     596               zhpi(ji,jj,iku+1) = zcoef0 * r1_e1u(ji,jj) * ge3rui(ji,jj) - zhpiint  
    600597            END IF 
    601598                
     
    603600            ikv = mikv(ji,jj) 
    604601            ze3wv  = (gdepw_0(ji,jj+1,ikv+1) - gdept_0(ji,jj+1,ikv)) - (gdepw_0(ji,jj,ikv+1) - gdept_0(ji,jj,ikv)) 
    605             IF ( ikv .GT. 1 ) THEN 
     602            IF( ikv > 1 ) THEN 
    606603               ! case ikv 
    607                zhpj(ji,jj,ikv)   =  zcoef0 / e2v(ji,jj) * ze3wv                                            & 
    608                      &                                  * ( rhd(ji,jj+1,ikv) + rhd   (ji,jj,ikv)           & 
    609                      &                                    + SIGN(1._wp,ze3wv) * grvi(ji,jj) + 2._wp * znad ) 
     604               zhpj(ji,jj,ikv) =  zcoef0 * r1_e2v(ji,jj) * ze3wv                             & 
     605                  &                      * ( rhd(ji,jj+1,ikv) + rhd(ji,jj,ikv)               & 
     606                  &                         + SIGN(1._wp,ze3wv) * grvi(ji,jj) + 2._wp * znad ) 
    610607               ! corrective term ( = 0 if z coordinate ) 
    611                zvap              = -zcoef0 * ( arvi(ji,jj) + 2._wp * znad ) * gzvi(ji,jj) / e2v(ji,jj) 
     608               zvap = -zcoef0 * ( arvi(ji,jj) + 2._wp * znad ) * gzvi(ji,jj) * r1_e2v(ji,jj) 
    612609               ! zhpi will be added in interior loop 
    613                va(ji,jj,ikv)      = va(ji,jj,ikv) + zvap 
     610               va(ji,jj,ikv) = va(ji,jj,ikv) + zvap 
    614611               ! in case of 2 cell water column, need to save the pressure gradient to compute the bottom pressure   
    615                IF (mbkv(ji,jj) == ikv + 1)  zpshpj(ji,jj)  = zhpj(ji,jj,ikv)  
     612               IF( mbkv(ji,jj) == ikv + 1 )   zpshpj(ji,jj) = zhpj(ji,jj,ikv)  
    616613                
    617614               ! case ikv + 1 (remove the zphj term added in the interior loop and compute the one corrected for zps) 
    618                zhpjint        =  zcoef0 / e2v(ji,jj)                                                              & 
    619                   &           * (  fse3w(ji  ,jj+1,ikv+1) * ( (rhd(ji,jj+1,ikv+1) + znad)                         & 
    620                   &                                       + (rhd(ji,jj+1,ikv  ) + znad) ) * tmask(ji,jj+1,ikv)    & 
    621                   &              - fse3w(ji  ,jj  ,ikv+1) * ( (rhd(ji,jj  ,ikv+1) + znad)                         & 
    622                   &                                       + (rhd(ji,jj  ,ikv  ) + znad) ) * tmask(ji,jj  ,ikv)  ) 
    623                zhpj(ji,jj,ikv+1) =  zcoef0 / e2v(ji,jj) * ge3rvi(ji,jj) - zhpjint 
    624             END IF 
     615               zhpjint =  zcoef0 * r1_e2v(ji,jj)                                                            & 
     616                  &    * (  e3w_n(ji  ,jj+1,ikv+1) * ( (rhd(ji,jj+1,ikv+1) + znad)                         & 
     617                  &                                   + (rhd(ji,jj+1,ikv  ) + znad) ) * tmask(ji,jj+1,ikv)  & 
     618                  &       - e3w_n(ji  ,jj  ,ikv+1) * ( (rhd(ji,jj  ,ikv+1) + znad)                         & 
     619                  &                                   + (rhd(ji,jj  ,ikv  ) + znad) ) * tmask(ji,jj  ,ikv)  ) 
     620               zhpj(ji,jj,ikv+1) =  zcoef0 * r1_e2v(ji,jj) * ge3rvi(ji,jj) - zhpjint 
     621            ENDIF 
    625622         END DO 
    626623      END DO 
     
    632629      DO jj = 2, jpjm1 
    633630         DO ji = fs_2, fs_jpim1   ! vector opt. 
    634             iku=miku(ji,jj); ikv=mikv(ji,jj) 
    635631            DO jk = 2, jpkm1 
    636632               ! hydrostatic pressure gradient along s-surfaces 
    637633               ! zhpi is masked for the first wet cell  (contribution already done in the upper bloc) 
    638                zhpi(ji,jj,jk) = zhpi(ji,jj,jk) + zhpi(ji,jj,jk-1)                                                              & 
    639                   &                            + zcoef0 / e1u(ji,jj)                                                           & 
    640                   &                                     * ( fse3w(ji+1,jj  ,jk) * ( (rhd(ji+1,jj,jk  ) + znad)                 & 
    641                   &                                                     + (rhd(ji+1,jj,jk-1) + znad) ) * tmask(ji+1,jj,jk-1)   & 
    642                   &                                       - fse3w(ji  ,jj  ,jk) * ( (rhd(ji  ,jj,jk  ) + znad)                 & 
    643                   &                                                     + (rhd(ji  ,jj,jk-1) + znad) ) * tmask(ji  ,jj,jk-1)   )  
     634               zhpi(ji,jj,jk) = zhpi(ji,jj,jk) + zhpi(ji,jj,jk-1)                                                     & 
     635                  &           + zcoef0 * r1_e1u(ji,jj)                                                                & 
     636                  &                    * ( e3w_n(ji+1,jj,jk) * ( (rhd(ji+1,jj,jk  ) + znad)                           & 
     637                  &                                            + (rhd(ji+1,jj,jk-1) + znad) ) * tmask(ji+1,jj,jk-1)   & 
     638                  &                      - e3w_n(ji  ,jj,jk) * ( (rhd(ji  ,jj,jk  ) + znad)                           & 
     639                  &                                            + (rhd(ji  ,jj,jk-1) + znad) ) * tmask(ji  ,jj,jk-1)   )  
    644640               ! s-coordinate pressure gradient correction 
    645641               ! corrective term, we mask this term for the first wet level beneath the ice shelf (contribution done in the upper bloc)  
    646                zuap = - zcoef0 * ( rhd   (ji+1,jj  ,jk) + rhd   (ji,jj,jk) + 2._wp * znad )                    & 
    647                   &            * ( fsde3w(ji+1,jj  ,jk) - fsde3w(ji,jj,jk) ) / e1u(ji,jj) * umask(ji,jj,jk-1) 
     642               zuap = - zcoef0 * ( rhd    (ji+1,jj  ,jk) + rhd    (ji,jj,jk) + 2._wp * znad )                    & 
     643                  &            * ( gde3w_n(ji+1,jj  ,jk) - gde3w_n(ji,jj,jk) ) * r1_e1u(ji,jj) * umask(ji,jj,jk-1) 
    648644               ua(ji,jj,jk) = ua(ji,jj,jk) + ( zhpi(ji,jj,jk) + zuap) * umask(ji,jj,jk) 
    649645 
    650646               ! hydrostatic pressure gradient along s-surfaces 
    651647               ! zhpi is masked for the first wet cell  (contribution already done in the upper bloc) 
    652                zhpj(ji,jj,jk) = zhpj(ji,jj,jk) + zhpj(ji,jj,jk-1)                                                              & 
    653                   &                            + zcoef0 / e2v(ji,jj)                                                           & 
    654                   &                                     * ( fse3w(ji  ,jj+1,jk) * ( (rhd(ji,jj+1,jk  ) + znad)                 & 
    655                   &                                                     + (rhd(ji,jj+1,jk-1) + znad) ) * tmask(ji,jj+1,jk-1)   & 
    656                   &                                       - fse3w(ji  ,jj  ,jk) * ( (rhd(ji,jj  ,jk  ) + znad)                 & 
    657                   &                                                     + (rhd(ji,jj  ,jk-1) + znad) ) * tmask(ji,jj  ,jk-1)   ) 
     648               zhpj(ji,jj,jk) = zhpj(ji,jj,jk) + zhpj(ji,jj,jk-1)                                                     & 
     649                  &           + zcoef0 * r1_e2v(ji,jj)                                                                & 
     650                  &                    * ( e3w_n(ji  ,jj+1,jk) * ( (rhd(ji,jj+1,jk  ) + znad)                           & 
     651                  &                                              + (rhd(ji,jj+1,jk-1) + znad) ) * tmask(ji,jj+1,jk-1)   & 
     652                  &                      - e3w_n(ji  ,jj  ,jk) * ( (rhd(ji,jj  ,jk  ) + znad)                           & 
     653                  &                                              + (rhd(ji,jj  ,jk-1) + znad) ) * tmask(ji,jj  ,jk-1)   ) 
    658654               ! s-coordinate pressure gradient correction 
    659655               ! corrective term, we mask this term for the first wet level beneath the ice shelf (contribution done in the upper bloc) 
    660                zvap = - zcoef0 * ( rhd   (ji  ,jj+1,jk) + rhd   (ji,jj,jk) + 2._wp * znad )                     & 
    661                   &            * ( fsde3w(ji  ,jj+1,jk) - fsde3w(ji,jj,jk) ) / e2v(ji,jj) * vmask(ji,jj,jk-1) 
     656               zvap = - zcoef0 * ( rhd    (ji  ,jj+1,jk) + rhd    (ji,jj,jk) + 2._wp * znad )                    & 
     657                  &            * ( gde3w_n(ji  ,jj+1,jk) - gde3w_n(ji,jj,jk) ) * r1_e2v(ji,jj) * vmask(ji,jj,jk-1) 
    662658               ! add to the general momentum trend 
    663659               va(ji,jj,jk) = va(ji,jj,jk) + ( zhpj(ji,jj,jk) + zvap ) * vmask(ji,jj,jk) 
     
    677673            IF (iku .GT. 1) THEN 
    678674               ! remove old value (interior case) 
    679                zuap            = -zcoef0 * ( rhd   (ji+1,jj  ,iku) + rhd   (ji,jj,iku) + 2._wp * znad )   & 
    680                      &                   * ( fsde3w(ji+1,jj  ,iku) - fsde3w(ji,jj,iku) ) / e1u(ji,jj) 
     675               zuap            = -zcoef0 * ( rhd    (ji+1,jj  ,iku) + rhd    (ji,jj,iku) + 2._wp * znad )   & 
     676                     &                   * ( gde3w_n(ji+1,jj  ,iku) - gde3w_n(ji,jj,iku) ) * r1_e1u(ji,jj) 
    681677               ua(ji,jj,iku)   = ua(ji,jj,iku) - zhpi(ji,jj,iku) - zuap 
    682678               ! put new value 
    683679               ! -zpshpi to avoid double contribution of the partial step in the top layer  
    684                zuap            = -zcoef0 * ( aru(ji,jj) + 2._wp * znad ) * gzu(ji,jj)  / e1u(ji,jj) 
    685                zhpi(ji,jj,iku) =  zhpi(ji,jj,iku-1) + zcoef0 / e1u(ji,jj) * ge3ru(ji,jj) - zpshpi(ji,jj)  
     680               zuap            = -zcoef0 * ( aru(ji,jj) + 2._wp * znad ) * gzu(ji,jj)  * r1_e1u(ji,jj) 
     681               zhpi(ji,jj,iku) =  zhpi(ji,jj,iku-1) + zcoef0 * r1_e1u(ji,jj) * ge3ru(ji,jj) - zpshpi(ji,jj)  
    686682               ua(ji,jj,iku)   =  ua(ji,jj,iku) + zhpi(ji,jj,iku) + zuap 
    687683            END IF 
     
    689685            IF (ikv .GT. 1) THEN 
    690686               ! remove old value (interior case) 
    691                zvap            = -zcoef0 * ( rhd   (ji  ,jj+1,ikv) + rhd   (ji,jj,ikv) + 2._wp * znad )   & 
    692                      &                   * ( fsde3w(ji  ,jj+1,ikv) - fsde3w(ji,jj,ikv) )   / e2v(ji,jj) 
     687               zvap            = -zcoef0 * ( rhd    (ji  ,jj+1,ikv) + rhd    (ji,jj,ikv) + 2._wp * znad )   & 
     688                     &                   * ( gde3w_n(ji  ,jj+1,ikv) - gde3w_n(ji,jj,ikv) ) * r1_e2v(ji,jj) 
    693689               va(ji,jj,ikv)   = va(ji,jj,ikv) - zhpj(ji,jj,ikv) - zvap 
    694690               ! put new value 
    695691               ! -zpshpj to avoid double contribution of the partial step in the top layer  
    696                zvap            = -zcoef0 * ( arv(ji,jj) + 2._wp * znad ) * gzv(ji,jj)     / e2v(ji,jj) 
    697                zhpj(ji,jj,ikv) =  zhpj(ji,jj,ikv-1) + zcoef0 / e2v(ji,jj) * ge3rv(ji,jj) - zpshpj(ji,jj)    
     692               zvap            = -zcoef0 * ( arv(ji,jj) + 2._wp * znad ) * gzv(ji,jj) * r1_e2v(ji,jj) 
     693               zhpj(ji,jj,ikv) =  zhpj(ji,jj,ikv-1) + zcoef0 * r1_e2v(ji,jj) * ge3rv(ji,jj) - zpshpj(ji,jj)    
    698694               va(ji,jj,ikv)   =  va(ji,jj,ikv) + zhpj(ji,jj,ikv) + zvap 
    699695            END IF 
     
    756752         DO jj = 2, jpjm1 
    757753            DO ji = fs_2, fs_jpim1   ! vector opt. 
    758                drhoz(ji,jj,jk) = rhd   (ji  ,jj  ,jk) - rhd   (ji,jj,jk-1) 
    759                dzz  (ji,jj,jk) = fsde3w(ji  ,jj  ,jk) - fsde3w(ji,jj,jk-1) 
    760                drhox(ji,jj,jk) = rhd   (ji+1,jj  ,jk) - rhd   (ji,jj,jk  ) 
    761                dzx  (ji,jj,jk) = fsde3w(ji+1,jj  ,jk) - fsde3w(ji,jj,jk  ) 
    762                drhoy(ji,jj,jk) = rhd   (ji  ,jj+1,jk) - rhd   (ji,jj,jk  ) 
    763                dzy  (ji,jj,jk) = fsde3w(ji  ,jj+1,jk) - fsde3w(ji,jj,jk  ) 
     754               drhoz(ji,jj,jk) = rhd    (ji  ,jj  ,jk) - rhd    (ji,jj,jk-1) 
     755               dzz  (ji,jj,jk) = gde3w_n(ji  ,jj  ,jk) - gde3w_n(ji,jj,jk-1) 
     756               drhox(ji,jj,jk) = rhd    (ji+1,jj  ,jk) - rhd    (ji,jj,jk  ) 
     757               dzx  (ji,jj,jk) = gde3w_n(ji+1,jj  ,jk) - gde3w_n(ji,jj,jk  ) 
     758               drhoy(ji,jj,jk) = rhd    (ji  ,jj+1,jk) - rhd    (ji,jj,jk  ) 
     759               dzy  (ji,jj,jk) = gde3w_n(ji  ,jj+1,jk) - gde3w_n(ji,jj,jk  ) 
    764760            END DO 
    765761         END DO 
     
    843839      !------------------------------------------------------------- 
    844840 
    845 !!bug gm   :  e3w-de3w = 0.5*e3w  ....  and de3w(2)-de3w(1)=e3w(2) ....   to be verified 
    846 !          true if de3w is really defined as the sum of the e3w scale factors as, it seems to me, it should be 
     841!!bug gm   :  e3w-gde3w = 0.5*e3w  ....  and gde3w(2)-gde3w(1)=e3w(2) ....   to be verified 
     842!          true if gde3w is really defined as the sum of the e3w scale factors as, it seems to me, it should be 
    847843 
    848844      DO jj = 2, jpjm1 
    849845         DO ji = fs_2, fs_jpim1   ! vector opt. 
    850             rho_k(ji,jj,1) = -grav * ( fse3w(ji,jj,1) - fsde3w(ji,jj,1) )               & 
    851                &                   * (  rhd(ji,jj,1)                                    & 
    852                &                     + 0.5_wp * ( rhd(ji,jj,2) - rhd(ji,jj,1) )         & 
    853                &                              * ( fse3w (ji,jj,1) - fsde3w(ji,jj,1) )   & 
    854                &                              / ( fsde3w(ji,jj,2) - fsde3w(ji,jj,1) )  ) 
     846            rho_k(ji,jj,1) = -grav * ( e3w_n(ji,jj,1) - gde3w_n(ji,jj,1) )               & 
     847               &                   * (  rhd(ji,jj,1)                                     & 
     848               &                     + 0.5_wp * ( rhd    (ji,jj,2) - rhd    (ji,jj,1) )  & 
     849               &                              * ( e3w_n  (ji,jj,1) - gde3w_n(ji,jj,1) )  & 
     850               &                              / ( gde3w_n(ji,jj,2) - gde3w_n(ji,jj,1) )  ) 
    855851         END DO 
    856852      END DO 
     
    863859            DO ji = fs_2, fs_jpim1   ! vector opt. 
    864860 
    865                rho_k(ji,jj,jk) = zcoef0 * ( rhd   (ji,jj,jk) + rhd   (ji,jj,jk-1) )                                   & 
    866                   &                     * ( fsde3w(ji,jj,jk) - fsde3w(ji,jj,jk-1) )                                   & 
    867                   &            - grav * z1_10 * (                                                                     & 
    868                   &     ( drhow (ji,jj,jk) - drhow (ji,jj,jk-1) )                                                     & 
    869                   &   * ( fsde3w(ji,jj,jk) - fsde3w(ji,jj,jk-1) - z1_12 * ( dzw  (ji,jj,jk) + dzw  (ji,jj,jk-1) ) )   & 
    870                   &   - ( dzw   (ji,jj,jk) - dzw   (ji,jj,jk-1) )                                                     & 
    871                   &   * ( rhd   (ji,jj,jk) - rhd   (ji,jj,jk-1) - z1_12 * ( drhow(ji,jj,jk) + drhow(ji,jj,jk-1) ) )   & 
     861               rho_k(ji,jj,jk) = zcoef0 * ( rhd    (ji,jj,jk) + rhd    (ji,jj,jk-1) )                                   & 
     862                  &                     * ( gde3w_n(ji,jj,jk) - gde3w_n(ji,jj,jk-1) )                                   & 
     863                  &            - grav * z1_10 * (                                                                   & 
     864                  &     ( drhow  (ji,jj,jk) - drhow (ji,jj,jk-1) )                                                     & 
     865                  &   * ( gde3w_n(ji,jj,jk) - gde3w_n(ji,jj,jk-1) - z1_12 * ( dzw  (ji,jj,jk) + dzw  (ji,jj,jk-1) ) )   & 
     866                  &   - ( dzw    (ji,jj,jk) - dzw    (ji,jj,jk-1) )                                                     & 
     867                  &   * ( rhd    (ji,jj,jk) - rhd    (ji,jj,jk-1) - z1_12 * ( drhow(ji,jj,jk) + drhow(ji,jj,jk-1) ) )   & 
    872868                  &                             ) 
    873869 
    874                rho_i(ji,jj,jk) = zcoef0 * ( rhd   (ji+1,jj,jk) + rhd   (ji,jj,jk) )                                   & 
    875                   &                     * ( fsde3w(ji+1,jj,jk) - fsde3w(ji,jj,jk) )                                   & 
    876                   &            - grav* z1_10 * (                                                                      & 
    877                   &     ( drhou (ji+1,jj,jk) - drhou (ji,jj,jk) )                                                     & 
    878                   &   * ( fsde3w(ji+1,jj,jk) - fsde3w(ji,jj,jk) - z1_12 * ( dzu  (ji+1,jj,jk) + dzu  (ji,jj,jk) ) )   & 
    879                   &   - ( dzu   (ji+1,jj,jk) - dzu   (ji,jj,jk) )                                                     & 
    880                   &   * ( rhd   (ji+1,jj,jk) - rhd   (ji,jj,jk) - z1_12 * ( drhou(ji+1,jj,jk) + drhou(ji,jj,jk) ) )   & 
     870               rho_i(ji,jj,jk) = zcoef0 * ( rhd    (ji+1,jj,jk) + rhd    (ji,jj,jk) )                                   & 
     871                  &                     * ( gde3w_n(ji+1,jj,jk) - gde3w_n(ji,jj,jk) )                                   & 
     872                  &            - grav* z1_10 * (                                                                    & 
     873                  &     ( drhou  (ji+1,jj,jk) - drhou (ji,jj,jk) )                                                     & 
     874                  &   * ( gde3w_n(ji+1,jj,jk) - gde3w_n(ji,jj,jk) - z1_12 * ( dzu  (ji+1,jj,jk) + dzu  (ji,jj,jk) ) )   & 
     875                  &   - ( dzu    (ji+1,jj,jk) - dzu    (ji,jj,jk) )                                                     & 
     876                  &   * ( rhd    (ji+1,jj,jk) - rhd    (ji,jj,jk) - z1_12 * ( drhou(ji+1,jj,jk) + drhou(ji,jj,jk) ) )   & 
    881877                  &                            ) 
    882878 
    883                rho_j(ji,jj,jk) = zcoef0 * ( rhd   (ji,jj+1,jk) + rhd   (ji,jj,jk) )                                   & 
    884                   &                     * ( fsde3w(ji,jj+1,jk) - fsde3w(ji,jj,jk) )                                   & 
    885                   &            - grav* z1_10 * (                                                                      & 
    886                   &     ( drhov (ji,jj+1,jk) - drhov (ji,jj,jk) )                                                     & 
    887                   &   * ( fsde3w(ji,jj+1,jk) - fsde3w(ji,jj,jk) - z1_12 * ( dzv  (ji,jj+1,jk) + dzv  (ji,jj,jk) ) )   & 
    888                   &   - ( dzv   (ji,jj+1,jk) - dzv   (ji,jj,jk) )                                                     & 
    889                   &   * ( rhd   (ji,jj+1,jk) - rhd   (ji,jj,jk) - z1_12 * ( drhov(ji,jj+1,jk) + drhov(ji,jj,jk) ) )   & 
     879               rho_j(ji,jj,jk) = zcoef0 * ( rhd    (ji,jj+1,jk) + rhd    (ji,jj,jk) )                                 & 
     880                  &                     * ( gde3w_n(ji,jj+1,jk) - gde3w_n(ji,jj,jk) )                                   & 
     881                  &            - grav* z1_10 * (                                                                    & 
     882                  &     ( drhov  (ji,jj+1,jk) - drhov (ji,jj,jk) )                                                     & 
     883                  &   * ( gde3w_n(ji,jj+1,jk) - gde3w_n(ji,jj,jk) - z1_12 * ( dzv  (ji,jj+1,jk) + dzv  (ji,jj,jk) ) )   & 
     884                  &   - ( dzv    (ji,jj+1,jk) - dzv    (ji,jj,jk) )                                                     & 
     885                  &   * ( rhd    (ji,jj+1,jk) - rhd    (ji,jj,jk) - z1_12 * ( drhov(ji,jj+1,jk) + drhov(ji,jj,jk) ) )   & 
    890886                  &                            ) 
    891887 
     
    903899      DO jj = 2, jpjm1 
    904900         DO ji = fs_2, fs_jpim1   ! vector opt. 
    905             zhpi(ji,jj,1) = ( rho_k(ji+1,jj  ,1) - rho_k(ji,jj,1) - rho_i(ji,jj,1) ) / e1u(ji,jj) 
    906             zhpj(ji,jj,1) = ( rho_k(ji  ,jj+1,1) - rho_k(ji,jj,1) - rho_j(ji,jj,1) ) / e2v(ji,jj) 
     901            zhpi(ji,jj,1) = ( rho_k(ji+1,jj  ,1) - rho_k(ji,jj,1) - rho_i(ji,jj,1) ) * r1_e1u(ji,jj) 
     902            zhpj(ji,jj,1) = ( rho_k(ji  ,jj+1,1) - rho_k(ji,jj,1) - rho_j(ji,jj,1) ) * r1_e2v(ji,jj) 
    907903            ! add to the general momentum trend 
    908904            ua(ji,jj,1) = ua(ji,jj,1) + zhpi(ji,jj,1) 
     
    920916               zhpi(ji,jj,jk) = zhpi(ji,jj,jk-1)                                & 
    921917                  &           + (  ( rho_k(ji+1,jj,jk) - rho_k(ji,jj,jk  ) )    & 
    922                   &              - ( rho_i(ji  ,jj,jk) - rho_i(ji,jj,jk-1) )  ) / e1u(ji,jj) 
     918                  &              - ( rho_i(ji  ,jj,jk) - rho_i(ji,jj,jk-1) )  ) * r1_e1u(ji,jj) 
    923919               zhpj(ji,jj,jk) = zhpj(ji,jj,jk-1)                                & 
    924920                  &           + (  ( rho_k(ji,jj+1,jk) - rho_k(ji,jj,jk  ) )    & 
    925                   &               -( rho_j(ji,jj  ,jk) - rho_j(ji,jj,jk-1) )  ) / e2v(ji,jj) 
     921                  &               -( rho_j(ji,jj  ,jk) - rho_j(ji,jj,jk-1) )  ) * r1_e2v(ji,jj) 
    926922               ! add to the general momentum trend 
    927923               ua(ji,jj,jk) = ua(ji,jj,jk) + zhpi(ji,jj,jk) 
     
    953949      !! 
    954950      INTEGER  ::   ji, jj, jk, jkk                 ! dummy loop indices 
    955       REAL(wp) ::   zcoef0, znad                    ! temporary scalars 
    956       !! 
     951      REAL(wp) ::   zcoef0, znad                    ! local scalars 
     952      ! 
    957953      !! The local variables for the correction term 
    958954      INTEGER  :: jk1, jis, jid, jjs, jjd 
     
    965961      !!---------------------------------------------------------------------- 
    966962      ! 
    967       CALL wrk_alloc( jpi,jpj,jpk, zhpi, zu, zv, fsp, xsp, asp, bsp, csp, dsp ) 
    968       CALL wrk_alloc( jpi,jpj,jpk, zdept, zrhh ) 
    969       CALL wrk_alloc( jpi,jpj, zsshu_n, zsshv_n ) 
     963      CALL wrk_alloc( jpi,jpj,jpk,   zhpi, zu, zv, fsp, xsp, asp, bsp, csp, dsp ) 
     964      CALL wrk_alloc( jpi,jpj,jpk,   zdept, zrhh ) 
     965      CALL wrk_alloc( jpi,jpj,       zsshu_n, zsshv_n ) 
    970966      ! 
    971967      IF( kt == nit000 ) THEN 
     
    975971      ENDIF 
    976972 
    977       !!---------------------------------------------------------------------- 
    978973      ! Local constant initialization 
    979974      zcoef0 = - grav 
    980       znad = 0.0_wp 
    981       IF( lk_vvl ) znad = 1._wp 
     975      znad = 1._wp 
     976      IF( ln_linssh )   znad = 0._wp 
    982977 
    983978      ! Clean 3-D work arrays 
     
    989984        DO ji = 1, jpi 
    990985          jk = mbathy(ji,jj) 
    991           IF( jk <= 0 ) THEN; zrhh(ji,jj,:) = 0._wp 
    992           ELSE IF(jk == 1) THEN; zrhh(ji,jj, jk+1:jpk) = rhd(ji,jj,jk) 
    993           ELSE IF(jk < jpkm1) THEN 
     986          IF(     jk <=  0   ) THEN   ;   zrhh(ji,jj,    :   ) = 0._wp 
     987          ELSEIF( jk ==  1   ) THEN   ;   zrhh(ji,jj,jk+1:jpk) = rhd(ji,jj,jk) 
     988          ELSEIF( jk < jpkm1 ) THEN 
    994989             DO jkk = jk+1, jpk 
    995                 zrhh(ji,jj,jkk) = interp1(fsde3w(ji,jj,jkk),   fsde3w(ji,jj,jkk-1), & 
    996                                          fsde3w(ji,jj,jkk-2), rhd(ji,jj,jkk-1), rhd(ji,jj,jkk-2)) 
     990                zrhh(ji,jj,jkk) = interp1(gde3w_n(ji,jj,jkk  ), gde3w_n(ji,jj,jkk-1),  & 
     991                   &                      gde3w_n(ji,jj,jkk-2), rhd    (ji,jj,jkk-1), rhd(ji,jj,jkk-2)) 
    997992             END DO 
    998993          ENDIF 
     
    1003998      DO jj = 1, jpj 
    1004999         DO ji = 1, jpi 
    1005             zdept(ji,jj,1) = 0.5_wp * fse3w(ji,jj,1) - sshn(ji,jj) * znad 
     1000            zdept(ji,jj,1) = 0.5_wp * e3w_n(ji,jj,1) - sshn(ji,jj) * znad 
    10061001         END DO 
    10071002      END DO 
     
    10101005         DO jj = 1, jpj 
    10111006            DO ji = 1, jpi 
    1012                zdept(ji,jj,jk) = zdept(ji,jj,jk-1) + fse3w(ji,jj,jk) 
     1007               zdept(ji,jj,jk) = zdept(ji,jj,jk-1) + e3w_n(ji,jj,jk) 
    10131008            END DO 
    10141009         END DO 
     
    10211016      ! constrained cubic spline interpolation 
    10221017      ! rho(z) = asp + bsp*z + csp*z^2 + dsp*z^3 
    1023       CALL cspline(fsp,xsp,asp,bsp,csp,dsp,polynomial_type) 
     1018      CALL cspline( fsp, xsp, asp, bsp, csp, dsp, polynomial_type ) 
    10241019 
    10251020      ! Integrate the hydrostatic pressure "zhpi(:,:,:)" at "T(ji,jj,1)" 
    10261021      DO jj = 2, jpj 
    10271022        DO ji = 2, jpi 
    1028           zrhdt1 = zrhh(ji,jj,1) - interp3(zdept(ji,jj,1),asp(ji,jj,1), & 
    1029                                          bsp(ji,jj,1),   csp(ji,jj,1), & 
    1030                                          dsp(ji,jj,1) ) * 0.25_wp * fse3w(ji,jj,1) 
     1023          zrhdt1 = zrhh(ji,jj,1) - interp3( zdept(ji,jj,1), asp(ji,jj,1), bsp(ji,jj,1),  & 
     1024             &                                              csp(ji,jj,1), dsp(ji,jj,1) ) * 0.25_wp * e3w_n(ji,jj,1) 
    10311025 
    10321026          ! assuming linear profile across the top half surface layer 
    1033           zhpi(ji,jj,1) =  0.5_wp * fse3w(ji,jj,1) * zrhdt1 
     1027          zhpi(ji,jj,1) =  0.5_wp * e3w_n(ji,jj,1) * zrhdt1 
    10341028        END DO 
    10351029      END DO 
     
    10391033        DO jj = 2, jpj 
    10401034          DO ji = 2, jpi 
    1041             zhpi(ji,jj,jk) = zhpi(ji,jj,jk-1) +                          & 
    1042                              integ_spline(zdept(ji,jj,jk-1), zdept(ji,jj,jk),& 
    1043                                     asp(ji,jj,jk-1),    bsp(ji,jj,jk-1), & 
    1044                                     csp(ji,jj,jk-1),    dsp(ji,jj,jk-1)) 
     1035            zhpi(ji,jj,jk) = zhpi(ji,jj,jk-1) +                                  & 
     1036               &             integ_spline( zdept(ji,jj,jk-1), zdept(ji,jj,jk),   & 
     1037               &                           asp  (ji,jj,jk-1), bsp  (ji,jj,jk-1), & 
     1038               &                           csp  (ji,jj,jk-1), dsp  (ji,jj,jk-1)  ) 
    10451039          END DO 
    10461040        END DO 
     
    10521046      DO jj = 2, jpjm1 
    10531047        DO ji = 2, jpim1 
     1048!!gm BUG ?    if it is ssh at u- & v-point then it should be: 
     1049!          zsshu_n(ji,jj) = (e1e2t(ji,jj) * sshn(ji,jj) + e1e2t(ji+1,jj) * sshn(ji+1,jj)) * & 
     1050!                         & r1_e1e2u(ji,jj) * umask(ji,jj,1) * 0.5_wp  
     1051!          zsshv_n(ji,jj) = (e1e2t(ji,jj) * sshn(ji,jj) + e1e2t(ji,jj+1) * sshn(ji,jj+1)) * & 
     1052!                         & r1_e1e2v(ji,jj) * vmask(ji,jj,1) * 0.5_wp  
     1053!!gm not this: 
    10541054          zsshu_n(ji,jj) = (e1e2u(ji,jj) * sshn(ji,jj) + e1e2u(ji+1, jj) * sshn(ji+1,jj)) * & 
    10551055                         & r1_e1e2u(ji,jj) * umask(ji,jj,1) * 0.5_wp  
     
    10611061      DO jj = 2, jpjm1 
    10621062        DO ji = 2, jpim1 
    1063           zu(ji,jj,1) = - ( fse3u(ji,jj,1) - zsshu_n(ji,jj) * znad)  
    1064           zv(ji,jj,1) = - ( fse3v(ji,jj,1) - zsshv_n(ji,jj) * znad) 
     1063          zu(ji,jj,1) = - ( e3u_n(ji,jj,1) - zsshu_n(ji,jj) * znad)  
     1064          zv(ji,jj,1) = - ( e3v_n(ji,jj,1) - zsshv_n(ji,jj) * znad) 
    10651065        END DO 
    10661066      END DO 
     
    10691069        DO jj = 2, jpjm1 
    10701070          DO ji = 2, jpim1 
    1071             zu(ji,jj,jk) = zu(ji,jj,jk-1)- fse3u(ji,jj,jk) 
    1072             zv(ji,jj,jk) = zv(ji,jj,jk-1)- fse3v(ji,jj,jk) 
     1071            zu(ji,jj,jk) = zu(ji,jj,jk-1) - e3u_n(ji,jj,jk) 
     1072            zv(ji,jj,jk) = zv(ji,jj,jk-1) - e3v_n(ji,jj,jk) 
    10731073          END DO 
    10741074        END DO 
     
    10781078        DO jj = 2, jpjm1 
    10791079          DO ji = 2, jpim1 
    1080             zu(ji,jj,jk) = zu(ji,jj,jk) + 0.5_wp * fse3u(ji,jj,jk) 
    1081             zv(ji,jj,jk) = zv(ji,jj,jk) + 0.5_wp * fse3v(ji,jj,jk) 
     1080            zu(ji,jj,jk) = zu(ji,jj,jk) + 0.5_wp * e3u_n(ji,jj,jk) 
     1081            zv(ji,jj,jk) = zv(ji,jj,jk) + 0.5_wp * e3v_n(ji,jj,jk) 
    10821082          END DO 
    10831083        END DO 
     
    10871087        DO jj = 2, jpjm1 
    10881088          DO ji = 2, jpim1 
    1089             zu(ji,jj,jk) = min(zu(ji,jj,jk), max(-zdept(ji,jj,jk), -zdept(ji+1,jj,jk))) 
    1090             zu(ji,jj,jk) = max(zu(ji,jj,jk), min(-zdept(ji,jj,jk), -zdept(ji+1,jj,jk))) 
    1091             zv(ji,jj,jk) = min(zv(ji,jj,jk), max(-zdept(ji,jj,jk), -zdept(ji,jj+1,jk))) 
    1092             zv(ji,jj,jk) = max(zv(ji,jj,jk), min(-zdept(ji,jj,jk), -zdept(ji,jj+1,jk))) 
     1089            zu(ji,jj,jk) = MIN(  zu(ji,jj,jk) , MAX( -zdept(ji,jj,jk) , -zdept(ji+1,jj,jk) )  ) 
     1090            zu(ji,jj,jk) = MAX(  zu(ji,jj,jk) , MIN( -zdept(ji,jj,jk) , -zdept(ji+1,jj,jk) )  ) 
     1091            zv(ji,jj,jk) = MIN(  zv(ji,jj,jk) , MAX( -zdept(ji,jj,jk) , -zdept(ji,jj+1,jk) )  ) 
     1092            zv(ji,jj,jk) = MAX(  zv(ji,jj,jk) , MIN( -zdept(ji,jj,jk) , -zdept(ji,jj+1,jk) )  ) 
    10931093          END DO 
    10941094        END DO 
     
    11481148               ! update the momentum trends in u direction 
    11491149 
    1150                zdpdx1 = zcoef0 / e1u(ji,jj) * (zhpi(ji+1,jj,jk) - zhpi(ji,jj,jk)) 
    1151                IF( lk_vvl ) THEN 
    1152                  zdpdx2 = zcoef0 / e1u(ji,jj) * & 
    1153                          ( REAL(jis-jid, wp) * (zpwes + zpwed) + (sshn(ji+1,jj)-sshn(ji,jj)) ) 
     1150               zdpdx1 = zcoef0 * r1_e1u(ji,jj) * ( zhpi(ji+1,jj,jk) - zhpi(ji,jj,jk) ) 
     1151               IF( .NOT.ln_linssh ) THEN 
     1152                 zdpdx2 = zcoef0 * r1_e1u(ji,jj) * & 
     1153                    &    ( REAL(jis-jid, wp) * (zpwes + zpwed) + (sshn(ji+1,jj)-sshn(ji,jj)) ) 
    11541154                ELSE 
    1155                  zdpdx2 = zcoef0 / e1u(ji,jj) * REAL(jis-jid, wp) * (zpwes + zpwed) 
     1155                 zdpdx2 = zcoef0 * r1_e1u(ji,jj) * REAL(jis-jid, wp) * (zpwes + zpwed) 
    11561156               ENDIF 
    1157  
    1158                ua(ji,jj,jk) = ua(ji,jj,jk) + (zdpdx1 + zdpdx2) * & 
    1159                &          umask(ji,jj,jk) * tmask(ji,jj,jk) * tmask(ji+1,jj,jk) 
     1157!!gm  Since umask(ji,:,:) = tmask(ji,:,:) * tmask(ji+1,:,:)  by definition 
     1158!!gm      in the line below only * umask(ji,jj,jk)  is needed !! 
     1159               ua(ji,jj,jk) = ua(ji,jj,jk) + (zdpdx1 + zdpdx2) * umask(ji,jj,jk) * tmask(ji,jj,jk) * tmask(ji+1,jj,jk) 
    11601160            ENDIF 
    11611161 
     
    12051205               ! update the momentum trends in v direction 
    12061206 
    1207                zdpdy1 = zcoef0 / e2v(ji,jj) * (zhpi(ji,jj+1,jk) - zhpi(ji,jj,jk)) 
    1208                IF( lk_vvl ) THEN 
    1209                    zdpdy2 = zcoef0 / e2v(ji,jj) * & 
    1210                            ( REAL(jjs-jjd, wp) * (zpnss + zpnsd) + (sshn(ji,jj+1)-sshn(ji,jj)) ) 
     1207               zdpdy1 = zcoef0 * r1_e2v(ji,jj) * ( zhpi(ji,jj+1,jk) - zhpi(ji,jj,jk) ) 
     1208               IF( .NOT.ln_linssh ) THEN 
     1209                  zdpdy2 = zcoef0 * r1_e2v(ji,jj) * & 
     1210                          ( REAL(jjs-jjd, wp) * (zpnss + zpnsd) + (sshn(ji,jj+1)-sshn(ji,jj)) ) 
    12111211               ELSE 
    1212                    zdpdy2 = zcoef0 / e2v(ji,jj) * REAL(jjs-jjd, wp) * (zpnss + zpnsd ) 
     1212                  zdpdy2 = zcoef0 * r1_e2v(ji,jj) * REAL(jjs-jjd, wp) * (zpnss + zpnsd ) 
    12131213               ENDIF 
    1214  
    1215                va(ji,jj,jk) = va(ji,jj,jk) + (zdpdy1 + zdpdy2)*& 
    1216                &              vmask(ji,jj,jk)*tmask(ji,jj,jk)*tmask(ji,jj+1,jk) 
     1214!!gm  Since vmask(:,jj,:) = tmask(:,jj,:) * tmask(:,jj+1,:)  by definition 
     1215!!gm      in the line below only * vmask(ji,jj,jk)  is needed !! 
     1216               va(ji,jj,jk) = va(ji,jj,jk) + ( zdpdy1 + zdpdy2 ) * vmask(ji,jj,jk)*tmask(ji,jj,jk)*tmask(ji,jj+1,jk) 
    12171217            ENDIF 
    1218  
    1219  
    1220            END DO 
    1221         END DO 
    1222       END DO 
    1223       ! 
    1224       CALL wrk_dealloc( jpi,jpj,jpk, zhpi, zu, zv, fsp, xsp, asp, bsp, csp, dsp ) 
    1225       CALL wrk_dealloc( jpi,jpj,jpk, zdept, zrhh ) 
    1226       CALL wrk_dealloc( jpi,jpj, zsshu_n, zsshv_n ) 
     1218               ! 
     1219            END DO 
     1220         END DO 
     1221      END DO 
     1222      ! 
     1223      CALL wrk_dealloc( jpi,jpj,jpk,   zhpi, zu, zv, fsp, xsp, asp, bsp, csp, dsp ) 
     1224      CALL wrk_dealloc( jpi,jpj,jpk,   zdept, zrhh ) 
     1225      CALL wrk_dealloc( jpi,jpj,       zsshu_n, zsshv_n ) 
    12271226      ! 
    12281227   END SUBROUTINE hpg_prj 
    12291228 
    12301229 
    1231    SUBROUTINE cspline(fsp, xsp, asp, bsp, csp, dsp, polynomial_type) 
     1230   SUBROUTINE cspline( fsp, xsp, asp, bsp, csp, dsp, polynomial_type ) 
    12321231      !!---------------------------------------------------------------------- 
    12331232      !!                 ***  ROUTINE cspline  *** 
     
    12391238      !! Reference: CJC Kruger, Constrained Cubic Spline Interpoltation 
    12401239      !!---------------------------------------------------------------------- 
    1241       IMPLICIT NONE 
    1242       REAL(wp), DIMENSION(:,:,:), INTENT(in)  :: fsp, xsp           ! value and coordinate 
    1243       REAL(wp), DIMENSION(:,:,:), INTENT(out) :: asp, bsp, csp, dsp ! coefficients of 
    1244                                                                     ! the interpoated function 
    1245       INTEGER, INTENT(in) :: polynomial_type                        ! 1: cubic spline 
    1246                                                                     ! 2: Linear 
     1240      REAL(wp), DIMENSION(:,:,:), INTENT(in   ) ::   fsp, xsp           ! value and coordinate 
     1241      REAL(wp), DIMENSION(:,:,:), INTENT(  out) ::   asp, bsp, csp, dsp ! coefficients of the interpoated function 
     1242      INTEGER                   , INTENT(in   ) ::   polynomial_type    ! 1: cubic spline   ;   2: Linear 
    12471243      ! 
    12481244      INTEGER  ::   ji, jj, jk                 ! dummy loop indices 
     
    12521248      REAL(wp) ::   zdf(size(fsp,3)) 
    12531249      !!---------------------------------------------------------------------- 
    1254  
     1250      ! 
     1251!!gm  WHAT !!!!!   THIS IS VERY DANGEROUS !!!!!   
    12551252      jpi   = size(fsp,1) 
    12561253      jpj   = size(fsp,2) 
    12571254      jpkm1 = size(fsp,3) - 1 
    1258  
    1259  
     1255      ! 
    12601256      IF (polynomial_type == 1) THEN     ! Constrained Cubic Spline 
    12611257         DO ji = 1, jpi 
     
    12901286 
    12911287               zdf(1)     = 1.5_wp * ( fsp(ji,jj,2) - fsp(ji,jj,1) ) / & 
    1292                           &          ( xsp(ji,jj,2) - xsp(ji,jj,1) ) -  0.5_wp * zdf(2) 
     1288                          &          ( xsp(ji,jj,2) - xsp(ji,jj,1) )           -  0.5_wp * zdf(2) 
    12931289               zdf(jpkm1) = 1.5_wp * ( fsp(ji,jj,jpkm1) - fsp(ji,jj,jpkm1-1) ) / & 
    1294                           &          ( xsp(ji,jj,jpkm1) - xsp(ji,jj,jpkm1-1) ) - & 
    1295                           & 0.5_wp * zdf(jpkm1 - 1) 
     1290                          &          ( xsp(ji,jj,jpkm1) - xsp(ji,jj,jpkm1-1) ) - 0.5_wp * zdf(jpkm1 - 1) 
    12961291 
    12971292               DO jk = 1, jpkm1 - 1 
     
    13161311         END DO 
    13171312 
    1318       ELSE IF (polynomial_type == 2) THEN     ! Linear 
     1313      ELSEIF ( polynomial_type == 2 ) THEN     ! Linear 
    13191314         DO ji = 1, jpi 
    13201315            DO jj = 1, jpj 
     
    13471342      !!                extrapolation is also permitted (no value limit) 
    13481343      !!---------------------------------------------------------------------- 
    1349       IMPLICIT NONE 
    13501344      REAL(wp), INTENT(in) ::  x, xl, xr, fl, fr 
    13511345      REAL(wp)             ::  f ! result of the interpolation (extrapolation) 
    13521346      REAL(wp)             ::  zdeltx 
    13531347      !!---------------------------------------------------------------------- 
    1354  
     1348      ! 
    13551349      zdeltx = xr - xl 
    1356       IF(abs(zdeltx) <= 10._wp * EPSILON(x)) THEN 
    1357         f = 0.5_wp * (fl + fr) 
     1350      IF( abs(zdeltx) <= 10._wp * EPSILON(x) ) THEN 
     1351         f = 0.5_wp * (fl + fr) 
    13581352      ELSE 
    1359         f = ( (x - xl ) * fr - ( x - xr ) * fl ) / zdeltx 
     1353         f = ( (x - xl ) * fr - ( x - xr ) * fl ) / zdeltx 
    13601354      ENDIF 
    1361  
     1355      ! 
    13621356   END FUNCTION interp1 
    13631357 
    13641358 
    1365    FUNCTION interp2(x, a, b, c, d)  RESULT(f) 
     1359   FUNCTION interp2( x, a, b, c, d )  RESULT(f) 
    13661360      !!---------------------------------------------------------------------- 
    13671361      !!                 ***  ROUTINE interp1  *** 
     
    13721366      !! 
    13731367      !!---------------------------------------------------------------------- 
    1374       IMPLICIT NONE 
    13751368      REAL(wp), INTENT(in) ::  x, a, b, c, d 
    13761369      REAL(wp)             ::  f ! value from the interpolation 
    13771370      !!---------------------------------------------------------------------- 
    1378  
     1371      ! 
    13791372      f = a + x* ( b + x * ( c + d * x ) ) 
    1380  
     1373      ! 
    13811374   END FUNCTION interp2 
    13821375 
    13831376 
    1384    FUNCTION interp3(x, a, b, c, d)  RESULT(f) 
     1377   FUNCTION interp3( x, a, b, c, d )  RESULT(f) 
    13851378      !!---------------------------------------------------------------------- 
    13861379      !!                 ***  ROUTINE interp1  *** 
     
    13921385      !! 
    13931386      !!---------------------------------------------------------------------- 
    1394       IMPLICIT NONE 
    13951387      REAL(wp), INTENT(in) ::  x, a, b, c, d 
    13961388      REAL(wp)             ::  f ! value from the interpolation 
    13971389      !!---------------------------------------------------------------------- 
    1398  
     1390      ! 
    13991391      f = b + x * ( 2._wp * c + 3._wp * d * x) 
    1400  
     1392      ! 
    14011393   END FUNCTION interp3 
    14021394 
    14031395 
    1404    FUNCTION integ_spline(xl, xr, a, b, c, d)  RESULT(f) 
     1396   FUNCTION integ_spline( xl, xr, a, b, c, d )  RESULT(f) 
    14051397      !!---------------------------------------------------------------------- 
    14061398      !!                 ***  ROUTINE interp1  *** 
     
    14111403      !! 
    14121404      !!---------------------------------------------------------------------- 
    1413       IMPLICIT NONE 
    14141405      REAL(wp), INTENT(in) ::  xl, xr, a, b, c, d 
    14151406      REAL(wp)             ::  za1, za2, za3 
    14161407      REAL(wp)             ::  f                   ! integration result 
    14171408      !!---------------------------------------------------------------------- 
    1418  
     1409      ! 
    14191410      za1 = 0.5_wp * b 
    14201411      za2 = c / 3.0_wp 
    14211412      za3 = 0.25_wp * d 
    1422  
     1413      ! 
    14231414      f  = xr * ( a + xr * ( za1 + xr * ( za2 + za3 * xr ) ) ) - & 
    14241415         & xl * ( a + xl * ( za1 + xl * ( za2 + za3 * xl ) ) ) 
    1425  
     1416      ! 
    14261417   END FUNCTION integ_spline 
    14271418 
Note: See TracChangeset for help on using the changeset viewer.