User Tools

Site Tools


other:python:jyp_steps

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
Next revision Both sides next revision
other:python:jyp_steps [2016/01/21 17:10]
jypeter numpy, scipy...
other:python:jyp_steps [2018/08/24 08:57]
jypeter [Extra numpy information] Added info about (masked) arrays
Line 1: Line 1:
-====== ​Following ​JYP's recommended steps ======+====== JYP's recommended steps for learning python ​====== 
 + 
 +<note tip>If you don't know which python distribution to use and how to start the python interpreter,​ you should first read the [[starting|Working with Python]] page</​note>​
  
 As can be expected, there is **a lot** of online python documentation available, and it's easy to get lost. You can always use google to find an answer to your problem, and you will probably end up looking at lots of answers on [[http://​stackoverflow.com/​questions/​tagged/​python|Stack Overflow]] or a similar site. But it's always better to know where you can find some good documentation... and to spend some time to read the documentation As can be expected, there is **a lot** of online python documentation available, and it's easy to get lost. You can always use google to find an answer to your problem, and you will probably end up looking at lots of answers on [[http://​stackoverflow.com/​questions/​tagged/​python|Stack Overflow]] or a similar site. But it's always better to know where you can find some good documentation... and to spend some time to read the documentation
  
 This page tries to list some //python for the scientist// related resources, in a suggested reading order. **Do not print anything** (or at least not everything),​ but it's a good idea to download all the //pdf// files in the same place, so that you can easily open and search the documents This page tries to list some //python for the scientist// related resources, in a suggested reading order. **Do not print anything** (or at least not everything),​ but it's a good idea to download all the //pdf// files in the same place, so that you can easily open and search the documents
 +
 +===== JYP's introduction to python =====
 +
 +==== Part 1 ====
 +
 +You can start using python by reading the {{:​other:​python:​python_intro_ipsl_oct2013_v2.pdf|Bien démarrer avec python}} tutorial that was used during a 2013 IPSL python class:
 +  * this tutorial is in French (my apologies for the lack of translation,​ but it should be easy to understand)
 +    * If you have too much trouble understanding this French Tutorial, you can read the first 6 chapters of the **Tutorial** in [[#​the_official_python_documentation|the official Python documentation]] and chapters 1.2.1 to 1.2.5 in the [[#​scipy_lecture_notes|Scipy Lecture Notes]]. Once you have read these, you can try to read the French tutorial again
 +  * it's an introduction to python (and programming) for the climate scientist: after reading this tutorial, you should be able to do most of the things you usually do in a shell script
 +    * python types, tests, loops, reading a text file
 +    * the tutorial is very detailed about string handling, because strings offer an easy way to practice working with indices (indexing and slicing), before indexing numpy arrays. And our usual pre/​post-processing scripts often need to do a lot of string handling in order to generate the file/​variable/​experiment names
 +  * after reading this tutorial, you should practice with the following:
 +    * [[https://​files.lsce.ipsl.fr/​public.php?​service=files&​t=9731fdad4521ac5fa6e84b392d3a2e44|Basic python training test (ipython notebook version)]]
 +    * {{:​other:​python:​tp_intro_python_oct2013_no_solutions.pdf|Basic python training test (pdf version)}}
 +    * {{:​other:​python:​tp_intro_python_oct2013_full.pdf|Basic python training test (pdf version, with answers)}}
 +
 +==== Part 2 ====
 +
 +Once you have done your first steps, you should read [[http://​www.lsce.ipsl.fr/​Phocea/​file.php?​class=page&​file=5/​pythonCDAT_jyp_1sur2_070227.pdf|Plus loin avec Python]] (start at page 39, the previous pages are an old version of what was covered in //Part 1// above)
 +  * this tutorial is in French (sorry again)
 +  * after reading this tutorial, you will be able to do more than you can do in a shell script, in an easier way
 +    * advanced string formatting
 +    * creating functions and using modules
 +    * working with file paths and handling files without calling external Linux programs\\ (e.g. using ''​os.remove(file_name)''​ instead of ''​rm $file_name''​)
 +    * using command-line options for scripts, or using configuration files
 +    * calling external programs
  
 ===== The official python documentation ===== ===== The official python documentation =====
  
-You do not need to read all the python documentation at this step, but it is really well made and you should at least have a look at it. The **Tutorial** is really well made, and you should have a look at the table of content of the **Python Standard Library**. There is a lot in the default library that can make your life easier+You do not need to read all the python documentation at this step, but it is really well made and you should at least have a look at it. The **Tutorial** is very good, and you should have a look at the table of content of the **Python Standard Library**. There is a lot in the default library that can make your life easier
  
 ==== Python 2.7 ==== ==== Python 2.7 ====
  
-[[https://​docs.python.org/​2.7/​|html]] - [[https://​docs.python.org/​2.7/​download.html|pdf]]+[[https://​docs.python.org/​2.7/​|html]] - [[https://​docs.python.org/​2.7/​download.html|pdf ​(in a zip file)]]
  
 ==== Python 3 ==== ==== Python 3 ====
  
-[[https://​docs.python.org/​3/​|html]] - [[https://​docs.python.org/​3/​download.html|pdf]]+[[https://​docs.python.org/​3/​|html]] - [[https://​docs.python.org/​3/​download.html|pdf ​(in a zip file)]]
  
  
 ===== Numpy and Scipy ===== ===== Numpy and Scipy =====
  
-Summary: Python provides //ordered// objects (e.g. lists, strings, ...) and some math operators, but you can't do real heavy computation with these. **Numpy** makes it possible to work with data arrays and using array syntax and masks (instead of explicit nested loops and tests) and the apropriate numpy functions will allow you to get performance similar to what you would get with a compiled program! **Scipy** adds more scientific functions+Summary: Python provides //ordered// objects (e.g. lists, strings, basic arrays, ...) and some math operators, but you can't do real heavy computation with these. **Numpy** makes it possible to work with multi-dimensional ​data arraysand using array syntax and masks (instead of explicit nested loops and tests) and the apropriate numpy functions will allow you to get performance similar to what you would get with a compiled program! **Scipy** adds more scientific functions
  
-How to get started? +Where: [[http://​docs.scipy.org/​doc/​|html and pdf documentation]] 
-  - always remember that indices start at ''​0''​ and that the last element of an array is at index ''​-1''​! ​Learn about indexing and slicing by manipulating ​a string ​(try '''​This document by JY is awesome!'​[::​-1]''​) + 
-  - read the [[https://​docs.scipy.org/​doc/​numpy-dev/​user/​quickstart.html|Quickstart tutorial]]+==== Getting ​started ​==== 
 + 
 +  - always remember that indices start at ''​0''​ and that the last element of an array is at index ''​-1''​!\\ First learn about //indexing// and //slicing// by manipulating ​strings, as shown in [[#​part1|Part 1]] above (try '''​This document by JY is awesome!'​[::​-1]'' ​and '''​This document by JY is awesome!'​[slice(None,​ None, -1)]''​) 8-
 +  - if you are a Matlab user (but the references are interesting for others as well), you can read the following:​ 
 +    - [[https://​docs.scipy.org/​doc/​numpy-dev/​user/​numpy-for-matlab-users.html|Numpy for Matlab users]] 
 +    - [[http://​mathesaurus.sourceforge.net/​matlab-numpy.html|NumPy for MATLAB users]] (nice, but does not seem to be maintained any more) 
 +  - read the really nice [[https://​docs.scipy.org/​doc/​numpy/​user/​quickstart.html|numpy Quickstart tutorial]]
   - have a quick look at the full documentation to know where things are   - have a quick look at the full documentation to know where things are
-    - Numpy User Guide:+    - Numpy User Guide
     - Numpy Reference Guide     - Numpy Reference Guide
     - Scipy Reference Guide     - Scipy Reference Guide
 +
 +==== Beware of the array view side effects ====
 +
 +<note warning>​When you take a slice of an array, you get a **//​View//​** : an array that has a new shape but that still shares its data with the first array.
 +
 +That is not a problem when you only read the values, but **if you change the values of the //View//, you change the values of the first array** (and vice-versa)! If that is not what want, do not forget to **make a copy** of the data before working on it!
 +
 +//Views// are a good thing most of the time, so only make a copy of your data when needed, because otherwise copying a big array will just be a waste of CPU and computer memory. Anyway, it is always better to understand what you are doing... :-P
 +
 +Check the example below and the [[https://​docs.scipy.org/​doc/​numpy-dev/​user/​quickstart.html#​copies-and-views|copies and views]] part of the quickstart tutorial.
 +
 +<code python>
 +>>>​ import numpy as np
 +>>>​ a = np.arange(30).reshape((3,​10))
 +>>>​ a
 +array([[ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9],
 +       [10, 11, 12, 13, 14, 15, 16, 17, 18, 19],
 +       [20, 21, 22, 23, 24, 25, 26, 27, 28, 29]])
 +
 +>>>​ b = a[1, :]
 +>>>​ b
 +array([10, 11, 12, 13, 14, 15, 16, 17, 18, 19])
 +
 +>>>​ b[3:7] = 0
 +>>>​ b
 +array([10, 11, 12,  0,  0,  0,  0, 17, 18, 19])
 +
 +>>>​ a
 +array([[ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9],
 +       [10, 11, 12,  0,  0,  0,  0, 17, 18, 19],
 +       [20, 21, 22, 23, 24, 25, 26, 27, 28, 29]])
 +       
 +>>>​ a[:, 2:4] = -1
 +>>>​ a
 +array([[ 0,  1, -1, -1,  4,  5,  6,  7,  8,  9],
 +       [10, 11, -1, -1,  0,  0,  0, 17, 18, 19],
 +       [20, 21, -1, -1, 24, 25, 26, 27, 28, 29]])
 +       
 +>>>​ b
 +array([10, 11, -1, -1,  0,  0,  0, 17, 18, 19])
 +
 +>>>​ c = a[1, :].copy()
 +>>>​ c
 +array([10, 11, -1, -1,  0,  0,  0, 17, 18, 19])
 +
 +>>>​ c[:] = 9
 +>>>​ c
 +array([9, 9, 9, 9, 9, 9, 9, 9, 9, 9])
 +
 +>>>​ b
 +array([10, 11, -1, -1,  0,  0,  0, 17, 18, 19])
 +
 +>>>​ a
 +array([[ 0,  1, -1, -1,  4,  5,  6,  7,  8,  9],
 +       [10, 11, -1, -1,  0,  0,  0, 17, 18, 19],
 +       [20, 21, -1, -1, 24, 25, 26, 27, 28, 29]])
 +</​code></​note>​
 +
 +==== Extra numpy information ====
 +
 +  * More information about array indexing:
 +    * Examples:
 +      * {{ :​other:​python:​indirect_indexing_2.py.txt |}}: Take a vertical slice in a 3D zyx array, along a varying y '​path'​
 +    * [[https://​docs.scipy.org/​doc/​numpy/​user/​basics.indexing.html|Indexing]] (//index arrays//, //boolean index arrays//, //​np.newaxis//,​ //​Ellipsis//,​ //variable numbers of indices//, ...)
 +    * [[https://​docs.scipy.org/​doc/​numpy/​user/​quickstart.html#​fancy-indexing-and-index-tricks|Fancy indexing]] and [[https://​docs.scipy.org/​doc/​numpy/​user/​quickstart.html#​the-ix-function|the ix_() function]]
 +    * [[https://​docs.scipy.org/​doc/​numpy/​reference/​arrays.indexing.html|Indexing (in the numpy reference manual)]]
 +    * [[https://​docs.scipy.org/​doc/​numpy/​reference/​routines.indexing.html#​routines-indexing|Indexing routines]] ​
 +  * More information about arrays:
 +    * [[https://​docs.scipy.org/​doc/​numpy/​reference/​routines.array-creation.html#​routines-array-creation|Array creation routines]]
 +    * [[https://​docs.scipy.org/​doc/​numpy/​reference/​routines.array-manipulation.html|Array manipulation routines]]
 +    * [[https://​docs.scipy.org/​doc/​numpy/​reference/​maskedarray.html|Masked arrays]]
 +      * [[https://​docs.scipy.org/​doc/​numpy/​reference/​routines.ma.html|Masked array operations]]
 +  * [[https://​docs.scipy.org/​doc/​numpy/​user/​misc.html#​ieee-754-floating-point-special-values|Dealing with special numerical values]] (//Nan//, //inf//)
 +    * If you know that your data has missing values, it is cleaner and safer to handle them with [[https://​docs.scipy.org/​doc/​numpy/​reference/​maskedarray.html|masked arrays]]!
 +    * [[https://​docs.scipy.org/​doc/​numpy/​user/​misc.html#​how-numpy-handles-numerical-exceptions|Handling numerical exceptions]]
 +    * [[https://​docs.scipy.org/​doc/​numpy/​reference/​routines.err.html|Floating point error handling]]
 +
 +===== cdms2 and netCDF4 =====
 +
 +There is a good chance that your input array data will come from a file in the [[other:​newppl:​starting#​netcdf_and_file_formats|NetCDF format]].
 +
 +Depending on which [[other:​python:​starting#​some_python_distributions|python distribution]] you are using, you can use the //cdms2// or or //netCDF4// modules to read the data.
 +
 +==== cdms2 ====
 +
 +Summary: cdms2 can read/write netCDF files (and read //grads// dat+ctl files) and provides a higher level interface than netCDF4. cdms2 is available in the [[other:​python:​starting#​uv-cdat|UV-CDAT distribution]],​ and can theoretically be installed independently of UV-CDAT (e.g. it will be installed when you install [[https://​cmor.llnl.gov/​mydoc_cmor3_conda/​|CMOR in conda)]]. When you can use cdms2, you also have access to //cdtime//, that is very useful for handling time axis data.
 +
 +How to get started:
 +  - read [[http://​www.lsce.ipsl.fr/​Phocea/​file.php?​class=page&​file=5/​pythonCDAT_jyp_2sur2_070306.pdf|JYP'​s cdms tutorial]], starting at page 54
 +    - the tutorial is in French (soooorry!)
 +    - you have to replace //cdms// with **cdms2**, and //MV// with **MV2** (sooorry about that, the tutorial was written when CDAT was based on //Numeric// instead of //numpy// to handle array data)
 +  - read the [[http://​cdms.readthedocs.io/​en/​docstanya/​index.html|official cdms documentation]] (link may change)
 +
 +
 +==== netCDF4 ====
 +
 +Summary: //netCDF4 can read/write netCDF files and is available in most python distributions//​
 +
 +Where: [[http://​unidata.github.io/​netcdf4-python/​]]
 +
 +===== CDAT-related resources =====
 +
 +Some links, in case they can't be found easily on the [[https://​uv-cdat.llnl.gov|UV-CDAT]] web site...
 +
 +  * [[https://​uv-cdat.llnl.gov/​tutorials.html|Tutorials in ipython notebooks]]
 +  * [[http://​cdat-vcs.readthedocs.io/​en/​latest/​|VCS:​ Visualization Control System]]
 +    * [[https://​github.com/​CDAT/​vcs/​issues/​238|Colormaps in vcs examples]]
 +  * [[https://​github.com/​CDAT/​cdat-site/​blob/​master/​eztemplate.md|EzTemplate Documentation]]
  
 ===== Matplotlib ===== ===== Matplotlib =====
Line 36: Line 178:
 Where: [[http://​matplotlib.org|Matplotlib web site]] Where: [[http://​matplotlib.org|Matplotlib web site]]
  
-The documentation is good, but not always easy to use. A good way to start with matplotlib is to:+Help on //stack overflow//: [[https://​stackoverflow.com/​questions/​tagged/​matplotlib|matplotlib help]] 
 + 
 +The documentation is good, but not always easy to use. <wrap hi>A good way to start with matplotlib</​wrap> ​is to:
   - Look at the [[http://​matplotlib.org/​gallery.html|matplotlib gallery]] to get an idea of all you can do with matplotlib. Later, when you need to plot something, come back to the gallery to find some examples that are close to what you need and click on them to get the sources   - Look at the [[http://​matplotlib.org/​gallery.html|matplotlib gallery]] to get an idea of all you can do with matplotlib. Later, when you need to plot something, come back to the gallery to find some examples that are close to what you need and click on them to get the sources
   - Use the free hints provided by JY!   - Use the free hints provided by JY!
Line 42: Line 186:
     - a Matplotlib //Axis// is a plot inside a Figure... [[http://​matplotlib.org/​faq/​usage_faq.html#​parts-of-a-figure|More details]]     - a Matplotlib //Axis// is a plot inside a Figure... [[http://​matplotlib.org/​faq/​usage_faq.html#​parts-of-a-figure|More details]]
     - some examples are more //​pythonic//​ (ie object oriented) than others, some example mix different styles of coding, all this can be confusing. Try to [[http://​matplotlib.org/​faq/​usage_faq.html#​coding-styles|use an object oriented way of doing things]]!     - some examples are more //​pythonic//​ (ie object oriented) than others, some example mix different styles of coding, all this can be confusing. Try to [[http://​matplotlib.org/​faq/​usage_faq.html#​coding-styles|use an object oriented way of doing things]]!
-    - sometimes the results of the python/​matplolib commands are shown directly, sometimes not. It depends if you are in [[http://​matplotlib.org/​faq/​usage_faq.html#​what-is-interactive-mode|interactive or non-interactive]] mode+    - sometimes the results of the python/​matplolib commands are displayed ​directly, sometimes not. It depends if you are in [[http://​matplotlib.org/​faq/​usage_faq.html#​what-is-interactive-mode|interactive or non-interactive]] mode
     - the documentation may mention [[http://​matplotlib.org/​faq/​usage_faq.html#​what-is-a-backend|backends]]. What?? Basically, you use python commands to create a plot, and the backend is the //thing// that will render your plot on the screen or in a file (png, pdf, etc...)     - the documentation may mention [[http://​matplotlib.org/​faq/​usage_faq.html#​what-is-a-backend|backends]]. What?? Basically, you use python commands to create a plot, and the backend is the //thing// that will render your plot on the screen or in a file (png, pdf, etc...)
 +    - if you don't see a part of what you have plotted, maybe it's hidden behind other elements! Use the [[https://​matplotlib.org/​examples/​pylab_examples/​zorder_demo.html|zorder parameter]] to explicitly specify the plotting order/​layers
   - Read the [[http://​www.labri.fr/​perso/​nrougier/​teaching/​matplotlib/​|Matplotlib tutorial by Nicolas Rougier]]   - Read the [[http://​www.labri.fr/​perso/​nrougier/​teaching/​matplotlib/​|Matplotlib tutorial by Nicolas Rougier]]
   - Download the [[http://​matplotlib.org/​contents.html|pdf version of the manual]]. **Do not print** the 2800+ pages of the manual! Read the beginner'​s guide (Chapter //FIVE// of //Part II//) and have a super quick look at the table of contents of the whole document.   - Download the [[http://​matplotlib.org/​contents.html|pdf version of the manual]]. **Do not print** the 2800+ pages of the manual! Read the beginner'​s guide (Chapter //FIVE// of //Part II//) and have a super quick look at the table of contents of the whole document.
 +
 +===== Graphics related resources =====
 +
 +  * [[http://​journals.plos.org/​ploscompbiol/​article?​id=10.1371/​journal.pcbi.1003833|Ten Simple Rules for Better Figures]]
 +  * [[http://​seaborn.pydata.org/​|Seaborn]] is a library for making attractive and informative statistical graphics in Python, built on top of matplotlib
 +    * See also: [[https://​www.datacamp.com/​community/​tutorials/​seaborn-python-tutorial|
 +Python Seaborn Tutorial For Beginners]]
 +  * Working with colors
 +    * [[https://​matplotlib.org/​users/​colormaps.html|Choosing colormaps]]
 +    * [[https://​matplotlib.org/​cmocean/​|Beautiful colormaps for oceanography:​ cmocean]]
 +    * [[http://​colorbrewer2.org|ColorBrewer 2.0]] is a tool that can help you understand, and experiment with //​sequential//,​ //​diverging//​ and //​qualitative//​ colormaps
 +
  
 ===== Basemap ===== ===== Basemap =====
  
-Summary: Basemap is an extension of Matplotlib that you can use for plotting maps, using different projections+<note warning>​Basemap is going to be slowly phased out, in favor of [[#​cartopy]]\\ More information in this: 
 +  * [[https://​github.com/​SciTools/​cartopy/​issues/​920|cartopy github issue]] 
 +  * [[https://​github.com/​matplotlib/​basemap/​issues/​267|basemap github issue]] 
 +</​note>​ 
 + 
 +Summary: ​//Basemap is an extension of Matplotlib that you can use for plotting maps, using different projections//
  
 Where: [[http://​matplotlib.org/​basemap/​|Basemap web site]] Where: [[http://​matplotlib.org/​basemap/​|Basemap web site]]
 +
 +Help on //stack overflow//: [[https://​stackoverflow.com/​questions/​tagged/​matplotlib-basemap|basemap help]]
  
 How to use basemap? How to use basemap?
   - look at the [[http://​matplotlib.org/​basemap/​users/​examples.html|examples]]   - look at the [[http://​matplotlib.org/​basemap/​users/​examples.html|examples]]
   - check the [[http://​matplotlib.org/​basemap/​users/​mapsetup.html|different projections]]   - check the [[http://​matplotlib.org/​basemap/​users/​mapsetup.html|different projections]]
-  - look at the [[http://​matplotlib.org/​basemap/​api/​basemap_api.html#​module-mpl_toolkits.basemap|detailed documentation]]+  ​- read some documentation! 
 +    - the **really nice** [[http://​basemaptutorial.readthedocs.io/​en/​latest/​index.html|basemap tutorial]] seems much better than the official documentation below 
 +    ​- look at the [[http://​matplotlib.org/​basemap/​api/​basemap_api.html#​module-mpl_toolkits.basemap|detailed ​official ​documentation]] 
 + 
 +===== Cartopy + Iris ===== 
 + 
 +Summary: //Cartopy is a Python package for advanced map generation with a simple matplotlib interface// and //Iris is a Python package for analysing and visualising meteorological and oceanographic data sets// 
 + 
 +Where: [[http://​scitools.org.uk/​cartopy/​docs/​latest/​|Cartopy]] and [[http://​scitools.org.uk/​iris/​index.html|Iris]] web sites 
 + 
 +Examples: 
 +  * [[http://​scitools.org.uk/​cartopy/​docs/​latest/​gallery.html|Gallery on the Cartopy web site]] 
 +  * [[http://​scitools.org.uk/​iris/​docs/​latest/​gallery.html|Gallery on the Iris web site]] 
 +  * [[http://​scitools.org.uk/​iris/​docs/​latest/​examples/​index.html|Examples on the Iris web site]] 
 + 
 +Help on //stack overflow//: [[https://​stackoverflow.com/​questions/​tagged/​cartopy|cartopy help]] 
 + 
 +===== Maps and projections resources ===== 
 + 
 +==== About projections ==== 
 + 
 +  * [[https://​egsc.usgs.gov/​isb//​pubs/​MapProjections/​projections.html|Map projections from USGS poster]] 
 +  * [[https://​pubs.usgs.gov/​pp/​1395/​report.pdf|Map projections - A working manual (USGS)]] 
 + 
 +==== Libraries ==== 
 + 
 +  * Projections in vcs 
 +  * [[http://​matplotlib.org/​basemap/​users/​mapsetup.html|Projections in basemap]] 
 +  * [[https://​scitools.org.uk/​cartopy/​docs/​latest/​crs/​projections.html|Projections in cartopy]] 
 + 
 + 
 +===== 3D resources ===== 
 + 
 +  * [[https://​ipyvolume.readthedocs.io/​en/​latest/​|Ipyvolume]] 
 +  * [[https://​zulko.wordpress.com/​2012/​09/​29/​animate-your-3d-plots-with-pythons-matplotlib/​|Animate your 3D plots with Python’s Matplotlib]] 
 +  * [[https://​stackoverflow.com/​questions/​26796997/​how-to-get-vertical-z-axis-in-3d-surface-plot-of-matplotlib|How to get vertical Z axis in 3D surface plot of Matplotlib?​]] 
 + 
 +=====  Data file formats =====  
 + 
 +We list here some resources about non-NetCDF data formats that can be useful 
 + 
 +==== json files ==== 
 + 
 +More and more applications use //json files// as configuration files or as a mean to use text files to exchange data (through serialization/​deserialization ). 
 + 
 +//json// files look basically like a **list of (nested) python dictionaries** that would have been dumped to a text file 
 + 
 +  * [[https://​docs.python.org/​2/​library/​json.html|json module]] documentation 
 +  * [[https://​realpython.com/​python-json/​|Working With JSON Data in Python]] tutorial 
 +  * example script: ''/​home/​users/​jypeter/​CDAT/​Progs/​Devel/​beaugendre/​nc2json.py''​ 
 +  * A compact (not easy to read...) //json// file can be pretty-printed with\\ ''​cat file.json | python -m json.tool | less''​ 
 + 
 +==== LiPD files ==== 
 + 
 +Resources for //Linked PaleoData//:​ 
 +  * [[http://​linked.earth/​projects/​lipd/​|LiPD]] 
 +  * [[https://​doi.org/​10.5194/​cp-12-1093-2016|Technical note: The Linked Paleo Data framework – 
 +a common tongue for paleoclimatology]] @ GMD 
 +  * [[https://​github.com/​nickmckay/​LiPD-utilities|LiPD-utilities]] @ github 
 + 
 +==== BagIt files ==== 
 + 
 +//BagIt//, a set of hierarchical file layout conventions for storage and transfer of arbitrary digital content. 
 + 
 +  * [[https://​tools.ietf.org/​html/​draft-kunze-bagit-16|The BagIt File Packaging Format]] 
 +  * [[https://​github.com/​LibraryOfCongress/​bagger|Bagger]] (BagIt GUI) 
 +  * [[https://​github.com/​LibraryOfCongress/​bagit-python|bagit-python]] 
 +===== Pandas ===== 
 + 
 +Summary: //pandas is a library providing high-performance,​ easy-to-use data structures and data analysis tools// 
 + 
 +Where: [[http://​pandas.pydata.org|Pandas web site]]
  
 +JYP's comment: pandas is supposed to be quite good for loading, processing and plotting time series, without writing custom code. You should at least have a quick look at:
 +  * The [[http://​www.scipy-lectures.org/​packages/​statistics/​index.html|Statistics in Python]] tutorial that combines Pandas, [[http://​statsmodels.sourceforge.net/​|Statsmodels]] and [[http://​seaborn.pydata.org/​|Seaborn]]
 +  * the cheat sheet on the [[https://​www.enthought.com/​services/​training/​pandas-mastery-workshop/​|Enthought workshops advertising page]]
 +  * the cheat sheet on the [[https://​github.com/​pandas-dev/​pandas/​tree/​master/​doc/​cheatsheet|github Pandas doc page]]
  
 ===== Scipy Lecture Notes ===== ===== Scipy Lecture Notes =====
Line 65: Line 304:
 Where: [[http://​www.scipy-lectures.org/​_downloads/​ScipyLectures-simple.pdf|pdf]] - [[http://​www.scipy-lectures.org/​|html]] Where: [[http://​www.scipy-lectures.org/​_downloads/​ScipyLectures-simple.pdf|pdf]] - [[http://​www.scipy-lectures.org/​|html]]
  
-This is a really nice document that is regularly updated and used for the [[https://​www.euroscipy.org/​|EuroScipy]] tutorials+This is **a really nice and useful ​document** that is regularly updated and used for the [[https://​www.euroscipy.org/​|EuroScipy]] tutorials. You will learn more things about python, numpy and matplotlib, debugging and optimizing scripts, and also learn about using python for statistics, image processing, machine learning, washing dishes (this is just to check if you have read this page), etc...
  
 ===== Quick Reference ===== ===== Quick Reference =====
  
-  * The nice Python 2.7 Quick Reference: [[http://​rgruet.free.fr/​PQR27/​PQR2.7_printing_a4.pdf|pdf]] - [[http://​rgruet.free.fr/​PQR27/​PQR2.7.html|html]]+  * The nice and convenient ​Python 2.7 Quick Reference: [[http://​rgruet.free.fr/​PQR27/​PQR2.7_printing_a4.pdf|pdf]] - [[http://​rgruet.free.fr/​PQR27/​PQR2.7.html|html]] 
 +    * A possibly more [[http://​iysik.com/​PQR2.7/​PQR2.7.html|up-date-version]] 
 + 
 +  * Python 3 [[https://​perso.limsi.fr/​pointal/​python:​abrege|Quick reference]] and [[https://​perso.limsi.fr/​pointal/​python:​memento|Cheat sheet]]
  
 ===== Some good coding tips ===== ===== Some good coding tips =====
Line 76: Line 318:
  
   * [[http://​blog.codinghorror.com/​a-pragmatic-quick-reference/​|A Pragmatic Quick Reference]]   * [[http://​blog.codinghorror.com/​a-pragmatic-quick-reference/​|A Pragmatic Quick Reference]]
 +
 +===== Debugging your code =====
 +
 +There is only so much you can do with staring at your code in your favorite text editor, and adding ''​print''​ lines in your code (or using [[https://​docs.python.org/​2/​howto/​logging.html#​logging-basic-tutorial|logging]] instead of ''​print''​). The next step is to **use the python debugger**!
 +
 +==== Debugging in text mode ====
 +
 +  - Start the script with: ''​python -m pdb my_script.py''​
 +  - Type ''​run''​ (or **r**) to go to the first line of the script
 +  - Type ''​continue''​ (or **c**) to execute the script to the end, or till the first breakpoint or error is reached
 +  - Use ''​where''​ (or **w**) to check the call stack that led to the current stop. Use ''​up''​ and ''​down''​ to navigate through the call stack and examine the values of the functions'​ parameters
 +  - Type ''​break NNN''​ to stop at line NNN
 +  - Use ''​type(var)''​ and ''​print var''​ to check the type and values of variables. You can also change the variables'​ values on the fly!
 +  - Type ''​run''​ (or **r**) to restart the script
 +  - Use ''​next''​ and ''​step''​ to execute some parts of the script line by line. If a code line calls a function:
 +    * ''​next''​ (or **n**) will execute a function and stop on the next line
 +    * ''​step''​ (or **s**) will stop at the first line **inside the function**  ​
 +  - Check the [[https://​docs.python.org/​2/​library/​pdb.html#​debugger-commands|debugger commands]] for details, or type ''​help''​ in the debugger for using the built-in help
 +
 +==== Using pydebug ====
 +
 +Depending on the distribution,​ the editor and the programming environment you use, you may have access to a graphical version of the debugger. UV-CDAT users can use ''​pydebug my_script.py''​
 +
 +===== Using a Python IDE =====
 +
 +**IDE** = //​Integrated Development Environment//​
 +
 +There are lots of ways to use Python and develop scripts, from using a lightweight approach (your favorite text editor with builtin python syntax highlighting,​ e.g. **emacs** and ''​python -i myscript.py''​) to a full-fledged IDE. You'll find below some IDE related links
 +
 +  * [[https://​www.datacamp.com/​community/​tutorials/​data-science-python-ide|Top 5 Python IDEs For Data Science]]
 +  * [[http://​noeticforce.com/​best-python-ide-for-programmers-windows-and-mac|Python IDE: The10 Best IDEs for Python Programmers]]
 +  * [[https://​wiki.python.org/​moin/​IntegratedDevelopmentEnvironments]]
 +
 +==== Spyder ====
 +
 +  * [[https://​github.com/​spyder-ide/​spyder|Home page]]
 +  * [[http://​pythonhosted.org/​spyder/​|Documentation]]
 +
  
 ===== Improving the performance of your code ===== ===== Improving the performance of your code =====
Line 83: Line 363:
   * **make sure that your script is not using too much memory** (the amount depends on the computer you are using)! Your script should be scalable (e.g. keeps on working even when your data gets bigger), so it's a good idea to load only the data you need in memory (e.g. not all the time steps), and learn how to load chunks of data   * **make sure that your script is not using too much memory** (the amount depends on the computer you are using)! Your script should be scalable (e.g. keeps on working even when your data gets bigger), so it's a good idea to load only the data you need in memory (e.g. not all the time steps), and learn how to load chunks of data
  
-  * **make sure that you are using array/​vector syntax and masks**, instead of using explicit loops and tests. The numpy documentation is big, because there are lots of optimized functions to help you! If you are stuck, ask JY or somebody else who is used to numpy.+  * **make sure that you are using array/​vector syntax and masks**, instead of using explicit loops and tests. The [[#​numpy_and_scipy|numpy documentation]] is big, because there are lots of optimized functions to help you! If you are stuck, ask JY or somebody else who is used to numpy.
  
 If your script is still not fast enough, there is a lot you can do to improve it, without resorting to parallelization (that may introduce extra bugs rather that extra performance). See the sections below If your script is still not fast enough, there is a lot you can do to improve it, without resorting to parallelization (that may introduce extra bugs rather that extra performance). See the sections below
  
 Hint: before optimizing your script, you should spent some time //​profiling//​ it, in order to only spend time improving the slow parts of your script Hint: before optimizing your script, you should spent some time //​profiling//​ it, in order to only spend time improving the slow parts of your script
 +
 +==== Useful packages ====
 +
 +  * [[https://​github.com/​pydata/​numexpr|Numexpr]]:​ //Numexpr is a **fast numerical expression evaluator for NumPy**. With it, expressions that operate on arrays (like "​3*a+4*b"​) are accelerated and use less memory than doing the same calculation in Python.//
 +  * [[http://​www.pytables.org/​|PyTables]]:​ //PyTables is a package for managing hierarchical datasets and designed to efficiently and **easily cope with extremely large amounts of data**//
  
 ==== Tutorials by Ian Osvald ==== ==== Tutorials by Ian Osvald ====
Line 97: Line 382:
  
 The official [[https://​docs.python.org/​2.7/​howto/​pyporting.html|Porting Python 2 Code to Python 3]] page gives the required information to make the transition from python 2 to python 3. It is still safe to use Python 2.7, so there is no rush to change to Python 3. The official [[https://​docs.python.org/​2.7/​howto/​pyporting.html|Porting Python 2 Code to Python 3]] page gives the required information to make the transition from python 2 to python 3. It is still safe to use Python 2.7, so there is no rush to change to Python 3.
 +
 +===== What now? =====
 +
 +You can do a lot more with python! But if you have read at least a part of this page, you should be able to find and use the modules you need. Make sure you do not reinvent the wheel! Use existing packages when possible, and make sure to report bugs or errors in the documentations when you find some
  
 /* standard page footer */ /* standard page footer */
other/python/jyp_steps.txt · Last modified: 2024/03/07 10:15 by jypeter