predictlm-mini-13m / README.md
01RAI's picture
PredictLM v11.0 + Mini ship-bundle
b846449 verified
---
license: apache-2.0
library_name: predictlm
pipeline_tag: tabular-classification
tags:
- tabular
- tabular-classification
- tabular-regression
- in-context-learning
- foundation-model
- prior-fitted-network
- tabpfn-style
- distilled
- compact
metrics:
- accuracy
- r2
base_model: zerooneresearch/predictlm-base-26m
model-index:
- name: predictlm-mini-13m
results:
- task:
type: tabular-classification
name: Tabular Classification
dataset:
type: openml
name: Locked OpenML eval (CC-18 + AMLB + TabPFN-extras), fair-set n_features 128
metrics:
- type: accuracy
value: 0.684
name: mean accuracy (n=12, seed=42, fair-set n_features 128)
- task:
type: tabular-regression
name: Tabular Regression
dataset:
type: openml
name: Locked OpenML eval (CTR-23 + AMLB), fair-set n_features 128
metrics:
- type: r2
value: 0.551
name: mean (n=13, seed=42, fair-set n_features 128)
- task:
type: tabular-classification
name: Tabular Classification (Duo + TTT recipe)
dataset:
type: openml
name: Locked OpenML eval (CC-18 + AMLB + TabPFN-extras), fair-set n_features 128
metrics:
- type: accuracy
value: 0.751
name: mean accuracy with Duo + TTT recipe (Mini + Base + test-time training)
- task:
type: tabular-regression
name: Tabular Regression (Duo + TTT recipe)
dataset:
type: openml
name: Locked OpenML eval (CTR-23 + AMLB), fair-set n_features 128
metrics:
- type: r2
value: 0.609
name: mean with Duo + TTT recipe (Mini + Base + test-time training)
---
# predictlm-mini-13m
A 13.5M-parameter **distilled tabular foundation model**. Half the parameters of [PredictLM Base (26M)](https://huggingface.co/zerooneresearch/predictlm-base-26m); **statistically tied with Base on classification accuracy** and within ~4 pp R² on regression.
This is the **compact deployment variant** of PredictLM, designed to run inference on any modern laptop or commodity GPU. Same single-forward-pass in-context-learning API as Base, same architecture family — just smaller, distilled, and re-trainable on hardware most teams already have.
## Getting started — the published 0.751 cls / 0.609 reg recipe, by default
```bash
pip install predictlm
```
```python
from predictlm import PredictLM
model = PredictLM.from_pretrained("zerooneresearch/predictlm-mini-13m") # cpu / mps / cuda all OK
# Regression — pass float y, get continuous predictions
preds = model.fit(X_train_reg, y_train_reg).predict(X_test_reg)
# Classification — same model, same API; auto-routed via y_train dtype
preds = model.fit(X_train_cls, y_train_cls).predict(X_test_cls)
probs = model.predict_proba(X_test_cls)
```
That's it. On the first `.predict()` call the package silently downloads its partner checkpoint (`predictlm-base-26m`), forms the published **Duo + TTT** ensemble under the hood, and returns the **0.751 cls / 0.609 reg** result on the locked 25-dataset OpenML eval. You never manage the ensemble; the partner is cached in `~/.cache/huggingface/`.
| Recipe (chosen via `auto_duo=` flag) | cls mean acc | reg mean R² |
|---|:---:|:---:|
| Default `.predict()` (Duo + TTT under the hood) | **0.751** | **0.609** |
| `auto_duo=False` (Mini-only, zero-tuning) | 0.673 | 0.536 |
| `auto_duo=False` + `fit_and_predict_with_ttt()` (Mini-only TTT) | 0.742 | 0.595 |
**Edge cases:**
- **No internet / air-gapped.** Pass `auto_duo=False` at load to disable partner download — `.predict()` returns the single-model in-context result.
- **Real-time inference** (<10 ms latency)? Use `auto_duo=False` zero-tuning. Duo + TTT adds ~1-60 s per query depending on table size.
**TTT** ([Test-Time Training](https://arxiv.org/abs/2503.11842)) does ~15 inner Adam steps of self-supervised fine-tuning on the user's in-context examples before predicting. Per-task specialization on top of a generic ICL prior. 19 / 20 datasets improved vs zero-tuning; no dataset regressed by more than 0.006.
PredictLM's TTT is an independent implementation of the published technique. This repo does not include or derive from TabPFN code or weights — PredictLM weights are trained from scratch (Mini distilled from PredictLM-Base) and shipped under Apache-2.0.
## Developers and affiliations
- **Developed by**: ZeroOne Research
- **Distilled from**: [predictlm-base-26m](https://huggingface.co/zerooneresearch/predictlm-base-26m) (v11.0)
- **Model card contact**: message the org on the Hub
- **License**: Apache 2.0 — permissive, commercial use allowed
## Why Mini (when to prefer this over Base)
- **GPU memory budget < 8 GB at inference** — Mini fits comfortably on a consumer GPU or M-series MPS
- **You want to re-distill / fine-tune yourself** — Mini's training recipe runs on a single consumer GPU; Base requires an A100/H100
- **You want a smaller artifact to ship inside a product** — 55 MB inference weights vs Base's 105 MB
- **You're running many concurrent inference jobs** — 4× as many parallel Mini instances fit per GPU vs Base
- **You can tolerate ~4 pp lower regression R²** (CI [-6.5, -1.5]; cls accuracy is statistically tied with Base)
Prefer **Base** instead if you have an A100/H100, value the last ~4 pp of regression accuracy, and don't need to re-distill.
## Performance benchmarks
### Locked OpenML eval (held-out, contamination-audited)
Same 30-dataset stratified sample, seed=42, fair-set filter `n_features ≤ 128`, 4-way comparison. Same eval pipeline as Base (`scripts/eval_v11.py`).
| | reg-R² (n=13) | cls-acc (n=12) |
|---|:---:|:---:|
| predictlm-base-26m (teacher) | +0.589 | 0.685 |
| **predictlm-mini-13m (this model, 13.5M)** | **+0.551** | **0.684** |
| XGBoost (200 trees, depth 6) | +0.516 | 0.743 |
| TabPFN-2.5 (hosted, ~100M, non-commercial license) | +0.662 | 0.780 |
| TabICLv2 (open, BSD-3, ~50M) | *(cls-only)* | 0.792 |
### Paired-bootstrap 95% CIs (10,000 resamples, seed=42)
Per-dataset deltas (predictlm-mini-13m minus baseline):
| comparison | mean Δ | 95% CI | n | significant? |
|---|:---:|:---:|:---:|:---:|
| **Mini vs Base (compression cost)** | | | | |
| Reg R² | **-0.038** | [-0.065, -0.015] | 13 | ✅ real (~4 pp loss) |
| Cls acc | **-0.001** | [-0.027, +0.029] | 12 | ✅ **statistical tie** |
| **vs other peers (Mini)** | | | | |
| Reg vs XGBoost | +0.035 | [-0.076, +0.158] | 13 | within noise |
| Reg vs TabPFN-2.5 | -0.111 | [-0.152, -0.067] | 13 | ✅ significant loss |
| Cls vs XGBoost | -0.059 | [-0.089, -0.031] | 12 | ✅ significant loss |
| Cls vs TabPFN-2.5 | -0.097 | [-0.132, -0.059] | 12 | ✅ significant loss |
| Cls vs TabICLv2 | -0.109 | [-0.147, -0.069] | 12 | ✅ significant loss |
**Retention vs Base — the headline compression story:**
- **Classification: statistical tie** with Base (delta -0.001, CI [-0.027, +0.029]). At half the parameters, Mini is indistinguishable from the 26M teacher on classification accuracy.
- **Regression: ~4 pp R² cost** vs Base, CI [-6.5, -1.5] (statistically real but small).
**Honest read on the peer comparisons.** Like Base, Mini's regression-vs-XGBoost point estimate is positive (+3.5 pp) but the 95% CI on this 13-dataset sample crosses zero. We can't claim a statistically significant XGBoost win on regression from this single-seed eval. What we *can* say: Mini and XGBoost are competitive on regression on this benchmark, with Mini's distribution being slightly better on most datasets.
**Significant losses (real, not noise):** loses to XGBoost on classification (-5.9 pp), and to TabPFN-2.5 / TabICLv2 on both axes — these are commercial / SOTA models 2-8× Mini's parameter count.
### Model size vs accuracy
| model | params | params (%) | reg-R² | cls-acc |
|---|:---:|:---:|:---:|:---:|
| TabPFN-2.5 | ~100M | 740% | 0.662 | 0.780 |
| TabICLv2 | ~50M | 370% | — | 0.792 |
| **predictlm-base-26m** | 26M | 192% | 0.589 | 0.685 |
| **predictlm-mini-13m** | 13.5M | 100% (baseline) | 0.551 | 0.684 |
Mini is the smallest open-source ICL tabular FM in this comparison and the only one that trains on a single commodity GPU.
## Architecture
Identical architecture family to PredictLM Base, with cross-layer parameter sharing (ALBERT-style) to halve the trunk parameter count.
| field | value |
|---|---|
| Parameters | 13.5 M |
| Layers (effective depth) | 12 (4 unique × 3 shares — ALBERT-style sharing in shared trunk; 2 unique × 2 shares per task head) |
| d_model | 256 |
| n_heads | 8 |
| max_features | 128 |
| max_classes | 10 |
| max_context | 1024 |
| max_query | 256 |
| Regression head | BarDistribution, 1024 bins (bins identical to Base — required for KL distillation) |
| Classification head | Per-task masked softmax |
| Attention | row-axis transformer (same as Base) |
| Inference precision | fp16 (T4-compatible — Base uses bf16 on A100/H100) |
Cross-layer sharing means Mini has 4 unique trunk blocks each applied 3 times during forward pass (vs Base's 8 unique blocks each applied once). The effective compute graph depth is preserved; only the parameter count is halved.
## Training recipe (distillation from Base)
Mini was trained via **warm-start sliced distillation**: a novel recipe for compressing in-context-learning models that preserves real-data transfer ability.
**Three-stage recipe:**
1. **Warm-start by slicing.** Copy every-Nth layer from the Base model (26M) into Mini's smaller unique-block list. Non-layer modules (feature embeddings, normalization, heads) copy verbatim. This initializes Mini at ~v11.0-half quality — student starts with the teacher's transfer ability already.
2. **Distill via teacher logits.** Train Mini on synthetic SCM tasks using Base as a frozen teacher. Loss = 0.7 × KL(student || teacher, T=2) + 0.2 × hard-label CE + 0.1 × feature MSE. Online distillation with replay buffer.
3. **30,000 training steps** with AdamW, cosine lr 3e-5 → 3e-6, fp16 mixed precision.
The critical insight: distillation from scratch (Option A in our experiments) **failed to transfer to real OpenML data** — student matched teacher on synthetic but couldn't generalize. Warm-start sliced distillation (Option B, this release) succeeded because the student inherits the teacher's transfer ability as the starting point; distillation only needs to refine.
## Intended use, limitations, ethical considerations
Identical to [predictlm-base-26m](https://huggingface.co/zerooneresearch/predictlm-base-26m) — see that model card for full details:
- **Intended**: drop-in tabular predictor for ≤128 features, ≤1024 training rows, ≤10 classes
- **Not intended**: high-stakes decisions without domain validation; wide tables (>128 features); many-class cls (>10); very large training sets (>10K rows); non-numeric features without encoding
- **No personal data in training**: distilled from Base, which was trained on synthetic priors + cleared real-data copulas. No raw eval-set rows seen.
- **Bias inheritance**: predictions reflect the labeled context the user supplies at inference time
The known weaknesses (cls below XGBoost; below TabPFN-2.5 / TabICLv2 on both axes) are inherited from Base; Mini does not amplify them but cannot fix them either.
## Reproducibility
- **Weights file**: `v11_06_tiny_final.pt` (inference-only, EMA-preferred state)
- **SHA-256**: `e27c8af6cda7a3426ffed33cb98eb8338966a8190712b5d37ff9e5f442b75a17`
- **Size**: 54.4 MB (inference-only, optimizer + curriculum + buffer + L2-SP state stripped from 217 MB raw)
- **Training step**: 30,000 (final)
- **Training seed**: 42
- **Teacher**: `predictlm-base-26m` (v11.0)
- **Distillation recipe**: warm-start slice + online KL distillation
- **Eval-lock manifest SHA-256**: `fe4da8cccfc78fc3c7746579f604154af7d37e525c4fd575965ba77ce4fe0841` (identical to Base)
## Licensing
Apache 2.0 — see [LICENSE](./LICENSE). Permissive, commercial use allowed.
The distillation recipe uses our own [predictlm-base-26m](https://huggingface.co/zerooneresearch/predictlm-base-26m) (Apache 2.0) as the teacher — no third-party license obligations propagate to this model. Mini is fully commercially usable.
## Version
- **v11.0.6-tiny** (current) — first public release of the compact distilled variant.
- Sibling: [predictlm-base-26m](https://huggingface.co/zerooneresearch/predictlm-base-26m) (full-size, 26M)
- Future releases under the same `predictlm` Python package.
## Citation
### BibTeX
```bibtex
@misc{predictlm_mini_2026,
author = {ZeroOne Research},
title = {predictlm-mini-13m: a compact distilled tabular foundation model for commodity hardware},
year = {2026},
publisher = {Hugging Face},
howpublished = {\url{https://huggingface.co/zerooneresearch/predictlm-mini-13m}}
}
```
### APA
ZeroOne Research. (2026). *predictlm-mini-13m: a compact distilled tabular foundation model for commodity hardware.* Hugging Face. https://huggingface.co/zerooneresearch/predictlm-mini-13m