Integer Atlas — stateless property methods and shard executor
Reason this release was yanked:
Incorrect license metadata; use 0.2.1
Project description
Integer Atlas — Algos
Directory name is provisional and will be renamed later.
The property methods and the compute engine (the executor). This repository is independent and stateless: nothing here imports the other repos, and it stores no information about any shard, pack, release, or lifecycle. It is used exactly twice per shard — compute (by a contributor) and verify (by a maintainer). Master design: ../Integer Atlas Documentation.docx.md (§16, §11, §17, §2.5).
Purpose
- Define each integer property as a small registered method.
- Provide the executor that computes shards and verifies them.
- Cut algorithm releases that downstream shards pin to.
What lives here
Algorithms are a single flat directory — one method per file, the filename matching the column it produces. Pack, shard, and release names never appear in the layout. Shared helpers live in _lib. There are no pack, coverage, or planner files here — those belong to the Shards repo.
integer_atlas_algos/ the installable package (atlas-algos)
registry.py @property_method + the flat column registry
context.py per-n memoized context (factorization, divisors)
properties/ one method per file; filename = column name (46 columns)
_lib/ shared helpers
factorization.py prime-table factorization
multiplicative.py sigma() shared by divisor functions
blake3_py.py pure-Python BLAKE3 fallback
precomputed/ regenerable resource cache (not state)
primes_le_31623.txt base primes up to ceil(sqrt(1e9))
executor/ the stateless engine
cli.py argparse CLI (compute / verify, estimate, resume)
compute.py chunked, resumable, crash-safe, streaming finalize
verify.py sampled recompute + compare
estimate.py pre-run work estimate from static complexity
manifest.py work-order loading, draft manifest, hashing
atomicio.py atomic write / checkpoint primitives
backends/ csv_backend (stdlib) + parquet_backend (pyarrow)
tools/ bench.py, perfrun.py, make_work_order.py (dev only)
tests/ unittest suite + sample work-order manifests
pyproject.toml package metadata, console script, extras
COMMANDS.md INTERFACE.md PUBLISHING.md reference docs
Run it with pip install -e . then atlas-algos …, or from a source checkout as
python3 -m integer_atlas_algos.executor … (run from the algos/ directory).
All 46 agreed properties are implemented. See INTERFACE.md for the complete command reference, output layout, exit codes, and the resume model.
Precomputed data
To factor any n up to BOUND² you only need primes up to BOUND; with
BOUND = 31623 (≥ √1e9) that is ~3401 primes covering the whole 0..1e9 range.
precomputed/primes_le_31623.txt holds them — a deterministic, regenerable cache
(sieved on first use if missing), not state about any shard or pack. It bounds
worst-case factorization to ~3401 trial divisions regardless of n's size in range.
Status and known limitations
Done and tested: 46 properties, the stateless executor (compute/verify/estimate,
resumable + atomic + streaming finalize), CSV and validated Parquet backends,
SHA256/SHA512/BLAKE3 hashing. Remaining performance work (not correctness):
per-shard run is single-threaded pure Python (~3700 rows/s/core — scale by running
many shards in parallel, one executor each); a segmented-sieve batch fast-path and
gmpy2 would speed factorization further; n is int64 (covers 0..2^63, hence the
0..1e9 target) — int128 only needed beyond that; partition_count is small-n only
(its values explode) even though its per-row recompute is now memoized.
Method contract
- Signature is
f(n, ctx) -> value. The method name becomes the column name. ctxis a memoized context of shared intermediates (factorization, divisor list, binary representation) declared viarequires, so expensive work is computed once per number, not once per method.- Metadata (canonical column id, dtype, nullable, zero/negative behavior,
requires, test vectors) is registered next to the function, so the schema, column ids, and manifest columns are generated from code. A method declares only its own column — it says nothing about packs, shards, releases, or any other entity. - A method may provide an optional vectorized fast-path for speed; the scalar form is always the verification ground truth.
- Test vectors live with the method and are reused by both the property-proposal gate and shard verification.
Executor verbs
The executor is stateless — both verbs are pure functions of an input manifest that names a start, an end, and the requested columns. It does not interpret packs, the grid, or policy; if the manifest does not follow project conventions that is fine, and it errors only if a requested column name is unknown.
compute --manifest <work-order> --out <shard>— run the requested column functions over[start, end]and write the shard, filling the output manifest's column types and hashes from the method metadata.verify --manifest <entry> --shard <file> --degree <fraction>— recompute a share of the requested columns (0.1 sampled … 1.0 full) and compare against the shard; report pass/fail.
Releases
Cut an algorithm release once enough methods have merged. It is stamped with the commit id and PR URLs, and is what a shard's algorithm_versions pins to. Only released methods are eligible for official shards; unreleased methods exist only for local side-loading.
Packaging
Distributed with uv: each release pins uv.lock, so integer-atlas algos sync (from the CLI) materializes the exact released code and dependencies on any platform — fast, reproducible, no system Python required. Optional PyInstaller one-file artifacts and an OCI image are conveniences; uv is canonical. Compute speed comes from native math libraries (e.g. gmpy2, primesieve) and the vectorized fast-paths, not from the packaging format.
State: none
This repo stores no state about any shard, pack, release, or lifecycle. Planning, pack definitions, the coverage policy, and the manifest sets all live in the Shards repo. Algos sees a given shard exactly twice — compute (contributor) and verify (maintainer).
Contributing
PRs add algorithms (the code pipeline). Include the method, its metadata, and its test vectors. See §10.1 and §17 in the master doc.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file integer_atlas_algos-0.1.0.tar.gz.
File metadata
- Download URL: integer_atlas_algos-0.1.0.tar.gz
- Upload date:
- Size: 46.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
af488e6f489b6cbb497bbd07257df99bc77c063a5857690eb797548e141be8d2
|
|
| MD5 |
d4f969c023dc50325e390027f2cc34e0
|
|
| BLAKE2b-256 |
333c45685c2896ca4ac8f0ec1612f85720e4d58fc13f3d609f583501fb9eb6ce
|
Provenance
The following attestation bundles were made for integer_atlas_algos-0.1.0.tar.gz:
Publisher:
release.yml on outcompute/integer-atlas-algos
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
integer_atlas_algos-0.1.0.tar.gz -
Subject digest:
af488e6f489b6cbb497bbd07257df99bc77c063a5857690eb797548e141be8d2 - Sigstore transparency entry: 1894259728
- Sigstore integration time:
-
Permalink:
outcompute/integer-atlas-algos@c73adccc29bede85655bc66d2fa73409d3ea9166 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/outcompute
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@c73adccc29bede85655bc66d2fa73409d3ea9166 -
Trigger Event:
push
-
Statement type:
File details
Details for the file integer_atlas_algos-0.1.0-py3-none-any.whl.
File metadata
- Download URL: integer_atlas_algos-0.1.0-py3-none-any.whl
- Upload date:
- Size: 53.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bd9a06b49001b3cc05a5ed0213d62309880fe30efc79c6a6622788213ea8d132
|
|
| MD5 |
92fa8d503223716921a899d9a1b829ab
|
|
| BLAKE2b-256 |
909c2c0b964470e25eb47fb73532ede8e0f1fb82a03dcaf55c6a0b318263d4bb
|
Provenance
The following attestation bundles were made for integer_atlas_algos-0.1.0-py3-none-any.whl:
Publisher:
release.yml on outcompute/integer-atlas-algos
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
integer_atlas_algos-0.1.0-py3-none-any.whl -
Subject digest:
bd9a06b49001b3cc05a5ed0213d62309880fe30efc79c6a6622788213ea8d132 - Sigstore transparency entry: 1894259824
- Sigstore integration time:
-
Permalink:
outcompute/integer-atlas-algos@c73adccc29bede85655bc66d2fa73409d3ea9166 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/outcompute
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@c73adccc29bede85655bc66d2fa73409d3ea9166 -
Trigger Event:
push
-
Statement type: