This extension adds functionality to work with Spherical Harmonics to Xarray.
- Gravity functionals: (convert from Stokes coefficients to various gravity functionals, such as equivalent water heights, geoid changes, etc.)
- Filter (e.g. Gaussian or anisotropic filter applied in the spectral domain)
- The use of Xarray like operations allow for applying functionality to multi-dimensional datasets
The tutorials in the documentation will gradually epxand and provide Jupyter notebook workflows to start with.
You can install this package from PyPi using:
pip install shxarray
If you want to help in the development of this package, it's best to clone the repository to allow for modifications and pull requests. The extension makes use of Cython generated code to speed up spherical harmonic synthesis and analysis.
- Create your own virtual environment with
venv
or Anaconda (Optional but recommended, when a user installation is desired) - Clone this repository
git clone https://github.com/ITC-Water-Resources/shxarray.git
- Change to the repository directory
cd shaxarray
- Set the environment variable
export USE_CYTHON=1
(Optional and only in the case Cython code is being developed or needs to be regenerated) - Install using pip
pip install .
or usepip install -e .
for an editable install
From the repository root directory, regenerating the shared library running
python ./setup.py build_ext
will be much faster than using
pip install -e .
This will build the shared library in for example ./build/lib.linux-x86_64-cpython-3xx/shxarray/shlib.cpython-3xx-x86_64-linux-gnu.so
. To make sure changes are picked up in your editable install you can create a symbolic link in the Python part of the library e.g. :
cd src/shxarray/
ln -sf ../../build/lib.linux-x86_64-cpython-311/shxarray/shlib.cpython-311-x86_64-linux-gnu.so
The provided c++ files are cythonized against numpy > 2. When building against older numpy versions (<2), the cpp files are re-cythonized upon install, this requires a working cython install.
This repository is under development and contributions and feedback is welcome.
- Main developer: Roelof Rietbroek ([email protected])
- Kiana Karimi