最終更新:2025-08-19
概要
本記事では、自作モジュール(MultiOptPy)で、SN2反応(基質-iodomethane, 求核剤-2,4-pentanedione)の遷移状態構造を算出してみる。使用する計算レベルは、Meta社のFAIR Chemistryが開発したニューラルネットワークポテンシャル(NNP)であるUMA(Meta’s Universal Model for Atoms)を使用する。
MultiOptPyは電子状態計算ソフトウェアを用いた分子構造最適化手法の勉強を目的として作成したpythonモジュールである。
MultiOptPyのレポジトリ:https://github.com/ss0832/MultiOptPy
SN2反応について:
今回使用したニューラルネットワークポテンシャルについて:
- https://ai.meta.com/blog/meta-fair-science-new-open-source-releases/ (UMAの公開に関する記事)
- https://github.com/facebookresearch/fairchem (FAIR Chemistryの提供するGitHubのレポジトリ)
- https://fair-chem.github.io/ (同上のレポジトリの内容に関して説明したサイト)
- https://huggingface.co/facebook/UMA (NNPの配布サイト, Hugging Faceへのアカウント登録と配布元の使用許諾が必要である。)
使用した自作モジュールMultiOptPyのバージョン
v1.12c
環境
Windows 11
※Windows 11環境下でAnaconda PowerShell Promptを使用した。
Source codeのダウンロード
wget https://github.com/ss0832/MultiOptPy/archive/refs/tags/v1.12c.zip
unzip v1.12c.zip
cd MultiOptPy-v1.12c
環境構築手順
今回は、Windows 11のPower Shellを使用した。初めに、NNPを使用できる環境が整ったAnaconda PowerShell Promptを用意する手順を説明する。
1, https://repo.anaconda.com/archive/ より、Anaconda3-2025.06-1-Windows-x86_64.exe
でAnacondaをインストールする。
2, 検索機能を使い、スタートからAnaconda PowerShell Prompt
を開く。
3, 以下のコマンドを実行し、仮想環境を作成する。
conda create -n (任意の仮想環境名) python=3.12.7
4, 先ほど作成した仮想環境をconda activate (仮想環境名)
で起動させる。
5, 以下のコマンドを実行し、必要なライブラリを導入する。
pip install fairchem-core==2.2.0 ase==3.25.0 torch==2.6.0
- fairchem-coreは、FAIR Chemistryが管理しているNNPを動作させるために必要なライブラリである。
- aseはNNPに電子エネルギーを算出したい分子構造を渡すために必要なインターフェイスの役割を果たすために必要なライブラリである。
- torchはPyTorchライブラリを指す。これはニューラルネットワークなどの機械学習を行ったり、学習結果を扱ったりするために必須なライブラリである。
これで、Anaconda PowerShell Prompt
から仮想環境を立ち上げることで、NNPを使用する準備が整えることが出来る。
次に、NNPを使用するために必要なModelの情報が保存されている.pt
ファイルのダウンロードおよびNNPの自作モジュールへの導入方法について説明する。
1, 以下のサイトにアクセスして、uma-s-1.pt
をダウンロードする。(使用許諾が下りていれば可能である。)
https://huggingface.co/facebook/UMA
2, ダウンロード後、MultiOptPy-v1.12c
ディレクトリ内に存在するsoftware_path.conf
に対して、uma-s-1.pt
の絶対パスを用いて以下を追記する。
uma-s-1::(uma-s-1.ptの絶対パス)
これで、MultiOptPy-v1.12c
がNNPuma-s-1
を使用できるようになる。
使用するNNPに関する具体的な説明
今回使用するNNPについて具体的に説明する。
- UMAのModel Checkpointは
uma-s-1
を使用した。 - 小分子系のトレーニングセットである
Omol25
(omol
)を使用して学習したニューラルネットワークポテンシャルを使用する。
※自作モジュールでの具体的な使用の仕方に関しては、ase_calculation_tools.py
を参照
手順
1. 初期構造の準備
モデル反応系として、以下の構造を用意した。今回はファイルの名前をsn2_I_beta_diketone.xyz
とした。 初期構造は以下のものを使用した。
19
OptimizedStructure
C -0.309630129944 -0.418245473370 -0.138920303453
C 1.178202517168 -0.595548750323 -0.114343972614
H -0.840025254358 -0.735263407793 -1.028072693155
C -1.069963645451 0.332274122730 0.905850316408
C 1.718312217050 -1.852642764974 0.507334863094
C -0.075449551698 1.966689380029 -2.105157735839
I 0.649629513715 2.958669853509 -3.845241233172
H 1.862942048561 -1.658819548796 1.570495398341
H 1.034515434709 -2.691693752319 0.398300808816
H 2.688850427285 -2.068721974188 0.072345357404
C -1.631480723756 -0.464016503672 2.054767334649
H -2.650926822476 -0.769523799074 1.813858263580
H -1.047948247279 -1.363281282856 2.242662104553
H -1.672026174197 0.173238395285 2.931692023666
O 1.912300286126 0.242763326795 -0.574031645726
O -1.227263416532 1.525484977494 0.814299605126
H 0.326905614275 0.965740106430 -2.152087192465
H 0.313074786576 2.473045941562 -1.230064530491
H -1.160018879773 1.979851153529 -2.123686768722
2. 遷移状態構造最適化のための初期構造の算出
a. 初期構造をカレントディレクトリにsn2_I_beta_diketone.xyz
として保存し、以下を実行する。
python .\optmain.py sn2_I_beta_diketone.xyz -opt rsirfo_fsb -os uma-s-1 -ma 300 1 6 -elec -1
-opt rsirfo_fsb
は準ニュートン法であるRS-I-RFO法を構造最適化に使用することを示す。初期のへシアンに関しては、特にオプションで指定しない限り、単位行列が使われる。-spin
はスピン多重度の指定である。PySCFを使用するときは目的とするスピン多重度に1を引いた値を指定する。(デフォルトでは1が指定される。)-elec M
は形式電荷をMとすることを示す。(デフォルトでは0が指定される。)-ma yyy a b
はyyykJ/molの活性化障壁を超えうるペア同士を近づける力を原子のラベル番号aとbのペアに構造最適化時に加えることを示す。-os uma-s-1
は今回使用するNNPを指定している。これを使用する際にASEライブラリが必要である。
これを実行すると、omol
のデータセットを使用したuma-s-1
モデルのNNPで得たエネルギーに対して、指定した人工力ポテンシャルを加えた上で初期構造を構造最適化することができる。
結果はyyyy_mm_dd
(今日の年月日)ディレクトリの中に存在するディレクトリを開いて確認できる。
正常終了していれば、このディレクトリ中に、sn2_I_beta_diketone_traj.xyz
が存在するので、これをコピーして、MultiOptPy-v1.12c
ディレクトリに置く。
sn2_I_beta_diketone_traj.xyz
は構造最適化の過程をAvogadro(公式ページ:https://avogadro.cc/ )等で可視化して確認できるようにしている。このsn2_I_beta_diketone_traj.xyz
は次のNEB計算に使用する。
※sn2_I_beta_diketone_traj.xyz
をアニメーションとして表示したい場合は、[https://github.com/ss0832/molecule_movie] を使うと良い。
(この人工力ポテンシャルを加えて行った構造最適化の結果はsn2_I_beta_diketone_optimized.xyz
で確認できる。構造を可視化して、生成系になっているか確認する。反応系のままであれば、-ma
の設定を見直してb.をやり直す。今回の場合以下の構造が得られた。生成系の安定構造に近いものが得られていると判断できるため、次のNEB計算を行うことが可能である。)
b. sn2_I_beta_diketone_traj.xyz
を初期パスとして、NEB法で経路の緩和を行う。
NEB法を用いることで、先ほど得られたsn2_I_beta_diketone_traj.xyz
全体のエネルギーを下げることができる。これにより、パスのエネルギー極大値を持つ構造を遷移状態構造に近づける。(この時点ではまだ正確な遷移状態構造は求められていない。)
python .\nebmain.py sn2_I_beta_diketone_traj.xyz -os uma-s-1 -ns 20 -modelhess -spng -nd 0.12 -elec -1
-nd N
はノード間の距離をN Åとして初期パスを作成することを示す。-ns n
はn回分NEB法による経路の緩和を行うことを示す。-fc M
はM回あたりの経路緩和回数に対して1回だけ正確なHessianを計算し、経路緩和に使用する。これを使用すると、Hessianを使用しない場合の経路緩和アルゴリズムとは別のものを使用して、経路緩和を行う。-spng
は緩和中のパスのエネルギープロファイルや各ノードの勾配のRMS値をmatplotlibで可視化するオプションである。-os uma-s-1
は今回使用するNNPを指定している。これを使用する際にASEライブラリが必要である。
c. 初期構造の決定及び遷移状態構造の計算
MultiOptPy-v1.12c
と同じディレクトリ内に、NEBという名前を含むディレクトリが生成されている。 そのディレクトリ内のenergy_plot.csv
を確認し、緩和後のパスのエネルギー極大値を示す構造を確認する。
パスの緩和後の各ノードのエネルギー一覧(単位
※bias_force_rms.csv
にて、各Iterationごとのすべてのノードの勾配のRMS値を確認できる。
経路緩和の結果、経路のエネルギー極大値を示す構造の中から目視で、ITR. 5の経路の5番(グラフ上では6番)の構造を遷移状態構造を求める初期構造として採用した。
※こちら[https://ss0832.github.io/molecule_viewer/] を使うことでも可視化は可能である。
sn2_I_beta_diketone_traj_5_itr5.xyz
19
-1 1
C -0.304164698767 -0.208919692541 -0.301336357567
C 1.136365537810 -0.556122709765 -0.141105957787
H -0.867933055171 -0.755265345468 -1.048568291820
C -1.041635046459 0.355770216157 0.845027300631
C 1.709752656428 -1.847024371999 0.510041511152
C -0.101008050574 1.809216837088 -1.960739906419
I 0.645621407786 3.014504083306 -3.886841212887
H 1.841354285216 -1.662992462217 1.582552873228
H 1.024139416418 -2.681804660978 0.395239646416
H 2.696427088729 -2.077861016804 0.084802996082
C -1.607436347669 -0.448962891601 2.052481252289
H -2.627433349034 -0.767452220482 1.794515534725
H -1.033463796815 -1.355138403630 2.239365224895
H -1.679505647979 0.175030586918 2.959561350979
O 1.990615396944 0.209673965906 -0.548813056375
O -1.308335738116 1.547892733115 0.886205211417
H 0.379435418603 0.897185966960 -2.188652999923
H 0.312475887531 2.427349355219 -1.186745620066
H -1.165271364882 1.924920030816 -2.086989498972
構造が壊れていないので、これを遷移状態を求めるための初期構造とする。
sn2_I_beta_diketone_traj_5_itr5.xyz
をMultiOptPy-v1.12c
と同じディレクトリ内にコピーする。
そして、以下を実行する。
python .\optmain.py sn2_I_beta_diketone_traj_5_itr5.xyz -freq -tcc -opt rsirfo_bofill -fc 5 -order 1 -os uma-s-1 -elec -1
-opt rsirfo_bofill
は遷移状態構造の最適化向けのoptimizerを指定することを意味する。準ニュートン法であるRS-I-RFO法を使用する。今回は-fc
で正確なへシアンを計算するようにしているので、初期へシアンは正確なへシアンを使用するようになっている。-order 1
は一次の鞍点を求めることを指定する。(デフォルトだと極小値を求めるようになっている。)-fc 5
は5回の反復回数当たり1回正確なへシアンを計算することを指定する。-freq
は収束条件を満たした後に基準振動解析を行うことを示す。(自前で実装しているため、あくまで目安として使用することを推奨する。各振動モードをvibration_animation
内のxyzファイルで可視化できる。)UMAモデルから算出されるHessianは数値微分により求めているため、原子数Zが多いとZの二乗オーダーで計算コストが急増する。-tcc
は収束条件を厳しくすることを示す。(Gaussianのtightと同等)
実行して得られた正確な遷移状態構造と思われる構造を以下に示す。
(実行して得られた正確な遷移状態構造は計算開始時に、yyyy_mm_dd
ディレクトリ内に生成された新規ディレクトリ内のYYY_optimized.xyz
として保存されている。)
19
OptimizedStructure
C 0.073350570329 -0.308680854338 0.465307613408
C 1.507056582727 -0.387363254185 0.369630989044
H -0.466746333672 -1.188664450589 0.128818555521
C -0.662609210051 0.583466791861 1.320246835392
C 2.034243063524 -1.644429911038 -0.327042163378
C -0.214681311230 0.967083487583 -1.460073194998
I -0.554023007579 2.334404278138 -3.568963504984
H 2.016942038249 -2.482206285236 0.374650753785
H 1.416846107881 -1.921812234386 -1.184355546851
H 3.060612514193 -1.473056606321 -0.645915004374
C -2.148102966606 0.247201063845 1.477637403225
H -2.571327217201 -0.188313863115 0.570163346837
H -2.265963590051 -0.482883838479 2.282383582715
H -2.691687279593 1.150947226603 1.747679827595
O 2.314778489066 0.448715007519 0.759062687830
O -0.225060946199 1.572160309723 1.898817477722
H 0.283300066743 0.177304592050 -1.990666473788
H 0.363438045495 1.709000997658 -0.935643921849
H -1.270365616024 0.887127542706 -1.281739262851
停留点に収束した分子構造が得られた。-freq
オプションにより生成されたnormal_modes.txt
やvibration_animation
ディレクトリ内の振動モードのアニメーションを確認した。
以下に-freq
オプションで生成されたnormal_modes.txt
の一部を示す。
Mode 0 1 2
Freq [cm^-1] -452.7557 32.2459 49.9163
Reduced mass [au] 11.7029 1.5019 5.8140
Force const [Dyne/A] -1.4134 0.0009 0.0085
Char temp [K] 0.0000 46.3947 71.8184
Normal mode x y z x y z x y z
C 0.01551 -0.06427 0.10095 -0.02273 0.00753 0.00957 -0.00061 0.02877 0.00720
C -0.01273 -0.00611 0.01404 -0.02606 0.01721 -0.02204 -0.00172 0.01066 0.01404
H -0.00256 -0.01792 0.01145 -0.02493 -0.00075 0.03257 -0.01426 0.06028 -0.05249
C 0.01089 -0.01614 0.00340 -0.01073 -0.00063 0.03083 0.00674 -0.00725 0.05159
C 0.00028 -0.00010 -0.00308 -0.02974 0.02049 -0.03109 -0.01496 0.06488 -0.09463
C -0.03260 0.14026 -0.21194 -0.01545 0.00405 0.00030 0.00445 0.04506 0.00686
I 0.00193 -0.00653 0.01077 0.01429 -0.00267 -0.00445 -0.00250 -0.00678 -0.02436
H 0.02424 -0.00347 -0.00661 0.07250 0.04428 -0.00011 0.08731 0.03684 -0.12543
H -0.00482 -0.01124 0.00250 -0.08904 -0.03843 0.03105 -0.07663 0.07096 -0.05164
H -0.00587 0.01655 -0.01656 -0.06395 0.05703 -0.12223 -0.04872 0.12036 -0.17438
C -0.00072 0.00040 -0.00192 0.01289 -0.06867 0.10757 -0.00736 0.02648 -0.00617
H -0.00209 -0.01313 0.00355 -0.08729 0.28509 -0.01728 0.00177 0.08975 -0.04077
H -0.01490 0.01583 0.01005 0.11137 -0.40028 -0.17856 -0.04870 -0.01489 -0.04973
H 0.00469 0.01031 -0.02107 0.03981 -0.17703 0.51982 0.01194 0.02682 0.03173
O 0.00507 0.00284 -0.00680 -0.02209 0.02194 -0.03822 0.01209 -0.04326 0.10186
O -0.00527 0.00883 -0.00280 -0.01679 0.02836 -0.01516 0.02233 -0.06260 0.13448
H -0.00769 0.00671 0.00688 -0.02553 -0.00516 0.00463 -0.00079 0.03359 0.01990
H -0.01182 -0.00718 -0.01996 -0.00610 -0.00435 0.00220 0.01055 0.05109 -0.00898
H 0.01216 -0.00329 -0.00100 -0.01613 0.01616 0.00235 0.00619 0.05173 0.01962
(...snip...)
その結果、虚振動が1つであることが確認できた。つまりこの構造は遷移状態構造である。
次に、vibration_animation
内の虚振動を示す分子振動が示されたxyzファイル(mode_1_XXXi_wave_number.xyz
)をAvogadroで確認すると、想定される反応系と生成系をつなぐ方向に振動していることを確認できた。
終わりに
自作モジュールで、UMAモデルのニューラルネットワークポテンシャル(NNP)を用いて、SN2反応(基質-iodomethane, 求核剤-2,4-pentanedione)のある1つの遷移状態構造を算出する手順を説明した。
参考
- https://github.com/ss0832/MultiOptPy (自作モジュールMultiOptPyのレポジトリ)
- https://avogadro.cc/ (Avogadro、分子構造可視化ツール)
- https://ai.meta.com/blog/meta-fair-science-new-open-source-releases/ (UMAの公開に関する記事)
- https://github.com/facebookresearch/fairchem (FAIR Chemistryの提供するGitHubのレポジトリ)
- https://fair-chem.github.io/ (同上のレポジトリの内容に関して説明したサイト)
- https://huggingface.co/facebook/UMA (NNPの配布サイト, Hugging Faceへのアカウント登録と配布元の使用許諾が必要である。)
- The Journal of Chemical Physics 2010, 132, 241102.
- The Journal of Chemical Physics 1991, 94, 751–760.
- In Classical and Quantum Dynamics in Condensed Phase Simulations; WORLD SCIENTIFIC: LERICI, Villa Marigola, 1998; pp 385–404.
- The Journal of Chemical Physics, 2020, 153, 024109.
- The Journal of Chemical Physics, 2022, 144, 214108.
個人的な技術的補足
-modelhess
を使わない場合のアルゴリズムを用いたnebmain.py
による経路緩和の結果
コマンド
python .\nebmain.py sn2_I_beta_diketone_traj.xyz -os uma-s-1 -ns 20 -spng -nd 0.12 -elec -1
結果
パスの緩和後の各ノードのエネルギー一覧(単位
※bias_force_rms.csv
にて、各Iterationごとのすべてのノードの勾配のRMS値を確認できる。
緩和後の経路のエネルギー極大値を示すノードの分子構造 sn2_I_beta_diketone_traj_21.xyz
19
-1 1
C -0.298568135833 -0.204446603644 -0.295689063849
C 1.153430332087 -0.563138204115 -0.152587441116
H -0.885090394931 -0.765022068677 -1.020877769952
C -1.044967021756 0.373351698953 0.853745172734
C 1.711374643696 -1.855393784349 0.487329285863
C -0.127334979402 1.794209806564 -1.896612685514
I 0.657467725912 3.011736837404 -3.864964945340
H 1.847330379718 -1.668024258061 1.562116844329
H 1.037149828056 -2.703940692106 0.392044284916
H 2.696460172074 -2.086981141176 0.071874882120
C -1.610447940819 -0.455310313854 2.032429533300
H -2.632658858010 -0.761047798807 1.782891785960
H -1.041453990529 -1.363043765094 2.233112481608
H -1.678973428246 0.160042264101 2.935611259461
O 2.005153937133 0.207522712704 -0.561737029029
O -1.296796806439 1.562477436784 0.882226452016
H 0.369441822302 0.893648643185 -2.158096536791
H 0.314650815962 2.464968511612 -1.178226640791
H -1.176168100976 1.958390718574 -2.104589869928