Newer
Older

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,'VERSION',IVERSION)
CALL IO_READ_FIELD(TPINFILE,'BUG', IBUGFIX)
IF (IVERSION<7 .OR. (IVERSION==7 .AND. IBUGFIX==0)) THEN
GCOVER_PACKED = .FALSE.
ELSE

WAUTELET Philippe
committed
TZFIELD%CMNHNAME = 'COVER_PACKED'
TZFIELD%CSTDNAME = ''

WAUTELET Philippe
committed
TZFIELD%CLONGNAME = 'COVER_PACKED'

WAUTELET Philippe
committed
TZFIELD%CUNITS = ''
TZFIELD%CDIR = '--'
TZFIELD%CCOMMENT = ''
TZFIELD%NGRID = 0
TZFIELD%NTYPE = TYPELOG
TZFIELD%NDIMS = 0
TZFIELD%LTIMEDEP = .FALSE.

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,GCOVER_PACKED,KRESP)
END IF
!
IF (.NOT. GCOVER_PACKED) THEN
WRITE(YREC,'(A5,I3.3)') 'COVER',KCOVER

WAUTELET Philippe
committed
TZFIELD%CMNHNAME = TRIM(YREC)
TZFIELD%CSTDNAME = ''

WAUTELET Philippe
committed
TZFIELD%CLONGNAME = TRIM(YREC)

WAUTELET Philippe
committed
TZFIELD%CUNITS = ''
TZFIELD%CDIR = YDIR1
TZFIELD%CCOMMENT = 'X_Y_'//TRIM(YREC)

WAUTELET Philippe
committed
TZFIELD%NGRID = 4
TZFIELD%NTYPE = TYPEREAL
TZFIELD%NDIMS = 2

WAUTELET Philippe
committed
TZFIELD%LTIMEDEP = .FALSE.

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,ZWORK2D,KRESP)

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error : GCOVER_PACKED = ', GCOVER_PACKED, ' and we try to read the covers one by one '
WRITE(ILUOUT,*) ' '
CALL ABORT
END IF
!

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ', HREC,'KRESP=',KRESP
WRITE(ILUOUT,*) ' '
ELSE IF (YDIR1=='H' .OR. YDIR1=='A' .OR. YDIR1=='E') THEN
CALL PACK_2D_1D(IMASK,ZWORK2D(IIB:IIE,IJB:IJE),PFIELD(:))
END IF
!
DEALLOCATE(ZWORK2D)
DEALLOCATE(IMASK)
!-------------------------------------------------------------------------------
END SUBROUTINE READ_SURFX2COV_1COV_MNH
!
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
! #############################################################
SUBROUTINE READ_SURFN0_MNH(HREC,KFIELD,KRESP,HCOMMENT)
! #############################################################
!
!!**** *READN0* - routine to read an integer
!!
!! PURPOSE
!! -------
!
! The purpose of READN0 is
!
!!** METHOD
!! ------
!!
!! EXTERNAL
!! --------
!!
!!
!!
!! IMPLICIT ARGUMENTS
!! ------------------
!!
!!
!! REFERENCE
!! ---------
!!
!!
!! AUTHOR
!! ------
!!
!! S.Malardel *METEO-FRANCE*
!!
!! MODIFICATIONS
!! -------------
!!
!! original 01/08/03
!----------------------------------------------------------------------------
!
!* 0. DECLARATIONS
! ------------
!
USE MODE_ll

WAUTELET Philippe
committed
USE MODE_FIELD, ONLY: TFIELDDATA,TYPEINT

WAUTELET Philippe
committed
USE MODE_READ_SURF_MNH_TOOLS

WAUTELET Philippe
committed
USE MODD_IO_SURF_MNH, ONLY : TOUT, TPINFILE, NMASK, &
NIU, NJU, NIB, NJB, NIE, NJE
USE MODD_CONF, ONLY : CPROGRAM
!
!
!
IMPLICIT NONE
!
!* 0.1 Declarations of arguments
!

WAUTELET Philippe
committed
CHARACTER(LEN=LEN_HREC),INTENT(IN) :: HREC ! name of the article to be read
INTEGER, INTENT(OUT) :: KFIELD ! the integer to be read
INTEGER, INTENT(OUT) :: KRESP ! KRESP : return-code if a problem appears
CHARACTER(LEN=100), INTENT(OUT) :: HCOMMENT ! comment
!
!* 0.2 Declarations of local variables
!
INTEGER :: IIMAX, IJMAX

