Skip to main content

A fast Lomb-Scargle periodogram. It's nifty, and uses a NUFFT.

Project description

nifty-ls

A fast Lomb-Scargle periodogram. It's nifty, and uses a NUFFT!

PyPI Tests pre-commit.ci status Jenkins Tests arXiv

Overview

The Lomb-Scargle periodogram, used for identifying periodicity in irregularly-spaced observations, is useful but computationally expensive. However, it can be phrased mathematically as a pair of non-uniform FFTs (NUFFTs). This allows us to leverage Flatiron Institute's finufft package, which is really fast! It also enables GPU (CUDA) support and is several orders of magnitude more accurate than Astropy's Lomb Scargle with default settings.

Background

The Press & Rybicki (1989) method for Lomb-Scargle poses the computation as four weighted trigonometric sums that are solved with a pair of FFTs by "extirpolation" to an equi-spaced grid. Specifically, the sums are of the form:

\begin{align}
S_k &= \sum_{j=1}^M h_j \sin(2 \pi f_k t_j), \\
C_k &= \sum_{j=1}^M h_j \cos(2 \pi f_k t_j),
\end{align}

where the $k$ subscript runs from 0 to $N$, the number of frequency bins, $f_k$ is the cyclic frequency of bin $k$, $t_j$ are the observation times (of which there are $M$), and $h_j$ are the weights.

The key observation for our purposes is that this is exactly what a non-uniform FFT computes! Specifically, a "type-1" (non-uniform to uniform) complex NUFFT in the finufft convention computes:

g_k = \sum_{j=1}^M h_j e^{i k t_j}.

The complex and real parts of this transform are Press & Rybicki's $S_k$ and $C_k$, with some adjustment for cyclic/angular frequencies, domain of $k$, real vs. complex transform, etc. finufft has a particularly fast and accurate spreading kernel ("exponential of semicircle") that it uses instead of Press & Rybicki's extirpolation.

There is some pre- and post-processing of $S_k$ and $C_k$ to compute the periodogram, which can become the bottleneck because finufft is so fast. This package also optimizes and parallelizes those computations.

Fast $\chi^2$ Method (nterms > 1)

Palmer (2009) extends the Lomb-Scargle model with a specified number of harmonics (called nterms in Astropy). This is implemented as a $\chi^2$ minimization at each frequency, requiring solving $N$ small matrix systems. This method is also amenable to FINUFFT acceleration, as the terms in these matrices can be computed with a NUFFT.

Because FINUFFT is so fast, the matrix assembly and linear‐algebra solve can be the primary bottlenecks of the fast $\chi^2$ method. These routines and other computational steps have been optimized and parallelized in nifty-ls.

Installation

From PyPI

For CPU support:

$ pip install nifty-ls

For GPU (CUDA) support:

$ pip install nifty-ls[cuda]

The default is to install with CUDA 12 support; one can use nifty-ls[cuda11] instead for CUDA 11 support (installs cupy-cuda11x).

From source

First, clone the repo and cd to the repo root:

$ git clone https://www.github.com/flatironinstitute/nifty-ls
$ cd nifty-ls

Then, to install with CPU support:

$ pip install .

To install with GPU (CUDA) support:

$ pip install .[cuda]

or .[cuda11] for CUDA 11.

For development (with automatic rebuilds enabled by default in pyproject.toml):

$ pip install nanobind scikit-build-core setuptools_scm ninja
$ pip install -e . --group dev --no-build-isolation

Developers may also be interested in setting these keys in pyproject.toml:

[tool.scikit-build]
cmake.build-type = "Debug"
cmake.verbose = true
install.strip = false

For best performance

You may wish to compile and install finufft and cufinufft yourself so they will be built with optimizations for your hardware. To do so, first install nifty-ls, then follow the Python installation instructions for finufft and cufinufft, configuring the libraries as desired. Note that (cu)finufft is not bundled with nifty-ls, but is instead used through its Python interface.

nifty-ls can likewise be built from source following the instructions above for best performance, but most of the heavy computations are offloaded to (cu)finufft, so the performance benefit is minimal.

Usage

From Astropy

Importing nifty_ls makes nifty-ls available via method="fastnifty" in Astropy's LombScargle module. The name is prefixed with "fast" as it's part of the fast family of methods that assume a regularly-spaced frequency grid.

import nifty_ls
from astropy.timeseries import LombScargle
frequency, power = LombScargle(t, y).autopower(method="fastnifty")

For nterms > 1, pass the "fastnifty_chi2" method:

