source: CPL/oasis3-mct/branches/OASIS3-MCT_2.0_branch/examples/tutorial/read_dimgrid.F90 @ 4775

Last change on this file since 4775 was 4775, checked in by aclsce, 5 years ago
  • Imported oasis3-mct from Cerfacs svn server (not suppotred anymore).

The version has been extracted from https://oasis3mct.cerfacs.fr/svn/branches/OASIS3-MCT_2.0_branch/oasis3-mct@1818

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