Skip to main content

ipython extension for pyferret

Project description

ipython_ferretmagic

IPython notebook extension for ferret (a great software for Data Visualisation and Analysis from NOAA/PMEL).

Browse the demo notebooks from http://nbviewer.ipython.org/github/PBrockmann/ipython_ferretmagic/tree/master/notebooks

Combine ferret and ipython widgets and create interactive notebooks !

Test it with binder. Binder

Browse a basic ferret tutorial using ferretmagic from: https://github.com/PBrockmann/C-CASCADES_notebooks/blob/master/ferretBasics.ipynb

ScreenShot

Latest news

2018/10/01

  • Compatibility with python 3 with print command and base64 encoding
  • Tested with pyferret==7.43, notebook==5.7.0, jupyter==1.0.0, ipython==5.8.0, ipywidgets==7.4.2
  • Update pip package (now last version is 20181001 https://pypi.org/project/ferretmagic/)

2018/01/18

2017/03/17

  • Tested with pyferret==7.1, jupyter==4.2.0, ipywidgets==6.0.0

2016/10/28

  • Tested with pyferret==7.0, jupyter==4.2.0 and ipython==5.1.0
  • Installation from pip

Installation

Install PyFerret following instructions from http://ferret.pmel.noaa.gov/Ferret/documentation/pyferret It will set all directories needed to run pyferret (font, ppl, jnls, datasets, ...).

You can also install PyFerret as a conda package from https://anaconda.org/conda-forge/pyferret (no datasets distributed).

Then install the ferret magic extension (ferretmagic.py) by typing pip install ferretmagic

Usage

In a Jupyter notebook with kernel python (previously named ipython), load the magics:

In [2]: %load_ext ferretmagic

Line magics

The %ferret_run magic enables one-line execution of ferret command in the IPython interpreter or notebook:

    In [3]: for i in [100,500,1000]:
      ....: 	%ferret_run -s 400,400 'plot sin(i[i=1:%(i)s]*0.1)' % locals()

Cell magics

Multi-line input can be entered with the %%ferret cell magic:

In [4]: %%ferret
  ....: use levitus_climatology
  ....: shade temp[k=1]			! comments
  • Control size of plot with --size, -s option.
  • Create a local pdf at the same time with --pdf, -p option.
In [5]: %%ferret -s 400,300 -pdf myfig.pdf
  ....: shade temp[k=1]			

Passing variables between Python and ferret

  • Variables can be pushed from IPython into ferret with %ferret_putdata:
In [18]: %%ferret
   ....: use levitus_climatology
In [19]: %ferret_getdata tempdict = temp
   ....: Message: tempdict is now available in python as a dictionary containing the variable's metadata and data array.
In [20]: print tempdict.keys()
   ....: ['axis_coords', 'axis_types', 'data_unit', 'axis_units', 'title', 'axis_names', 'missing_value', 'data']
  • Variables can be pulled from ferret into IPython with %ferret_getdata:
In [31]: import numpy as np
   ....: b = {}
   ....: b['name']='myvar'
   ....: b['name']='myvar'
   ....: x=np.linspace(-np.pi*4, np.pi*4, 500)
   ....: b['data']=np.sin(x)/x
   ....: b.keys()
Out[31]: ['data', 'name']
In [32]: %ferret_putdata --axis_pos (1,0,2,3,4,5) b
   ....: Message: b is now available in ferret as myvar

Explore notebook for examples.

Known issues and limitations

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ferretmagic-20181001.tar.gz (7.5 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

ferretmagic-20181001-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

ferretmagic-20181001-py2-none-any.whl (8.1 kB view details)

Uploaded Python 2

File details

Details for the file ferretmagic-20181001.tar.gz.

File metadata

  • Download URL: ferretmagic-20181001.tar.gz
  • Upload date:
  • Size: 7.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/40.2.0 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/2.7.15

File hashes

Hashes for ferretmagic-20181001.tar.gz
Algorithm Hash digest
SHA256 e1ad96c267a877aac902e070c73bec73e6eaed75ac6bcf05137caddc56f42626
MD5 533471287567b379cfdbde6968d3f86a
BLAKE2b-256 21b6b143120ea4f9934dc6c8b4cb9c01873c59b764b8feb9f394e55cf1e2e306

See more details on using hashes here.

File details

Details for the file ferretmagic-20181001-py3-none-any.whl.

File metadata

  • Download URL: ferretmagic-20181001-py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/40.2.0 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/2.7.15

File hashes

Hashes for ferretmagic-20181001-py3-none-any.whl
Algorithm Hash digest
SHA256 95a5bb6c2addc0bb66748bd9a59dbf0ca6d5156a887b76797121d9112a0a3d94
MD5 ce1f613740fba165f5602e8571a40ef0
BLAKE2b-256 f296a74de7ad391d5298222f7c2beefea3f2231d877199cfb6564d7179086be0

See more details on using hashes here.

File details

Details for the file ferretmagic-20181001-py2-none-any.whl.

File metadata

  • Download URL: ferretmagic-20181001-py2-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/2.7.12

File hashes

Hashes for ferretmagic-20181001-py2-none-any.whl
Algorithm Hash digest
SHA256 04569de9e8502996646c6708d15a9902c72f6c8ca979f0fa51736231e1ea31e6
MD5 b4ca7fdb07d66ed15b3ba7cd897ec6c5
BLAKE2b-256 8cda964534bdebd7736ae9d89602e280557865f48b0d03845a0c1697752496c5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page