WAUTELET Philippe
committed
INTEGER :: ILUOUT

WAUTELET Philippe
committed
TYPE(TFIELDDATA) :: TZFIELD
!
!-------------------------------------------------------------------------------
!
CALL PRINT_MSG(NVERB_DEBUG,'IO','READ_SURFN0_MNH',TRIM(TPINFILE%CNAME)//': reading '//TRIM(HREC))
!

WAUTELET Philippe
committed
KRESP=0

WAUTELET Philippe
committed
ILUOUT = TOUT%NLU

WAUTELET Philippe
committed
!
IF (HREC=='DIM_FULL' .AND. ( CPROGRAM=='IDEAL ' .OR. &
CPROGRAM=='SPAWN ' .OR. CPROGRAM=='ZOOMPG' ))THEN

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,'IMAX',IIMAX)
CALL IO_READ_FIELD(TPINFILE,'JMAX',IJMAX)

WAUTELET Philippe
committed
CALL PREPARE_METADATA_READ_SURF(HREC,'--',0,TYPEINT,0,'READ_SURFN0_MNH',TZFIELD)

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,KFIELD,KRESP)

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ', HREC,'KRESP=',KRESP
WRITE(ILUOUT,*) 'default value may be used, who knows???'
WRITE(ILUOUT,*) ' '
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
ENDIF
ENDIF
!-------------------------------------------------------------------------------
END SUBROUTINE READ_SURFN0_MNH
!
! #############################################################
SUBROUTINE READ_SURFN1_MNH(HREC,KL,KFIELD,KRESP,HCOMMENT,HDIR)
! #############################################################
!
!!**** *READN0* - routine to read an integer
!!
!! PURPOSE
!! -------
!
! The purpose of READN0 is
!
!!** METHOD
!! ------
!!
!! EXTERNAL
!! --------
!!
!!
!!
!! IMPLICIT ARGUMENTS
!! ------------------
!!
!!
!! REFERENCE
!! ---------
!!
!!
!! AUTHOR
!! ------
!!
!! S.Malardel *METEO-FRANCE*
!!
!! MODIFICATIONS
!! -------------
!!
!! original 01/08/03
!----------------------------------------------------------------------------
!
!* 0. DECLARATIONS
! ------------
!

WAUTELET Philippe
committed
USE MODE_FIELD, ONLY: TFIELDDATA,TYPEINT

WAUTELET Philippe
committed
USE MODE_READ_SURF_MNH_TOOLS

WAUTELET Philippe
committed
USE MODD_IO_SURF_MNH, ONLY : TOUT, TPINFILE, NMASK, &
NIU, NJU, NIB, NJB, NIE, NJE
!
USE MODI_PACK_2D_1D
!
IMPLICIT NONE
!
!* 0.1 Declarations of arguments
!

WAUTELET Philippe
committed
CHARACTER(LEN=LEN_HREC),INTENT(IN) :: HREC ! name of the article to be read
INTEGER, INTENT(IN) :: KL ! number of points
INTEGER, DIMENSION(KL), INTENT(OUT) :: KFIELD ! the integer to be read
INTEGER, INTENT(OUT) :: KRESP ! KRESP : return-code if a problem appears
CHARACTER(LEN=100), INTENT(OUT) :: HCOMMENT ! comment
CHARACTER(LEN=1), INTENT(IN) :: HDIR ! type of field :
! ! 'H' : field with
! ! horizontal spatial dim.
! ! '-' : no horizontal dim.
!
!* 0.2 Declarations of local variables
!
INTEGER :: IGRID ! IGRID : grid indicator
INTEGER :: ILENCH ! ILENCH : length of comment string

WAUTELET Philippe
committed
INTEGER :: ILUOUT
!
INTEGER, DIMENSION(:,:), ALLOCATABLE :: IWORK ! work array read in the file

WAUTELET Philippe
committed
TYPE(TFIELDDATA) :: TZFIELD
!---------------------------------------------------------------------
!
CALL PRINT_MSG(NVERB_DEBUG,'IO','READ_SURFN1_MNH',TRIM(TPINFILE%CNAME)//': reading '//TRIM(HREC))
!

WAUTELET Philippe
committed
ILUOUT = TOUT%NLU
!

WAUTELET Philippe
committed
CALL PREPARE_METADATA_READ_SURF(HREC,'--',0,TYPEINT,1,'READ_SURFN1_MNH',TZFIELD)

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,KFIELD,KRESP)