frequency_chi2, power_chi2 = LombScargle(t, y, nterms=2).autopower(method="fastnifty_chi2")
Full example
import matplotlib.pyplot as plt
import nifty_ls
import numpy as np
from astropy.timeseries import LombScargle

rng = np.random.default_rng(seed=123)
N = 1000
t = rng.uniform(0, 100, size=N)
y = np.sin(50 * t) + 1 + rng.poisson(size=N)

frequency, power = LombScargle(t, y).autopower(method='fastnifty')

nterms = 4
frequency_chi2, power_chi2 = LombScargle(t, y, nterms=nterms).autopower(method='fastnifty_chi2')

plt.figure(figsize=(12, 5))

# Plot 1: Single component signal
plt.subplot(1, 2, 1)
plt.plot(frequency, power, label='nifty-ls (single component)')
plt.xlabel('Frequency (cycles per unit time)')
plt.ylabel('Power')
plt.title('Single Component Signal')
plt.legend()

# Plot 2: Two component signal with chi2
plt.subplot(1, 2, 2)
plt.plot(frequency_chi2, power_chi2, label='nifty-ls Chi2 (multi-component)', color='red')
plt.xlabel('Frequency (cycles per unit time)')
plt.ylabel('Power')
plt.title('Multi-Component Signal (nterms=4)')
plt.legend()

plt.tight_layout()
plt.show()

To use the CUDA (cufinufft) backend, pass the appropriate argument via method_kws:

frequency, power = LombScargle(t, y).autopower(method="fastnifty", method_kws=dict(backend="cufinufft"))

Likewise, for nterms > 1:

frequency_chi2, power_chi2 = LombScargle(t, y, nterms=2).autopower(method="fastnifty_chi2", method_kws=dict(backend="cufinufft_chi2"))

In many cases, accelerating your periodogram is as simple as setting the method in your Astropy Lomb Scargle code! More advanced usage, such as computing multiple periodograms in parallel, should go directly through the nifty-ls interface.

From nifty-ls (native interface)

nifty-ls has its own interface that offers more flexibility than the Astropy interface for batched periodograms.

Single periodograms

A single periodogram can be computed through nifty-ls as:

import nifty_ls
# with automatic frequency grid:
nifty_res = nifty_ls.lombscargle(t, y, dy)

# with automatic backend method selection:
nifty_res_chi2 = nifty_ls.lombscargle(t, y, dy, nterms=4)

# with user-specified frequency grid:
nifty_res = nifty_ls.lombscargle(t, y, dy, fmin=0.1, fmax=10, Nf=10**6)

# with user-specified backend method:
nifty_res_chi2 = nifty_ls.lombscargle(t, y, dy, Nf=10**6, nterms=4, backend='finufft_chi2')
Full example
import matplotlib.pyplot as plt
import nifty_ls
import numpy as np

rng = np.random.default_rng(seed=123)
N = 1000
t = np.sort(rng.uniform(0, 100, size=N))
y = np.sin(50 * t) + 1 + rng.poisson(size=N)

# with automatic frequency grid:
nifty_res = nifty_ls.lombscargle(t, y)

# Automatically selects the backend method based on the available options and the specified nterms:
nifty_res_chi2 = nifty_ls.lombscargle(t, y, dy=None, nterms=4)

# with user-specified frequency grid:
nifty_res = nifty_ls.lombscargle(t, y, fmin=0.1, fmax=10, Nf=10**6)

# with user-specified backend method:
nifty_res_chi2 = nifty_ls.lombscargle(t, y, dy=None, Nf=10**6, nterms=4, backend='finufft_chi2')

plt.figure(figsize=(12, 5))

# Plot 1: Finufft Grid
plt.subplot(1, 2, 1)
plt.plot(nifty_res.freq(), nifty_res.power, label='Default Grid')
plt.xlabel('Frequency (cycles per unit time)')
plt.ylabel('Power')
plt.title('Default Grid')
plt.legend()

# Plot 2: Finufft_chi2 Backend
plt.subplot(1, 2, 2)
plt.plot(nifty_res_chi2.freq(), nifty_res_chi2.power, label='Chi2 Backend', color='red')
plt.xlabel('Frequency (cycles per unit time)')
plt.ylabel('Power')
plt.title('Chi2 Backend (nterms=4)')
plt.legend()

plt.tight_layout()
plt.show()

Batched Periodograms

Batched periodograms (multiple objects with the same observation times) can be computed as:

import nifty_ls
import numpy as np

N_t = 100
N_obj = 10
Nf = 200

rng = np.random.default_rng()
t = np.sort(rng.random(N_t))
obj_freqs = rng.random(N_obj).reshape(-1,1)
y_batch = np.sin(obj_freqs * t)
dy_batch = rng.random(y_batch.shape)

