source: trunk/mesoscale/LMD_MM_MARS/SRC/ARWpost/idl/model_levels.pro @ 69

Last change on this file since 69 was 11, checked in by aslmd, 14 years ago

spiga@svn-planeto:ajoute le modele meso-echelle martien

File size: 2.0 KB
Line 
1pro model_levels, plotlev
2;; first is one (as in gw.def)
3
4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
5;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
6file = './zefolder/'
7file = file + 'wrfout_d01_2024-03-21_00:00:00'
8
9file = './wrfout_d01_9999-09-09_09:00:00'
10;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
11;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
12
13;;
14;; ini
15;;
16;if (n_elements(plotlev) eq 0) then plotlev=7
17
18;set_plot, 'ps'
19;device, filename='model_levels.ps'
20
21;
22; constantes
23;
24grav = 3.72
25
26;
27; retrieve model geopotential
28;
29openr,unit,'heights.dat',/get_lun,error=err
30;IF (err ne 0) THEN BEGIN
31        getcdf, $
32                file=file, $
33                charvar='PHTOT', $
34                invar=geop
35        getcdf, $
36                file=file, $
37                charvar='HGT', $
38                invar=hgt
39;       save, geop, filename='heights.dat'
40;ENDIF ELSE BEGIN
41;       restore, filename='heights.dat'
42;ENDELSE
43
44;
45; size
46;
47s = size(geop)
48nx = s[1] ;& print, nx
49ny = s[2] ;& print, ny
50nz = s[3] ;& print, nz
51nt = s[4] ;& print, nt
52
53if (n_elements(plotlev) eq 0) then plotlev=nz-1
54
55for lev = 1, nz-1 do begin
56
57print, '*************************************************************************'
58print, 'model level ', lev
59 
60;
61; heights of model levels
62;
63;height = (geop(*,*,lev-1,*) - geop(*,*,0.,*)) / grav
64height = fltarr(nx,ny,nt)
65for i=0,nt-1 do height(*,*,i) = geop(*,*,lev-1,i) / grav - hgt(*,*)
66
67;
68; spatial mean (temporal variations)
69;
70yes = TOTAL(TOTAL(height,1),1) / float(nx) / float(ny)
71print, 'spat. mean (temp. var.) ', mean(yes), max(yes), min(yes);, max(yes) - min(yes)
72
73;
74; temporal mean (spatial variations)
75;
76yet = TOTAL(height,3) / float(nt) 
77print, 'temp. mean (spat. var.) ', mean(yet), max(yet), min(yet);, max(yet) - min(yet)
78
79;
80; complete mean
81;
82ye = TOTAL(TOTAL(TOTAL(height,1),1),1) / float(nx) / float(ny) / float(nt)
83print, '******* mean ', ye
84
85if (lev eq plotlev) then begin
86        !p.multi=[0,2,1]
87        contour, yet, /cell_fill, nlevels=30, title=string(min(yet))+string(max(yet))
88        plot, yes, yrange=[min(yes),max(yes)]
89        stop
90endif
91
92endfor
93
94;device, /close
95end
Note: See TracBrowser for help on using the repository browser.