WAUTELET Philippe
committed
ALLOCATE(IWORK(NIU,NJU))

WAUTELET Philippe
committed
CALL PREPARE_METADATA_READ_SURF(HREC,'XY',4,TYPEINT,2,'READ_SURFN1_MNH',TZFIELD)

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,IWORK,KRESP)

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ', HREC,'KRESP=',KRESP
WRITE(ILUOUT,*) 'default value may be used, who knows???'
WRITE(ILUOUT,*) ' '
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
ELSE
CALL PACK_2D_1D(NMASK,IWORK(NIB:NIE,NJB:NJE),KFIELD)
END IF
!
DEALLOCATE(IWORK)
ENDIF
!-------------------------------------------------------------------------------
END SUBROUTINE READ_SURFN1_MNH
!
! #############################################################
SUBROUTINE READ_SURFC0_MNH(HREC,HFIELD,KRESP,HCOMMENT)
! #############################################################
!
!!**** *READC0* - routine to read an integer
!!
!! PURPOSE
!! -------
!
! The purpose of READC0 is
!
!!** METHOD
!! ------
!!
!! EXTERNAL
!! --------
!!
!!
!!
!! IMPLICIT ARGUMENTS
!! ------------------
!!
!!
!! REFERENCE
!! ---------
!!
!!
!! AUTHOR
!! ------
!!
!! S.Malardel *METEO-FRANCE*
!!
!! MODIFICATIONS
!! -------------
!!
!! original 01/08/03
!----------------------------------------------------------------------------
!
!* 0. DECLARATIONS
! ------------
!
USE MODE_ll

WAUTELET Philippe
committed
USE MODE_FIELD, ONLY : TFIELDDATA,TYPECHAR

WAUTELET Philippe
committed
USE MODE_READ_SURF_MNH_TOOLS

WAUTELET Philippe
committed
USE MODD_IO_SURF_MNH, ONLY : TOUT, TPINFILE
USE MODD_CONF, ONLY : LCARTESIAN, CPROGRAM
USE MODD_LUNIT, ONLY : TPGDFILE
!
!
IMPLICIT NONE
!
!* 0.1 Declarations of arguments
!

WAUTELET Philippe
committed
CHARACTER(LEN=LEN_HREC),INTENT(IN) :: HREC ! name of the article to be read
CHARACTER(LEN=40), INTENT(OUT) :: HFIELD ! the integer to be read
INTEGER, INTENT(OUT) :: KRESP ! KRESP : return-code if a problem appears
CHARACTER(LEN=100), INTENT(OUT) :: HCOMMENT ! comment
!
!* 0.2 Declarations of local variables
!
INTEGER :: IRESP ! return code
INTEGER :: IGRID ! IGRID : grid indicator
INTEGER :: ILENCH ! ILENCH : length of comment string

WAUTELET Philippe
committed
INTEGER :: ILUOUT
!
INTEGER :: IMASDEV ! mesonh version of the input file
INTEGER :: ILUDES ! .des file logical unit
!
LOGICAL :: GFOUND
CHARACTER(LEN=4) :: CTURB,CRAD,CGROUND,CCLOUD,CDCONV,CELEC
CHARACTER(LEN=6) :: CSEA_FLUX

WAUTELET Philippe
committed
TYPE(TFIELDDATA) :: TZFIELD

WAUTELET Philippe
committed
!
NAMELIST/NAM_PARAMn/CTURB,CRAD,CGROUND,CCLOUD,CDCONV,CSEA_FLUX, CELEC
!----------------------------------------------------------------------------