batched = nifty_ls.lombscargle(t, y_batch, dy_batch, Nf=Nf)

# Similarly for Chi2 method
batched_chi2 = nifty_ls.lombscargle(t, y_batch, dy_batch, Nf=Nf, nterms=4)

print(batched.power.shape)  # (10, 200)
print(batched_chi2.power.shape)  # same: (10, 200)

Note that this computes multiple periodograms simultaneously on a set of time series with the same observation times. This approach is particularly efficient for short time series, and/or when using the GPU.

Batching multiple time series with distinct observation times is not directly supported currently, but a similar effect can be achieved with free-threaded Python.

Free-Threaded Parallelism

nifty-ls supports free-threaded Python since version 1.1.0. With a free-threaded build of Python, efficient parallelism over many time series with distinct observation times can be achieved with:

from concurrent.futures import ThreadPoolExecutor

with ThreadPoolExecutor(max_workers=nthreads) as executor:
    futures = [
        executor.submit(nifty_ls.lombscargle, t, y, nthreads=1) for (t,y) in zip(t_values, y_values)
    ]
results = [future.result() for future in futures]
Full example
import concurrent.futures

import matplotlib.pyplot as plt
import nifty_ls
import numpy as np

N_periodograms = 200
N_points_poisson = 10000
python_threads = 32  # "None" will use all CPUs
rng = np.random.default_rng(42)

t_values = []
y_values = []
frequencies = rng.uniform(0.1, 100.0, size=N_periodograms)

for i in range(N_periodograms):
    n_points = rng.poisson(N_points_poisson)
    t = np.sort(rng.uniform(0, 100, size=n_points))
    y = np.sin(2 * np.pi * frequencies[i] * t) + 0.1 * rng.normal(size=n_points)
    t_values.append(t)
    y_values.append(y)

with concurrent.futures.ThreadPoolExecutor(max_workers=python_threads) as executor:
    futures = [
        executor.submit(nifty_ls.lombscargle, t, y, nthreads=1) for (t,y) in zip(t_values, y_values)
    ]

results = [future.result() for future in futures]

fig, axes = plt.subplots(N_periodograms, 1, figsize=(6, 2 * N_periodograms), constrained_layout=True)
for i in range(N_periodograms):
    axes[i].plot(results[i].freq(), results[i].power)
    axes[i].set_title(f"Periodogram {i + 1}")
    axes[i].set_xlabel("Frequency")
    axes[i].set_ylabel("Power")

plt.show()
plt.savefig("periodograms.png", dpi=300, bbox_inches="tight")

This approach allows you to compute multiple heterogeneous periodograms in parallel. A similar effect can be achieved with multiple processes, but this is less efficient due to the overhead of inter-process communication.

Astropy (as of version 7.1.0) does not support free-threaded Python, however. Be alert for messages printed to the interpreter that free threading is disabled due to Astropy, and remove Astropy from your environment if necessary.

Note that each nifty-ls computation may use multiple OpenMP threads internally. To avoid spawning too many threads, we recommend setting nthreads=1 in the call to nifty-ls.

Limitations

The code only supports frequency grids with fixed spacing; however, finufft does support type 3 NUFFTs (non-uniform to non-uniform), which would enable arbitrary frequency grids. It's not clear how useful this is, so it hasn't been implemented, but please open a GitHub issue if this is of interest to you.

Performance

Using 16 cores of an Intel Icelake CPU and a NVIDIA A100 GPU, we obtain the following performance. First, we'll look at results from a single periodogram (i.e. unbatched):

benchmarks

In this case, finufft is 5× faster (11× with threads) than Astropy for large transforms, and 2× faster for (very) small transforms. Small transforms improve futher relative to Astropy with more frequency bins. (Dynamic multi-threaded dispatch of transforms is planned as a future feature which will especially benefit small $N$.)

cufinufft is 200× faster than Astropy for large $N$! The performance plateaus towards small $N$, mostly due to the overhead of sending data to the GPU and fetching the result. (Concurrent job execution on the GPU is another planned feature, which will especially help small $N$.)

Similar performance trends are observed for the $\chi^2$ method. The following results use nterms=4 as an example:

benchmarks

In this case, finufft is 100× faster than Astropy's fastchi2 method, and 300× faster with multi-threading enabled. cufinufft achieves an impressive 5600× speedup over Astropy for large $N$! However, it suffers from similar overhead for small $N$ due to data transfer costs between CPU and GPU. The performance gain being larger for the $\chi^2$ method than the standard method is partially due to the greater number of NUFFTs in this method, and partially due to the large number of small matrix operations, which nifty-ls accelerates.

