Skip to main content

Generic MD analysis tools for protein-ligand simulations

Project description

mdatools

Generic MD analysis tools for protein-ligand simulations.

Installation

pip / uv

pip install mdatools
uv add mdatools

バージョン固定(推奨)

pip install "mdatools==0.2.1"
uv add "mdatools==0.2.1"

Optional extras

Extra 追加機能 インストール例
posebusters PoseBusters バッチ検証(NB06) pip install "mdatools[posebusters] @ git+..."
pocket ポケット環境プロファイル・比較(NB07–08) pip install "mdatools[pocket] @ git+..."

⚠️ posebusters extra を使う際は リガンドの SMILES または SDF が必須です。 詳細は docs/POSEBUSTERS_PREREQUISITES.md を参照。

開発用(リポジトリを clone して editable install)

git clone https://github.com/rkakamilan/md-analysis-tools-public.git
cd md-analysis-tools-public
uv sync --extra dev          # 開発依存も含めてインストール
uv sync --extra dev --extra notebook  # Notebook 用依存も追加

Quick start

各ノートブックの先頭 CONFIG セルだけ編集して実行します:

from pathlib import Path
from mdatools.config import AnalysisConfig, ResidueGroup

cfg = AnalysisConfig(
    ligand_resname = "LIG",
    dt_ns          = 2.0,
    # residue_groups: name any set of residues you want to prioritise in
    # template selection (NB03).  When the ligand contacts one of these
    # residues, `bonus` points are added to the total score on top of the
    # H-bond quality score (max ~100 pts) and stability score (max 15 pts).
    # A bonus of 20 corresponds to roughly one "good H-bond distance" worth
    # of score — enough to promote a snapshot that hits the target region
    # without completely overriding H-bond quality.
    # Examples:
    #   GPCR   — extracellular domain (ECD) residues contacted by peptide ligands
    #   Kinase — hinge residues that anchor ATP-competitive inhibitors
    #   Any    — allosteric pocket, key salt-bridge partner, etc.
    residue_groups = {
        # GPCR ECD example
        "ECD":    ResidueGroup(resids=[35, 36, 39], bonus=20),
        # Kinase hinge example
        # "Hinge": ResidueGroup(resids=[83, 85], bonus=20),
    },
)
REPLICA_ROOTS = [Path("../run01"), Path("../run02")]

Notebooks

Notebook 内容 依存 extra
01_rmsd.ipynb Backbone + ligand RMSD グリッド
02_hbonds.ipynb H-bond 解析 + プロット
03_template_selection.ipynb スコアリング + スナップショット抽出
04_validation.ipynb PyMOL コンフォメーションタイムライン
05_dihedral.ipynb 回転可能結合の二面角解析
06_posebusters.ipynb PoseBusters バッチ検証 posebusters
07_pocket_profile.ipynb ポケット環境プロファイル(単一スナップショット) pocket
08_pocket_comparison.ipynb ポケット環境プロファイル複数比較 pocket

CLI

# H-bond バッチ解析
mdatools-batch-hbonds run01/ run02/ --ligand UNK --output-dir ./hbond_results

# RMSD バッチ解析
mdatools-batch-rmsd run01/ run02/ --output-dir ./results

# PoseBusters バッチ検証
mdatools-pb-validate \
  --topology run01/equilibrating_topology.pdb \
  --trajectory run01/trajectory.xtc \
  --protein protein_clean.pdb \
  --smiles "CC1=CC=CC=C1" \
  --output-dir ./pb_results

# Movie 生成
mdatools-movie --pse run01/traj.pse --output movie.mp4 --fps 15

API overview

Pocket environment (NB07–08)

from mdatools.pocket import PocketProfiler, PocketComparator
from mdatools.pocket.profiler import build_2d_mol
from mdatools.plotting.pocket_profile import make_snapshot_png
from mdatools.plotting.pocket_comparison import plot_pocket_comparison

# 単一スナップショット
profiler = PocketProfiler(ligand_resname="UNK")
metrics  = profiler.profile(Path("snapshot_clean.pdb"))

# 複数スナップショット比較
metrics_dict = profiler.profile_batch(pdb_paths, output_dir=Path("./results"))
comparator   = PocketComparator()
comparison   = comparator.run(metrics_dict)
print(comparator.auto_report(comparison))

# 可視化
mol, name2idx = build_2d_mol(Path("snapshot_clean.pdb"))
make_snapshot_png(mol, name2idx, metrics, out_path=Path("pocket.png"))
plot_pocket_comparison(mol, name2idx, comparison, output_path=Path("comparison.png"))