WAUTELET Philippe
committed
!
CALL PRINT_MSG(NVERB_DEBUG,'IO','READ_SURFC0_MNH',TRIM(TPINFILE%CNAME)//': reading '//TRIM(HREC))
!

WAUTELET Philippe
committed
KRESP = 0

WAUTELET Philippe
committed
ILUOUT = TOUT%NLU
! On lit la version de Mesonh usilisée pour fabriquer le fichier
!

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,'MASDEV',IMASDEV)
IF (HREC=='SNOW_VEG_TYPE'.AND.IMASDEV<46) THEN
HFIELD='D95'
ELSE IF (HREC=='SNOW_ROAD_TYPE'.AND.IMASDEV<46) THEN
HFIELD='1-L'
ELSE IF (HREC=='SNOW_ROOF_TYPE'.AND.IMASDEV<46) THEN
HFIELD='1-L'
ELSE IF (HREC=='PHOTO'.AND.IMASDEV<46) THEN
HFIELD='NON'
ELSE IF ( HREC=='GRID_TYPE'.AND. (IMASDEV<46 .OR. &
(CPROGRAM=='IDEAL ' .AND. .NOT.ASSOCIATED(TPGDFILE,TOUT)) .OR. &
(CPROGRAM=='SPAWN ' .AND. .NOT.ASSOCIATED(TPGDFILE,TOUT)) .OR. &
CPROGRAM=='ZOOMPG' )) THEN
IF (LCARTESIAN) THEN
HFIELD="CARTESIAN "
ELSE
HFIELD='CONF PROJ '
END IF
ELSE IF ( HREC=='ISBA ' .AND.IMASDEV<46) THEN
HFIELD = '3-L'
ELSE IF ( (HREC=='NATURE'.OR.HREC=='SEA '.OR.HREC=='WATER ' &
.OR.HREC=='TOWN ') .AND.IMASDEV<46) THEN
IF (CPROGRAM=='REAL ' .OR. CPROGRAM=='IDEAL ') THEN
CGROUND='ISBA'
ELSE
CGROUND='NONE'

WAUTELET Philippe
committed
ILUDES = TPINFILE%TDESFILE%NLU

WAUTELET Philippe
committed
CALL POSNAM(ILUDES,'NAM_PARAMN',GFOUND,ILUOUT)
IF (GFOUND) READ(UNIT=ILUDES,NML=NAM_PARAMn)
END IF
IF (CGROUND=='NONE') THEN
HFIELD ='NONE '
ELSE IF (CGROUND=='FLUX') THEN
HFIELD ='FLUX '
ELSE IF (CGROUND=='ISBA') THEN
IF(HREC=='SEA ') HFIELD ='SEAFLX'
IF(HREC=='WATER ') HFIELD ='WATFLX'
IF(HREC=='NATURE') HFIELD ='ISBA '
IF(HREC=='TOWN ') HFIELD ='TEB '
ELSE

WAUTELET Philippe
committed
WRITE(ILUOUT,*) ' '
WRITE(ILUOUT,*) 'error when reading article', HREC,'KRESP=',KRESP
WRITE(ILUOUT,*) 'avec CGROUND = "',CGROUND,'"'
!callabortstop
CALL ABORT
STOP
END IF
ELSE

WAUTELET Philippe
committed
CALL PREPARE_METADATA_READ_SURF(HREC,'--',0,TYPECHAR,0,'READ_SURFC0_MNH',TZFIELD)

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,HFIELD,KRESP)

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ', HREC,'KRESP=',KRESP
WRITE(ILUOUT,*) 'default value may be used, who knows???'
WRITE(ILUOUT,*) ' '
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
!callabortstop
CALL ABORT
STOP
ENDIF
ENDIF
!
!-------------------------------------------------------------------------------
END SUBROUTINE READ_SURFC0_MNH
!
! #############################################################
SUBROUTINE READ_SURFL1_MNH(HREC,KL,OFIELD,KRESP,HCOMMENT,HDIR)
! #############################################################
!
!!**** *READL1* - routine to read a logical array
!!
!! PURPOSE
!! -------
!
! The purpose of READL1 is
!
!!** METHOD
!! ------
!!
!! EXTERNAL
!! --------
!!
!!
!!
!! IMPLICIT ARGUMENTS
!! ------------------
!!
!!
!! REFERENCE
!! ---------
!!
!!
!! AUTHOR
!! ------
!!
!! S.Malardel *METEO-FRANCE*
!!
!! MODIFICATIONS
!! -------------
!!
!! original 01/08/03
!----------------------------------------------------------------------------
!
!* 0. DECLARATIONS
! ------------
!

WAUTELET Philippe
committed
USE MODD_IO_SURF_MNH, ONLY : TOUT, TPINFILE, NMASK, &
NIU, NJU, NIB, NJB, NIE, NJE

WAUTELET Philippe
committed
!

WAUTELET Philippe
committed
USE MODE_FIELD, ONLY : TFIELDDATA,TYPEINT,TYPELOG

WAUTELET Philippe
committed
USE MODE_READ_SURF_MNH_TOOLS

WAUTELET Philippe
committed
!
USE MODI_PACK_2D_1D
!
!
!
IMPLICIT NONE
!
!* 0.1 Declarations of arguments
!

