Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ajdawson/eofs
EOF analysis in Python
https://github.com/ajdawson/eofs
Last synced: 4 days ago
JSON representation
EOF analysis in Python
- Host: GitHub
- URL: https://github.com/ajdawson/eofs
- Owner: ajdawson
- License: gpl-3.0
- Created: 2013-03-15T13:49:09.000Z (over 11 years ago)
- Default Branch: main
- Last Pushed: 2024-04-09T14:11:02.000Z (7 months ago)
- Last Synced: 2024-06-11T19:22:29.360Z (5 months ago)
- Language: Python
- Homepage: http://ajdawson.github.io/eofs/
- Size: 51.2 MB
- Stars: 193
- Watchers: 18
- Forks: 60
- Open Issues: 24
-
Metadata Files:
- Readme: README.md
- License: COPYING
Awesome Lists containing this project
- awesome-meteo - eofs
README
eofs - EOF analysis in Python
=============================[![Build Status](https://travis-ci.org/ajdawson/eofs.svg?branch=master)](https://travis-ci.org/ajdawson/eofs) [![DOI (paper)](https://img.shields.io/badge/DOI%20%28paper%29-10.5334%2Fjors.122-blue.svg)](http://doi.org/10.5334/jors.122) [![DOI (latest release)](https://zenodo.org/badge/20448/ajdawson/eofs.svg)](https://zenodo.org/badge/latestdoi/20448/ajdawson/eofs)
Overview
--------eofs is a Python package for performing empirical orthogonal function (EOF) analysis on spatial-temporal data sets, licensed under the GNU GPLv3.
The package was created to simplify the process of EOF analysis in the Python environment.
Some of the key features are listed below:* Suitable for large data sets: computationally efficient for the large data sets typical of modern climate model output.
* Transparent handling of missing values: missing values are removed automatically when computing EOFs and re-inserted into output fields.
* Meta-data preserving interfaces (optional): works with the iris data analysis package, xarray, or the cdms2 module (from UV-CDAT) to carry meta-data over from input fields to output.
* No Fortran dependencies: written in Python using the power of NumPy, no compilers required.Requirements
------------eofs only requires the NumPy package (and setuptools to install).
In order to use the meta-data preserving interfaces one (or more) of cdms2 (part of [UV-CDAT](http://uvcdat.llnl.gov/)), [iris](http://scitools.org.uk/iris), or [xarray](http://xarray.pydata.org) is needed.Documentation
-------------Documentation is available [online](http://ajdawson.github.io/eofs).
The package docstrings are also very complete and can be used as a source of reference when working interactively.Citation
--------If you use eofs in published research, please cite it by referencing the [peer-reviewed paper](http://doi.org/10.5334/jors.122).
You can additionally cite the [Zenodo DOI](http://dx.doi.org/10.5281/zenodo.46871) if you need to cite a particular version (but please also cite the paper, it helps me justify my time working on this and similar projects).Installation
------------eofs works on Python 2 or 3 on Linux, Windows or OSX.
The easiest way to install eofs is by using [conda](http://conda.pydata.org/docs/) or pip:conda install -c conda-forge eofs
or
pip install eofs
You can also install from the source distribution:
python setup.py install
Frequently asked questions
--------------------------* **Do I need UV-CDAT/cdms2, iris or xarray to use eofs?**
No. All the computation code uses NumPy only.
The cdms2 module, iris and xarray are only required for the meta-data preserving interfaces.