The following demonstrates "batch mode", in which 10 periodograms are computed from 10 different time series with the same observation times:

batched benchmarks

Here, the finufft single-threaded advantage is consistently 6× across problem sizes, while the multi-threaded advantage is up to 30× for large transforms.

The 200× advantage of the GPU extends to even smaller $N$ in this case, since we're sending and receiving more data at once.

We see that both multi-threaded finufft and cufinufft particularly benefit from batched transforms, as this exposes more parallelism and amortizes fixed latencies.

We use FFTW_MEASURE for finufft in these benchmarks, which improves performance a few tens of percents.

Multi-threading hurts the performance of small problem sizes; the default behavior of nifty-ls is to use fewer threads in such cases. The "multi-threaded" line uses between 1 and 16 threads.

On the CPU, nifty-ls gets its performance not only through its use of finufft, but also by offloading the pre- and post-processing steps to compiled extensions. The extensions enable us to do much more processing element-wise, rather than array-wise. In other words, they enable "kernel fusion" (to borrow a term from GPU computing), increasing the compute density.

Accuracy

While we compared performance with Astropy's fast and fastchi2 methods, this isn't quite fair. nifty-ls is much more accurate than Astropy fast and fastchi2! These Astropy methods use Press & Rybicki's extirpolation approximation, trading accuracy for speed, but thanks to finufft, nifty-ls can have both.

In the figure below, we plot the median periodogram error in circles and the 99th percentile error in triangles for astropy, finufft, and cufinufft for a range of $N$ (and default $N_F \approx 12N$).

The astropy result is presented for two cases: a nominal case and a "worst case". Internally, astropy uses an FFT grid whose size is the next power of 2 above the target oversampling rate. Each jump to a new power of 2 typically yields an increase in accuracy. The "worst case", therefore, is the highest frequency that does not yield such a jump.

Errors of $\mathcal{O}(10%)$ or greater are common with worst-case evaluations. Errors of $\mathcal{O}(1%)$ or greater are common in typical evaluations. nifty-ls is conservatively 6 orders of magnitude more accurate.

The reference result in the above figure comes from the "phase winding" method, which uses trigonometric identities to avoid expensive sin and cos evaluations. One can also use astropy's fast method or fastchi2 method as a reference with exact evaluation enabled via use_fft=False, and one finds the same result. The phase winding is used because it is a few orders of magnitude faster (but still not competitive with finufft).

The following shows a similar accuracy comparison for the $\chi^2$ variants, finding similar results:

In summary, nifty-ls is highly accurate while also giving high performance.

Numerics

float32 vs float64

While 32-bit floats provide a substantial speedup for finufft and cufinufft, we generally don't recommend their use for Lomb-Scargle. The reason is the challenging condition number of the problem. The condition number is the response in the output to a small perturbation in the input—in other words, the derivative. It can easily be shown that the derivative of a NUFFT with respect to the non-uniform points is proportional to $N$, the transform length (i.e. the number of modes). In other words, errors in the observation times are amplified by $\mathcal{O}(N)$. Since float32 has a relative error of $\mathcal{O}(10^{-7})$, transforms of length $10^5$ already suffer $\mathcal{O}(1%)$ error. Therefore, we focus on float64 in nifty-ls, but float32 is also natively supported by all backends for adventurous users.

The condition number is also a likely contributor to the mild upward trend in error versus $N$ in the above figure, at least for finufft/cufinufft. With a relative error of $\mathcal{O}(10^{-16})$ for float64 and a transform length of $\mathcal{O}(10^{6})$, the minimum error is $\mathcal{O}(10^{-10})$.

Fast $\chi^2$ matrix condition number

In the $\chi^2$ backends with nterms > 1, users should be aware that the first few modes tend to have ill-conditioned matrices, especially when using the default frequency grid. Each matrix represents a Fourier mode and its nterms harmonics, and the loss of conditioning appears to represent a loss of linear independence between the harmonics because the default minimum frequency (inherited from Astropy) is so low. In other words, the harmonics are not picking up appreciably different power across the signal. Solving for the harmonic amplitudes is thus under-constrained, which can amplify differences between nifty-ls and Astropy. Most users will not notice this unless directly comparing Astropy and nifty-ls periodograms, but if you encounter this, consider using fewer nterms or a higher minimum frequency.

Testing

First, install from source (pip install . --group test). Then, from the repo root, run:

$ pytest

Or, with uv, the previous steps can be combined as:

$ uv run pytest

