SPONGE分子模拟实践

Linux GPU 模型开发 高级 查看源文件  

概述

分子模拟是指利用计算机以原子水平的分子模型来模拟分子结构与行为,进而模拟分子体系的各种物理、化学性质的方法。它是在实验基础上,通过基本原理,构筑起一套模型和算法,从而计算出合理的分子结构与分子行为。

近年来,分子模拟技术发展迅速并且在多个学科领域得到了广泛的应用。在药物设计领域,可用于研究病毒、药物的作用机理等;在生物科学领域,可用于表征蛋白质的多级结构与性质;在材料学领域,可用于研究结构与力学性能、材料的优化设计等;在化学领域,可用于研究表面催化及机理;在石油化工领域,可用于分子筛催化剂结构表征、合成设计、吸附扩散,可构建和表征高分子链以及晶态或非晶态本体聚合物的结构,预测包括共混行为、机械性质、扩散、内聚等重要性质。

MindSpore版的SPONGE是北大和深圳湾实验室高毅勤课题组与华为MindSpore团队联合开发的分子模拟库,具有高性能、模块化等特性。基于MindSpore自动并行、图算融合等特性,SPONGE可高效地完成传统分子模拟过程。SPONGE利用MindSpore自动微分的特性,可以将神经网络等AI方法与传统分子模拟进行结合。

本篇教程将主要介绍如何在GPU上,使用MindSpore内置的SPONGE进行高性能分子模拟。

你可以在这里下载完整的示例代码:https://gitee.com/mindspore/mindspore/tree/r1.3/model_zoo/research/hpc/sponge

整体执行

  1. 准备分子模拟输入文件,加载数据,确定计算的分子体系;

  2. 定义 SPONGE 模块并初始化,确定计算流程;

  3. 运行训练脚本,输出模拟的热力学信息文件,并查看结果;

准备环节

实践前,确保已经正确安装MindSpore。如果没有,可以通过MindSpore安装页面安装MindSpore。

模拟多肽水溶液体系示例

SPONGE具有高性能及易用的优势,本教程使用SPONGE模拟多肽水溶液体系。模拟体系为丙氨酸三肽水溶液体系。

准备输入文件

本教程模拟体系中需要加载三个输入文件,分别是:

  • 属性文件(后缀为.in的文件),声明模拟的基本条件,对整个模拟过程进行参数控制。

  • 拓扑文件(后缀为.param7的文件),拓扑文件描述的是体系内部分子的拓扑关系及各种参数。

  • 坐标文件(后缀为.rst7的文件),坐标文件描述的是每个原子在体系中的初始时刻的坐标。

