source: trunk/UTIL/PYTHON/planetoplot_v2/examples/simple.py @ 910

Last change on this file since 910 was 910, checked in by aslmd, 12 years ago

PLANETOPLOT v2


  1. Spiga LMD/UPMC 24/03/2013

Contents


core


  • ppclass.py --> main class with pp() objects (need ppplot and ppcompute)
  • ppplot.py --> plot class (can be used independently, need ppcompute)
  • ppcompute.py --> computation class (can be used independently)

scripts


  • pp.py --> command line utility to use ppclass
  • pp_reload.py --> command line utility to load saved plot objects *.ppobj
  • example/* --> example scripts using ppclass

settings files


  • set_area.txt --> setting file: predefined areas for plotting (can be omitted)
  • set_back.txt --> setting file: predefined backgrounds for plotting (can be omitted)
  • set_multiplot.txt --> setting file: predefined coefficients for multiplots (can be omitted)
  • set_ppclass.txt --> setting file: predefined variables for x,y,z,t (can be omitted)
  • set_var.txt --> setting file: predefined colorbars, format, labels, etc... for variables (can be omitted)

documentation


  • README.TXT --> this README file

data


  • demo_data/* --> plot objects for a demonstration tour and customizing tests

Requirements


python + numpy + matplotlib + netCDF4

  • for mapping --> Basemap
  • for scientific computations --> scipy

[recommended: Enthought Python Distribution (free for academics)]

Installation


  • install required softwares and librairies in requirements
  • add planetoplot_v2 in your PYTHONPATH environment variable (and in your PATH to use pp.py)

Take a demo tour


pp_reload.py demo_data/*

Improvements compared to v1


  • code readability and structuration for future improvements
  • modularity (class formulation) + easy definition/addition of attributes
  • separation between data retrieval and plotting
  • versatility + command line (pp.py)

--> for quick inspection

+ interactive session (ipython)

--> for testing and exploring

+ scripts

--> for powerful and fully customized results

  • performance (overall and on large files) + memory consumption (only retrieve what is needed)
  • saving/loading plot objects in/from *.ppobj
  • plot aesthetics and customizing (see header in ppplot)
  • multiplot flexibility with .plotin attribute
  • easy definition of presets with set_*.txt files
  • function: one field vs. another one
  • emulation of + - / * operations on fields (between two fields or between a field and a int/float)
  • computations of min/max in addition to mean
  • simple inspection of dimensions+variables in a file (pp.py -f file)
  • verbose / non verbose mode

Acknowledgements


Thanks to A. Colaitis, T. Navarro, J. Leconte
for feedbacks and contributions on version 1

  • Property svn:executable set to *
File size: 859 bytes
Line 
1#! /usr/bin/env python
2from ppclass import pp
3
4# we define a "planetoplot" object
5u = pp()
6
7# we define its attributes
8u.file = "/home/aymeric/Big_Data/DATAPLOT/diagfired.nc"
9u.var = "u"
10u.t = "0.5" #NB: also works without quotes
11u.z = "10" #NB: also works without quotes
12
13# we get data
14u.get()
15
16## we smooth the field a little bit
17#u.smooth(15)
18
19# we define the plot, then set a few personal stuff
20u.defineplot() 
21u.p[0].title = "This is what we name $u$ (m s$^{-1}$)"
22u.p[0].proj = "robin"
23
24# we plot
25u.makeplot()
26
27# we simply change the colorbar
28# ... no need to reload data
29u.p[0].colorb = "RdBu"
30u.makeplot()
31
32# we remove map projection
33# ... idem, no need to reload data
34# ... but have to redefine plot
35u.noproj = True
36u.defineplot()
37u.makeplot()
38
39# we multiply the field by two
40# ... and redefine+remake the plot
41u = u * 2.
42u.defineplot()
43u.makeplot()
Note: See TracBrowser for help on using the repository browser.