source: LMDZ6/branches/contrails/libf/phylmd/iotd_ini.f90 @ 5467

Last change on this file since 5467 was 5450, checked in by aborella, 3 weeks ago

Merge with trunk

File size: 5.1 KB
Line 
1      SUBROUTINE iotd_ini(fichnom,iim,jjm,llm,prlon,prlat,pcoordv,jour0,mois0,an0,t0,timestep,calendrier)
2      USE netcdf, ONLY: nf90_enddef, nf90_put_att, nf90_float, nf90_def_var, nf90_redef, &
3            nf90_global, nf90_def_dim, nf90_create, nf90_clobber, nf90_unlimited, nf90_put_var
4      USE iotd_mod_h
5      IMPLICIT NONE
6
7!=======================================================================
8!
9!   Auteur:  F. Hourdin
10!   -------
11!
12!   Objet:
13!   ------
14!   Light interface for netcdf outputs. can be used outside LMDZ
15!
16!=======================================================================
17!-----------------------------------------------------------------------
18
19!   Arguments:
20!   ----------
21
22      integer iim,jjm,llm
23      real prlon(iim),prlat(jjm),pcoordv(llm),timestep,t0
24      INTEGER id_FOCE
25      INTEGER jour0,mois0,an0
26      CHARACTER*(*) calendrier
27
28      integer corner(4),edges(4),ndim
29      real  px(1000)
30      character (len=10) :: nom
31      real*4 rlon(iim),rlat(jjm),coordv(llm)
32
33!   Local:
34!   ------
35      CHARACTER*3,DIMENSION(12) :: cmois=(/'JAN','FEB','MAR','APR','MAY','JUN','JUL','AUG','SEP','OCT','NOV','DEC'/)
36      CHARACTER*10 date0
37      CHARACTER*11 date0b
38
39      INTEGER :: ierr
40
41      integer :: nvarid
42      integer, dimension(2) :: id 
43
44      character*(*) fichnom
45
46      real pi
47
48      iotd_ts=timestep
49      iotd_t0=t0
50      print*,'iotd_ini, ',timestep,iotd_ts
51      imax=iim
52      jmax=jjm
53      lmax=llm
54      ! Utile pour passer en real*4 pour les ecritures
55      rlon=prlon
56      rlat=prlat
57      coordv=pcoordv
58
59
60      !-----------------------------------------------------------------------
61      ! Possibilité de spécifier une liste de variables à sortir
62      ! dans iotd.def
63      ! Si iotd.def existe et est non vide,
64      ! seules les variables faisant à la fois l'objet d'un call iotd_ecrit
65      ! et étant spécifiées dans iotd.def sont sorties.
66      ! Sinon, toutes les variables faisant l'objet d'un call iotd_ecrit
67      ! sont sorties
68      !-----------------------------------------------------------------------
69      n_names_iotd_def=0
70      open(99,file='iotd.def',form='formatted',status='old',iostat=ierr)
71         if ( ierr.eq.0 ) then
72            ierr=0
73            do while (ierr==0)
74               read(99,*,iostat=ierr) un_nom
75               if (ierr==0) then
76                  n_names_iotd_def=n_names_iotd_def+1
77                  names_iotd_def(n_names_iotd_def)=un_nom
78               endif
79            enddo
80         endif
81         print*,n_names_iotd_def,names_iotd_def(1:n_names_iotd_def)
82      close(99)
83
84
85      pi=2.*asin(1.)
86
87! Define dimensions
88   
89      ! Create the NetCDF file
90      ierr=nf90_create(fichnom, nf90_clobber, nid)
91      ierr=nf90_def_dim(nid, "lon", iim, dim_coord(1))
92      ierr=nf90_def_dim(nid, "lat", jjm, dim_coord(2))
93      ierr=nf90_def_dim(nid, "lev", llm, dim_coord(3))
94      ierr=nf90_def_dim(nid,"time",nf90_unlimited,dim_coord(4))
95      ierr = nf90_put_att(nid,nf90_global,'Conventions',"CF-1.1")
96      ierr=nf90_enddef(nid)
97
98      ! Switch out of NetCDF Define mode
99
100
101      ierr=nf90_enddef(nid)
102!
103!  Contol parameters for this run
104! ---- longitude -----------
105
106      ierr=nf90_redef(nid)
107      ierr=nf90_def_var(nid,"lon", nf90_float, dim_coord(1),nvarid)
108      ierr = nf90_put_att(nid,nvarid,'axis','X')
109      ierr=nf90_put_att(nid,nvarid,'units',"degrees_east")
110      ierr=nf90_enddef(nid)
111      ierr=nf90_put_var(nid,nvarid,rlon)
112       print*,ierr
113
114! ---- latitude ------------
115      ierr=nf90_redef(nid)
116      ierr=nf90_def_var(nid, "lat", nf90_float, dim_coord(2),nvarid)
117      ierr = nf90_put_att(nid,nvarid,'axis','Y')
118      ierr=nf90_put_att(nid,nvarid,'units',"degrees_north")
119      ierr=nf90_enddef(nid)
120      ierr=nf90_put_var(nid,nvarid,rlat)
121!
122! ---- vertical ------------
123      ierr=nf90_redef(nid)
124      ierr=nf90_def_var(nid, "lev", nf90_float, dim_coord(3),nvarid)
125      ierr=nf90_put_att(nid,nvarid,"long_name","vert level")
126
127      if ( coordv(min(2,llm))>=coordv(1) ) then
128         ierr=nf90_put_att(nid,nvarid,"long_name","pseudo-alt")
129         ierr=nf90_put_att(nid,nvarid,'positive',"up")
130      else
131         ierr=nf90_put_att(nid,nvarid,"long_name","pressure")
132         ierr = nf90_put_att (nid,nvarid,'positive',"down")
133      endif
134      ierr=nf90_enddef(nid)
135      ierr=nf90_put_var(nid,nvarid,coordv)
136
137!
138! ---- time ----------------
139      ierr=nf90_redef(nid)
140      ! Define the 'time' variable
141      ierr=nf90_def_var(nid, "time", nf90_float, dim_coord(4),nvarid)
142!     ! Add attributes
143      ierr = nf90_put_att(nid,nvarid,'axis','T')
144      ierr = nf90_put_att(nid,nvarid,'standard_name','time')
145      WRITE(date0,'(i4.4,"-",i2.2,"-",i2.2)') an0,mois0,jour0
146      ierr=nf90_put_att(nid, nvarid,'units', &
147     & "seconds since "//date0//" 00:00:00")
148      ierr = nf90_put_att(nid,nvarid,'calendar',calendrier)
149      !ierr = nf90_put_att(nid,nvarid,'calendar','360d')
150      ierr = nf90_put_att(nid,nvarid,'title','Time')
151      ierr = nf90_put_att(nid,nvarid,'long_name','Time axis')
152      WRITE(date0b,'(i4.4,"-",a3,"-",i2.2)') an0,cmois(mois0),jour0
153      ierr = nf90_put_att(nid,nvarid,'time_origin', &
154     &        date0b//' 00:00:00')
155      ierr=nf90_enddef(nid)
156
157
158      END SUBROUTINE iotd_ini
Note: See TracBrowser for help on using the repository browser.