拓扑文件和坐标文件可以通过建模过程由AmberTools中自带的tleap工具(下载地址http://ambermd.org/GetAmber.php, 遵守GPL协议)建模完成。建模过程如下:

  • 打开tleap

    tleap
    
  • 加载tleap自带的ff14SB力场

    > source leaprc.protein.ff14SB
    
  • 搭建丙氨酸三肽模型

    > ala = sequence {ALA ALA ALA}
    
  • 利用tleap加载其自带的tip3p力场

    > source leaprc.water.tip3p
    
  • 利用tleap中的slovatebox溶解丙氨酸三肽链, 完成体系构建。10.0代表加入的水距离我们溶解的分子及体系边界至少在10.0埃以上

    > solvatebox ala TIP3PBOX 10.0
    
  • 将建好的体系保存成parm7rst7文件

    > saveamberparm ala ala.parm7 ala_350_cool_290.rst7
    

通过tleap构建了所需要的拓扑文件(WATER_ALA.parm7)和坐标文件(WATER_ALA_350_cool_290.rst7)后,需要通过属性文件声明模拟的基本条件,对整个模拟过程进行参数控制。以本教程中的属性文件NVT_290_10ns.in为例,其文件内容如下:

NVT 290k
   mode = 1,                              # Simulation mode ; mode=1 for NVT ensemble
   dt= 0.001,                             # Time step in picoseconds (ps). The time length of each MD step
   step_limit = 1,                        # Total step limit, number of MD steps run
   thermostat=1,                          # Thermostat for temperature ; thermostat=0 for Langevin thermostat
   langevin_gamma=1.0,                    # Gamma_ln for Langevin thermostat represents coupling strength between thermostat and system
   target_temperature=290,               # Target temperature
   write_information_interval=1000,       # Output frequency
   amber_irest=0,                         # Input style ;  amber_irest=1 for using amber style input & rst7 file contains veclocity
   cut=10.0,                              # Nonbonded cutoff distance in Angstroms
  • mode,分子动力学(MD)模式,1表示模拟采用NVT系综。

  • dt,表示模拟步长。

  • step_limit,表示模拟总步数。

  • thermostat,表示控温方法,1表示采用的是Liujian-Langevin方法。

  • langevin_gamma,表示控温器中的Gamma_ln参数。

  • target_temperature,表示目标温度。

  • amber_irest,表示输入方式,0表示使用amber方式输入,并且rst7文件中不包含veclocity属性。

  • cut,表示非键相互作用的距离。

加载数据

完成输入文件的构建后,将文件存放在本地工作区的sponge_in路径下,其目录结构如下:

└─sponge
    ├─sponge_in
    │      NVT_290_10ns.in                 # specific MD simulation setting
    │      WATER_ALA.parm7                 # topology file include atom & residue & bond & nonbond information
    │      WATER_ALA_350_cool_290.rst7     # restart file record atom coordinate & velocity and box information

从三个输入文件中,读取模拟体系需要的参数,用于MindSpore的计算。加载代码如下:

import argparse
from mindspore import context

parser = argparse.ArgumentParser(description='Sponge Controller')
parser.add_argument('--i', type=str, default=None, help='input file')
parser.add_argument('--amber_parm', type=str, default=None, help='paramter file in AMBER type')
parser.add_argument('--c', type=str, default=None, help='initial coordinates file')
parser.add_argument('--r', type=str, default="restrt", help='')
parser.add_argument('--x', type=str, default="mdcrd", help='')
parser.add_argument('--o', type=str, default="mdout", help="")
parser.add_argument('--box', type=str, default="mdbox", help='')
parser.add_argument('--device_id', type=int, default=0, help='')
args_opt = parser.parse_args()

context.set_context(mode=context.GRAPH_MODE, device_target="GPU", device_id=args_opt.device_id, save_graphs=False)

构建模拟流程

使用SPONGE中定义的计算力模块和计算能量模块,通过多次迭代进行分子动力学过程演化,使得体系达到我们所需要的平衡态,并记录每一个模拟步骤中得到的能量等数据。为了方便起见,本教程的计算迭代次数设置为1,其模拟流程构建代码如下:

from src.simulation_initial import Simulation
from mindspore import Tensor

if __name__ == "__main__":
    simulation = Simulation(args_opt)
    save_path = args_opt.o
    for steps in range(simulation.md_info.step_limit):
        print_step = steps % simulation.ntwx
        if steps == simulation.md_info.step_limit - 1:
            print_step = 0
        temperature, total_potential_energy, sigma_of_bond_ene, sigma_of_angle_ene, sigma_of_dihedral_ene, \
        nb14_lj_energy_sum, nb14_cf_energy_sum, LJ_energy_sum, ee_ene, _ = simulation(Tensor(steps), Tensor(print_step))
        # compute energy and temperature

运行脚本

执行以下命令,启动训练脚本main.py进行训练:

python main.py --i /path/NVT_290_10ns.in \
               --amber_parm /path/WATER_ALA.parm7 \
               --c /path/WATER_ALA_350_cool_290.rst7 \
               --o /path/ala_NVT_290_10ns.out
  • -i 为MD模拟的属性文件,控制模拟过程

  • -amber_parm 为MD模拟体系的拓扑文件

  • -c 为我们输入的初始坐标文件

  • -o 为我们模拟输出的记录文件,其记录了输出每步的能量等信息

  • -path 为文件所在的路径,在本教程中为sponge_in

训练过程中,使用属性文件(后缀为.in的文件)、拓扑文件(后缀为.param7的文件)以及坐标文件(后缀为.rst7的文件),通过在指定温度下进行模拟,计算力和能量,进行分子动力学过程演化。

运行结果

训练结束后,可以得到输出文件ala_NVT_290_10ns.out,体系能量变化被记录在了该文件中,可以查看模拟体系的热力学信息。查看ala_NVT_290_10ns.out可以看到如下内容:

_steps_ _TEMP_ _TOT_POT_ENE_ _BOND_ENE_ _ANGLE_ENE_ _DIHEDRAL_ENE_ _14LJ_ENE_ _14CF_ENE_ _LJ_ENE_ _CF_PME_ENE_
      0 0.000   -5713.804         0.037       0.900         14.909      9.072    194.477  765.398    -6698.648
   ...

其中记录了模拟过程中输出的各类能量, 分别是迭代次数(steps),温度(TEMP),总能量(TOT_POT_E),键长(BOND_ENE),键角(ANGLE_ENE),二面角相互作用(DIHEDRAL_ENE),非键相互作用,其包含静电力及Leonard-Jones相互作用。