MCP server that turns the OpenAIRE Graph into a ranked replication queue — impact-ranked targets, independent reusable tooling, and the Science Live verification overlay.
Project description
Replication Radar
🔗 Live demo → https://openaire-hackathon.netlify.app
A tool that makes the OpenAIRE Graph more useful for replication. Search a research field and it answers the question the Graph structurally cannot: what high-impact work is worth replicating, has it already been independently checked — with what verdict — and is the software reusable?
Ships as a live web app (the link above — pure static, queries OpenAIRE + the nanopub network + GitHub/Software Heritage from the browser) and an MCP server (this package) that exposes the same engine to any agent. Built for the OpenAIRE AI Hackathon (Theme B), CC-BY.
OpenAIRE's only value signal is citation-popularity (BIP! influence / popularity / impulse, classes C1–C5) — paper-bound, and orthogonal to whether a claim is true. The Radar joins three sources to add a replication layer on top:
- OpenAIRE Graph — impact-ranks candidate papers (
api.openaire.eu/graph/v1). - Software Heritage + repo signals — surfaces reusable method software.
- Science Live nanopub verdicts — the "already checked → did it hold" overlay.
OpenAIRE AI Hackathon · Theme B (Build) · CC-BY. Built to be reused through the forrt-replication-template: discovery at the start of a replication, where the template's existing skills handle the nanopub chain at the end.
Tools
| Tool | What it answers |
|---|---|
radar(topic) |
Impact-ranked replication targets in a field — each OPEN (opportunity) or VERIFIED (done, with verdict) + independent tooling + funder context |
find_independent_software(doi, topic) |
Reusable engines not authored by the original team (author-disjoint = replication, not reproduction), ranked by reuse signal not citations |
replication_status(doi) |
Has this DOI been replicated, did it hold? Verdict(s) — live from the nanopub network, any signer — with status, CiTO relation, repo, and signed Outcome/CiTO nanopub links; open if not |
verified_claims() |
The whole verified-knowledge corpus — every claim the network holds a verdict for (author-agnostic) |
The verdict tools pull live from the nanopub network (the FORRT Outcome/CiTO templates on
query.knowledgepixels.com); the bundled verdicts.json is an offline fallback. So the MCP is the
verified-knowledge layer — pair it with the OpenAIRE MCP and an agent has both the structural
Graph and "has this been checked, and did it hold".
The reproduction-vs-replication distinction, made computable
A reproduction re-runs the original code; a replication tests the same claim by a
different route. So the Radar filters tooling by author-disjointness from the
original paper — e.g. for Phillips et al. 2009, the dismo package (co-authored by
Phillips & Elith) is flagged rooted / non-independent, while biomod2 and jSDM
are independent. That filter is the difference between the two, and it's the thing
that makes this replication-aware rather than just "find the code".
Run
pip install -e . # installs the `mcp` runtime
python -m replication_radar.server # stdio MCP server
Add to an MCP client (.mcp.json):
{ "mcpServers": {
"replication-radar": { "command": "python", "args": ["-m", "replication_radar.server"] }
} }
The core (OpenAIRE client + radar logic) is stdlib-only — try it without the MCP runtime:
PYTHONPATH=src python3 demo_sdm.py # live vertical-slice demo on SDM
Configuration
| Env var | Default | Purpose |
|---|---|---|
RADAR_OPENAIRE_BASE |
https://api.openaire.eu/graph/v1 |
Swap to the Alien AI-Gateway or a mirror — the Radar is endpoint-agnostic |
RADAR_HTTP_TIMEOUT |
30 |
Per-request timeout (s) |
Known limits (v1, honest)
- Keyword-bound discovery. OpenAIRE free-text terms are AND-ed; long queries return nothing. Use short topics. The VERIFIED overlay is guaranteed (resolved from the verdict index directly), but OPEN-target recall depends on the query.
- No graph-relation traversal on the public API (paper→its software/data/grant edges aren't exposed): tooling/data are matched heuristically by topic + author independence, not by a hard relation. Upgrades cleanly if a gateway exposes relations.
- Funder context is field-level, not per-paper (per-paper funder attribution is not reachable); budgets are frequently reported as 0 in records.
- The verdict index ships 6 source works / 12 chains (Science Live). Extend
data/verdicts.jsonto grow coverage.
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 replication_radar-0.3.1.tar.gz.
File metadata
- Download URL: replication_radar-0.3.1.tar.gz
- Upload date:
- Size: 67.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eb48deaecd664ad0a147944fb7622c477a10aea2e8f8728538fa93e5681f9bf5
|
|
| MD5 |
dcd4fe14686506debc99eb23d6710bb2
|
|
| BLAKE2b-256 |
4490f1cab3d85aec0bdc079d4a782082a23a76f9cac786924feced6e620b6898
|
Provenance
The following attestation bundles were made for replication_radar-0.3.1.tar.gz:
Publisher:
publish-pypi.yml on ScienceLiveHub/replication-radar
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
replication_radar-0.3.1.tar.gz -
Subject digest:
eb48deaecd664ad0a147944fb7622c477a10aea2e8f8728538fa93e5681f9bf5 - Sigstore transparency entry: 1819942141
- Sigstore integration time:
-
Permalink:
ScienceLiveHub/replication-radar@26954bab49de617c69d672ddc42142ae37c9cf44 -
Branch / Tag:
refs/tags/v0.3.1 - Owner: https://github.com/ScienceLiveHub
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@26954bab49de617c69d672ddc42142ae37c9cf44 -
Trigger Event:
release
-
Statement type:
File details
Details for the file replication_radar-0.3.1-py3-none-any.whl.
File metadata
- Download URL: replication_radar-0.3.1-py3-none-any.whl
- Upload date:
- Size: 19.5 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 |
fe0ff0689afcedf6fa699f8901c9dfe4a5b79b617a120f26b032c33e411d477b
|
|
| MD5 |
04b0fa6f37861cd3613660a04e9e9569
|
|
| BLAKE2b-256 |
5b5086317bbde89a3426b31b1719fad93757d50c835f65514daee68783d6b2da
|
Provenance
The following attestation bundles were made for replication_radar-0.3.1-py3-none-any.whl:
Publisher:
publish-pypi.yml on ScienceLiveHub/replication-radar
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
replication_radar-0.3.1-py3-none-any.whl -
Subject digest:
fe0ff0689afcedf6fa699f8901c9dfe4a5b79b617a120f26b032c33e411d477b - Sigstore transparency entry: 1819942151
- Sigstore integration time:
-
Permalink:
ScienceLiveHub/replication-radar@26954bab49de617c69d672ddc42142ae37c9cf44 -
Branch / Tag:
refs/tags/v0.3.1 - Owner: https://github.com/ScienceLiveHub
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@26954bab49de617c69d672ddc42142ae37c9cf44 -
Trigger Event:
release
-
Statement type: