source: CONFIG_DEVT/IPSLCM6.5_work_ENSEMBLES/oasis3-mct/examples/test_1bin_ocnice/read_dimgrid.F90 @ 5725

Last change on this file since 5725 was 5725, checked in by aclsce, 3 years ago

Added new oasis3-MCT version to be used to handle ensembles simulations with XIOS.

File size: 2.9 KB
Line 
1!****************************************************************************************
2SUBROUTINE read_dimgrid (nlon,nlat,data_filename,w_unit,FILE_Debug)
3  !**************************************************************************************
4  USE netcdf
5  IMPLICIT NONE
6
7  INTEGER                  :: i,j,k,w_unit,FILE_Debug
8
9  INTEGER                  :: il_file_id,il_grid_id,il_lon_id, &
10     il_lat_id,il_indice_id, &
11     lon_dims,lat_dims,imask_dims
12
13  INTEGER, DIMENSION(NF90_MAX_VAR_DIMS) :: lon_dims_ids,lat_dims_ids,&
14     imask_dims_ids,lon_dims_len,&
15     lat_dims_len,imask_dims_len 
16
17  INTEGER, INTENT(out)     :: nlon,nlat
18
19  CHARACTER(len=*)        :: data_filename
20
21  ! Dimensions
22
23  IF (FILE_Debug >= 2) THEN
24      WRITE(w_unit,*) 'Reading input file ',data_filename
25      CALL FLUSH(w_unit)
26  ENDIF
27
28  CALL hdlerr(NF90_OPEN(data_filename, NF90_NOWRITE, il_file_id), __LINE__ )
29
30  CALL hdlerr( NF90_INQ_VARID(il_file_id, 'lon' ,  il_lon_id),    __LINE__ )
31  CALL hdlerr( NF90_INQ_VARID(il_file_id, 'lat' ,  il_lat_id),    __LINE__ )
32  CALL hdlerr( NF90_INQ_VARID(il_file_id, 'imask', il_indice_id), __LINE__ )
33
34  CALL hdlerr( NF90_INQUIRE_VARIABLE(il_file_id, varid=il_lon_id, ndims=lon_dims, dimids=lon_dims_ids), __LINE__ )
35
36  ! The value lon_dims_len(i) is obtained thanks to the lon_dims_ids ID already obtained from the file
37  DO i=1,lon_dims
38    CALL hdlerr( NF90_INQUIRE_DIMENSION(ncid=il_file_id,dimid=lon_dims_ids(i),len=lon_dims_len(i)), __LINE__ )
39  ENDDO
40
41  nlon=lon_dims_len(1)
42  nlat=lon_dims_len(2)
43  !++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
44
45  CALL hdlerr( NF90_INQUIRE_VARIABLE(ncid=il_file_id, varid=il_lat_id, ndims=lat_dims, dimids=lat_dims_ids), __LINE__ )
46
47  ! The value lat_dims_len(i) is obtained thanks to the lat_dims_ids ID already obtained from the file
48  DO i=1,lat_dims
49    CALL hdlerr( NF90_INQUIRE_DIMENSION(ncid=il_file_id,dimid=lat_dims_ids(i),len=lat_dims_len(i)), __LINE__ )
50  ENDDO
51
52  IF ( (lat_dims_len(1) .NE. lon_dims_len(1)).OR.(lat_dims_len(2) .NE. lon_dims_len(2)) ) THEN
53      WRITE(w_unit,*) 'Problem in read_dimgrid'
54      WRITE(w_unit,*) 'Dimensions of the latitude are not the same as the ones of the longitude'
55      CALL flush(w_unit)
56      STOP
57  ENDIF
58  !++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
59
60  CALL hdlerr( NF90_INQUIRE_VARIABLE(ncid=il_file_id, varid=il_indice_id, ndims=imask_dims, dimids=imask_dims_ids), __LINE__ )
61
62  ! The value imask_dims_len(i) is obtained thanks to the imask_dims_ids ID already obtained from the file
63  DO i=1,imask_dims
64    CALL hdlerr( NF90_INQUIRE_DIMENSION(ncid=il_file_id,dimid=imask_dims_ids(i),len=imask_dims_len(i)), __LINE__ )
65  ENDDO
66
67  CALL hdlerr(NF90_CLOSE(il_file_id), __LINE__ )
68
69  IF (FILE_Debug >= 2) THEN
70      WRITE(w_unit,*) 'Done with input file ',data_filename
71      WRITE(w_unit,*) 'Global dimensions nlon=',nlon,' nlat=',nlat
72      CALL FLUSH(w_unit)
73  ENDIF
74
75
76END SUBROUTINE read_dimgrid
Note: See TracBrowser for help on using the repository browser.