Skip to main content

MotionScoreHRpQCT core CLI for dataset-first HR-pQCT motion grading

Project description

MotionScoreHRpQCT logo

MotionScoreHRpQCT

CI Coverage Gate PyPI PyPI Downloads

Motion scoring for HR-pQCT scans using deep convolutional neural networks.

This refactor provides a dataset-first pipeline with BIDS-style derivatives and review-state persistence for direct Slicer integration.

Related repositories:

What Changed In v2

  • Legacy CLI commands grade and confirm are removed.
  • New dataset-driven commands: discover, predict, review-init, review-apply, explain, export.
  • Default output structure is now:
<dataset_root>/derivatives/MotionScore/
  index.tsv
  dataset_description.json
  <mirrored-source-path-or-flat-aim-name>/
    predictions/predictions.tsv
    preview/<scan_id>_preview.png
    preview/<scan_id>_slice_profile.png
    review/review.tsv
    review/review.json
    review/review_audit.tsv
    explain/<scan_id>_gradcam.mha
  • AIM reading now uses aimio-py.
  • Python baseline is now >=3.10.
  • Output path mapping:
    • Flat input (*.AIM directly in dataset root): outputs are grouped under folder named after each AIM file stem.
    • Structured input (nested folders): outputs mirror the source folder structure under MotionScore.
  • Raw-vs-mask identification:
    • Primary: AIM header processing log (ISQ-origin markers indicate raw images).
    • Fallback: filename-based heuristics when header signal is unavailable.

Installation

conda create -n motionscore python=3.10 -y
conda activate motionscore

# Clone
# git clone <repo-url>
# cd MotionScoreHRpQCT

# Install CLI + torch inference backend
pip install -e ".[torch]"

Models

Place torch model files (for example DNN_0.pt ... DNN_9.pt) in one of these locations:

  • ./models
  • motionscore/models
  • explicit --model-dir <path>

Model weights are licensed for usage tracking. In the current deployment configuration, licenses are automatically granted at signup.

CLI Usage

1) Discover scans

motionscore discover /path/to/dataset
motionscore discover /path/to/dataset --json

2) Run prediction + initialize review tables

motionscore predict /path/to/dataset --confidence-threshold 75
# blinded operator training mode
motionscore predict /path/to/dataset --training-mode
# optional: restrict to one scan_id (repeat flag for multiple)
motionscore predict /path/to/dataset --scan-id sub-001_site-tibia_ses-T1_abcdef1234
# optional quick-look PNG controls
motionscore predict /path/to/dataset --preview-panels 5
motionscore predict /path/to/dataset --no-preview-png

Default output root:

/path/to/dataset/derivatives/MotionScore

Optional custom output root:

motionscore predict /path/to/dataset --output-root /tmp/results

3) Update review threshold policy

motionscore review-init /path/to/dataset/derivatives/MotionScore --confidence-threshold 90
# keep/enable blinded operator training mode
motionscore review-init /path/to/dataset/derivatives/MotionScore --training-mode

--confidence-threshold 100 effectively requires review of all scans. When --training-mode is enabled, pending scans are always operator-first and AI prediction is revealed after manual grading.

4) Apply manual review decision for one scan

motionscore review-apply /path/to/dataset/derivatives/MotionScore \
  --scan-id sub-001_site-tibia_ses-T1_abcdef1234 \
  --manual-grade 3 \
  --reviewer mwalle

4b) Clear manual grades for re-review

# clear one operator across all scans
motionscore review-clear /path/to/dataset/derivatives/MotionScore --reviewer opA

# clear everyone
motionscore review-clear /path/to/dataset/derivatives/MotionScore --all-reviewers

5) Generate on-demand Grad-CAM attention map

motionscore explain /path/to/dataset/derivatives/MotionScore \
  --scan-id sub-001_site-tibia_ses-T1_abcdef1234

6) Export final grade table

motionscore export /path/to/dataset/derivatives/MotionScore

Writes motion_grades.tsv at the derivatives root (or custom --output). Export includes current per-scan review state plus machine-readable multi-reviewer summary columns:

  • reviewer_count
  • reviewers (pipe-delimited reviewer IDs)
  • consensus_method (currently mean_manual_grade)
  • consensus_mean_manual_grade
  • consensus_grade_rounded
  • dynamic reviewer slots: reviewer_1_id, reviewer_1_grade, reviewer_2_id, reviewer_2_grade, ...

Slicer Integration Contract

This repository is core logic only. A separate Slicer extension should:

  1. run motionscore predict ... from a Run button,
  2. run motionscore review-apply ... as reviewers step through scans,
  3. request motionscore explain ... on demand to overlay Grad-CAM maps,
  4. optionally show preview/*_preview.png for quick QC,
  5. load all outputs from derivatives without ad hoc state files.

Reference Slicer repository:

Citation

If you use this software, please cite:

Walle, M., Eggemann, D., Atkins, P.R., Kendall, J.J., Stock, K., Müller, R. and Collins, C.J., 2023. Motion grading of high-resolution quantitative computed tomography supported by deep convolutional neural networks. Bone, 166, p.116607. https://doi.org/10.1016/j.bone.2022.116607

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

motionscorehrpqct-2.2.3.tar.gz (41.4 kB view details)

Uploaded Source

Built Distribution

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

motionscorehrpqct-2.2.3-py3-none-any.whl (35.7 kB view details)

Uploaded Python 3

File details

Details for the file motionscorehrpqct-2.2.3.tar.gz.

File metadata

  • Download URL: motionscorehrpqct-2.2.3.tar.gz
  • Upload date:
  • Size: 41.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for motionscorehrpqct-2.2.3.tar.gz
Algorithm Hash digest
SHA256 e17f83a48510095ff1f1bbce710b4fac883179b92e438d49dd42fb4308165418
MD5 64a0cbed03a07d4536d4ed95080aa4f7
BLAKE2b-256 10081ee20a37a4712a52e510cc27fc067dae16e22ca8ce5236e425d3c4b0fe96

See more details on using hashes here.

Provenance

The following attestation bundles were made for motionscorehrpqct-2.2.3.tar.gz:

Publisher: publish-pypi.yml on wallematthias/MotionScoreHRpQCT

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

File details

Details for the file motionscorehrpqct-2.2.3-py3-none-any.whl.

File metadata

File hashes

Hashes for motionscorehrpqct-2.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 e613c78b4ceaea1f18ae5d1e2b340058a64de97ba61196005d73d43bee0b0f1d
MD5 72e1cb5981716933f0a0e31a9afd7d0f
BLAKE2b-256 5d8d8f2989711c4c4da6e7ff6f75fda3965c533df67d32c7500e6d50e1c358f5

See more details on using hashes here.

Provenance

The following attestation bundles were made for motionscorehrpqct-2.2.3-py3-none-any.whl:

Publisher: publish-pypi.yml on wallematthias/MotionScoreHRpQCT

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