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.
in_out_manager.F90 in NEMO/branches/UKMO/NEMO4_beta_mirror/src/OCE/IOM – NEMO

source: NEMO/branches/UKMO/NEMO4_beta_mirror/src/OCE/IOM/in_out_manager.F90 @ 9950

Last change on this file since 9950 was 9950, checked in by davestorkey, 6 years ago

UKMO/NEMO4_beta_mirror branch: remove SVN keywords

File size: 11.1 KB
RevLine 
[544]1MODULE in_out_manager   
2   !!======================================================================
3   !!                       ***  MODULE  in_out_manager  ***
[3294]4   !! I/O manager utilities : Defines run parameters together with logical units
[544]5   !!=====================================================================
[1581]6   !! History :   1.0  !  2002-06  (G. Madec)   original code
[1056]7   !!             2.0  !  2006-07  (S. Masson)  iom, add ctl_stop, ctl_warn
[1581]8   !!             3.0  !  2008-06  (G. Madec)   add ctmp4 to ctmp10
9   !!             3.2  !  2009-08  (S. MAsson)  add new ctl_opn
[2528]10   !!             3.3  !  2010-10  (A. Coward)  add NetCDF4 usage
[544]11   !!----------------------------------------------------------------------
12
13   !!----------------------------------------------------------------------
[2528]14   USE par_oce       ! ocean parameter
15   USE nc4interface  ! NetCDF4 interface
[544]16
17   IMPLICIT NONE
18   PUBLIC
19
20   !!----------------------------------------------------------------------
21   !!                   namrun namelist parameters
22   !!----------------------------------------------------------------------
[4147]23   CHARACTER(lc) ::   cn_exp           !: experiment name used for output filename
24   CHARACTER(lc) ::   cn_ocerst_in     !: suffix of ocean restart name (input)
[5341]25   CHARACTER(lc) ::   cn_ocerst_indir  !: restart input directory
[4147]26   CHARACTER(lc) ::   cn_ocerst_out    !: suffix of ocean restart name (output)
[5341]27   CHARACTER(lc) ::   cn_ocerst_outdir !: restart output directory
[4147]28   LOGICAL       ::   ln_rstart        !: start from (F) rest or (T) a restart file
[5341]29   LOGICAL       ::   ln_rst_list      !: output restarts at list of times (T) or by frequency (F)
[4147]30   INTEGER       ::   nn_rstctl        !: control of the time step (0, 1 or 2)
31   INTEGER       ::   nn_rstssh   = 0  !: hand made initilization of ssh or not (1/0)
32   INTEGER       ::   nn_it000         !: index of the first time step
33   INTEGER       ::   nn_itend         !: index of the last time step
34   INTEGER       ::   nn_date0         !: initial calendar date aammjj
[6140]35   INTEGER       ::   nn_time0         !: initial time of day in hhmm
[4147]36   INTEGER       ::   nn_leapy         !: Leap year calendar flag (0/1 or 30)
37   INTEGER       ::   nn_istate        !: initial state output flag (0/1)
38   INTEGER       ::   nn_write         !: model standard output frequency
39   INTEGER       ::   nn_stock         !: restart file frequency
[5341]40   INTEGER, DIMENSION(10) :: nn_stocklist  !: restart dump times
[4147]41   LOGICAL       ::   ln_mskland       !: mask land points in NetCDF outputs (costly: + ~15%)
[5363]42   LOGICAL       ::   ln_cfmeta        !: output additional data to netCDF files required for compliance with the CF metadata standard
[4147]43   LOGICAL       ::   ln_clobber       !: clobber (overwrite) an existing file
44   INTEGER       ::   nn_chunksz       !: chunksize (bytes) for NetCDF file (works only with iom_nf90 routines)
[9367]45   LOGICAL       ::   ln_xios_read     !: use xios to read single file restart
46   INTEGER       ::   nn_wxios         !: write resart using xios 0 - no, 1 - single, 2 - multiple file output
[9490]47   INTEGER       ::   nn_no            !: Assimilation cycle
[7646]48
[2528]49#if defined key_netcdf4
50   !!----------------------------------------------------------------------
51   !!                   namnc4 namelist parameters                         (key_netcdf4)
52   !!----------------------------------------------------------------------
53   ! The following four values determine the partitioning of the output fields
54   ! into netcdf4 chunks. They are unrelated to the nn_chunk_sz setting which is
55   ! for runtime optimisation. The individual netcdf4 chunks can be optionally
56   ! gzipped (recommended) leading to significant reductions in I/O volumes
[4147]57   !                         !!!**  variables only used with iom_nf90 routines and key_netcdf4 **
58   INTEGER ::   nn_nchunks_i   !: number of chunks required in the i-dimension
59   INTEGER ::   nn_nchunks_j   !: number of chunks required in the j-dimension
60   INTEGER ::   nn_nchunks_k   !: number of chunks required in the k-dimension
61   INTEGER ::   nn_nchunks_t   !: number of chunks required in the t-dimension
62   LOGICAL ::   ln_nc4zip      !: netcdf4 usage: (T) chunk and compress output using the HDF5 sublayers of netcdf4
63   !                           !                 (F) ignore chunking request and use the netcdf4 library
64   !                           !                     to produce netcdf3-compatible files
[2528]65#endif
[7646]66
[2528]67!$AGRIF_DO_NOT_TREAT
68   TYPE(snc4_ctl)     :: snc4set        !: netcdf4 chunking control structure (always needed for decision making)
69!$AGRIF_END_DO_NOT_TREAT
[1601]70
[2528]71
[1601]72   !! conversion of DOCTOR norm namelist name into model name
73   !! (this should disappear in a near futur)
74
[2528]75   CHARACTER(lc) ::   cexper                      !: experiment name used for output filename
76   INTEGER       ::   nrstdt                      !: control of the time step (0, 1 or 2)
77   INTEGER       ::   nit000                      !: index of the first time step
78   INTEGER       ::   nitend                      !: index of the last time step
79   INTEGER       ::   ndate0                      !: initial calendar date aammjj
80   INTEGER       ::   nleapy                      !: Leap year calendar flag (0/1 or 30)
81   INTEGER       ::   ninist                      !: initial state output flag (0/1)
82   INTEGER       ::   nwrite                      !: model standard output frequency
83   INTEGER       ::   nstock                      !: restart file frequency
[5341]84   INTEGER, DIMENSION(10) :: nstocklist           !: restart dump times
[1601]85
[544]86   !!----------------------------------------------------------------------
[557]87   !! was in restart but moved here because of the OFF line... better solution should be found...
88   !!----------------------------------------------------------------------
[3680]89   INTEGER ::   nitrst                !: time step at which restart file should be written
90   LOGICAL ::   lrst_oce              !: logical to control the oce restart write
[9019]91   LOGICAL ::   lrst_ice              !: logical to control the ice restart write
[5518]92   INTEGER ::   numror = 0            !: logical unit for ocean restart (read). Init to 0 is needed for SAS (in daymod.F90)
[9019]93   INTEGER ::   numrir                !: logical unit for ice   restart (read)
[5518]94   INTEGER ::   numrow                !: logical unit for ocean restart (write)
[9019]95   INTEGER ::   numriw                !: logical unit for ice   restart (write)
[5341]96   INTEGER ::   nrst_lst              !: number of restart to output next
[1601]97
[557]98   !!----------------------------------------------------------------------
[544]99   !!                    output monitoring
100   !!----------------------------------------------------------------------
[7646]101   LOGICAL ::   ln_ctl           !: run control for debugging
[9019]102   LOGICAL ::   ln_timing        !: run control for timing
103   LOGICAL ::   ln_diacfl        !: flag whether to create CFL diagnostics
[7646]104   INTEGER ::   nn_print         !: level of print (0 no print)
105   INTEGER ::   nn_ictls         !: Start i indice for the SUM control
106   INTEGER ::   nn_ictle         !: End   i indice for the SUM control
107   INTEGER ::   nn_jctls         !: Start j indice for the SUM control
108   INTEGER ::   nn_jctle         !: End   j indice for the SUM control
109   INTEGER ::   nn_isplt         !: number of processors following i
110   INTEGER ::   nn_jsplt         !: number of processors following j
111   INTEGER ::   nn_bench         !: benchmark parameter (0/1)
112   INTEGER ::   nn_bit_cmp = 0   !: bit reproducibility  (0/1)
[2528]113   !                                         
[7646]114   INTEGER ::   nprint, nictls, nictle, njctls, njctle, isplt, jsplt    !: OLD namelist names
[1601]115
[2528]116   INTEGER ::   ijsplt     =    1      !: nb of local domain = nb of processors
[1601]117
[544]118   !!----------------------------------------------------------------------
119   !!                        logical units
120   !!----------------------------------------------------------------------
[4147]121   INTEGER ::   numstp          =   -1      !: logical unit for time step
122   INTEGER ::   numtime         =   -1      !: logical unit for timing
[9490]123   INTEGER ::   numout          =    6      !: logical unit for output print; Set to stdout to ensure any
124      !                                     !  early output can be collected; do not change
[4147]125   INTEGER ::   numnam_ref      =   -1      !: logical unit for reference namelist
126   INTEGER ::   numnam_cfg      =   -1      !: logical unit for configuration specific namelist
[4990]127   INTEGER ::   numond          =   -1      !: logical unit for Output Namelist Dynamics
[4147]128   INTEGER ::   numnam_ice_ref  =   -1      !: logical unit for ice reference namelist
129   INTEGER ::   numnam_ice_cfg  =   -1      !: logical unit for ice reference namelist
[4990]130   INTEGER ::   numoni          =   -1      !: logical unit for Output Namelist Ice
[4147]131   INTEGER ::   numevo_ice      =   -1      !: logical unit for ice variables (temp. evolution)
[9019]132   INTEGER ::   numrun          =   -1      !: logical unit for run statistics
[4147]133   INTEGER ::   numdct_in       =   -1      !: logical unit for transports computing
134   INTEGER ::   numdct_vol      =   -1      !: logical unit for voulume transports output
135   INTEGER ::   numdct_heat     =   -1      !: logical unit for heat    transports output
136   INTEGER ::   numdct_salt     =   -1      !: logical unit for salt    transports output
137   INTEGER ::   numfl           =   -1      !: logical unit for floats ascii output
138   INTEGER ::   numflo          =   -1      !: logical unit for floats ascii output
[544]139
140   !!----------------------------------------------------------------------
141   !!                          Run control 
142   !!----------------------------------------------------------------------
[7646]143   INTEGER       ::   no_print = 0          !: optional argument of fld_fill (if present, suppress some control print)
[2528]144   INTEGER       ::   nstop = 0             !: error flag (=number of reason for a premature stop run)
145   INTEGER       ::   nwarn = 0             !: warning flag (=number of warning found during the run)
146   CHARACTER(lc) ::   ctmp1, ctmp2, ctmp3   !: temporary characters 1 to 3
147   CHARACTER(lc) ::   ctmp4, ctmp5, ctmp6   !: temporary characters 4 to 6
148   CHARACTER(lc) ::   ctmp7, ctmp8, ctmp9   !: temporary characters 7 to 9
149   CHARACTER(lc) ::   ctmp10                !: temporary character 10
150   CHARACTER(lc) ::   cform_err = "(/,' ===>>> : E R R O R',     /,'         ===========',/)"       !:
151   CHARACTER(lc) ::   cform_war = "(/,' ===>>> : W A R N I N G', /,'         ===============',/)"   !:
[4624]152   LOGICAL       ::   lwm      = .FALSE.    !: boolean : true on the 1st processor only (always)
153   LOGICAL       ::   lwp      = .FALSE.    !: boolean : true on the 1st processor only .OR. ln_ctl
[2528]154   LOGICAL       ::   lsp_area = .TRUE.     !: to make a control print over a specific area
[5407]155   CHARACTER(lc) ::   cxios_context         !: context name used in xios
[9367]156   CHARACTER(lc) ::   crxios_context         !: context name used in xios to read restart
157   CHARACTER(lc) ::   cwxios_context        !: context name used in xios to write restart file
[2528]158
[544]159   !!----------------------------------------------------------------------
[9570]160   !! NEMO/OCE 4.0 , NEMO Consortium (2018)
[1146]161   !! $Id$
[9598]162   !! Software governed by the CeCILL licence     (./LICENSE)
[544]163   !!=====================================================================
164END MODULE in_out_manager
Note: See TracBrowser for help on using the repository browser.