PoseBusters バッチ検証 (NB06)

from mdatools.posebusters import FrameExporter, PoseBustersValidator
from mdatools.config import AnalysisConfig
from mdatools.universe import load_and_align

cfg = AnalysisConfig(ligand_resname="UNK", output_dir=Path("./results"))
u   = load_and_align(Path("topology.pdb"), Path("trajectory.xtc"), cfg)

exporter  = FrameExporter(cfg)
pdb_files = exporter.export_from_universe(u, output_dir=Path("./pb_frames"), prefix="snap")

validator = PoseBustersValidator(cfg, ligand_smiles="CC1=CC=CC=C1")
result    = validator.run(pdb_dir=Path("./pb_frames"), protein_path=Path("protein_clean.pdb"))
print(f"Pass rate: {result.pass_rate:.1%}")
print(result.top_frames(10))

Tests

uv run pytest tests/

Project structure

src/mdatools/
├── config.py              # Pydantic v2 設定モデル
├── universe.py            # Universe ロード + アライメント
├── analysis/              # RMSD, H-bonds, contacts, dihedral
├── scoring/               # Template scorer + snapshot selector
├── posebusters/           # PoseBusters バッチ検証 (optional: posebusters extra)
│   ├── frame_exporter.py  #   軌跡フレーム → PDB 一括出力
│   └── batch_validator.py #   PoseBusters 全フレーム実行・集計
├── pocket/                # ポケット環境解析 (optional: pocket extra)
│   ├── profiler.py        #   d_min / hydrophob / n_NO / cone_dist 計算
│   └── comparator.py      #   複数スナップショット間の集計・考察
├── pymol_bridge/          # PML 生成, PyMOL subprocess, movie
├── io/                    # ファイル探索・CSV 入出力
├── plotting/              # Matplotlib / PIL 描画関数
│   ├── pocket_profile.py  #   2D 構造式 + d_min ハロー PNG
│   └── pocket_comparison.py # 2D 構造式 + メトリクステーブル PNG
└── cli/                   # CLI エントリポイント

Related Tools

Tool 役割
docking-analysis-tools ドッキング結果解析・ポーズフィルタリング・仮想スクリーニング評価 (EF / ROC-AUC)

連携ワークフロー

mdatools                          docking-analysis-tools
─────────────────────────────     ──────────────────────────────────
MD トラジェクトリ解析
  └─ PoseClusterer
      代表コンフォメーション PDB ──► 受容体準備 → ドッキング実行
                                    ポーズフィルタリング・クラスタリング
                                    EF / ROC-AUC で最良コンフォメーション選定
上位ヒットの MD バリデーション ◄── 上位ポーズ PDB
  └─ RMSD · H-bond · コンセンサス
      最終ヒットリスト

アンサンブルドッキング(MD コンフォメーション → ドッキング → VS 評価)の 詳細な手順は docs/ensemble_docking.md を参照。

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

mdatools-0.3.0.tar.gz (416.8 kB view details)

Uploaded Source

Built Distribution

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

mdatools-0.3.0-py3-none-any.whl (178.2 kB view details)

Uploaded Python 3

File details

Details for the file mdatools-0.3.0.tar.gz.

File metadata

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

File hashes

Hashes for mdatools-0.3.0.tar.gz
Algorithm Hash digest
SHA256 22feeec828d5b7af69c25e14cbc52bdbb858c04deca98ed69b4312eea7681a67
MD5 e65731a388c2b3df6b8e7a1c8da25286
BLAKE2b-256 7c0f9e8c2648f0df49809d627fce63355017d38331e65c795389f536e03f6373

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdatools-0.3.0.tar.gz:

Publisher: publish.yml on rkakamilan/md-analysis-tools-public

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

File details

Details for the file mdatools-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: mdatools-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 178.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mdatools-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 055c3e9b470802b1f4a75fe7cb590bb73b7d422c5b29a4af2b59dababe8ecc87
MD5 d823cffc839dbe0595f8f0959c4d06df
BLAKE2b-256 3cfbf06cc8de2bfc7b2ca69e199a387fc71e75df2de9f2bdf5c20143a200d881

See more details on using hashes here.

Provenance

The following attestation bundles were made for mdatools-0.3.0-py3-none-any.whl:

Publisher: publish.yml on rkakamilan/md-analysis-tools-public

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