WAUTELET Philippe
committed
CHARACTER(LEN=LEN_HREC),INTENT(IN) :: HREC ! name of the article to be read
INTEGER, INTENT(IN) :: KL ! number of points
LOGICAL, DIMENSION(KL), INTENT(OUT) :: OFIELD ! array containing the data field
INTEGER, INTENT(OUT) :: KRESP ! KRESP : return-code if a problem appears
CHARACTER(LEN=100), INTENT(OUT) :: HCOMMENT ! comment
CHARACTER(LEN=1), INTENT(IN) :: HDIR ! type of field :
! ! 'H' : field with
! ! horizontal spatial dim.
! ! '-' : no horizontal dim.
!
!* 0.2 Declarations of local variables
!
INTEGER :: IGRID ! IGRID : grid indicator
INTEGER :: ILENCH ! ILENCH : length of comment string

WAUTELET Philippe
committed
INTEGER :: ILUOUT
LOGICAL, DIMENSION(:,:), ALLOCATABLE :: GWORK ! work array read in the file
INTEGER, DIMENSION(:,:), ALLOCATABLE :: IWORK ! work array read in the file

WAUTELET Philippe
committed
TYPE(TFIELDDATA) :: TZFIELD
!-------------------------------------------------------------------------------
CALL PRINT_MSG(NVERB_DEBUG,'IO','READ_SURFL1_MNH',TRIM(TPINFILE%CNAME)//': reading '//TRIM(HREC))
!

WAUTELET Philippe
committed
ILUOUT = TOUT%NLU
!

WAUTELET Philippe
committed
CALL PREPARE_METADATA_READ_SURF(HREC,'--',0,TYPELOG,1,'READ_SURFL1_MNH',TZFIELD)

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,OFIELD,KRESP)

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ', HREC,'KRESP=',KRESP
WRITE(ILUOUT,*) 'default value may be used, who knows???'
WRITE(ILUOUT,*) ' '

WAUTELET Philippe
committed
ENDIF

WAUTELET Philippe
committed
ALLOCATE(GWORK(NIU,NJU))
GWORK = .FALSE.
!
ALLOCATE(IWORK(NIU,NJU))

WAUTELET Philippe
committed
CALL PREPARE_METADATA_READ_SURF(HREC,'XY',4,TYPEINT,2,'READ_SURFL1_MNH',TZFIELD)

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,IWORK,KRESP)
WHERE (IWORK==1) GWORK = .TRUE.
DEALLOCATE(IWORK)
!

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ', HREC,'KRESP=',KRESP
WRITE(ILUOUT,*) 'default value may be used, who knows???'
WRITE(ILUOUT,*) ' '

WAUTELET Philippe
committed
ELSE
CALL PACK_2D_1D(NMASK,GWORK(NIB:NIE,NJB:NJE),OFIELD)

WAUTELET Philippe
committed
END IF

WAUTELET Philippe
committed
DEALLOCATE(GWORK)
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
END IF
!-------------------------------------------------------------------------------
END SUBROUTINE READ_SURFL1_MNH
!
! #############################################################
SUBROUTINE READ_SURFL0_MNH(HREC,OFIELD,KRESP,HCOMMENT)
! #############################################################
!
!!**** *READL0* - routine to read a logical
!!
!! PURPOSE
!! -------
!
!
!!** METHOD
!! ------
!!
!! EXTERNAL
!! --------
!!
!!
!!
!! IMPLICIT ARGUMENTS
!! ------------------
!!
!!
!! REFERENCE
!! ---------
!!
!!
!! AUTHOR
!! ------
!!
!! S.Malardel *METEO-FRANCE*
!!
!! MODIFICATIONS
!! -------------
!!
!! original 01/08/03
!----------------------------------------------------------------------------
!
!* 0. DECLARATIONS
! ------------
!

WAUTELET Philippe
committed
USE MODE_FIELD, ONLY : TFIELDDATA,TYPELOG

WAUTELET Philippe
committed
USE MODE_READ_SURF_MNH_TOOLS

WAUTELET Philippe
committed
USE MODD_IO_SURF_MNH, ONLY : TOUT, TPINFILE
!
!
IMPLICIT NONE
!
!* 0.1 Declarations of arguments
!