The tests are defined in the tests/ directory, and include a mini-benchmark of nifty-ls and Astropy, shown below:

$ pytest
============================= test session starts ==============================
platform linux -- Python 3.10.13, pytest-8.4.0, pluggy-1.6.0
benchmark: 5.1.0 (defaults: timer=time.perf_counter disable_gc=True min_rounds=5 min_time=0.000005 max_time=1.0 calibration_precision=10 warmup=False warmup_iterations=100000)
rootdir: /mnt/home/psun1/nifty_ls_nterm_support/nifty-ls
configfile: pyproject.toml
plugins: asdf-4.3.0, benchmark-5.1.0
collected 82 items

tests/test_ls.py ....................................................... [ 67%]
..........                                                               [ 79%]
tests/test_perf.py .................                                     [100%]


------------------------------------ benchmark 'batched_standard Nf=1000': 5 tests -------------------------------------
Name (time in ms)                                Min                Mean            StdDev            Rounds  Iterations
------------------------------------------------------------------------------------------------------------------------
test_batched_standard[cufinufft-1000]         6.1639 (1.0)        6.6860 (1.0)      0.4799 (4.07)         83           1
test_batched_standard[finufft-1000]          17.5466 (2.85)      26.0489 (3.90)     7.5615 (64.16)        40           1
test_unbatched_standard[finufft-1000]       140.0611 (22.72)    140.2554 (20.98)    0.1179 (1.0)           8           1
test_unbatched_standard[astropy-1000]       201.8929 (32.75)    202.0876 (30.23)    0.2012 (1.71)          5           1
test_unbatched_standard[cufinufft-1000]     300.5980 (48.77)    305.7871 (45.74)    4.1439 (35.16)         5           1
------------------------------------------------------------------------------------------------------------------------

----------------------------------------- benchmark 'chi2_nterms4 Nf=10000': 3 tests -----------------------------------------
Name (time in ms)                                    Min                  Mean            StdDev            Rounds  Iterations
------------------------------------------------------------------------------------------------------------------------------
test_chi2_nterms4[cufinufft_chi2-10000]          10.1617 (1.0)         10.2186 (1.0)      0.1002 (2.51)         85           1
test_chi2_nterms4[finufft_chi2-10000]            11.9403 (1.18)        11.9854 (1.17)     0.0399 (1.0)          78           1
test_chi2_nterms4[astropy_fastchi2-10000]     9,430.5506 (928.05)   9,437.9781 (923.61)   5.2359 (131.36)        5           1
------------------------------------------------------------------------------------------------------------------------------

---------------------------------- benchmark 'standard Nf=10000': 3 tests ---------------------------------
Name (time in ms)                     Min              Mean            StdDev            Rounds  Iterations
-----------------------------------------------------------------------------------------------------------
test_standard[finufft-10000]       2.3321 (1.0)      2.3486 (1.0)      0.0084 (1.0)         391           1
test_standard[cufinufft-10000]     2.8325 (1.21)     2.8743 (1.22)     0.0229 (2.72)        268           1
test_standard[astropy-10000]       5.7358 (2.46)     5.7815 (2.46)     0.1054 (12.54)       150           1
-----------------------------------------------------------------------------------------------------------

---------------------------------- benchmark 'standard Nf=100000': 3 tests -----------------------------------
Name (time in ms)                       Min               Mean            StdDev            Rounds  Iterations
--------------------------------------------------------------------------------------------------------------
test_standard[cufinufft-100000]      3.6294 (1.0)       3.6634 (1.0)      0.0608 (1.0)         237           1
test_standard[finufft-100000]        8.0218 (2.21)      8.9424 (2.44)     2.0032 (32.93)        74           1
test_standard[astropy-100000]       45.1638 (12.44)    45.5427 (12.43)    0.4489 (7.38)         19           1
--------------------------------------------------------------------------------------------------------------

-------------------------------------- benchmark 'standard Nf=1000000': 3 tests --------------------------------------
Name (time in ms)                           Min                  Mean             StdDev            Rounds  Iterations
----------------------------------------------------------------------------------------------------------------------
test_standard[cufinufft-1000000]         5.5406 (1.0)          5.6519 (1.0)       0.1557 (1.0)         146           1
test_standard[finufft-1000000]          80.2681 (14.49)       90.6020 (16.03)    11.3134 (72.67)        10           1
test_standard[astropy-1000000]       1,207.3889 (217.92)   1,210.8376 (214.23)    4.5923 (29.50)         5           1
----------------------------------------------------------------------------------------------------------------------

Legend:
  Outliers: 1 Standard Deviation from Mean; 1.5 IQR (InterQuartile Range) from 1st Quartile and 3rd Quartile.
  OPS: Operations Per Second, computed as 1 / Mean
