Forked from
NEMO Workspace / Nemo
968 commits behind, 66 commits ahead of the upstream repository.
-
Sebastien Masson authorede0e6ed97
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
usrdef_nam.F90 5.08 KiB
MODULE usrdef_nam
!!======================================================================
!! *** MODULE usrdef_nam ***
!!
!! === ICE_RHEO configuration ===
!!
!! User defined : set the domain characteristics of a user configuration
!!======================================================================
!! History : NEMO ! 2016-03 (S. Flavoni, G. Madec) Original code
!!----------------------------------------------------------------------
!!----------------------------------------------------------------------
!! usr_def_nam : read user defined namelist and set global domain size
!! usr_def_hgr : initialize the horizontal mesh
!!----------------------------------------------------------------------
USE par_oce ! ocean space and time domain
USE phycst ! physical constants
!
USE in_out_manager ! I/O manager
USE lib_mpp ! MPP library
USE timing ! Timing
IMPLICIT NONE
PRIVATE
PUBLIC usr_def_nam ! called by nemogcm.F90
! !!* namusr_def namelist *!!
REAL(wp), PUBLIC :: rn_dx ! resolution in meters defining the horizontal domain size
REAL(wp), PUBLIC :: rn_dy ! resolution in meters defining the horizontal domain size
REAL(wp), PUBLIC :: rn_ppgphi0 ! reference latitude for beta-plane
LOGICAL , PUBLIC :: ln_corio ! set coriolis at 0 (ln_corio=F) or not
!!----------------------------------------------------------------------
!! NEMO/OCE 4.0 , NEMO Consortium (2018)
!! $Id: usrdef_nam.F90 10161 2018-10-01 09:48:55Z clem $
!! Software governed by the CeCILL license (see ./LICENSE)
!!----------------------------------------------------------------------
CONTAINS
SUBROUTINE usr_def_nam( cd_cfg, kk_cfg, kpi, kpj, kpk, ldIperio, ldJperio, ldNFold, cdNFtype )
!!----------------------------------------------------------------------
!! *** ROUTINE dom_nam ***
!!
!! ** Purpose : read user defined namelist and define the domain size
!!
!! ** Method : read in namusr_def containing all the user specific namelist parameter
!!
!! Here ICE_RHEO configuration
!!
!! ** input : - namusr_def namelist found in namelist_cfg
!!----------------------------------------------------------------------
CHARACTER(len=*), INTENT(out) :: cd_cfg ! configuration name
INTEGER , INTENT(out) :: kk_cfg ! configuration resolution
INTEGER , INTENT(out) :: kpi, kpj, kpk ! global domain sizes
LOGICAL , INTENT(out) :: ldIperio, ldJperio ! i- and j- periodicity
LOGICAL , INTENT(out) :: ldNFold ! North pole folding
CHARACTER(len=1), INTENT(out) :: cdNFtype ! Folding type: T or F
!
INTEGER :: ios ! Local integer
REAL(wp):: zlx, zly ! Local scalars
!!
NAMELIST/namusr_def/ rn_dx, rn_dy, ln_corio, rn_ppgphi0
!!----------------------------------------------------------------------
!
READ ( numnam_cfg, namusr_def, IOSTAT = ios, ERR = 902 )
902 IF( ios /= 0 ) CALL ctl_nam ( ios , 'namusr_def in configuration namelist' )
!
IF(lwm) WRITE( numond, namusr_def )
!
cd_cfg = 'ICE_RHEO' ! name & resolution (not used)
kk_cfg = NINT( rn_dx )
!
! Global Domain size: domain is 2000 km x 2000 Km x 10 m
kpi = NINT( 2000.e3 / rn_dx )
kpj = NINT( 2000.e3 / rn_dy )
kpk = 1
!
!! zlx = (kpi-2)*rn_dx*1.e-3
!! zly = (kpj-2)*rn_dy*1.e-3
zlx = kpi*rn_dx*1.e-3
zly = kpj*rn_dy*1.e-3
!
ldIperio = .FALSE. ; ldJperio = .FALSE. ! ICE_RHEO configuration : closed domain
ldNFold = .FALSE. ; cdNFtype = '-'
!
! ! control print
IF(lwp) THEN
WRITE(numout,*) ' '
WRITE(numout,*) 'usr_def_nam : read the user defined namelist (namusr_def) in namelist_cfg'
WRITE(numout,*) '~~~~~~~~~~~ '
WRITE(numout,*) ' Namelist namusr_def : ICE_RHEO test case'
WRITE(numout,*) ' horizontal resolution rn_dx = ', rn_dx, ' meters'
WRITE(numout,*) ' horizontal resolution rn_dy = ', rn_dy, ' meters'
WRITE(numout,*) ' ICE_RHEO domain = 2000 km x 2000 km'
WRITE(numout,*) ' LX [km]: ', zlx
WRITE(numout,*) ' LY [km]: ', zly
WRITE(numout,*) ' resulting global domain size : jpiglo = ', kpi
WRITE(numout,*) ' jpjglo = ', kpj
WRITE(numout,*) ' jpkglo = ', kpk
WRITE(numout,*) ' Coriolis:', ln_corio
WRITE(numout,*) ' '
ENDIF
!
END SUBROUTINE usr_def_nam
!!======================================================================
END MODULE usrdef_nam