WAUTELET Philippe
committed
CHARACTER(LEN=LEN_HREC),INTENT(IN) :: HREC ! name of the article to be read
LOGICAL, INTENT(OUT) :: OFIELD ! array containing the data field
INTEGER, INTENT(OUT) :: KRESP ! KRESP : return-code if a problem appears
CHARACTER(LEN=100), INTENT(OUT) :: HCOMMENT ! comment
!
!* 0.2 Declarations of local variables
!
INTEGER :: IMASDEV ! MESONH version

WAUTELET Philippe
committed
INTEGER :: ILUOUT

WAUTELET Philippe
committed
TYPE(TFIELDDATA) :: TZFIELD
!-------------------------------------------------------------------------------
CALL PRINT_MSG(NVERB_DEBUG,'IO','READ_SURFL0_MNH',TRIM(TPINFILE%CNAME)//': reading '//TRIM(HREC))
!

WAUTELET Philippe
committed
ILUOUT = TOUT%NLU
!

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,'MASDEV',IMASDEV)
IF (IMASDEV<=45) THEN
OFIELD = .FALSE.
KRESP = 0
RETURN
END IF
END IF
!
IF (HREC=='ECOCLIMAP') THEN

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,'MASDEV',IMASDEV)
IF (IMASDEV<=46) THEN
OFIELD = .TRUE.
KRESP = 0
RETURN
END IF
END IF
!

WAUTELET Philippe
committed
CALL PREPARE_METADATA_READ_SURF(HREC,'--',0,TYPELOG,0,'READ_SURFL0_MNH',TZFIELD)

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,OFIELD,KRESP)
HCOMMENT = TZFIELD%CCOMMENT
!

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ', HREC,'KRESP=',KRESP
WRITE(ILUOUT,*) 'default value may be used, who knows???'
WRITE(ILUOUT,*) ' '
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
ENDIF
!-------------------------------------------------------------------------------
END SUBROUTINE READ_SURFL0_MNH
!
! #############################################################
SUBROUTINE READ_SURFT0_MNH(HREC,KYEAR,KMONTH,KDAY,PTIME,KRESP,HCOMMENT)
! #############################################################
!
!!**** *READT0* - routine to read a MESO-NH date_time scalar
!!
!! PURPOSE
!! -------
!
! The purpose of READT0 is
!
!!** METHOD
!! ------
!!
!! EXTERNAL
!! --------
!!
!!
!!
!! IMPLICIT ARGUMENTS
!! ------------------
!!
!!
!! REFERENCE
!! ---------
!!
!!
!! AUTHOR
!! ------
!!
!! V. MASSON *METEO-FRANCE*
!!
!! MODIFICATIONS
!! -------------
!!
!! original 18/08/97
!----------------------------------------------------------------------------
!
!* 0. DECLARATIONS
! ------------
!

WAUTELET Philippe
committed
USE MODE_FIELD, ONLY : TFIELDDATA,TYPECHAR

WAUTELET Philippe
committed
USE MODD_IO_SURF_MNH, ONLY : TOUT, TPINFILE

WAUTELET Philippe
committed
USE MODD_TYPE_DATE
!
!
IMPLICIT NONE
!
!* 0.1 Declarations of arguments
!

WAUTELET Philippe
committed
CHARACTER(LEN=LEN_HREC),INTENT(IN) :: HREC ! name of the article to be read
INTEGER, INTENT(OUT) :: KYEAR ! year
INTEGER, INTENT(OUT) :: KMONTH ! month
INTEGER, INTENT(OUT) :: KDAY ! day
REAL, INTENT(OUT) :: PTIME ! time
INTEGER, INTENT(OUT) :: KRESP ! KRESP : return-code if a problem appears
CHARACTER(LEN=100), INTENT(OUT) :: HCOMMENT ! comment
!* 0.2 Declarations of local variables
!
INTEGER :: IGRID ! IGRID : grid indicator
INTEGER :: ILENCH ! ILENCH : length of comment string

WAUTELET Philippe
committed
INTEGER :: ILUOUT

WAUTELET Philippe
committed
CHARACTER(LEN=LEN_HREC) :: YRECFM ! Name of the article to be written
CHARACTER(LEN=40) :: YFILETYPE40! MESONH file type
CHARACTER(LEN=2) :: YFILETYPE2 ! MESONH file type
INTEGER, DIMENSION(3) :: ITDATE
INTEGER :: IMASDEV ! MESONH version

