Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
🐙 Poulpy-CPU-AVX
Poulpy-CPU-AVX is a Rust crate that provides an AVX2 + FMA accelerated CPU backend for Poulpy.
This backend implements the Poulpy HAL extension traits and can be used by:
poulpy-halpoulpy-corepoulpy-ckks(backend wiring opt-in viaenable-ckks)poulpy-bin-fhethrough the crate's explicitenable-avxintegration feature
🚩 Safety and Requirements
To avoid illegal hardware instructions (SIGILL) on unsupported CPUs, this backend is opt-in and only builds when explicitly requested.
| Requirement | Status |
|---|---|
| Cargo feature flag | --features enable-avx must be enabled |
| CPU architecture | x86_64 |
| CPU target features | AVX2 + FMA |
If enable-avx is enabled but the target does not provide these capabilities, the build fails immediately with a clear error message, rather than generating invalid binaries.
When enable-avx is not enabled, this crate is simply skipped and Poulpy automatically falls back to the portable poulpy-cpu-ref backend. This ensures that Poulpy's workspace remains portable (e.g. for macOS ARM).
⚙️ Building with the AVX backend enabled
Because the compiler must generate AVX2 + FMA instructions, both the Cargo feature and CPU target flags must be specified:
RUSTFLAGS="-C target-feature=+avx2,+fma" \
Running an example
RUSTFLAGS="-C target-feature=+avx2,+fma" \
Running benchmarks
RUSTFLAGS="-C target-feature=+avx2,+fma" \
Running Tests
RUSTFLAGS="-C target-feature=+avx2,+fma" \
To include CKKS backend wiring in the AVX test build:
RUSTFLAGS="-C target-feature=+avx2,+fma" \
Basic Usage
This crate exposes two AVX2-accelerated backends:
use ;
use ;
let log_n: usize = 10;
// f64 FFT backend (AVX2 + FMA)
let module: = new;
// Q120 NTT backend (AVX2, CRT over four ~30-bit primes)
let module: = new;
Once compiled with enable-avx, both backends are usable anywhere Poulpy expects a backend type in the HAL/core/CKKS layers. poulpy-bin-fhe has a separate enable-avx feature for its current crate-local integration.
🤝 Contributors
To implement your own Poulpy backend (SIMD or accelerator):
- Define a backend struct and implement the
Backendtrait frompoulpy-hal. - For each HAL operation family, either call the blanket default or implement the OEP trait directly with a custom dispatch.
- For each
poulpy-coreoperation family, either call the correspondingimpl_*_defaults_full!macro to inherit the portable implementation, or implement the OEP trait directly to override it. - Optionally, do the same for
poulpy-ckksbehind a backend-ownedenable-ckksfeature using theimpl_ckks_*_defaults!macros or direct OEP trait implementations.
At every layer the macro and the direct implementation are mutually exclusive per operation family: the macro opts the backend into the portable default path, while a direct OEP impl replaces it entirely. There is no requirement to use the macros — a backend that needs full control can implement every OEP trait by hand.
Your backend will automatically integrate with the backend-generic layers:
poulpy-halpoulpy-corepoulpy-ckks
No modifications to those crates are required — the HAL provides the extension points. Scheme crates that still carry crate-specific backend glue, such as parts of poulpy-bin-fhe in v0.6.0, may need follow-up integration work. Only operations that need a faster implementation require explicit overrides; everything else is inherited from the default layer for free.
For questions or guidance, feel free to open an issue or discussion in the repository.