MLflow plugin: automatic PRML manifest hash tagging for runs. Pre-registered ML evaluation claims.
Project description
mlflow-falsify — automatic PRML manifest hash tagging for MLflow runs
Drop a PRML manifest in your repo. Every MLflow run gets cryptographically bound to it. No workflow changes.
Install
pip install mlflow-falsify
The plugin is discovered automatically through MLflow's mlflow.run_context_provider entry point.
Usage
import mlflow
# .prml.yaml exists in CWD or any parent directory — that's all you need.
with mlflow.start_run():
mlflow.log_metric("accuracy", 0.873)
# The run now carries prml.manifest_hash and friends as tags.
What gets tagged
When a .prml.yaml or prml.yaml is found in the current directory or any ancestor, every run is tagged with:
prml.manifest_hash— SHA-256 of the canonical manifest bytes (PRML v0.1 §3)prml.manifest_path— relative path to the discovered manifestprml.version— manifest schema version (e.g.prml/0.1)prml.metric— the pre-registered metric (e.g.accuracy)prml.comparator— one of>=,>,==,<=,<prml.threshold— the numeric threshold, as a stringprml.dataset_id— the pre-registered dataset identifier
Missing or malformed fields are silently skipped. The provider never raises into your run.
HPO sweeps and tag scope
In an HPO sweep the same PRML claim repeats across thousands of runs, so emitting the 5 descriptive tags per-run becomes pure tag noise. As of v0.2.0 the plugin supports lifting them to experiment level:
export MLFLOW_FALSIFY_TAG_SCOPE=experiment
import mlflow_falsify
mlflow.set_experiment("credit-scorer-hpo")
mlflow_falsify.tag_experiment() # idempotent; sets metric/comparator/threshold/dataset_id/version once
for params in hpo_grid:
with mlflow.start_run():
... # only prml.manifest_hash and prml.manifest_path attach per-run
Default behaviour (MLFLOW_FALSIFY_TAG_SCOPE=run or unset) is unchanged: all 7 tags attach per-run, backward-compatible with v0.1.x.
Why this matters
- EU AI Act Article 12 evidence layer. Every logged run carries a tamper-evident pointer to the claim it was meant to test.
- Eval reproducibility by default. The hash freezes metric, threshold, dataset, and seed before the experiment runs.
- Audit trails for free. Reviewers can recompute the manifest hash from the YAML and compare it against your tracked runs.
- No workflow change. Existing MLflow code is untouched — the plugin attaches via entry points.
Links
- PRML specification: spec.falsify.dev/v0.1
- Falsify reference implementation: github.com/studio-11-co/falsify
- Zenodo (this plugin): doi.org/10.5281/zenodo.20235451
- Zenodo (PRML spec): doi.org/10.5281/zenodo.20177839
- Registry: registry.falsify.dev
Audit & compliance crosswalks
Where the manifest hash this plugin attaches fits in major AI governance frameworks (FULL / PARTIAL / NONE tagged):
- EU AI Act Article 12 — automated-logging pattern for the 2 August 2026 high-risk deadline
- NIST AI RMF 1.0 — GOVERN / MAP / MEASURE / MANAGE subcategory map
- ISO/IEC 42001:2023 — AI Management System clause-by-clause evidence map
License
MIT. Copyright 2026 Studio 11 / Cüneyt Öztürk.
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
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 mlflow_falsify-0.2.0.tar.gz.
File metadata
- Download URL: mlflow_falsify-0.2.0.tar.gz
- Upload date:
- Size: 9.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f99394417e9456be47761cf433c5fe900411742c553eb12794ec718068241fbb
|
|
| MD5 |
5f39e95ce96d05c4318e08fde97fcd71
|
|
| BLAKE2b-256 |
964e64d092e15219ec79c10314c854c77116ac8354982e3530871db1e9ddcac4
|
Provenance
The following attestation bundles were made for mlflow_falsify-0.2.0.tar.gz:
Publisher:
publish.yml on studio-11-co/mlflow-falsify
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mlflow_falsify-0.2.0.tar.gz -
Subject digest:
f99394417e9456be47761cf433c5fe900411742c553eb12794ec718068241fbb - Sigstore transparency entry: 1615095126
- Sigstore integration time:
-
Permalink:
studio-11-co/mlflow-falsify@52636e6283f77796434bef8c7bcfc0d29c496c98 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/studio-11-co
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@52636e6283f77796434bef8c7bcfc0d29c496c98 -
Trigger Event:
push
-
Statement type:
File details
Details for the file mlflow_falsify-0.2.0-py3-none-any.whl.
File metadata
- Download URL: mlflow_falsify-0.2.0-py3-none-any.whl
- Upload date:
- Size: 8.9 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 |
d93c26a3f4ff1107661e971adcaca3be0caca5aba101a123dea53f12fef9d8eb
|
|
| MD5 |
0e5dd27b9574f7682718025664d96c47
|
|
| BLAKE2b-256 |
ae6206f4b9b0e44036dee258f0b325d58d00eed3a2613dc4612f2b27ff05c504
|
Provenance
The following attestation bundles were made for mlflow_falsify-0.2.0-py3-none-any.whl:
Publisher:
publish.yml on studio-11-co/mlflow-falsify
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mlflow_falsify-0.2.0-py3-none-any.whl -
Subject digest:
d93c26a3f4ff1107661e971adcaca3be0caca5aba101a123dea53f12fef9d8eb - Sigstore transparency entry: 1615095131
- Sigstore integration time:
-
Permalink:
studio-11-co/mlflow-falsify@52636e6283f77796434bef8c7bcfc0d29c496c98 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/studio-11-co
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@52636e6283f77796434bef8c7bcfc0d29c496c98 -
Trigger Event:
push
-
Statement type: