Skip to main content

Manifest-backed real-data ingestion and OpenML materialization for tabular workflows

Project description

tab-realdata-hub

tab-realdata-hub materializes external tabular data sources into the manifest-backed packed-shard contract consumed by tab-foundry.

tab-realdata-hub is the sole owner of that manifest contract. The parquet manifest is the stable index layer, and richer evolving dataset/provenance fields live in metadata.ndjson. Downstream consumers are expected to read through this package rather than reimplementing compatibility shims.

Install from the upstream git tag with:

python -m pip install "tab-realdata-hub @ git+https://github.com/bensonlee5/tab-realdata-hub.git@v0.1.2"

For repo-local development:

uv sync

The v1 surface is OpenML-first:

  • build pinned OpenML bundle JSON from known task pools or live discovery
  • materialize bundle tasks into packed shards plus manifest parquet
  • inspect manifest-backed datasets through a stable library and CLI surface

Example:

uv sync

.venv/bin/tab-realdata-hub bundle build-openml \
  --out-path bundles/many_class_v1.json \
  --bundle-name many_class_v1 \
  --version 1 \
  --task-source tabarena_v0_1 \
  --min-classes 2 \
  --max-features 10 \
  --max-classes 10 \
  --max-missing-pct 10.0

.venv/bin/tab-realdata-hub materialize openml-bundle \
  --bundle-path bundles/many_class_v1.json \
  --out-root outputs/openml/many_class_v1

.venv/bin/tab-realdata-hub manifest inspect \
  --manifest outputs/openml/many_class_v1/manifest.parquet

The repo now tracks two hub-owned classification validation bundles for tab-foundry under src/tab_realdata_hub/bench/:

  • nanotabpfn_openml_classification_medium_v1.json
  • nanotabpfn_openml_classification_large_v1.json

The current TF-RD-010 contract is:

  • medium: no-missing multiclass validation with max_features=10, min_classes=3, max_classes=10, and min_minority_class_pct=2.5
  • large: allow-missing multiclass validation with max_features=20, max_missing_pct=5.0, min_classes=3, max_classes=10, and min_minority_class_pct=2.5

Refresh the checked-in bundle definitions from the pinned tabarena_v0_1 source with:

.venv/bin/tab-realdata-hub bundle build-openml \
  --out-path src/tab_realdata_hub/bench/nanotabpfn_openml_classification_medium_v1.json \
  --bundle-name nanotabpfn_openml_classification_medium \
  --version 1 \
  --task-source tabarena_v0_1 \
  --new-instances 200 \
  --max-features 10 \
  --min-classes 3 \
  --max-classes 10 \
  --max-missing-pct 0.0 \
  --min-minority-class-pct 2.5

.venv/bin/tab-realdata-hub bundle build-openml \
  --out-path src/tab_realdata_hub/bench/nanotabpfn_openml_classification_large_v1.json \
  --bundle-name nanotabpfn_openml_classification_large \
  --version 1 \
  --task-source tabarena_v0_1 \
  --new-instances 200 \
  --max-features 20 \
  --min-classes 3 \
  --max-classes 10 \
  --max-missing-pct 5.0 \
  --min-minority-class-pct 2.5

Materialize the checked-in bundle definitions into the manifest paths consumed downstream by tab-foundry with:

.venv/bin/tab-realdata-hub materialize openml-bundle \
  --bundle-path src/tab_realdata_hub/bench/nanotabpfn_openml_classification_medium_v1.json \
  --out-root data/manifests/bench/nanotabpfn_openml_classification_medium_v1

.venv/bin/tab-realdata-hub materialize openml-bundle \
  --bundle-path src/tab_realdata_hub/bench/nanotabpfn_openml_classification_large_v1.json \
  --out-root data/manifests/bench/nanotabpfn_openml_classification_large_v1

Inspect the resulting manifests with:

.venv/bin/tab-realdata-hub manifest inspect \
  --manifest data/manifests/bench/nanotabpfn_openml_classification_medium_v1/manifest.parquet

.venv/bin/tab-realdata-hub manifest inspect \
  --manifest data/manifests/bench/nanotabpfn_openml_classification_large_v1/manifest.parquet

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

tab_realdata_hub-0.1.3.tar.gz (86.8 kB view details)

Uploaded Source

Built Distribution

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

tab_realdata_hub-0.1.3-py3-none-any.whl (51.1 kB view details)

Uploaded Python 3

File details

Details for the file tab_realdata_hub-0.1.3.tar.gz.

File metadata

  • Download URL: tab_realdata_hub-0.1.3.tar.gz
  • Upload date:
  • Size: 86.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tab_realdata_hub-0.1.3.tar.gz
Algorithm Hash digest
SHA256 6e70c5e602a08df90f0bcd7823dd2ca4691da9831c8a4249e972f3969dc233dd
MD5 1bd371ed35c4d629da318b6045aaf171
BLAKE2b-256 834fa2574f1319df2fb5ff5d39ff9ee2e023b6bbca65a3e6422cc5dbbb833a40

See more details on using hashes here.

Provenance

The following attestation bundles were made for tab_realdata_hub-0.1.3.tar.gz:

Publisher: publish.yml on bensonlee5/tab-realdata-hub

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

File details

Details for the file tab_realdata_hub-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for tab_realdata_hub-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 0d4ff6ce7142a21bbf185dc354478b3d1c2af7529a2abac90ea4541d7c8b0665
MD5 29b03c6e2d8110303458aa7af8b96be2
BLAKE2b-256 fe71dc8fd54dd6538100d03915bea421f408522a6f76bcdd559cd6157ce1e057

See more details on using hashes here.

Provenance

The following attestation bundles were made for tab_realdata_hub-0.1.3-py3-none-any.whl:

Publisher: publish.yml on bensonlee5/tab-realdata-hub

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