SHTOOLS - Tools for working with spherical harmonics
Project description
SHTOOLS is a Fortran 95 / Python library that can be used to perform spherical harmonic transforms and reconstructions, rotations of data expressed in spherical harmonics, and multitaper spectral analyses on the sphere.
FEATURES
A wide range of supported spherical harmonic functions:
real and complex,
different normalizations (Geodesy 4π, Schmidt semi-normalized, orthonormalized, unnormalized),
Condon-Shortley phase factor of (-1)m.
Selected applications and routines:
global spectral analysis, spherical harmonic rotations, Wigner 3j symbols,
localized multitaper spectral analyses, optimal window generation, spherical harmonic coupling matrices,
standard gravity and magnetic field calculations, computation of the geoid, finite-amplitude potential from topography.
Clean implementation of the spherical harmonic transforms:
Exact quadrature rules using either the sampling theorem of Driscoll and Healy (1994) where data are equally sampled (or spaced) in latitude and longitude, or Gauss-Legendre quadrature.
Accurate and fast to approximately degree 2800, corresponding to a spatial resolution higher than 4 arc minutes. Transforms and reconstructions take on the order of 1 second for bandwidths less than 600 and about 3 minutes for bandwidths close to 2800 on standard machines. The Fortran 95 routines are OpenMP compatible and OpenMP thread-safe.
INSTALLATION
Requirements
Linux:
sudo apt-get install libblas-dev liblapack-dev g++ gfortran libfftw3-dev tcsh
OSX:
brew install fftw --with-fortran
Python Library
pip install pyshtools
Or, to install a developer version, download or clone the SHTOOLS repository, enter the SHTOOLS folder and then execute one of the following commands:
pip install . # installs into the active python environment lib folder
pip install -v -e . # installs into the SHTOOLS/pyshtools folder and links to the active python environment
Fortran Library
To install the Fortran 95 library, enter one of the following
make fortran
make fortran-mp # Open-MP Fortran routines
Or, with OSX, use the brew package manager:
brew tap shtools/shtools
brew install shtools
To also install the OpenMP components, add --with-openmp to the last command.
More installation instructions and options can be found in the web documentation and GitHub wiki.
HOW TO USE
SHTOOLS can be invoked from Fortran 95, Python 2, or Python 3. The base SHTOOLS software is written in Fortran 95, and the Python library allows simple access to all fortran-compiled routines and offers helper routines as well as simple interfaces.
To get started, check out the following Python tutorial notebooks:
Introduction 1: Grids and Spherical Harmonic Coefficients [ipynb]
Introduction 2: Localization Windows and Spectral Analysis [ipynb]
Tutorial 1: Simple Spherical Harmonic Analyses [ipynb]
Tutorial 2: Localized Spectral Analysis on the Sphere [ipynb]
Tutorial 3: The SHTOOLS Class Interface [ipynb]
Tutorial 4: Spherical Harmonic Normalizations and Parseval’s theorem [ipynb]
Tutorial 5: Multitaper Spectral Analysis Class Interface [ipynb]
Tutorial 6: 3D Spherical Harmonic Plots [ipynb]
You can keep up to date by following SHTOOLS on Twitter.
ACKNOWLEDGMENTS
SHTOOLS is open source (revised BSD license) and makes use of the freely available Fourier transform package FFTW and the linear algebra packages LAPACK and BLAS.
CITATION
Wieczorek, M. A., M. Meschede, I. Oshchepkov, E. Sales de Andrade (2016). SHTOOLS: Version 3.4. Zenodo. doi:10.5281/zenodo.61180.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file pyshtools-4.0.tar.gz
.
File metadata
- Download URL: pyshtools-4.0.tar.gz
- Upload date:
- Size: 18.5 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dbd2b7b676a590152e864a399662c83ad7256afba576d77bb1b152b523e47aef |
|
MD5 | 4ec3d2b5ab2749515c90cf66246e0227 |
|
BLAKE2b-256 | cc2ec2d8268390c1f8105fafa262f82b1f7df8125405fa07dded37bb13938bd9 |