irc¶
概要¶
要約: 遷移状態(TS)から反応物・生成物方向へ固有反応座標(IRC)を追跡します。デフォルトで前方・後方の両方向を実行します。VRAM に余裕がある場合は
--hessian-calc-mode Analyticalが推奨されます。
要点¶
想定場面:
tsoptで最適化・検証済みの TS 構造を出発点に、固有反応座標を追跡して端点接続性(R ↔ TS ↔ P)を確認するケース。手法: EulerPC(Euler Predictor-Corrector)積分 + MLIP バックエンドのヘシアン(デフォルト UMA、ORB/MACE/AIMNet2 も選択可)。デフォルトでは前方・後方両方の分岐を実行します。
主な出力:
finished_irc_trj.xyz、forward_irc_trj.xyz、backward_irc_trj.xyz(参照 PDB が利用可能なら.pdbコンパニオンも)。デフォルト:
--max-cycles 125、--step-size 0.10Bohr、--root 0、--forward/--backward両方有効、--hessian-calc-mode FiniteDifference、バックエンドuma。強制上書き: IRC は YAML/CLI マージ後にgeom.coord_type = cartおよびcalc.return_partial_hessian = trueを強制します。次ステップ: IRC 端点を opt で真の極小に最適化、または freq と組み合わせて熱化学量を取得。ヘシアン評価モードの詳細は ヘシアン評価モード を参照。
pdb2reaction irc は MLIP(デフォルト: UMA、-b/--backend で ORB・MACE・AIMNet2 も選択可能)を用いた EulerPC(Euler Predictor-Corrector)ベースの固有反応座標(IRC)積分を実行します。
XYZ/GJF 入力では --ref-pdb で参照 PDB トポロジーを指定し、XYZ 座標を保持したまま PDB 出力変換が可能になります。一般的な手順は tsopt(内部で虚振動数チェック済み、1 つ であることを確認)→ irc です。
最小例¶
pdb2reaction irc -i ts.pdb -q 0 -m 1 --max-cycles 50 --out-dir ./result_irc
出力の見方¶
result_irc/finished_irc_trj.xyzresult_irc/forward_irc_trj.xyzresult_irc/backward_irc_trj.xyz
よくある例¶
正方向のみを実行する。
pdb2reaction irc -i ts.pdb -q 0 -m 1 --no-backward \
--out-dir ./result_irc_forward
ステップを大きくし、解析ヘシアンを使う。
pdb2reaction irc -i ts.pdb -q 0 -m 1 --step-size 0.20 \
--hessian-calc-mode Analytical --out-dir ./result_irc_analytical
両方向を維持したままステップ数上限を増やす。
pdb2reaction irc -i ts.pdb -q 0 -m 1 --max-cycles 150 \
--out-dir ./result_irc_long
使用法¶
pdb2reaction irc -i INPUT.{pdb|xyz|trj|...} [-q CHARGE] [-l, --ligand-charge <number|'RES:Q,...'>] \
[-b/--backend uma|orb|mace|aimnet2] [--solvent SOLVENT] [--solvent-model alpb|cpcmx] \
[--workers N] [--workers-per-node N] [-m 2S+1] \
[--max-cycles N] [--step-size Δs] [--root k] \
[--forward/--no-forward] [--backward/--no-backward] \
[--freeze-links/--no-freeze-links] \
[--out-dir DIR] [--config FILE] \
[--convert-files/--no-convert-files] [--ref-pdb FILE] \
[--hessian-calc-mode Analytical|FiniteDifference] \
[--show-config] [--dry-run]
例¶
# 順方向のみ、有限差分ヘシアン、大きいステップサイズ
pdb2reaction irc -i ts.pdb -q 0 -m 1 --no-backward \
--step-size 0.2 --hessian-calc-mode FiniteDifference --out-dir ./irc_fd/
# PDB 入力: 完成軌跡と方向別軌跡もPDBとしてエクスポート
pdb2reaction irc -i ts.pdb -q 0 -m 1 --max-cycles 50 --out-dir ./result_irc/
ワークフロー¶
入力準備 –
geom_loaderがサポートする任意のフォーマットを受け入れます。参照 PDB が利用可能な場合(PDB 入力時、または--ref-pdbで指定した場合)、EulerPC 軌跡はそのトポロジーで PDB に変換されます。--freeze-linksが有効な場合、リンク水素の親原子は自動的に凍結されます(リンク水素と凍結原子 を参照)。注:geom.coord_typeは YAML/CLI の設定に関わらずcart(デカルト座標)に強制され、calc.return_partial_hessianはtrue(partial Hessian、active-DOF 処理)に強制されます。EulerPC 積分 – EulerPC 予測子-修正子積分器が遷移状態から IRC 経路をたどります。
--forward/--backwardフラグに従って順方向および/または逆方向の分岐が実行されます。各ステップではエネルギーベースの予測子と修正子ステップを使用します。軌跡出力 – 完了済み、順方向、逆方向の IRC 軌跡が XYZ ファイルとして書き込まれます。参照 PDB が利用可能な場合、PDB コンパニオンも生成されます(
--convert-files)。
CLI オプション¶
オプション |
説明 |
デフォルト |
|---|---|---|
|
|
必須 |
|
総電荷; YAML が |
テンプレート/導出が適用されない限り必須 |
|
残基別電荷マッピング(例: |
None |
|
MLIP予測器の並列度(workers > 1 で解析ヘシアン無効)。診断上の注意は workers > 1 による暗黙的な FD ダウングレード を参照。 |
|
|
ノードあたりのワーカー数。並列予測器に渡されます |
|
|
スピン多重度(2S+1)。YAML が |
|
|
最大IRCステップ(YAML が |
|
|
ステップ長(Bohr、非質量加重デカルト座標)(YAML が |
|
|
射影ヘシアンの固有値を昇順(最も負の値を先頭)に並べたときの0 始まりのインデックス。初期 IRC 変位に使用するモードを指定します。虚振動が 1 個だけの妥当な TS では |
|
|
順方向分岐を実行(YAML が |
|
|
逆方向分岐を実行(YAML が |
|
|
PDB 入力用、リンクH親を凍結( |
|
|
凍結する原子の 1 始まりインデックスをカンマ区切りで明示的に指定(例: |
None |
|
出力ディレクトリ(YAML が |
|
|
参照 PDB が利用可能な場合に XYZ/TRJ → PDB コンパニオンを出力するかどうか |
|
|
入力がXYZ/GJFの場合に使用する参照 PDB トポロジー |
None |
|
MLIPヘシアンモード(YAML が |
|
|
明示CLI適用前に読み込むベース YAML。 |
None |
|
解決済み YAML レイヤー/設定を表示して続行。 |
|
|
|
|
|
MLIP バックエンド |
|
|
xTB 暗黙溶媒(例: |
|
|
xTB 溶媒モデル |
|
|
実行せずに検証と実行計画のみ表示。 |
|
出力¶
out_dir/ (デフォルト:./result_irc/)
├─ <prefix>finished_irc_trj.xyz # 完全な IRC 軌跡
├─ <prefix>forward_irc_trj.xyz # 順方向分岐が実行された場合
├─ <prefix>backward_irc_trj.xyz # 逆方向分岐が実行された場合
└─ *.pdb # PDB 入力用の軌跡コンパニオン(変換有効時)
コンソールには確定済みの geom/calc/irc 設定と実行時間の要約が表示されます。
終了コード¶
終了コードは CLI 規約の 終了コード を参照。
注意事項¶
症状起点で切り分ける場合は 典型エラー別レシピ を先に参照し、詳細は トラブルシューティング を確認してください。
MLIP バックエンド(デフォルト: UMA)は IRC 全体で再利用されます。
step_lengthを大きくし過ぎると EulerPC が不安定になることがあります。ヘシアン評価モードの詳細は ヘシアン評価モード を参照してください。
--freeze-linksが有効な場合、リンク水素の親原子が自動的に凍結されます(リンク水素と凍結原子 を参照)。
設定の優先順位は CLI 規約: 設定の優先順位 を参照してください。
geom、calc、irc の各セクションは YAML リファレンス の正規定義から変更ありません: geom、calc、irc を参照してください。--freeze-links は PDB 入力で geom.freeze_atoms を拡張し、--hessian-calc-mode と CLI の charge/spin 値はマージ済み calc ブロックを補完します。
irc 固有の強制上書き(YAML/CLI マージ後に YAML 値を無視して適用):
geom:
coord_type: cart # irc では cart に強制(YAML 値は無視)
calc:
return_partial_hessian: true # irc では true に強制(partial Hessian、active-DOF 処理)