source: LMDZ4/branches/IPSL-CM4_IPCC_branch/libf/phylmd/ini_histday.h @ 1117

Last change on this file since 1117 was 524, checked in by lmdzadmin, 21 years ago

Initial revision

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 17.7 KB
Line 
1!
2! $Header$
3!
4      IF (ok_journe) THEN
5c
6         zsto = dtime
7         zout = dtime * FLOAT(ecrit_day)
8         zsto1= dtime * FLOAT(ecrit_day)
9c         zout = dtime * REAL(ecrit_day)
10c         zsto1= dtime * REAL(ecrit_day)
11c
12         idayref = day_ref
13         CALL ymds2ju(annee_ref, 1, idayref, 0.0, zjulian)
14c
15         CALL gr_fi_ecrit(1,klon,iim,jjmp1,rlon,zx_lon)
16         DO i = 1, iim
17            zx_lon(i,1) = rlon(i+1)
18            zx_lon(i,jjmp1) = rlon(i+1)
19         ENDDO
20         DO ll=1,klev
21            znivsig(ll)=float(ll)
22         ENDDO
23         CALL gr_fi_ecrit(1,klon,iim,jjmp1,rlat,zx_lat)
24         CALL histbeg("histday", iim,zx_lon(:,1), jjmp1,zx_lat(1,:),
25     .                 1,iim,1,jjmp1, itau_phy, zjulian, dtime, 
26     .                 nhori, nid_day)
27         write(*,*)'Journee ', itau_phy, zjulian
28         CALL histvert(nid_day, "presnivs", "Vertical levels", "mb",
29     .                 klev, presnivs, nvert)
30c
31       IF(lev_histday.GE.1) THEN
32c
33         CALL histdef(nid_day, "phis", "Surface geop. height", "-",
34     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
35     .                "once", zsto,zout)
36c
37         CALL histdef(nid_day, "aire", "Grid area", "-",
38     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
39     .                "once", zsto,zout)
40c
41         CALL histdef(nid_day, "contfracATM","% sfce ter+lic ","-",
42     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
43     .                "once", zsto,zout)
44c
45         CALL histdef(nid_day, "contfracOR","% sfce terre OR", "-",
46     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
47     .                "once", zsto,zout)
48c
49c Champs 2D:
50c
51         CALL histdef(nid_day, "tsol", "Surface Temperature", "K",
52     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
53     .                "ave(X)", zsto,zout)
54c
55         CALL histdef(nid_day, "t2m", "Temperature 2m", "K",
56     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
57     .                "ave(X)", zsto,zout)
58c
59c Champs retires momentannéement en attendant un hypothetique
60c debugage
61
62         CALL histdef(nid_day, "t2m_min", "Temp. 2m min.",
63     .                "K",
64     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
65     .                t2mincels, zsto,zout)
66c
67         CALL histdef(nid_day, "t2m_max", "Temp. 2m max.",
68     .                "K",
69     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
70     .                t2maxcels, zsto,zout)
71c
72         CALL histdef(nid_day, "plul", "Large-scale Precip.",
73     .   "kg/(s*m2)",
74     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
75     .                "ave(X)", zsto,zout)
76c
77         CALL histdef(nid_day, "pluc", "Convective Precip.",
78     .   "kg/(s*m2)",
79     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
80     .                "ave(X)", zsto,zout)
81c
82         CALL histdef(nid_day, "snowl", "Solid Large-scale Precip.",
83     .   "kg/(s*m2)",
84     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
85     .                "ave(X)", zsto,zout)
86c
87         IF(1.EQ.0) THEN !snowc=0.
88         CALL histdef(nid_day, "snowc", "Solid Convective Precip.",
89     .   "kg/(s*m2)",
90     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
91     .                "ave(X)", zsto,zout)
92         ENDIF !snowc=0.
93c
94         CALL histdef(nid_day, "flat", "Latent heat flux", "W/m2",
95     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
96     .                "ave(X)", zsto,zout)
97c
98         CALL histdef(nid_day, "sicf", "Sea-ice fraction", "-",
99     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
100     .                "inst(X)", zsto1,zout)
101c
102         CALL histdef(nid_day, "q2m", "Specific humidity", "kg/kg",
103     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
104     .                "ave(X)", zsto,zout)
105c
106         CALL histdef(nid_day, "u10m", "Vent zonal 10m", "m/s",
107     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
108     .                "ave(X)", zsto,zout)
109c
110         CALL histdef(nid_day, "v10m", "Vent meridien 10m", "m/s",
111     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
112     .                "ave(X)", zsto,zout)
113c
114         CALL histdef(nid_day, "wind10m","10-m wind speed","m/s",
115     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
116     .                "ave(X)", zsto,zout)
117c
118         CALL histdef(nid_day, "wind10max", "10-m wind speed max.",
119     .                "m/s",
120     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
121     .                t2maxcels, zsto,zout)
122c
123         CALL histdef(nid_day, "psol", "Surface Pressure", "Pa",
124     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
125     .                "ave(X)", zsto,zout)
126c
127         CALL histdef(nid_day, "precip","Precipitation Totale liq+sol"
128     .                , "kg/(s*m2)",
129     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
130     .                "ave(X)", zsto,zout)
131c
132         CALL histdef(nid_day, "snowf", "Snow fall", "kg/(s*m2)",
133     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
134     .                "ave(X)", zsto,zout)
135c
136         CALL histdef(nid_day, "snow_mass", "Snow Mass", "kg/m2",
137     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
138     .                "ave(X)", zsto,zout)
139c
140         CALL histdef(nid_day, "evap", "Evaporation", "kg/(s*m2)",
141     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
142     .                "ave(X)", zsto,zout)
143c
144         CALL histdef(nid_day, "tops", "Solar rad. at TOA", "W/m2",
145     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
146     .                "ave(X)", zsto,zout)
147c
148         CALL histdef(nid_day, "topl", "IR rad. at TOA", "W/m2",
149     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
150     .                "ave(X)", zsto,zout)
151c
152         CALL histdef(nid_day, "sols", "Net Solar rad. at surf.", 
153     .                "W/m2",
154     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
155     .                "ave(X)", zsto,zout)
156c
157         CALL histdef(nid_day, "soll", "Net IR rad. at surface", "W/m2",
158     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
159     .                "ave(X)", zsto,zout)
160c
161         CALL histdef(nid_day, "cldl", "Low-level cloudiness", "-",
162     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
163     .                "ave(X)", zsto,zout)
164c
165         CALL histdef(nid_day, "cldm", "Mid-level cloudiness", "-",
166     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
167     .                "ave(X)", zsto,zout)
168c
169         CALL histdef(nid_day, "cldh", "High-level cloudiness", "-",
170     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
171     .                "ave(X)", zsto,zout)
172c
173         CALL histdef(nid_day, "cldt", "Total cloudiness", "-",
174     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
175     .                "ave(X)", zsto,zout)
176c
177         CALL histdef(nid_day, "cldq", "Cloud liquid water path", 
178     .                "kg/m2",
179     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
180     .                "ave(X)", zsto,zout)
181c
182         CALL histdef(nid_day, "prw", "Precipitable water", "kg/m2",
183     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
184     .                "ave(X)", zsto,zout)
185c
186c  Champs dynamiques sur niveaux de pression
187         DO k=1, nlevENS
188c
189          CALL histdef(nid_day, "u"//clev(k),
190     .                 "Zonal wind"//clev(k)//"mb","m/s",
191     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
192     .                "ave(X)", zsto,zout)
193c
194          CALL histdef(nid_day, "v"//clev(k),
195     .                 "Meridional wind"//clev(k)//"mb","m/s",
196     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
197     .                "ave(X)", zsto,zout)
198c
199         ENDDO !nlevENS
200c
201         CALL histdef(nid_day, "w500", "Verical wind 500mb", "m/s",
202     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
203     .                "ave(X)", zsto,zout)
204c
205         CALL histdef(nid_day,"phi500", "Geopotentiel a 500mb","m2/s2",
206     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
207     .                "ave(X)", zsto,zout)
208c
209         CALL histdef(nid_day, "slp", "Sea Level Pressure", "Pa",
210     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
211     .                "ave(X)", zsto,zout)
212c
213         CALL histdef(nid_day, "cape_max", "CAPE max.",
214     .                "J/kg",
215     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
216     .                capemaxcels, zsto,zout)
217c
218         CALL histdef(nid_day, "solldown", "Down. IR rad. at surface", 
219     .                "W/m2", iim,jjmp1,nhori, 1,1,1, -99, 32, 
220     .                "ave(X)", zsto,zout)
221c
222         CALL histdef(nid_day, "sens", "Sensible heat flux", "W/m2",
223     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
224     .                "ave(X)", zsto,zout)
225c
226         CALL histdef(nid_day, "SWdnSFC", "SWdn at surface","W/m2",
227     .                iim,jjmp1,nhori, 1,1,1,-99,
228     .                32, "ave(X)", zsto,zout)
229c
230      ENDIF !lev_histday.GE.1
231c
232      IF (lev_histday.GE.2) THEN
233c
234         CALL histdef(nid_day, "bils", "Surf. total heat flux", "W/m2",
235     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
236     .                "ave(X)", zsto,zout)
237c
238         CALL histdef(nid_day, "fder", "Heat flux derivation", "W/m2/K",
239     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
240     .                "ave(X)", zsto,zout)
241c
242      ENDIF !lev_histday.GE.2
243c=================================================================
244      IF(lev_histday.GE.3) THEN
245c=================================================================
246c   INITIALISATION DES CHAMPS 3D
247c=================================================================
248c=================================================================
249c=================================================================
250c Champs 3D:
251c
252         CALL histdef(nid_day, "temp", "Air temperature", "K",
253     .                iim,jjmp1,nhori, klev,1,klev,nvert, 32,
254     .                "ave(X)", zsto,zout)
255c
256         CALL histdef(nid_day, "ovap", "Specific humidity", "kg/kg",
257     .                iim,jjmp1,nhori, klev,1,klev,nvert, 32,
258     .                "ave(X)", zsto,zout)
259c
260         CALL histdef(nid_day, "geop", "Geopotential height", "m",
261     .                iim,jjmp1,nhori, klev,1,klev,nvert, 32,
262     .                "ave(X)", zsto,zout)
263c
264         CALL histdef(nid_day, "vitu", "Zonal wind", "m/s",
265     .                iim,jjmp1,nhori, klev,1,klev,nvert, 32,
266     .                "ave(X)", zsto,zout)
267c
268         CALL histdef(nid_day, "vitv", "Meridional wind", "m/s",
269     .                iim,jjmp1,nhori, klev,1,klev,nvert, 32,
270     .                "ave(X)", zsto,zout)
271c
272         CALL histdef(nid_day, "vitw", "Vertical wind", "m/s",
273     .                iim,jjmp1,nhori, klev,1,klev,nvert, 32,
274     .                "ave(X)", zsto,zout)
275c
276         CALL histdef(nid_day, "pres", "Air pressure", "Pa",
277     .                iim,jjmp1,nhori, klev,1,klev,nvert, 32,
278     .                "ave(X)", zsto,zout)
279c
280c=================================================================
281c   FIN INITIALISATION DES CHAMPS 3D
282c=================================================================
283      ENDIF !  lev_histday.GE.3
284c
285      IF (lev_histday.GE.4) THEN
286c=================================================================
287c
288c   INITIALISATION DES CHAMPS SUR LES SOUS SURFACES
289c
290c=================================================================
291c
292         CALL histdef(nid_day, "SWupTOA", "SWup at TOA","W/m2",
293     .                iim,jjmp1,nhori, 1,1,1,-99,
294     .                32, "ave(X)", zsto,zout)
295c
296         CALL histdef(nid_day, "SWupSFC", "SWup at surface","W/m2",
297     .                iim,jjmp1,nhori, 1,1,1,-99,
298     .                32, "ave(X)", zsto,zout)
299c
300         CALL histdef(nid_day, "SWdnTOA", "SWdn at TOA","W/m2",
301     .                iim,jjmp1,nhori, 1,1,1,-99,
302     .                32, "ave(X)", zsto,zout)
303c
304         CALL histdef(nid_day, "SWupTOAclr",
305     .                "SWup clear sky at TOA","W/m2",
306     .                iim,jjmp1,nhori, 1,1,1,-99,
307     .                32, "ave(X)", zsto,zout)
308
309         CALL histdef(nid_day, "SWupSFCclr",
310     .                "SWup clear sky at surface","W/m2",
311     .                iim,jjmp1,nhori, 1,1,1,-99,
312     .                32, "ave(X)", zsto,zout)
313
314         CALL histdef(nid_day, "SWdnTOAclr",
315     .                "SWdn clear sky at TOA","W/m2",
316     .                iim,jjmp1,nhori, 1,1,1,-99,
317     .                32, "ave(X)", zsto,zout)
318
319         CALL histdef(nid_day, "SWdnSFCclr",
320     .                "SWdn clear sky at surface","W/m2",
321     .                iim,jjmp1,nhori, 1,1,1,-99,
322     .                32, "ave(X)", zsto,zout)
323c
324c=================================================================
325c=================================================================
326c=================================================================
327c   INITIALISATION DES CHAMPS SUR LES SOUS SURFACES
328c=================================================================
329c
330         CALL histdef(nid_day, "tter", "Surface Temperature", "K",
331     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
332     .                "ave(X)", zsto,zout)
333c
334         CALL histdef(nid_day, "tlic", "Surface Temperature", "K",
335     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
336     .                "ave(X)", zsto,zout)
337c
338         CALL histdef(nid_day, "toce", "Surface Temperature", "K",
339     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
340     .                "ave(X)", zsto,zout)
341c
342         CALL histdef(nid_day, "tsic", "Surface Temperature", "K",
343     .                iim,jjmp1,nhori, 1,1,1, -99, 32, 
344     .                "ave(X)", zsto,zout)
345c
346         CALL histdef(nid_day, "t2mter", "Temp.terre 2m", "K",
347     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
348     .                "ave(X)", zsto,zout)
349c
350         CALL histdef(nid_day, "t2mlic", "Temp.lic 2m", "K",
351     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
352     .                "ave(X)", zsto,zout)
353c
354         CALL histdef(nid_day, "t2moce", "Temp.oce 2m", "K",
355     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
356     .                "ave(X)", zsto,zout)
357c
358         CALL histdef(nid_day, "t2msic", "Temp.sic 2m", "K",
359     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
360     .                "ave(X)", zsto,zout)
361c
362         CALL histdef(nid_day, "t2mter_min", "Temp.terre 2m min.",
363     .                "K",
364     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
365     .                t2mincels, zsto,zout)
366c
367         CALL histdef(nid_day, "t2mter_max", "Temp.terre 2m max.",
368     .                "K",
369     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
370     .                t2maxcels, zsto,zout)
371c
372         CALL histdef(nid_day, "u10mter", "Vent zonal ter 10m", "m/s",
373     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
374     .                "ave(X)", zsto,zout)
375c
376         CALL histdef(nid_day, "u10mlic", "Vent zonal lic 10m", "m/s",
377     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
378     .                "ave(X)", zsto,zout)
379c
380         CALL histdef(nid_day, "u10moce", "Vent zonal oce 10m", "m/s",
381     .                iim,jjmp1,nhori, 1,1,1, -99, 32,
382     .                "ave(X)", zsto,zout)
383c
384         CALL histdef(nid_day, "u10msic", "Vent zonal sic 10m",
385     .                 "m/s",iim,jjmp1,nhori, 1,1,1, -99, 32,
386     .                "ave(X)", zsto,zout)
387c
388         CALL histdef(nid_day, "v10mter", "Vent meridien ter 10m", 
389     .                "m/s", iim,jjmp1,nhori, 1,1,1, -99, 32,
390     .                "ave(X)", zsto,zout)
391c
392         CALL histdef(nid_day, "v10mlic", "Vent meridien lic 10m",
393     .                 "m/s",iim,jjmp1,nhori, 1,1,1, -99, 32,
394     .                "ave(X)", zsto,zout)
395c
396         CALL histdef(nid_day, "v10moce", "Vent meridien oce 10m",
397     .                 "m/s",iim,jjmp1,nhori, 1,1,1, -99, 32,
398     .                "ave(X)", zsto,zout)
399c
400         CALL histdef(nid_day, "v10msic", "Vent meridien sic 10m",
401     .                 "m/s",iim,jjmp1,nhori, 1,1,1, -99, 32,
402     .                "ave(X)", zsto,zout)
403c
404         DO nsrf = 1, nbsrf
405C
406           call histdef(nid_day, "pourc_"//clnsurf(nsrf),
407     $         "Fraction"//clnsurf(nsrf), "W/m2", 
408     $         iim,jjmp1,nhori, 1,1,1, -99, 32,
409     $         "ave(X)", zsto,zout)
410C
411           call histdef(nid_day, "tsol_"//clnsurf(nsrf),
412     $         "Fraction"//clnsurf(nsrf), "W/m2", 
413     $         iim,jjmp1,nhori, 1,1,1, -99, 32,
414     $         "ave(X)", zsto,zout)
415C
416           call histdef(nid_day, "sens_"//clnsurf(nsrf),
417     $         "Sensible heat flux "//clnsurf(nsrf), "W/m2", 
418     $         iim,jjmp1,nhori, 1,1,1, -99, 32,
419     $         "ave(X)", zsto,zout)
420c
421           call histdef(nid_day, "lat_"//clnsurf(nsrf),
422     $         "Latent heat flux "//clnsurf(nsrf), "W/m2", 
423     $         iim,jjmp1,nhori, 1,1,1, -99, 32,
424     $         "ave(X)", zsto,zout)
425C
426           call histdef(nid_day, "taux_"//clnsurf(nsrf),
427     $         "Zonal wind stress"//clnsurf(nsrf),"Pa",
428     $         iim,jjmp1,nhori, 1,1,1, -99, 32,
429     $         "ave(X)", zsto,zout)
430
431           call histdef(nid_day, "tauy_"//clnsurf(nsrf),
432     $         "Meridional xind stress "//clnsurf(nsrf), "Pa", 
433     $         iim,jjmp1,nhori, 1,1,1, -99, 32,
434     $         "ave(X)", zsto,zout)
435C
436           call histdef(nid_day, "albe_"//clnsurf(nsrf),
437     $         "Albedo surf. "//clnsurf(nsrf), "W/m2", 
438     $         iim,jjmp1,nhori, 1,1,1, -99, 32,
439     $         "ave(X)", zsto,zout)
440C
441           call histdef(nid_day, "rugs_"//clnsurf(nsrf),
442     $         "Latent heat flux "//clnsurf(nsrf), "W/m2", 
443     $         iim,jjmp1,nhori, 1,1,1, -99, 32,
444     $         "ave(X)", zsto,zout)
445C
446         END DO
447C           
448c=================================================================
449c
450c   FIN INITIALISATION DES CHAMPS SUR LES SOUS SURFACES
451c
452c=================================================================
453      ENDIF !lev_histday.GE.4
454c=================================================================
455c
456         CALL histend(nid_day)
457c
458         ndex2d = 0
459         ndex3d = 0
460c
461c=================================================================
462      ENDIF ! fin de test sur ok_journe
Note: See TracBrowser for help on using the repository browser.