-
Notifications
You must be signed in to change notification settings - Fork 1
/
iom_def.F90
73 lines (64 loc) · 4.55 KB
/
iom_def.F90
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
MODULE iom_def
!!=====================================================================
!! *** MODULE iom_def ***
!! IOM variables definitions
!!====================================================================
!! History : 9.0 ! 06 09 (S. Masson) Original code
!! " ! 07 07 (D. Storkey) Add uldname
!!--------------------------------------------------------------------
!!---------------------------------------------------------------------------------
!! NEMO/OPA 3.3 , NEMO Consortium (2010)
!! $Id: iom_def.F90 2528 2010-12-27 17:33:53Z rblod $
!! Software governed by the CeCILL licence (NEMOGCM/NEMO_CeCILL.txt)
!!---------------------------------------------------------------------------------
USE par_kind
IMPLICIT NONE
PRIVATE
INTEGER, PARAMETER, PUBLIC :: jpdom_data = 1 !: ( 1 :jpidta, 1 :jpjdta)
INTEGER, PARAMETER, PUBLIC :: jpdom_global = 2 !: ( 1 :jpiglo, 1 :jpjglo)
INTEGER, PARAMETER, PUBLIC :: jpdom_local = 3 !: One of the 3 following cases
INTEGER, PARAMETER, PUBLIC :: jpdom_local_full = 4 !: ( 1 :jpi , 1 :jpi )
INTEGER, PARAMETER, PUBLIC :: jpdom_local_noextra = 5 !: ( 1 :nlci , 1 :nlcj )
INTEGER, PARAMETER, PUBLIC :: jpdom_local_noovlap = 6 !: (nldi:nlei ,nldj:nlej )
INTEGER, PARAMETER, PUBLIC :: jpdom_unknown = 7 !: No dimension checking
INTEGER, PARAMETER, PUBLIC :: jpdom_autoglo = 8 !:
INTEGER, PARAMETER, PUBLIC :: jpdom_autodta = 9 !:
INTEGER, PARAMETER, PUBLIC :: jpioipsl = 100 !: Use ioipsl (fliocom only) library
INTEGER, PARAMETER, PUBLIC :: jpnf90 = 101 !: Use nf90 library
INTEGER, PARAMETER, PUBLIC :: jprstdimg = 102 !: Use restart dimgs (fortran direct acces) library
#if defined key_dimgout
INTEGER, PARAMETER, PUBLIC :: jprstlib = jprstdimg !: restarts io library
#else
INTEGER, PARAMETER, PUBLIC :: jprstlib = jpnf90 !: restarts io library
#endif
INTEGER, PARAMETER, PUBLIC :: jp_r8 = 200 !: write REAL(8)
INTEGER, PARAMETER, PUBLIC :: jp_r4 = 201 !: write REAL(4)
INTEGER, PARAMETER, PUBLIC :: jp_i4 = 202 !: write INTEGER(4)
INTEGER, PARAMETER, PUBLIC :: jp_i2 = 203 !: write INTEGER(2)
INTEGER, PARAMETER, PUBLIC :: jp_i1 = 204 !: write INTEGER(1)
INTEGER, PARAMETER, PUBLIC :: jpmax_files = 200 !: maximum number of simultaneously opened file
INTEGER, PARAMETER, PUBLIC :: jpmax_vars = 360 !: maximum number of variables in one file
INTEGER, PARAMETER, PUBLIC :: jpmax_dims = 4 !: maximum number of dimensions for one variable
INTEGER, PARAMETER, PUBLIC :: jpmax_digits = 5 !: maximum number of digits for the cpu number in the file name
!$AGRIF_DO_NOT_TREAT
INTEGER, PUBLIC :: iom_open_init = 0 !: used to initialize iom_file(:)%nfid to 0
TYPE, PUBLIC :: file_descriptor
CHARACTER(LEN=240) :: name !: name of the file
INTEGER :: nfid !: identifier of the file (0 if closed)
INTEGER :: iolib !: library used to read the file (jpioipsl, jpnf90 or jprstdimg)
INTEGER :: nvars !: number of identified varibles in the file
INTEGER :: iduld !: id of the unlimited dimension
INTEGER :: irec !: writing record position
CHARACTER(LEN=32) :: uldname !: name of the unlimited dimension
CHARACTER(LEN=32), DIMENSION(jpmax_vars) :: cn_var !: names of the variables
INTEGER, DIMENSION(jpmax_vars) :: nvid !: id of the variables
INTEGER, DIMENSION(jpmax_vars) :: ndims !: number of dimensions of the variables
LOGICAL, DIMENSION(jpmax_vars) :: luld !: variable using the unlimited dimension
INTEGER, DIMENSION(jpmax_dims,jpmax_vars) :: dimsz !: size of variables dimensions
REAL(kind=wp), DIMENSION(jpmax_vars) :: scf !: scale_factor of the variables
REAL(kind=wp), DIMENSION(jpmax_vars) :: ofs !: add_offset of the variables
END TYPE file_descriptor
TYPE(file_descriptor), DIMENSION(jpmax_files), PUBLIC :: iom_file !: array containing the info for all opened files
!$AGRIF_END_DO_NOT_TREAT
!!=====================================================================
END MODULE iom_def