source: trunk/UTIL/PYTHON/planetoplot_v2/pp.py @ 1170

Last change on this file since 1170 was 1084, checked in by aslmd, 11 years ago

planetoplot. now full control on ticks : X Y colorbar. also included a secret XKCD mode for advanced users (thanks to native support in matplotlib 1.3)

  • Property svn:executable set to *
File size: 11.3 KB
RevLine 
[910]1#! /usr/bin/env python
2##############################################
3##  A MINIMAL PP.PY SCRIPT USING PPCLASS.PY ##
4##  Author: A. Spiga 03/2013                ##
5##############################################
6from optparse import OptionParser ### TBR by argparse
7from ppclass import pp, inspect
[912]8import sys
[910]9##############################################
10
11# NB: this is a convenient command-line script
12#     ... but ppclass is more versatile
13#     ... than what is proposed here
14#     ... e.g. differences between files,
15#     ... complex operations,
16#     ... see sample scripts
17
[923]18######################################
19# define parser with version and usage
20######################################
[910]21parser = OptionParser()
[923]22parser.version = \
[924]23'''**************************************************
24******** PLANETOPLOT (for help: pp.py -h) ********
25**************************************************'''
26parser.usage = \
27'''pp.py [options] netCDF file(s)
28(NB: no options --> simple inspection of variables and dimensions in netCDF files)
29-------------------
30PLANETOPLOT
[923]31--> command line tool to make nice & quick plots from netCDF files
32--> based on python + numpy + scipy + matplotlib + basemap + netCDF4
33--> Author: A. Spiga (LMD/UPMC) aymeric.spiga@upmc.fr
[924]34-------------------'''
[923]35parser.print_version()
36
37########################################
38# set options for the pp.py command line
39########################################
[920]40parser.add_option('--verbose',action='store_true',dest='verbose',default=False,help='make the program verbose')
[910]41# field --> lower case
[920]42parser.add_option('-v','--var',action='append',dest='var',type="string",default=None,help="'variable' or ['var1','var2',etc]")
[923]43parser.add_option('-x','--lon',action='append',dest='x',type="string",default=None,help="x axis value. one value; or val1,val2 (computations)")
44parser.add_option('-y','--lat',action='append',dest='y',type="string",default=None,help="y axis value. one value; or val1,val2 (computations)")
45parser.add_option('-z','--vert',action='append',dest='z',type="string",default=None,help="z axis value. one value; or val1,val2 (computations)")
46parser.add_option('-t','--time',action='append',dest='t',type="string",default=None,help="t axis value. one value; or val1,val2 (computations)")
47parser.add_option('-u','--compute',action='store',dest='compute',type="string",default="mean",help="computation: mean, min, max, meanarea")
[920]48parser.add_option('-c','--contour',action='store',dest='contour',type="string",default=None,help="one 'variable' for contour")
49parser.add_option('-i','--vecx',action='store',dest='vecx',type="string",default=None,help="one 'variable' for wind vector x component")
[981]50parser.add_option('-j','--vecy',action='store',dest='vecy',type="string",default=None,help="one 'variable' for wind vector y component")
[920]51parser.add_option('-m','--mult',action='store',dest='mult',type="float",default=None,help="multiplicative factor on field")
52parser.add_option('-a','--add',action='store',dest='add',type="float",default=None,help="additive factor on field")
53parser.add_option('-o','--output',action='store',dest='filename',type="string",default="myplot",help="name of output files")
54parser.add_option('-d','--directory',action='store',dest='folder',type="string",default="./",help="directory of output files")
[942]55parser.add_option('-s','--changetime',action='store',dest='changetime',type="string",default=None,\
[1029]56                  help="transformation on time axis : [None] | correctls | mars_sol2ls | mars_dayini | mars_meso_ls | mars_meso_sol | mars_meso_utc | mars_meso_lt ")
[990]57parser.add_option('-p','--print',action='store_true',dest='savtxt',default=False,help="[1D] output field+coord in an ASCII file")
[1050]58parser.add_option('--sx',action='store',dest='sx',type="int",default=1,help="Load data every sx grid points over x dimension")
59parser.add_option('--sy',action='store',dest='sy',type="int",default=1,help="Load data every sy grid points over y dimension")
60parser.add_option('--sz',action='store',dest='sz',type="int",default=1,help="Load data every sz grid points over z dimension")
61parser.add_option('--st',action='store',dest='st',type="int",default=1,help="Load data every st grid points over t dimension")
[910]62# plot --> upper case
63# -- generic
[920]64parser.add_option('-T','--title',action='append',dest='title',type="string",default=None,help="change 'title'")
65parser.add_option('-X','--xlabel',action='append',dest='xlabel',type="string",default=None,help="change 'xlabel'")
66parser.add_option('-Y','--ylabel',action='append',dest='ylabel',type="string",default=None,help="change 'ylabel'")
67parser.add_option('-D','--div',action='store',dest='div',type="int",default=20,help="integer for number of divisions")
68parser.add_option('-H','--trans',action='store',dest='trans',type="float",default=1.0,help="float for transparency (0=transp,1=opaque)")
69parser.add_option('-Z','--logy',action='store_true',dest='logy',default=False,help="set log for vertical axis")
70parser.add_option('-O','--save',action='store',dest='out',type="string",default="gui",help="save mode: 'gui' 'png' 'pdf' 'eps' 'svg' 'ps'")
[972]71parser.add_option('-V','--void',action='store_true',dest='void',default=False,help="no colorbar, no title, no labels")
72parser.add_option('-U','--units',action='append',dest='units',type="string",default=None,help="units for the field")
[1054]73parser.add_option('-F','--fmt',action='append',dest='fmt',type="string",default=None,help="values formatting. ex: '%.0f' '%3.1e'")
[1084]74parser.add_option('--xcoeff',action='append',dest='xcoeff',type="float",default=None,help="multiply x axis [not for 2D map]")
75parser.add_option('--ycoeff',action='append',dest='ycoeff',type="float",default=None,help="multiply y axis [not for 2D map]")
76parser.add_option('--xmin',action='append',dest='xmin',type="float",default=None,help="min bound x axis [not for 2D map]")
77parser.add_option('--ymin',action='append',dest='ymin',type="float",default=None,help="min bound y axis [not for 2D map]")
78parser.add_option('--xmax',action='append',dest='xmax',type="float",default=None,help="max bound x axis [not for 2D map]")
79parser.add_option('--ymax',action='append',dest='ymax',type="float",default=None,help="max bound y axis [not for 2D map]")
80parser.add_option('--nxticks',action='append',dest='nxticks',type="float",default=None,help="ticks for x axis [not for 2D map]")
81parser.add_option('--nyticks',action='append',dest='nyticks',type="float",default=None,help="ticks for y axis [not for 2D map]")
[910]82# -- 1D plot
[1050]83parser.add_option('-L','--linestyle',action='append',dest='linestyle',type="string",default=None,help="[1D] linestyle: '-' '--' '.' '..'")
[920]84parser.add_option('-Q','--color',action='append',dest='color',type="string",default=None,help="[1D] color: 'b' 'g' 'r' etc")
85parser.add_option('-K','--marker',action='append',dest='marker',type="string",default=None,help="[1D] marker: '' 'x' 'o' etc")
86parser.add_option('-S','--superpose',action='store_true',dest='superpose',default=False,help="[1D] use same axis for all plots")
[1050]87parser.add_option('-E','--legend',action='append',dest='legend',type="string",default=None,help="[1D] legend for line")
[991]88parser.add_option('--modx',action='append',dest='modx',type="float",default=None,help="[1D] change xticks with a modulo")
[910]89# -- 2D plot
[1050]90parser.add_option('-C','--colorbar',action='append',dest='colorbar',type="string",default=None,help="[2D] colormap: http://micropore.files.wordpress.com/2010/06/colormaps.png")
[972]91parser.add_option('-P','--proj',action='append',dest='proj',type="string",default=None,help="[2D] map projection: 'cyl' 'npstere' 'spstere' 'ortho' 'moll' 'robin' 'lcc' 'laea' 'merc' 'noproj'")
[920]92parser.add_option('-B','--back',action='append',dest='back',type="string",default=None,help='[2D] predefined map background (cf. set_back.txt)')
93parser.add_option('-A','--area',action='append',dest='area',type="string",default=None,help='[2D] predefined region of mapping (cf. set_area.txt)')
94parser.add_option('-I','--blon',action='append',dest='blon',type="float",default=None,help='[2D] float: bounding longitude for stere (or center longitude for ortho)')
95parser.add_option('-J','--blat',action='append',dest='blat',type="float",default=None,help='[2D] float: bounding latitude for stere (or center latitude for ortho) ')
96parser.add_option('-N','--vmin',action='append',dest='vmin',type="float",default=None,help='[2D] float: minimum value for displayed field')
97parser.add_option('-M','--vmax',action='append',dest='vmax',type="float",default=None,help='[2D] float: maximum value for displayed field')
[972]98parser.add_option('-W','--wscale',action='append',dest='wscale',type="float",default=None,help='[2D] float: set size of reference wind vector')
[1050]99parser.add_option('--svx',action='store',dest='svx',type="int",default=1,help="Define an abscissa stride on vectors only -- not on field")
100parser.add_option('--svy',action='store',dest='svy',type="int",default=1,help="Define an ordinate stride on vectors only -- not on field")
[1084]101parser.add_option('--cbticks',action='append',dest='cbticks',type="float",default=None,help="ticks for colorbar")
[982]102###########################
[910]103(opt,args) = parser.parse_args()
[972]104# remains F G R 
[910]105
[923]106######################################
107# get arguments (one or several files)
108######################################
109if args is None:
110    print "Stop here! I need file(s) as argument(s)!" ; exit()
111else:
112    files = args
113
114#############################################
115# a possibility to simply inspect the file(s)
116#############################################
[910]117if opt.var is None:
[923]118    for filename in files: inspect(filename)
[910]119    exit()
120
121######################################
122# use ppclass to get field and plot it
123######################################
124# treat the case of additional vectors or contours (contours must be before vectors)
125var = [] ; vargoal = []
126for element in opt.var:
127    var.append(element) ; vargoal.append("main")
128    if opt.contour is not None: var.append(opt.contour) ; vargoal.append("contour")
129    if opt.vecx is not None: var.append(opt.vecx) ; vargoal.append("vector")
130    if opt.vecy is not None: var.append(opt.vecy) ; vargoal.append("vector")
131# set pp object
[920]132user = pp()
[923]133user.file = files
134user.var = var ; user.vargoal = vargoal
135user.x = opt.x ; user.y = opt.y
136user.z = opt.z ; user.t = opt.t
[920]137user.verbose = opt.verbose
138user.compute = opt.compute
[939]139user.changetime = opt.changetime
[1050]140user.sx = opt.sx ; user.sy = opt.sy
141user.sz = opt.sz ; user.st = opt.st
142user.svx = opt.svx ; user.svy = opt.svy
[990]143user.savtxt = opt.savtxt
[910]144# define field
145user.define()
146# retrieve field
147user.retrieve()
148# some possible operations
149if opt.add is not None: user = user + opt.add
150if opt.mult is not None: user = user * opt.mult
[912]151# get some options
152user.superpose = opt.superpose
153user.filename = opt.filename
154user.folder = opt.folder
155user.out = opt.out
[972]156# if noproj is given for proj, no map mode
157if opt.proj is not None:
158    if 'noproj' in opt.proj: 
159        user.noproj = True
[963]160# if user wants to give a name, we drop the indication of date
161if opt.filename != "myplot":
162    user.includedate = False
[910]163# define plot
164user.defineplot()
165# user-defined plot settings
[972]166# ... shouldn't this be before defineplot?
[910]167user.getopt(opt)
168# make plot
169user.makeplot()
[912]170
171####################################
172# save a .sh file with the command #
173####################################
174command = ""
175for arg in sys.argv: command = command + arg + ' '
[920]176try:
177    f = open(opt.folder+'/'+opt.filename+'.sh', 'w')
[923]178    f.write(command)   
[920]179except IOError:
180    print "!! WARNING !! pp.py command not saved. Probably do not have permission to write here."
Note: See TracBrowser for help on using the repository browser.