Changeset 202 for trunk/MESOSCALE/PLOT/PYTHON/scripts
- Timestamp:
- Jul 11, 2011, 12:02:13 AM (13 years ago)
- Location:
- trunk/MESOSCALE/PLOT/PYTHON/scripts
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/MESOSCALE/PLOT/PYTHON/scripts/domain.py
r184 r202 1 1 #!/usr/bin/env python 2 2 3 ### A. Spiga -- LMD -- 30/0 5/20113 ### A. Spiga -- LMD -- 30/06/2011 -- slight modif early 07/2011 4 4 5 def domain (namefile,proj="ortho",back=" molabw",target=None,var='HGT'):5 def domain (namefile,proj="ortho",back="vishires",target=None,var='HGT'): 6 6 from netCDF4 import Dataset 7 from myplot import getcoord2d,define_proj,makeplotpng,simplinterv 8 from matplotlib.pyplot import contourf 7 from myplot import getcoord2d,define_proj,makeplotpng,simplinterv,getprefix 8 from matplotlib.pyplot import contourf,rcParams 9 from numpy.core.defchararray import find 10 ### 9 11 nc = Dataset(namefile) 12 ### 10 13 [lon2d,lat2d] = getcoord2d(nc) 11 14 [wlon,wlat] = simplinterv(lon2d,lat2d) 15 ### 12 16 m = define_proj(proj,wlon,wlat,back=back) 13 17 x, y = m(lon2d, lat2d) 18 ### 14 19 contourf(x, y, nc.variables[var][0,:,:], 40) 15 if not target: zeplot = namefile+".domain" 16 else: zeplot = target+"/domain" 20 ### 21 zeplot = getprefix(nc) + "domain" 22 if not target: zeplot = namefile[0:find(namefile,'wrfout')] + zeplot 23 else: zeplot = target + "/" + zeplot 24 ### 17 25 makeplotpng(zeplot,pad_inches_value=0.35) 26 #rcParams['savefig.facecolor'] = 'black' 27 #makeplotpng(zeplot+"b",pad_inches_value=0.35) 18 28 19 29 if __name__ == "__main__": … … 22 32 from optparse import OptionParser 23 33 parser = OptionParser() 24 parser.add_option('-f', action='store', dest='namefile', type="string", default=None, help='name of WRF file [NEEDED]')25 parser.add_option('-p', action='store', dest='proj', type="string", default="ortho", help='projection')26 parser.add_option('-b', action='store', dest='back', type="string", default=" molabw", help='background')27 parser.add_option('-t', action='store', dest='target', type="string", default=None, help='destination folder')28 parser.add_option('-v', action='store', dest='var', type="string", default='HGT', help='variable contoured')34 parser.add_option('-f', action='store', dest='namefile', type="string", default=None, help='name of WRF file [NEEDED]') 35 parser.add_option('-p', action='store', dest='proj', type="string", default="ortho", help='projection') 36 parser.add_option('-b', action='store', dest='back', type="string", default="vishires", help='background') 37 parser.add_option('-t', action='store', dest='target', type="string", default=None, help='destination folder') 38 parser.add_option('-v', action='store', dest='var', type="string", default='HGT', help='variable contoured') 29 39 (opt,args) = parser.parse_args() 30 40 if opt.namefile is None: -
trunk/MESOSCALE/PLOT/PYTHON/scripts/winds.py
r201 r202 1 1 #!/usr/bin/env python 2 2 3 ### A. Spiga -- LMD -- 30/06/2011 to 04/07/20113 ### A. Spiga -- LMD -- 30/06/2011 to 10/07/2011 4 4 ### Thanks to A. Colaitis for the parser trick 5 5 … … 30 30 ### Load librairies and functions 31 31 from netCDF4 import Dataset 32 from myplot import getcoord2d,define_proj,makeplotpng,simplinterv,vectorfield,ptitle,latinterv,getproj,wrfinterv,dumpbdy,fmtvar 32 from myplot import getcoord2d,define_proj,makeplotpng,simplinterv,vectorfield,ptitle,latinterv,getproj,wrfinterv,dumpbdy,\ 33 fmtvar,definecolorvec,getwinds,defcolorb,getprefix 33 34 from mymath import deg,max,min,mean 34 from matplotlib.pyplot import contour f, subplot, figure, rcParams, savefig, colorbar, pcolor35 from matplotlib.pyplot import contour,contourf, subplot, figure, rcParams, savefig, colorbar, pcolor 35 36 from matplotlib.cm import get_cmap 36 37 import numpy as np 38 from numpy.core.defchararray import find 39 40 ### 41 #rcParams['text.usetex'] = True 42 #rcParams['cairo.format'] = 'svg' 37 43 38 44 ###################### … … 78 84 elif proj == "lcc": [wlon,wlat] = wrfinterv(lon2d,lat2d) 79 85 else: [wlon,wlat] = simplinterv(lon2d,lat2d) 80 81 ###################82 #### Get local time83 #if typefile in ['mesoapi','meso']:84 # ltst = interv[0]85 # #ltst = int(getattr(nc, 'GMT') + 0.5*(wlon[0]+wlon[1])/15.)86 #elif typefile in ['gcm']:87 # ltst = 088 86 89 87 ############################################################################## … … 118 116 else: zevmax = vmax 119 117 print "bounds ", zevmin, zevmax 118 ### some already defined colormaps 119 if colorb is True: colorb = defcolorb(var) 120 120 121 121 ########################### … … 128 128 ######################################### 129 129 ### Name for title and graphics save file 130 if winds: basename = " WINDS_"130 if winds: basename = "UV_" 131 131 else: basename = "" 132 if var: 133 basename = basename + var134 if typefile is 'meso':stralt = "_lvl" + str(nvert)132 if var: basename = basename + var 133 ### 134 if typefile is 'meso': stralt = "_lvl" + str(nvert) 135 135 elif typefile is 'mesoapi': 136 136 zelevel = int(nc.variables['vert'][nvert]) 137 if 'altitude_abg' in nc.dimensions: stralt = "_"+str(zelevel)+"m-ALS" 138 elif 'bottom_top' in nc.dimensions: stralt = "_"+str(zelevel)+"m-AMR" 137 if 'altitude' in nc.dimensions: stralt = "_"+str(zelevel)+"m-AMR" 138 elif 'altitude_abg' in nc.dimensions: stralt = "_"+str(zelevel)+"m-ALS" 139 elif 'bottom_top' in nc.dimensions: stralt = "_"+str(zelevel)+"m" 139 140 elif 'pressure' in nc.dimensions: stralt = "_"+str(zelevel)+"Pa" 140 141 else: stralt = "" 142 ### 141 143 basename = basename + stralt 142 144 … … 147 149 if numplot == 4: 148 150 sub = 221 149 #fig.subplots_adjust(wspace = 0.1, hspace = 0.3)150 151 fig.subplots_adjust(wspace = 0.3, hspace = 0.3) 151 152 rcParams['font.size'] = int( rcParams['font.size'] * 2. / 3. ) … … 156 157 elif numplot == 3: 157 158 sub = 131 158 fig.subplots_adjust(wspace = 0. 3)159 rcParams['font.size'] = int( rcParams['font.size'] * 2. / 3. )159 fig.subplots_adjust(wspace = 0.5) 160 rcParams['font.size'] = int( rcParams['font.size'] * 1. / 2. ) 160 161 elif numplot == 6: 161 162 sub = 231 162 163 fig.subplots_adjust(wspace = 0.4, hspace = 0.0) 163 rcParams['font.size'] = int( rcParams['font.size'] * 2. / 3. )164 rcParams['font.size'] = int( rcParams['font.size'] * 1. / 2. ) 164 165 elif numplot == 8: 165 166 sub = 331 #241 166 fig.subplots_adjust(wspace = 0. 1, hspace = 0.3)167 fig.subplots_adjust(wspace = 0.3, hspace = 0.3) 167 168 rcParams['font.size'] = int( rcParams['font.size'] * 1. / 2. ) 168 169 elif numplot == 9: 169 170 sub = 331 170 fig.subplots_adjust(wspace = 0. 1, hspace = 0.3)171 fig.subplots_adjust(wspace = 0.3, hspace = 0.3) 171 172 rcParams['font.size'] = int( rcParams['font.size'] * 1. / 2. ) 172 173 elif numplot == 1: … … 223 224 else: 224 225 pcolor( x, y, what_I_plot, cmap = get_cmap(name=colorb), vmin=zevmin, vmax=zevmax ) 225 if colorb: colorbar(fraction=0.05,pad=0.1,format=fmtvar(var)) 226 if var in ['HGT']: pass 227 elif colorb: colorbar(fraction=0.05,pad=0.1,format=fmtvar(var)) 226 228 227 229 ### Vector plot … … 234 236 key = False 235 237 if metwind: [vecx,vecy] = m.rotate_vector(vecx, vecy, lon2d, lat2d) 236 if var == None and back == "vishires": colorvec = 'w'237 else: colorvec = 'k'238 if var == None: colorvec = definecolorvec(back) 239 else: colorvec = definecolorvec(colorb) 238 240 vectorfield(vecx, vecy,\ 239 241 x, y, stride=stride, csmooth=stride,\ … … 242 244 243 245 ### Next subplot 244 plottitle = basename + "_LT"+str(ltst) 245 if addchar: plottitle = plottitle + addchar 246 plottitle = basename 247 if addchar: plottitle = plottitle + addchar + "_LT"+str(ltst) 248 else: plottitle = plottitle + "_LT"+str(ltst) 246 249 ptitle( plottitle ) 247 250 sub += 1 … … 249 252 ########################################################################## 250 253 ### Save the figure in a file in the data folder or an user-defined folder 251 if not target: zeplot = namefile+"_"+basename 252 else: zeplot = target+"/"+basename 253 if numplot <= 0: zeplot = zeplot + "_LT"+str(abs(numplot)) 254 if typefile in ['meso','mesoapi']: prefix = getprefix(nc) 255 elif typefile in ['gcm']: prefix = 'LMD_GCM_' 256 else: prefix = '' 257 ### 258 zeplot = prefix + basename 259 if addchar: zeplot = zeplot + addchar 260 if numplot <= 0: zeplot = zeplot + "_LT"+str(abs(numplot)) 261 ### 262 if not target: zeplot = namefile[0:find(namefile,'wrfout')] + zeplot 263 else: zeplot = target + "/" + zeplot 264 ### 254 265 if found_lct: makeplotpng(zeplot,pad_inches_value=0.35) 255 266 else: print "Local time not found" 267 268 ############### 269 ### Now the end 256 270 return zeplot 257 258 259 ####################################################260 ####################################################261 ### A simple program to get wind vectors' components262 def getwinds (nc,charu='Um',charv='Vm'):263 import numpy as np264 u = nc.variables[charu]265 v = nc.variables[charv]266 if charu == 'U': u = u[:, :, :, 0:len(u[0,0,0,:])-1]267 if charv == 'V': v = v[:, :, 0:len(v[0,0,:,0])-1, :]268 ### ou alors prendre les coordonnees speciales269 return u,v270 271 272 271 273 272 ########################################################################################### … … 293 292 parser.add_option('-n', action='store', dest='numplot', type="int", default=4, help='number of plots (def=1)(<0: 1 plot of LT -*numplot*)') 294 293 parser.add_option('-i', action='store', dest='interp', type="int", default=None, help='interpolation method (2: press, 3: z-amr, 4:z-als)') 295 parser.add_option('-c', action='store', dest='colorb', type="string", default=True, help='change colormap (and draw a colorbar)')294 parser.add_option('-c', action='store', dest='colorb', type="string", default=True, help='change colormap') 296 295 parser.add_option('-x', action='store_false', dest='winds', default=True, help='flag: no wind vectors') 297 296 parser.add_option('-m', action='store', dest='vmin', type="float", default=None, help='bounding minimum value for color plot') … … 334 333 proj=opt.proj,back=opt.back,target=opt.target,stride=opt.stride,var=opt.var,numplot=opt.numplot,colorb=opt.colorb,winds=opt.winds,\ 335 334 addchar=lschar,interv=[zehour,zehourin],vmin=opt.vmin,vmax=opt.vmax,tile=opt.tile) 335 print 'Done: '+name 336 336 337 337 #########################################################
Note: See TracChangeset
for help on using the changeset viewer.