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 15008 for NEMO/branches/2021/ticket2680_C1D_PAPA/src/OCE/C1D/dtauvd.F90 – NEMO

Ignore:
Timestamp:
2021-06-17T12:11:24+02:00 (3 years ago)
Author:
gsamson
Message:

add dyn_dmp to mlf step; update dta_uvd interface; adapt istate accordingly & cleaning (#2680)

File:
1 edited

Legend:

Unmodified
Added
Removed
  • NEMO/branches/2021/ticket2680_C1D_PAPA/src/OCE/C1D/dtauvd.F90

    r14915 r15008  
    9393 
    9494      ! 
    95       IF(  ln_uvd_init .OR. ln_uvd_dyndmp ) THEN 
     95      IF( ln_uvd_init .OR. ln_uvd_dyndmp ) THEN 
    9696         !                          !==   allocate the data arrays   ==! 
    9797         ALLOCATE( sf_uvd(2), STAT=ierr0 ) 
     
    117117 
    118118 
    119    SUBROUTINE dta_uvd( kt, Kmm, puvd ) 
     119   SUBROUTINE dta_uvd( kt, Kmm, pud, pvd ) 
    120120      !!---------------------------------------------------------------------- 
    121121      !!                   ***  ROUTINE dta_uvd  *** 
     
    134134      INTEGER                           , INTENT(in   ) ::   kt     ! ocean time-step 
    135135      INTEGER                           , INTENT(in   ) ::   Kmm    ! time level index 
    136       REAL(wp), DIMENSION(jpi,jpj,jpk,2), INTENT(  out) ::   puvd   ! U & V current data 
     136      REAL(wp), DIMENSION(jpi,jpj,jpk)  , INTENT(  out) ::   pud    ! U & V current data 
     137      REAL(wp), DIMENSION(jpi,jpj,jpk)  , INTENT(  out) ::   pvd    ! U & V current data 
    137138      ! 
    138139      INTEGER ::   ji, jj, jk, jl, jkk               ! dummy loop indicies 
     
    146147      CALL fld_read( kt, 1, sf_uvd )      !==   read U & V current data at time step kt   ==! 
    147148      ! 
    148       puvd(:,:,:,1) = sf_uvd(1)%fnow(:,:,:)                 ! NO mask 
    149       puvd(:,:,:,2) = sf_uvd(2)%fnow(:,:,:)  
     149      pud(:,:,:) = sf_uvd(1)%fnow(:,:,:)                 ! NO mask 
     150      pvd(:,:,:) = sf_uvd(2)%fnow(:,:,:)  
    150151      ! 
    151152      IF( ln_sco ) THEN                   !==   s- or mixed s-zps-coordinate   ==! 
     
    162163               zl = gdept(ji,jj,jk,Kmm) 
    163164               IF    ( zl < gdept_1d(1  ) ) THEN          ! extrapolate above the first level of data 
    164                   zup(jk) =  puvd(ji,jj,1    ,1) 
    165                   zvp(jk) =  puvd(ji,jj,1    ,2) 
     165                  zup(jk) =  pud(ji,jj,1) 
     166                  zvp(jk) =  pvd(ji,jj,1) 
    166167               ELSEIF( zl > gdept_1d(jpk) ) THEN          ! extrapolate below the last level of data 
    167                   zup(jk) =  puvd(ji,jj,jpkm1,1) 
    168                   zvp(jk) =  puvd(ji,jj,jpkm1,2) 
     168                  zup(jk) =  pud(ji,jj,jpkm1) 
     169                  zvp(jk) =  pvd(ji,jj,jpkm1) 
    169170               ELSE                                      ! inbetween : vertical interpolation between jkk & jkk+1 
    170171                  DO jkk = 1, jpkm1                      ! when  gdept(jkk) < zl < gdept(jkk+1) 
    171172                     IF( (zl-gdept_1d(jkk)) * (zl-gdept_1d(jkk+1)) <= 0._wp ) THEN 
    172173                        zi = ( zl - gdept_1d(jkk) ) / (gdept_1d(jkk+1)-gdept_1d(jkk)) 
    173                         zup(jk) = puvd(ji,jj,jkk,1) + ( puvd(ji,jj,jkk+1,1 ) - puvd(ji,jj,jkk,1) ) * zi  
    174                         zvp(jk) = puvd(ji,jj,jkk,2) + ( puvd(ji,jj,jkk+1,2 ) - puvd(ji,jj,jkk,2) ) * zi 
     174                        zup(jk) = pud(ji,jj,jkk) + ( pud(ji,jj,jkk+1) - pud(ji,jj,jkk) ) * zi  
     175                        zvp(jk) = pvd(ji,jj,jkk) + ( pvd(ji,jj,jkk+1) - pvd(ji,jj,jkk) ) * zi 
    175176                     ENDIF 
    176177                  END DO 
     
    178179            END DO 
    179180            DO jk = 1, jpkm1           ! apply mask 
    180                puvd(ji,jj,jk,1) = zup(jk) * umask(ji,jj,jk) 
    181                puvd(ji,jj,jk,2) = zvp(jk) * vmask(ji,jj,jk) 
     181               pud(ji,jj,jk) = zup(jk) * umask(ji,jj,jk) 
     182               pvd(ji,jj,jk) = zvp(jk) * vmask(ji,jj,jk) 
    182183            END DO 
    183             puvd(ji,jj,jpk,1) = 0._wp 
    184             puvd(ji,jj,jpk,2) = 0._wp 
     184            pud(ji,jj,jpk) = 0._wp 
     185            pvd(ji,jj,jpk) = 0._wp 
    185186         END_2D 
    186187         !  
     
    189190      ELSE                                !==   z- or zps- coordinate   ==! 
    190191         !                              
    191          puvd(:,:,:,1) = puvd(:,:,:,1) * umask(:,:,:)       ! apply mask 
    192          puvd(:,:,:,2) = puvd(:,:,:,2) * vmask(:,:,:) 
     192         pud(:,:,:) = pud(:,:,:) * umask(:,:,:)       ! apply mask 
     193         pvd(:,:,:) = pvd(:,:,:) * vmask(:,:,:) 
    193194         ! 
    194195         IF( ln_zps ) THEN                ! zps-coordinate (partial steps) interpolation at the last ocean level 
     
    197198               IF( ik > 1 ) THEN 
    198199                  zl = ( gdept_1d(ik) - gdept_0(ji,jj,ik) ) / ( gdept_1d(ik) - gdept_1d(ik-1) ) 
    199                   puvd(ji,jj,ik,1) = (1.-zl) * puvd(ji,jj,ik,1) + zl * puvd(ji,jj,ik-1,1) 
    200                   puvd(ji,jj,ik,2) = (1.-zl) * puvd(ji,jj,ik,2) + zl * puvd(ji,jj,ik-1,2) 
     200                  pud(ji,jj,ik) = (1.-zl) * pud(ji,jj,ik) + zl * pud(ji,jj,ik-1) 
     201                  pvd(ji,jj,ik) = (1.-zl) * pvd(ji,jj,ik) + zl * pvd(ji,jj,ik-1) 
    201202               ENDIF 
    202203            END_2D 
Note: See TracChangeset for help on using the changeset viewer.