======================== 82 passed in 167.49s (0:02:47) ========================

The results were obtained using 16 cores of an Intel Icelake CPU and 1 NVIDIA A100 GPU. The ratio of the runtime relative to the fastest are shown in parentheses. You may obtain very different performance on your platform! The slowest Astropy results in particular may depend on the Numpy distribution you have installed and its trig function performance.

Authors

nifty-ls was originally implemented by Lehman Garrison based on work done by Dan Foreman-Mackey in the dfm/nufft-ls repo, with consulting from Alex Barnett.

Citation

If you use nifty-ls in an academic work, please cite our RNAAS research note:

@article{Garrison_2024,
  doi = {10.3847/2515-5172/ad82cd},
  url = {https://dx.doi.org/10.3847/2515-5172/ad82cd},
  year = {2024},
  month = {oct},
  publisher = {The American Astronomical Society},
  volume = {8},
  number = {10},
  pages = {250},
  author = {Lehman H. Garrison and Dan Foreman-Mackey and Yu-hsuan Shih and Alex Barnett},
  title = {nifty-ls: Fast and Accurate Lomb–Scargle Periodograms Using a Non-uniform FFT},
  journal = {Research Notes of the AAS},
  abstract = {We present nifty-ls, a software package for fast and accurate evaluation of the Lomb–Scargle periodogram. nifty-ls leverages the fact that Lomb–Scargle can be computed using a non-uniform fast Fourier transform (NUFFT), which we evaluate with the Flatiron Institute NUFFT package (finufft). This approach achieves a many-fold speedup over the Press & Rybicki method as implemented in Astropy and is simultaneously many orders of magnitude more accurate. nifty-ls also supports fast evaluation on GPUs via CUDA and integrates with the Astropy Lomb–Scargle interface. nifty-ls is publicly available at https://github.com/flatironinstitute/nifty-ls/.}
}

A pre-print of the article is available on arXiv: https://arxiv.org/abs/2409.08090

Acknowledgements

nifty-ls builds directly on top of the excellent finufft package by Alex Barnett and others (see the finufft Acknowledgements).

Many parts of this package are an adaptation of Astropy LombScargle, in particular the Press & Rybicki (1989) method.

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

nifty_ls-1.1.0.tar.gz (346.2 kB view details)

Uploaded Source

Built Distributions

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

nifty_ls-1.1.0-cp314-cp314t-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl (413.6 kB view details)

Uploaded CPython 3.14tmanylinux: glibc 2.27+ x86-64manylinux: glibc 2.28+ x86-64

nifty_ls-1.1.0-cp314-cp314t-macosx_14_0_arm64.whl (411.8 kB view details)

Uploaded CPython 3.14tmacOS 14.0+ ARM64

nifty_ls-1.1.0-cp314-cp314t-macosx_13_0_x86_64.whl (451.6 kB view details)

Uploaded CPython 3.14tmacOS 13.0+ x86-64

nifty_ls-1.1.0-cp313-cp313t-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl (413.6 kB view details)

Uploaded CPython 3.13tmanylinux: glibc 2.27+ x86-64manylinux: glibc 2.28+ x86-64

nifty_ls-1.1.0-cp313-cp313t-macosx_14_0_arm64.whl (411.8 kB view details)

Uploaded CPython 3.13tmacOS 14.0+ ARM64

nifty_ls-1.1.0-cp313-cp313t-macosx_13_0_x86_64.whl (451.6 kB view details)

Uploaded CPython 3.13tmacOS 13.0+ x86-64

nifty_ls-1.1.0-cp312-abi3-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl (408.2 kB view details)

Uploaded CPython 3.12+manylinux: glibc 2.24+ x86-64manylinux: glibc 2.28+ x86-64

nifty_ls-1.1.0-cp312-abi3-macosx_14_0_arm64.whl (408.2 kB view details)

Uploaded CPython 3.12+macOS 14.0+ ARM64

nifty_ls-1.1.0-cp312-abi3-macosx_13_0_x86_64.whl (448.1 kB view details)

Uploaded CPython 3.12+macOS 13.0+ x86-64

nifty_ls-1.1.0-cp311-cp311-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl (415.2 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.24+ x86-64manylinux: glibc 2.28+ x86-64

nifty_ls-1.1.0-cp311-cp311-macosx_14_0_arm64.whl (410.5 kB view details)

Uploaded CPython 3.11macOS 14.0+ ARM64

nifty_ls-1.1.0-cp311-cp311-macosx_13_0_x86_64.whl (450.3 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64

nifty_ls-1.1.0-cp310-cp310-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl (414.2 kB view details)

Uploaded CPython 3.10manylinux: glibc 2.24+ x86-64manylinux: glibc 2.28+ x86-64

nifty_ls-1.1.0-cp310-cp310-macosx_14_0_arm64.whl (409.6 kB view details)

Uploaded CPython 3.10macOS 14.0+ ARM64

nifty_ls-1.1.0-cp310-cp310-macosx_13_0_x86_64.whl (449.2 kB view details)

Uploaded CPython 3.10macOS 13.0+ x86-64

nifty_ls-1.1.0-cp39-cp39-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl (414.5 kB view details)

Uploaded CPython 3.9manylinux: glibc 2.24+ x86-64manylinux: glibc 2.28+ x86-64

nifty_ls-1.1.0-cp39-cp39-macosx_14_0_arm64.whl (409.7 kB view details)

Uploaded CPython 3.9macOS 14.0+ ARM64

nifty_ls-1.1.0-cp39-cp39-macosx_13_0_x86_64.whl (449.4 kB view details)

Uploaded CPython 3.9macOS 13.0+ x86-64

File details

Details for the file nifty_ls-1.1.0.tar.gz.

File metadata

  • Download URL: nifty_ls-1.1.0.tar.gz
  • Upload date:
  • Size: 346.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for nifty_ls-1.1.0.tar.gz
Algorithm Hash digest
SHA256 84d730ebdf9cba62e7cd4185f7997802ab8ad408c1246f44817c87fd69c1485c
MD5 43da666d49a8bccd181141c53431beef
BLAKE2b-256 0aea65a9a8134c09bf09f54cd0724c0a66e7b59be8ad306c30760191c0509bdf

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0.tar.gz:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp314-cp314t-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp314-cp314t-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 688550c939e4d6a19e6ee73877b5ee6f5aad84729635bad6f14c088c504a6369
MD5 d87e1edb939ff012e6f2cd43d6ea7d05
BLAKE2b-256 dd0023ef0b275505c85541e50b87631bd6d63497374597b6b86d53611addccec

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp314-cp314t-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp314-cp314t-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp314-cp314t-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 231460bf57574d7a32bfc798f34713a8767293d842a8a7891affd602ea00ef56
MD5 cb4d2e1c4823eeece1ad2a3e865c5a8a
BLAKE2b-256 bf563912b1de5a77f09f619a2778265ea35f57790c6579f29b2ae5a79bcbd594

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp314-cp314t-macosx_14_0_arm64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp314-cp314t-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp314-cp314t-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 2a85a6a13af268e80740818cfcf58db793e9da56e9bf9057e090082b07a89ceb
MD5 e0b7ec4b24f1bcf7c1e747f86be155ad
BLAKE2b-256 f9c1999fd1c88ba7e124ef48dedd6f18fcb0c91b4889fbbe402e1709aae84f86

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp314-cp314t-macosx_13_0_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp313-cp313t-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp313-cp313t-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 e9fae54d778fee1f398d9381b631eab7cd71a83e6d8e88537d7fd427a704ecb2
MD5 d6cc6714d22d9cc3a195831c12333d7b
BLAKE2b-256 5ec3397a4bfd0034ac2e1cde9206b873bc14a3b77ddd58943d509cb7905300f9

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp313-cp313t-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp313-cp313t-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp313-cp313t-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 4d63ed3454f95d7fff9418091986f5fa2d0346466ecff40105ca4fc32e5bdf28
MD5 47a845aa095299617d54a799be53dc3c
BLAKE2b-256 5d5078f6775a73ee5224aaeccd1b70feb219ae3f632234f4dd272f495fd13028

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp313-cp313t-macosx_14_0_arm64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp313-cp313t-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp313-cp313t-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 af77737077b3c45f3d8e6f21bf54fe14b130d086c936ecbb92b28ee7107fa4e9
MD5 828f75c670fa144890e16e9740113454
BLAKE2b-256 005d53229172b96ebf8ad84a758b49245217c24e3ce9886dc4aaa84686d2e06c

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp313-cp313t-macosx_13_0_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp312-abi3-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp312-abi3-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 98ce65b4175d112cff89f91102c68f594b9bc042db657be99bc8b2693fa0a0e7
MD5 ad305244b1b37dbd279fd2028e13fe28
BLAKE2b-256 a89b646e80103d9a8588336b5038498129debf0a4d11aaa51084f14bf15abbbc

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp312-abi3-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp312-abi3-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp312-abi3-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 b6f6e51c1229c49805c528fc864254ed4497c3d0265d010189f4676f50072535
MD5 3559ef6bdf75c2cc9b7fcd2b164a0108
BLAKE2b-256 baa81ffc12ee7a7b6b49024f8b7e78546fd4d82c7471ae180e1ab76b03784d7e

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp312-abi3-macosx_14_0_arm64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp312-abi3-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp312-abi3-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 5b47f1a33f0d7e33e7dd2432fe3b8b9299240d29086efeffded5263f0d10fffd
MD5 c2f16707e308e1f74fb7447b3ee605c2
BLAKE2b-256 52183e4f2e1531c5f66d1d0441b62ec3e238de53363620351e41180e61ba4b9e

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp312-abi3-macosx_13_0_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp311-cp311-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp311-cp311-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 84ee87906eac3c65aac78f48fd66a4c8e3a3eb4f342dfeb2a636dcae16c9372e
MD5 dccddf6c39aa77be9f8ca6b82c088b59
BLAKE2b-256 e71f1dba14429b83340462ffa25ddc664785d2af7249f843acff83a90d945dc9

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp311-cp311-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp311-cp311-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp311-cp311-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 fdfc3e29561d8085df82cc093d32f1ad8ee97935d93f21378eb2e5e26a9823e8
MD5 42f03e3aef6d0321d47c4e2c52fc70c5
BLAKE2b-256 80f1ef240ea88858dde32e62eed7c7dee6cbb09beded9ed259490c8b092a500c

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp311-cp311-macosx_14_0_arm64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp311-cp311-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp311-cp311-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 ec62d0108987fdbad739e93f556ecbbbb7452301f5319470ce1b3466779fb265
MD5 a2c4a0d73f4bd0aa3cf97ccd73e7d6f0
BLAKE2b-256 acc42857874a6f19b6d5dc7b609bb205723eee34c7ee68106da53735f57ec571

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp311-cp311-macosx_13_0_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp310-cp310-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp310-cp310-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 b9badc953c7fc9062d8a998baf009e484c882a0c030dab9f674a2eb45c04bf0d
MD5 f3b677008f8e6086d7b2b1380d806608
BLAKE2b-256 0958da5f37f1f76aa51675fa485036c21df29889940e68332fe178d4df643310

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp310-cp310-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp310-cp310-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp310-cp310-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 4c274e6ceeb46c2ee740a3ac3a4a7b04b8f289e5e5cbcf423bdf240a06071a37
MD5 38c1c56eef672d83dfcef3910e5dce0b
BLAKE2b-256 e3f079d7818848f4d5d46b56193322ba63dc36c1d6c54c8054d869ef0c02c00a

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp310-cp310-macosx_14_0_arm64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp310-cp310-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp310-cp310-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 745cafa3f2ab4bd979352c32f4dfd9a16eda74dedeeba38880fbae9dfe299630
MD5 fe34f82dc029012557c837c97eed30c3
BLAKE2b-256 b0a51d9a2323bc3ccd39c7d214a932a1b36280a717f034890f9ea8b0c088adc0

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp310-cp310-macosx_13_0_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp39-cp39-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp39-cp39-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 234b615896dc7d7e5a89155cc59d9f9662d9ff9973dc52f29d504d9b5504f251
MD5 4ee7a9e84b57d358810c8e8fb6f79187
BLAKE2b-256 e670fef6e6106789bd64a45cea0a31782830958bb85f5b26eea5238442e58ec2

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp39-cp39-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp39-cp39-macosx_14_0_arm64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp39-cp39-macosx_14_0_arm64.whl
Algorithm Hash digest
SHA256 ef569887d5a61058c6145f74d2c60acfe456c9794d4a2c5b552550052e361f5d
MD5 0cc11b4a81d5edf1897ddfe6d120a1a4
BLAKE2b-256 65b3df3a76c06582ea643da1feb517054d0226433b8ebb61628ecdb7a9a9fa92

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp39-cp39-macosx_14_0_arm64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nifty_ls-1.1.0-cp39-cp39-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for nifty_ls-1.1.0-cp39-cp39-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 8f5b89b71720341670da8cb98405d197afd6b781356f552a70a5fa8783511bcf
MD5 ee2271ad86951ef71bbcde4cc5d5ab53
BLAKE2b-256 6b3bbfd1de3e49cf273226128fe6733bbe8259a79c3af54f8859edb895c71946

See more details on using hashes here.

Provenance

The following attestation bundles were made for nifty_ls-1.1.0-cp39-cp39-macosx_13_0_x86_64.whl:

Publisher: wheels.yml on flatironinstitute/nifty-ls

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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