Metadata-Version: 2.4
Name: cudakima
Version: 0.2.2
Summary: GPU-accelerated, parallel implementation of Akima Splines
Project-URL: Homepage, https://github.com/asantini29/CudAkima
Project-URL: Repository, https://github.com/asantini29/CudAkima
Project-URL: Documentation, https://asantini29.github.io/CudAkima/
Project-URL: Bug Tracker, https://github.com/asantini29/CudAkima/issues
Author-email: Alessandro Santini <alessandro.santini@aei.mpg.de>
License: MIT
License-File: LICENSE
Keywords: CUDA,GPU,akima,interpolation,numba,spline
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Topic :: Scientific/Engineering :: Mathematics
Requires-Python: >=3.11
Requires-Dist: numba>=0.63.1
Requires-Dist: numpy>=2.3.5
Provides-Extra: docs
Requires-Dist: ipython>=8.0.0; extra == 'docs'
Requires-Dist: nbsphinx>=0.9.0; extra == 'docs'
Requires-Dist: sphinx-rtd-theme>=2.0.0; extra == 'docs'
Requires-Dist: sphinx>=7.0.0; extra == 'docs'
Description-Content-Type: text/markdown

# 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 <a href="https://asantini29.github.io/CudAkima/index.html">here</a>, while the code is hosted on  <a href="https://github.com/asantini29/CudAkima">GitHub</a>.

## Getting started:

[Akima Splines](https://en.wikipedia.org/wiki/Akima_spline) 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 <a href="https://docs.astral.sh/uv/">uv</a>. `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](http://semver.org/) 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](LICENSE) 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.
