Numba-friendly Python bindings to Cephes math library
Project description
cephes4py
cephes4py is a Python interface to the HCephes library, which is a reformatted version of Netlib Cephes. It provides a convenient way to access the functionality of the HCephes library within Python. cephes4py has been updated to ensure compatibility with modern Numba releases (specifically tested on version 0.57.0).
Motivation
The motivation behind developing cephes4py was the need to use SciPy special functions within Numba functions running in nopython mode. Unfortunately, this was not possible due to compatibility issues. Since many of SciPy's special functions are actually wrappers of Cephes functions, I decided to create my own bindings to Cephes that were compatible with Numba.
Although cephes4py is much less "batteries included", I have conducted a preliminary experiment that suggests some performance improvements as well. You can refer to this notebook for more details.
No Argument Validation
It is important to note that cephes4py does not perform validation of the arguments passed to the underlying C-functions. This decision was made because validating even a single argument in Python could potentially double the execution time. Additionally, it would require wrapping the functions with the validation code, which makes them uncompatible with Numba. Therefore, I have chosen to leave the responsibility and freedom of argument validation to you. Please refer to FUNCTIONS.txt or interface.h to see the expected parameter and return types.
In the event that you provide invalid arguments, Hcephes will display an error message and return a fallback value. Please keep in mind that an argument can be considered invalid even if the data type is correct. For example, the binomial distribution function requires arguments to be positive, with the parameter p
ranging from 0 to 1 and k
being smaller than n
. Once again, please consult FUNCTIONS.txt for more information.
Cephes Function Bindings
For a list of available Cephes functions and their descriptions, please refer to FUNCTIONS.txt. Please note that I have not tested all of the functions extensively, but as long as the parameters and return types are scalar-valued, they should work properly. If you intend to pass Numpy arrays as arguments, things get a little more involved as you'll have to get the pointer to its buffer:
a = np.zeros(10, dtype=np.float64)
pointer = cephes4py.from_buffer("double[]", a)
function_you_want_to_use(pointer)
Installation
To install cephes4py, please follow these steps:
- Install the hcephes binary. It is recommended to compile it from source, but you will need Cmake to do so. You can use the following command to install it:
curl -fsSL https://git.io/JerYI | GITHUB_USER=limix GITHUB_PROJECT=hcephes bash
- Navigate to the root directory of this repository.
- Install the cephes4py package by running the following command:
pip install .
- You're all set! You can now use cephes4py in your Python code:
import cephes4py # Example usage bdtr = cephes4py.bdtr(4, 6, 0.3) # You can even use the function in Numba-jitted functions running in nopython mode: @nb.njit def nb_bdtr(k, n, p): return cephes4py.bdtr(k, n, p) bdtr = nb_bdtr(4, 6, 0.3)
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
Built Distribution
File details
Details for the file cephes4py-0.0.3.tar.gz
.
File metadata
- Download URL: cephes4py-0.0.3.tar.gz
- Upload date:
- Size: 10.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dea54185141b3e86554fae494a2b4e607c3129d204872ad0459a6ca787ea973c |
|
MD5 | a52936f1a2000dd86d2249e8cc0871a2 |
|
BLAKE2b-256 | 7618d2bc2f94531dec883fa6503042a9dce29d4718b7bf26be3dd6f5f31479fa |
File details
Details for the file cephes4py-0.0.3-cp310-cp310-manylinux_2_24_x86_64.whl
.
File metadata
- Download URL: cephes4py-0.0.3-cp310-cp310-manylinux_2_24_x86_64.whl
- Upload date:
- Size: 181.0 kB
- Tags: CPython 3.10, manylinux: glibc 2.24+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f7a2d225c20939caf72028f183d02e7c11e8fba6543065830ae908f962351fef |
|
MD5 | e7d7ee6db1e6a3c3940b7abaafd810d4 |
|
BLAKE2b-256 | 04277090093cf490f6a379c175b71660c7a358339054801c58ce3af8ac131af0 |