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 15023 for NEMO/trunk/src/OCE/C1D – NEMO

Ignore:
Timestamp:
2021-06-18T16:35:25+02:00 (3 years ago)
Author:
gsamson
Message:

merge ticket2680_C1D_PAPA branch back into the trunk; see ticket #2680 for details

Location:
NEMO/trunk/src/OCE/C1D
Files:
2 deleted
3 edited

Legend:

Unmodified
Added
Removed
  • NEMO/trunk/src/OCE/C1D/c1d.F90

    r12377 r15023  
    88   !!            3.5  !  2013-10 (D. Calvert)  add namelist 
    99   !!---------------------------------------------------------------------- 
    10 #if defined key_c1d 
    11    !!---------------------------------------------------------------------- 
    12    !!   'key_c1d'                                   1D column configuration 
     10 
    1311   !!---------------------------------------------------------------------- 
    1412   !!   c1d_init      : read in the C1D namelist 
     
    2422   PUBLIC   c1d_init   ! called by nemogcm.F90 
    2523 
    26    LOGICAL , PUBLIC, PARAMETER ::  lk_c1d = .TRUE.   ! 1D config. flag 
    27  
    2824   REAL(wp), PUBLIC ::  rn_lat1d     !: Column latitude 
    2925   REAL(wp), PUBLIC ::  rn_lon1d     !: Column longitude 
    30    LOGICAL , PUBLIC ::  ln_c1d_locpt !: Localization (or not) of 1D column in a grid 
    3126 
    3227   !!---------------------------------------------------------------------- 
     
    4742      INTEGER ::   ios   ! Local integer 
    4843      !! 
    49       NAMELIST/namc1d/ rn_lat1d, rn_lon1d , ln_c1d_locpt 
     44      NAMELIST/namc1d/ rn_lat1d, rn_lon1d 
    5045      !!---------------------------------------------------------------------- 
    5146      ! 
     
    6459         WRITE(numout,*) '      column latitude                 rn_lat1d     = ', rn_lat1d 
    6560         WRITE(numout,*) '      column longitude                rn_lon1d     = ', rn_lon1d 
    66          WRITE(numout,*) '      column localization in a grid   ln_c1d_locpt = ', ln_c1d_locpt 
    6761      ENDIF 
    6862      ! 
    6963   END SUBROUTINE c1d_init 
    7064 
    71 #else 
    72    !!---------------------------------------------------------------------- 
    73    !!   Dummy module :                           No use of 1D configuration 
    74    !!---------------------------------------------------------------------- 
    75    USE par_kind         ! kind parameters 
    76    LOGICAL, PUBLIC, PARAMETER ::   lk_c1d = .FALSE.   !: 1D config. flag de-activated 
    77    REAL(wp)                   ::   rn_lat1d, rn_lon1d 
    78    LOGICAL , PUBLIC           ::   ln_c1d_locpt = .FALSE.  
    79 CONTAINS 
    80    SUBROUTINE c1d_init               ! Dummy routine 
    81    END SUBROUTINE c1d_init 
    82 #endif 
    83  
    8465   !!====================================================================== 
    8566END MODULE c1d 
  • NEMO/trunk/src/OCE/C1D/dtauvd.F90

    r13497 r15023  
    2626   PUBLIC   dta_uvd        ! called by istate.F90 and dyndmp.90 
    2727 
    28    LOGICAL , PUBLIC ::   ln_uvd_init     ! Flag to initialise with U & V current data 
    29    LOGICAL , PUBLIC ::   ln_uvd_dyndmp   ! Flag for Newtonian damping toward U & V current data 
     28   LOGICAL , PUBLIC ::   ln_uvd_init   = .FALSE.   ! Flag to initialise with U & V current data 
     29   LOGICAL , PUBLIC ::   ln_uvd_dyndmp = .FALSE.   ! Flag for Newtonian damping toward U & V current data 
    3030 
    3131   TYPE(FLD), ALLOCATABLE, DIMENSION(:) ::   sf_uvd   ! structure for input U & V current (file information and data) 
     
    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 
  • NEMO/trunk/src/OCE/C1D/dyndmp.F90

    r13295 r15023  
    159159      ! 
    160160      !                           !==   read and interpolate U & V current data at kt   ==! 
    161       CALL dta_uvd( kt, Kmm, zuv_dta ) !!! NOTE: This subroutine must be altered for use outside 
    162                                   !!!       the C1D context (use of U,V grid variables) 
     161      CALL dta_uvd( kt, Kmm, zuv_dta(:,:,:,1), zuv_dta(:,:,:,2)) 
    163162      ! 
    164163      SELECT CASE ( nn_zdmp )     !==   Calculate/add Newtonian damping to the momentum trend   ==! 
Note: See TracChangeset for help on using the changeset viewer.