Skip to main content

Python implementation (translation) of qMRLab models for quantitative MRI.

Project description

qmrpy

qMRLab(MATLAB実装)の概念・モデルを Python へ段階的に移植するためのリポジトリです。

本プロジェクトは upstream の qMRLab(MIT License)に着想を得ており、モデル定義・検証方針は qMRLab を参照しつつ Python で再構成します。

方針(重要)

  • 研究運用の規約は AGENTS.md に従います。
  • 実装を始める前に docs/studyplan.md を完成させ(Status: active, Version: v0.1.0)、そこに沿って進めます。
  • 出力(実験結果やログ)は原則 output/ に出し、Git 管理しません。

ディレクトリ構成(予定)

.
├─ .github/                  # CI(pytest等)
│  └─ workflows/
├─ qMRLab/                   # 参照用: upstreamのMATLAB実装(ローカル配置・Git管理外)
├─ src/                      # Python実装(import対象)
│  └─ qmrpy/                  # 配布対象パッケージ
├─ tests/                    # pytest
├─ scripts/                  # 実験・実行入口(薄く保つ)
├─ configs/                  # 実験設定(再現性の入力)
├─ docs/                     # 計画・記録・論文
├─ notebooks/                # 探索・可視化(任意)
└─ output/                   # 実験結果(Git外)

代表コマンド(後で有効化)

docs/studyplan.md に従って、run 形式で検証を回します。

  • uv sync --locked --extra viz --extra dev
  • uv run scripts/run_experiment.py --config configs/exp/mono_t2_baseline.toml

vfa_t1 比較run(おすすめ)

まずは以下の3条件を回して比較します(ノイズモデル/B1ばらつき/外れ値耐性の差を見る):

  • uv run --locked scripts/run_experiment.py --config configs/exp/vfa_t1_baseline.toml
  • uv run --locked scripts/run_experiment.py --config configs/exp/vfa_t1_rician.toml
  • uv run --locked scripts/run_experiment.py --config configs/exp/vfa_t1_b1range_rician_outlier.toml

比較レポート(集計CSV+比較図):

  • uv run --locked scripts/compare_runs.py --runs output/runs/<run_id1> output/runs/<run_id2> output/runs/<run_id3>

run_experiment.pymetrics/*_per_sample.csv も出力するため、比較レポートでは残差分布や T1 true / B1 に対する誤差の層別図も生成されます。

さらに、T1 true / B1 をビン分けした 層別 |誤差| 集計(mean / median / p95) の図とCSV(failure__abs_t1_err_by_*_bin.* / failure__abs_t1_err_p95_by_*_bin.png)も出力します。

固定ビン(run間で同じ境界で比較したい場合):

  • uv run --locked scripts/compare_runs.py --runs ... --t1-range 0.2 2.0 --t1-bins 10 --b1-range 0.8 1.2 --b1-bins 10

開発(ローカル)

現時点では最小のパッケージ雛形のみです(今後、モデル実装を段階的に追加します)。

  • uv sync --extra viz(可視化を含める)
  • uv sync --extra viz --extra dev(pytest/ruff 等を含める)
  • uv run --locked -m pytest

パッケージ利用

インストール(ローカル利用)

開発中のローカルソースをそのまま使う場合(編集可能インストール):

uv pip install -e /Users/sugim/Developments/qmrpy

このリポジトリ内だけで使う場合:

uv sync --locked
uv run python -c "import qmrpy; print(qmrpy.__version__)"

最小利用例

import numpy as np
from qmrpy.models.t1.vfa_t1 import VfaT1

model = VfaT1(
    tr_s=0.015,
    flip_angles_deg=np.array([2, 5, 10, 15]),
)

signal = model.forward(m0=1.0, t1_s=1.2)
fit = model.fit(signal)
print(fit["t1_s"], fit["m0"])

ライセンス

  • qmrpy 本体:MIT(LICENSE
  • 参照元 qMRLab/:MIT(upstream、ローカル参照用)
  • 翻訳・参考実装・vendor の詳細は THIRD_PARTY_NOTICES.md を参照

第三者由来コードの扱い

  • qMRLab(MATLAB)および DECAES.jl の概念・アルゴリズムを翻訳/再構成しています。
  • epgpysrc/epgpy/ に vendor しています。
  • ライセンス表記・出自は THIRD_PARTY_NOTICES.md に集約しています。

コミットメッセージ規約

  • <emoji> <type>(<scope>): <description>
  • 例:✨ feat(core): add mono_t2 forward model

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

qmrpy-0.1.0.tar.gz (261.2 kB view details)

Uploaded Source

Built Distribution

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

qmrpy-0.1.0-py3-none-any.whl (118.3 kB view details)

Uploaded Python 3

File details

Details for the file qmrpy-0.1.0.tar.gz.

File metadata

  • Download URL: qmrpy-0.1.0.tar.gz
  • Upload date:
  • Size: 261.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.13

File hashes

Hashes for qmrpy-0.1.0.tar.gz
Algorithm Hash digest
SHA256 9c1cda2646cf26214db9055d92e600e0fe46c47e645548b1ee62736166436d1c
MD5 75534a4fdb6da0e9686ecc6c3c08c820
BLAKE2b-256 3d04d84f7724e9f1bb1bedb7448e7740a38719c083c62a8f5b796cb8d8c16be9

See more details on using hashes here.

File details

Details for the file qmrpy-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: qmrpy-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 118.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.13

File hashes

Hashes for qmrpy-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3c678412b920364be47f112237efed59a3b924720dd7c4b870170f9213df3fd6
MD5 686cbdb45f9cbe14aae3b09bfb0e4748
BLAKE2b-256 418ca97f1a709389ea2c12748336856a321dc04a5ac7b0b38dca59b25cc0a834

See more details on using hashes here.

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