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.7.tar.gz (41.7 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.7-py3-none-any.whl (36.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: motionscorehrpqct-2.2.7.tar.gz
  • Upload date:
  • Size: 41.7 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.7.tar.gz
Algorithm Hash digest
SHA256 3e2e3b1f7632277ff715c13535c39cc06ccd425a491dc51fe74d35053383acb1
MD5 421f98a6bded8b6620b3c41e8c438ec6
BLAKE2b-256 2a2a59d89f2cdfe90f01a67066ccbf3d5c554803faf0284f7717a6d56d9fe795

See more details on using hashes here.

Provenance

The following attestation bundles were made for motionscorehrpqct-2.2.7.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.7-py3-none-any.whl.

File metadata

File hashes

Hashes for motionscorehrpqct-2.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 e54b87f73d00a5fba70ed03abe61b84bdf8c6910c7d42bb90ab9707a12d625d9
MD5 9bd763d0d82ef3885d788fa6a23781db
BLAKE2b-256 169dec39dfcbfa11ff153ac90ae995621830a30d5e608ff1a893c9951e06e2de

See more details on using hashes here.

Provenance

The following attestation bundles were made for motionscorehrpqct-2.2.7-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