Skip to main content

GPU-accelerated, parallel implementation of Akima Splines

Project description

CudAkima: Parallel Akima Splines on GPUs

CudAkima is a Python package that offers a parallel, GPU-accelerated implementation of Akima Splines. The code also provides CPU support. The documentation is available here, while the code is hosted on GitHub.

Getting started:

Akima Splines are spline interpolants that tend to show smoother behaviors with respect to the widely used Cubic Splines. On the other hand, Akima Splines have a discontinuous second derivative.

Both scipy and cupy already offer implementations of Akima Splines. However, in these versions, the $x$ array along which the interpolation is performed can only be 1D. The main point behind the whole package is the fast, parallel interpolation of batches of arrays of different lengths. This is achieved by padding the1D arrays with NaN values and stacking them into multidimensional arrays.

In this implementation, the coefficients of the polynomials used for the interpolation are not stored in memory. For this reason, the package is particularly suited for applications where the arrays to perform the interpolation on keep changing (e.g., when doing parameter estimation on the location and amplitude of the spline knots). In this specific case, where $x$ and $y$ are matrices of different arrays, CudAkima results faster than a naive loop over the matrices using scipy (cupy) by a factor of $\sim 3$ ($\sim 20$) on CPUs (GPUs). This comparison can be found in the examples directory.

The interpolation scheme needs at least 4 finite points to work successfully. This caveat is due to the current boundary conditions. If this condition is not met (ie, the interpolation grid is made of less than 4 points), linear interpolation is used instead.

Here is a quick example of how to get started with the package:

from cudakima import AkimaInterpolant1D

interpolant = AkimaInterpolant1D()

Check out the examples directory for more info and comparisons.

Prerequisites:

CudAkima depends only on numba and numpy. It also requires cupy to be used on GPUs.

Installation

This project is managed by uv. uv can be installed with:

# macOS/Linux
curl -LsSf https://astral.sh/uv/install.sh | sh

# or with Homebrew
brew install uv

# or with pipx
pipx install uv

To set up the development environment, first clone the repository:

git clone https://github.com/asantini29/CudAkima.git
cd CudAkima
uv sync

This will create a virtual environment and install all necessary dependencies. Run your commands within this environment using

uv run <YOUR-COMMAND>

Versioning

We use SemVer for versioning.

Current Version: 0.2.2

Authors

  • Alesandro Santini

Contributors

Get in touch if you would like to contribute!

Code TODO:

  • extend documentation.
  • look at different boundary conditions.
  • work on a possible 2D interpolation.

License

This project is licensed under the MIT License - see the LICENSE.md file for details.

Citing

If you use CudAkima in your research, you can cite it in the following way:

@software{cudakima_2024_13919394,
  author       = {Alessandro Santini},
  title        = {asantini29/CudAkima: First official release},
  month        = oct,
  year         = 2024,
  publisher    = {Zenodo},
  version      = {v0.2.2},
  doi          = {10.5281/zenodo.13919394},
  url          = {https://doi.org/10.5281/zenodo.13919394}
}

Aknowledgments

We thank Nikolaos Karnesis for discussions.

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

cudakima-0.2.2.tar.gz (617.3 kB view details)

Uploaded Source

Built Distribution

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

cudakima-0.2.2-py3-none-any.whl (14.4 kB view details)

Uploaded Python 3

File details

Details for the file cudakima-0.2.2.tar.gz.

File metadata

  • Download URL: cudakima-0.2.2.tar.gz
  • Upload date:
  • Size: 617.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for cudakima-0.2.2.tar.gz
Algorithm Hash digest
SHA256 b5f2d6c5856f4bd2fe405b3b08df80d5663f597f7d05c0533027b71434c6656c
MD5 3da2983621ad97661214cc96a5ecff3d
BLAKE2b-256 db4495fd3a410580003078613872ea4326c6d4b5de47c62341e295fd11150416

See more details on using hashes here.

File details

Details for the file cudakima-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: cudakima-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 14.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for cudakima-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ef769f8ca35646913c419f144ce0a507f49616ca9f01080e3ee4175a94b58da9
MD5 1d864dec1fc5a1b6cb1ff6a8521d284b
BLAKE2b-256 e96de9627806d49bc5fffc69f9fa0faf78cb7e4a5dab668c9f2c686483873ecb

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