source: CPL/oasis3-mct/branches/OASIS3-MCT_2.0_branch/examples/test_interpolation/write_all_fields.F90

Last change on this file 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: 3.5 KB
Line 
1MODULE write_all_fields 
2  !
3  USE netcdf
4  IMPLICIT NONE
5  !
6  !
7  CONTAINS
8    !
9 !****************************************************************************************
10  SUBROUTINE write_field (nlon,nlat, &
11                          data_filename, field_name, w_unit, FILE_Debug, &
12                          gridlon, gridlat, array)
13  !**************************************************************************************
14  !
15#ifdef NO_USE_DOUBLE_PRECISION
16  INTEGER, PARAMETER :: wp = SELECTED_REAL_KIND(6,37)   ! real
17#elif defined USE_DOUBLE_PRECISION
18  INTEGER, PARAMETER :: wp = SELECTED_REAL_KIND(12,307) ! double
19#endif
20  !
21  !
22  INTEGER                  :: i,j,k,w_unit,FILE_Debug
23  !
24  INTEGER                  :: il_file_id, il_array_id, il_lon_id, il_lat_id 
25  INTEGER                  :: LONID, LATID
26  !               
27  INTEGER, INTENT(in)     :: nlon,nlat
28  !
29  CHARACTER(len=30)        :: data_filename,field_name
30  !
31  INTEGER,  DIMENSION(2)   :: ila_dim
32  INTEGER,  DIMENSION(2)   :: ila_what
33  !
34  REAL (kind=wp), DIMENSION(nlon,nlat)  :: gridlon,gridlat
35  REAL (kind=wp), DIMENSION(nlon,nlat)  :: array
36  !
37  !
38  ! Dimensions
39  !
40  CALL hdlerr(NF90_CREATE(data_filename, NF90_CLOBBER, il_file_id), __LINE__ )
41  !
42  CALL hdlerr( NF90_DEF_DIM(il_file_id, "lon", nlon, LONID), __LINE__ )
43  CALL hdlerr( NF90_DEF_DIM(il_file_id, "lat", nlat, LATID), __LINE__ )
44  !
45#ifdef NO_USE_DOUBLE_PRECISION
46  CALL hdlerr( NF90_DEF_VAR(il_file_id, "lon", NF90_REAL, (/LONID, LATID/), il_lon_id), __LINE__ )
47  CALL hdlerr( NF90_PUT_ATT(il_file_id, il_lon_id, "units", "degrees_east"), __LINE__ )
48  CALL hdlerr( NF90_PUT_ATT(il_file_id, il_lon_id, "standard_name", "longitude"), __LINE__ )
49  CALL hdlerr( NF90_DEF_VAR(il_file_id, "lat", NF90_REAL, (/LONID, LATID/), il_lat_id), __LINE__ )
50  CALL hdlerr( NF90_PUT_ATT(il_file_id, il_lat_id, "units", "degrees_north"), __LINE__ )
51  CALL hdlerr( NF90_PUT_ATT(il_file_id, il_lat_id, "standard_name", "latitude"), __LINE__ )
52  !
53  CALL hdlerr( NF90_DEF_VAR(il_file_id, TRIM(field_name), NF90_REAL, (/LONID, LATID/), il_array_id), __LINE__ )
54#elif defined USE_DOUBLE_PRECISION
55  CALL hdlerr( NF90_DEF_VAR(il_file_id, "lon", NF90_DOUBLE, (/LONID, LATID/), il_lon_id), __LINE__ )
56  CALL hdlerr( NF90_PUT_ATT(il_file_id, il_lon_id, "units", "degrees_east"), __LINE__ )
57  CALL hdlerr( NF90_PUT_ATT(il_file_id, il_lon_id, "standard_name", "longitude"), __LINE__ )
58  CALL hdlerr( NF90_DEF_VAR(il_file_id, "lat", NF90_DOUBLE, (/LONID, LATID/), il_lat_id), __LINE__ )
59  CALL hdlerr( NF90_PUT_ATT(il_file_id, il_lat_id, "units", "degrees_north"), __LINE__ )
60  CALL hdlerr( NF90_PUT_ATT(il_file_id, il_lat_id, "standard_name", "latitude"), __LINE__ )
61  !
62  CALL hdlerr( NF90_DEF_VAR(il_file_id, TRIM(field_name), NF90_DOUBLE, (/LONID, LATID/), il_array_id), __LINE__ )
63#endif
64  !
65  CALL hdlerr( NF90_ENDDEF(il_file_id), __LINE__ )
66  !
67  ila_what(:)=1
68  !
69  ila_dim(1)=nlon
70  ila_dim(2)=nlat
71  !
72  ! Data
73  !
74  CALL hdlerr( NF90_PUT_VAR (il_file_id, il_lon_id, gridlon, &
75     ila_what, ila_dim), __LINE__ )
76  !
77  CALL hdlerr( NF90_PUT_VAR (il_file_id, il_lat_id, gridlat, &
78     ila_what, ila_dim), __LINE__ )
79  !
80  CALL hdlerr( NF90_PUT_VAR (il_file_id, il_array_id, array, &
81     ila_what, ila_dim), __LINE__ )
82  IF (FILE_Debug >= 2) THEN
83      WRITE(w_unit,*) 'Global grid mask reading done'
84      CALL FLUSH(w_unit)
85  ENDIF
86  !
87  CALL hdlerr( NF90_CLOSE(il_file_id), __LINE__ )
88  !
89  IF (FILE_Debug >= 2) THEN
90      WRITE(w_unit,*) 'End of routine write field'
91      CALL FLUSH(w_unit)
92  ENDIF
93  !
94END SUBROUTINE write_field
95
96END MODULE write_all_fields
Note: See TracBrowser for help on using the repository browser.