2.4 KiB
Reference platforms for expected_features.sha256
The hash in expected_features.sha256 was generated on a specific BLAS / FFT
backend. Numpy + scipy delegate FFT/linear-algebra to platform-native
libraries, and those libraries produce bit-different output on identical
IEEE 754 inputs depending on the backend. This is not a bug in the proof
pipeline — it is a property of the underlying numerical libraries. (See
issue #560.)
Platforms where the hash is expected to MATCH
| Platform | BLAS backend | Status |
|---|---|---|
linux-x86_64-gnu (Python 3.11.x, numpy 1.26.4 from PyPI wheels, scipy 1.14.1) |
OpenBLAS | ✅ Reference |
windows-x86_64-msvc (Python 3.11.x / 3.13.x, numpy 1.26.4 from PyPI wheels, scipy 1.14.1) |
OpenBLAS | ✅ Reference |
Platforms where the hash is expected to MISMATCH
| Platform | BLAS backend | Why |
|---|---|---|
darwin-arm64 (macOS arm64, Apple Silicon) |
Accelerate.framework | FFT + matrix kernels differ in last-bit positions; the SHA-256 will differ even with pinned numpy 1.26.4 / scipy 1.14.1. |
| Any environment with MKL installed | Intel MKL | Same root cause as Accelerate: different vectorized FFT path. |
What to do if you get MISMATCH on a non-reference platform
The pipeline is still correct on your platform — the output is bit-different because the backend is bit-different, not because the proof code has a bug. Three workable responses:
-
Run the proof on a reference platform (Linux x86_64 or Windows x86_64 with the PyPI OpenBLAS wheels). This is what CI does.
-
Generate a new local-reference hash for your platform and check it against the same hash on a teammate's machine with the same backend:
# Regenerate from your platform python archive/v1/data/proof/verify.py --generate-hash # Commit the new hash to a side file (do NOT overwrite expected_features.sha256 # unless you are publishing a new cross-platform reference) -
Compare numerical output, not the hash. A relaxed-tolerance comparison on the feature vectors (e.g.
np.allclose(features, reference, atol=1e-10)) will pass across backends. This is on the roadmap (see issue #560).
The verify.py runtime environment block
Every run of verify.py now prints a RUNTIME ENVIRONMENT block before the
pipeline runs. Include that block in any issue report — it identifies the
platform + numpy version + BLAS backend in one place.