WAUTELET Philippe
committed
TYPE(TFIELDDATA) :: TZFIELD
TYPE(DATE_TIME) :: TZDATETIME
!-------------------------------------------------------------------------------
!
CALL PRINT_MSG(NVERB_DEBUG,'IO','READ_SURFT0_MNH',TRIM(TPINFILE%CNAME)//': reading '//TRIM(HREC))

WAUTELET Philippe
committed
ILUOUT = TOUT%NLU
!

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,'MASDEV',IMASDEV)

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,'STORAGE_TYPE',YFILETYPE2)

WAUTELET Philippe
committed
TZFIELD%CMNHNAME = 'STORAGETYPE'
TZFIELD%CSTDNAME = ''

WAUTELET Philippe
committed
TZFIELD%CLONGNAME = 'STORAGETYPE'

WAUTELET Philippe
committed
TZFIELD%CUNITS = ''
TZFIELD%CDIR = '--'

WAUTELET Philippe
committed
TZFIELD%CCOMMENT = ''

WAUTELET Philippe
committed
TZFIELD%NGRID = 0
TZFIELD%NTYPE = TYPECHAR
TZFIELD%NDIMS = 0
TZFIELD%LTIMEDEP = .FALSE.

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,YFILETYPE40)
YFILETYPE2 = YFILETYPE40(1:2)
END IF
IF (YFILETYPE2(1:2)=='PG') THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'Date is not read in a PGD file'
WRITE(ILUOUT,*) 'Atmospheric model value is kept'
WRITE(ILUOUT,*) ' '
KRESP = -2
RETURN
END IF
!

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,HREC,TZDATETIME,KRESP)
!

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ',YRECFM,'KRESP=',KRESP
WRITE(ILUOUT,*) 'default value may be used, who knows???'
WRITE(ILUOUT,*) ' '

WAUTELET Philippe
committed
ENDIF
!
KYEAR = TZDATETIME%TDATE%YEAR
KMONTH = TZDATETIME%TDATE%MONTH
KDAY = TZDATETIME%TDATE%DAY
PTIME = TZDATETIME%TIME
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
!
!-------------------------------------------------------------------------------
END SUBROUTINE READ_SURFT0_MNH
! #############################################################
SUBROUTINE READ_SURFT1_MNH(HREC,KL1,KYEAR,KMONTH,KDAY,PTIME,KRESP,HCOMMENT)
! #############################################################
!
!!**** *READT0* - routine to read a MESO-NH date_time vector
!!
!! PURPOSE
!! -------
!
! The purpose of READT1 is
!
!!** METHOD
!! ------
!!
!! EXTERNAL
!! --------
!!
!!
!!
!! IMPLICIT ARGUMENTS
!! ------------------
!!
!!
!! REFERENCE
!! ---------
!!
!!
!! AUTHOR
!! ------
!!
!! G. TANGUY *METEO-FRANCE*
!!
!! MODIFICATIONS
!! -------------
!!
!! original 03/2009
!----------------------------------------------------------------------------
!
!* 0. DECLARATIONS
! ------------
!
USE MODE_FIELD, ONLY : TFIELDDATA,TYPECHAR,TYPEINT,TYPEREAL

WAUTELET Philippe
committed
USE MODD_IO_SURF_MNH, ONLY : TOUT, TPINFILE
!
!
IMPLICIT NONE
!
!* 0.1 Declarations of arguments
!

WAUTELET Philippe
committed
CHARACTER(LEN=LEN_HREC), INTENT(IN) :: HREC ! name of the article to be read
INTEGER, INTENT(IN) :: KL1 ! number of points
INTEGER, DIMENSION(KL1), INTENT(OUT) :: KYEAR ! year
INTEGER, DIMENSION(KL1), INTENT(OUT) :: KMONTH ! month
INTEGER, DIMENSION(KL1), INTENT(OUT) :: KDAY ! day
REAL, DIMENSION(KL1), INTENT(OUT) :: PTIME ! time

WAUTELET Philippe
committed
INTEGER, INTENT(OUT) :: KRESP ! KRESP : return-code if a problem appears
CHARACTER(LEN=100), INTENT(OUT) :: HCOMMENT ! comment
!* 0.2 Declarations of local variables
!
INTEGER :: IGRID ! IGRID : grid indicator
INTEGER :: ILENCH ! ILENCH : length of comment string

WAUTELET Philippe
committed
INTEGER :: ILUOUT

