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.4.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.4-py3-none-any.whl (35.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: motionscorehrpqct-2.2.4.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.4.tar.gz
Algorithm Hash digest
SHA256 aa7643eda33c407d9d1a2008288a17b5d9ca58e6524d01de750f0042d1e5a6b9
MD5 befb2a9a8ce8d4b679e55a711f2e95b1
BLAKE2b-256 1f6c7b0eeb974f319f5decbfa6ab7eb54c64c0e62b8196b89c35e595bbe690bc

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for motionscorehrpqct-2.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 34aa4a81919dc57835687849b116989ed5e102ea09d3c8a37ff72edc5ee4159f
MD5 bb74387f3da06c299d0a6ed37ec58f39
BLAKE2b-256 4483dfa660c343751398fc05bfd907d88658fba8ccb4a20c7a0339bfc7c47ae9

See more details on using hashes here.

Provenance

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