WAUTELET Philippe
committed
CHARACTER(LEN=LEN_HREC) :: YRECFM ! Name of the article to be written
CHARACTER(LEN=40) :: YFILETYPE40! MESONH file type
CHARACTER(LEN=2) :: YFILETYPE2 ! MESONH file type
INTEGER, DIMENSION(3,KL1) :: ITDATE
INTEGER :: IMASDEV ! MESONH version

WAUTELET Philippe
committed
TYPE(TFIELDDATA) :: TZFIELD
!-------------------------------------------------------------------------------
!
CALL PRINT_MSG(NVERB_DEBUG,'IO','READ_SURFT1_MNH',TRIM(TPINFILE%CNAME)//': reading '//TRIM(HREC))

WAUTELET Philippe
committed
ILUOUT = TOUT%NLU
!

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,'MASDEV',IMASDEV)

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,'STORAGE_TYPE',YFILETYPE2)

WAUTELET Philippe
committed
TZFIELD%CMNHNAME = 'STORAGETYPE'
TZFIELD%CSTDNAME = ''

WAUTELET Philippe
committed
TZFIELD%CLONGNAME = 'STORAGETYPE'

WAUTELET Philippe
committed
TZFIELD%CUNITS = ''
TZFIELD%CDIR = '--'

WAUTELET Philippe
committed
TZFIELD%CCOMMENT = ''

WAUTELET Philippe
committed
TZFIELD%NGRID = 0
TZFIELD%NTYPE = TYPECHAR
TZFIELD%NDIMS = 0
TZFIELD%LTIMEDEP = .FALSE.

WAUTELET Philippe
committed
CALL IO_READ_FIELD(TPINFILE,TZFIELD,YFILETYPE40)
YFILETYPE2 = YFILETYPE40(1:2)
END IF
!IF (YFILETYPE2(1:2)=='PG') THEN

WAUTELET Philippe
committed
! WRITE(ILUOUT,*) 'WARNING'
! WRITE(ILUOUT,*) '-------'
! WRITE(ILUOUT,*) 'Date is not read in a PGD file'
! WRITE(ILUOUT,*) 'Atmospheric model value is kept'
! WRITE(ILUOUT,*) ' '
! KRESP = -2
! RETURN
!END IF
!
TZFIELD%CMNHNAME = TRIM(HREC)//'%TDATE'
TZFIELD%CSTDNAME = ''

WAUTELET Philippe
committed
TZFIELD%CLONGNAME = TRIM(TZFIELD%CMNHNAME)
TZFIELD%CUNITS = ''
TZFIELD%CDIR = '--'
TZFIELD%CCOMMENT = TRIM(HCOMMENT)
TZFIELD%NGRID = 0
TZFIELD%NTYPE = TYPEINT
TZFIELD%NDIMS = 2
TZFIELD%LTIMEDEP = .FALSE.
!
CALL IO_READ_FIELD(TPINFILE,TZFIELD,ITDATE(:,:),KRESP)
!
KYEAR(:) = ITDATE(1,:)
KMONTH(:) = ITDATE(2,:)
KDAY(:) = ITDATE(3,:)

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ',YRECFM,'KRESP=',KRESP
WRITE(ILUOUT,*) 'default value may be used, who knows???'
WRITE(ILUOUT,*) ' '

WAUTELET Philippe
committed
ENDIF
TZFIELD%CMNHNAME = TRIM(HREC)//'%TIME'
TZFIELD%CSTDNAME = ''

WAUTELET Philippe
committed
TZFIELD%CLONGNAME = TRIM(TZFIELD%CMNHNAME)
TZFIELD%CUNITS = ''
TZFIELD%CDIR = '--'
TZFIELD%CCOMMENT = TRIM(HCOMMENT)
TZFIELD%NGRID = 0
TZFIELD%NTYPE = TYPEREAL
TZFIELD%NDIMS = 1
TZFIELD%LTIMEDEP = .FALSE.
!
CALL IO_READ_FIELD(TPINFILE,TZFIELD,PTIME(:),KRESP)
!

WAUTELET Philippe
committed
IF (KRESP /=0) THEN

WAUTELET Philippe
committed
WRITE(ILUOUT,*) 'WARNING'
WRITE(ILUOUT,*) '-------'
WRITE(ILUOUT,*) 'error when reading article ',YRECFM,'KRESP=',KRESP
WRITE(ILUOUT,*) 'default value may be used, who knows???'
WRITE(ILUOUT,*) ' '

WAUTELET Philippe
committed
ENDIF
!-------------------------------------------------------------------------------
END SUBROUTINE READ_SURFT1_MNH