python分子化学模拟_#分子模拟#MDTraj分子模拟python包(一)

python分子化学模拟_#分子模拟#MDTraj分子模拟python包(一)MDTraj是分子动力学模拟的一个python包,相对于MDAnalysis个人觉得操作性更强,更加Python范一些。其能够进行不同模拟软件的轨迹转换,常规计算,分析等等一体化。今天我们介绍其安装方法和简单使用。官方地址:点击进入安装方法推荐使用conda安装mdtraj.$condainstall-cconda-forgemdtraj同样也可以使用pip来安装mdtraj测试安装运…

大家好,又见面了,我是你们的朋友全栈君。

MDTraj是分子动力学模拟的一个python包,相对于MDAnalysis个人觉得操作性更强,更加Python范一些。其能够进行不同模拟软件的轨迹转换,常规计算,分析等等一体化。今天我们介绍其安装方法和简单使用。

19e7a9833ee1c6d324dc18c39af1aebd.png

官方地址:点击进入

安装方法

推荐使用conda安装mdtraj.

$ conda install -c conda-forge mdtraj

同样也可以使用pip来安装mdtraj

测试安装

运行测试是一个非常好的方法来认证工作,测试套件采用nose,如果还没有安装可以使用pip来进行安装

pip install nose

运行测试命令如下

nosetests mdtraj -v

例子

这段文字提供一系列的例子,资源和代码来帮助使用mdtraj

如果是通过编译安装的mdtraj可以进入path-to-mdtraj/examples查看,如果是一键安装,可以通过Github进行查看,其为Ipython notebook格式。

1. MDTraj介绍

首先从硬盘中加载轨迹,MDTraj会自动的使用最合适的方式加载不同的文件格式。

import mdtraj as md

t=md.load(‘trajectory.xtc’,top=’trajectory.pdb’)

print t

一些轨迹例如Gromacs XTC轨迹文件并不包含拓扑信息,我们需要采用top关键字来加载拓扑文件,例如PDB文件.

如果你只对部分轨迹感兴趣,你可以切割(slice)他们

#查看十帧(frames)

print t[1:10]

#查看最后一帧

print t[-1]

轨迹对象包含许多对象,最多显而易见的是卡迪儿(Cartesuab)坐标.作为numpy array存储在xyz下.轨迹中的距离单位均为纳米(nanometers).时间单位为皮秒(picoseconds).角度存储为度(不是弧度).

print t.xyz.shape

print np.mean(t.xyz)

#第一个十帧时间模拟

print t.time[0:10]

# 最后一帧的晶胞长度

t.unitcell_lengths[-1]

(100, 22, 3)

0.89365752249053032

array([ 0.002, 0.004, 0.006, 0.008, 0.01 , 0.012, 0.014, 0.016,0.018, 0.02 ], dtype=float32)

array([ 2., 2., 2.], dtype=float32)

保存轨迹到文件也非常容易操作

# 保存成hdf5格式,最后一个2表示每2帧保存一次

t[::2].save(‘halftraj.h5’)

#个人推荐的保存成dcd格式

t[0:10].save_dcd(‘first-ten-frames.dcd)

轨迹包含拓扑对象的引用,这可以派上用场。例如,如果你想保存你的轨迹一份只含有α碳原子的轨迹,你可以这样做:

atoms_to_keep=[a.index for a in t.topology.atoms if a.name == ‘CA’]

t.restrict_atoms(atoms_to_keep) #在轨迹中扮演适当的作用

t.save(‘CA-only.h5’)

下期我们将会介绍其基本的原子选择操作。

更多原创精彩内容敬请关注生信杂谈:

108da3abdd430b2f7ab159f41ec5c92e.png

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/141933.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月9日 下午9:20
下一篇 2022年5月9日 下午9:20


相关推荐

  • linux密码记录木马,注意 “QQ大盗”木马注入 QQ 进程记录QQ账号与密码[通俗易懂]

    linux密码记录木马,注意 “QQ大盗”木马注入 QQ 进程记录QQ账号与密码[通俗易懂]“QQ大盗”变种AC(Win32.PSWTroj.QQPass.ac)是一个盗取QQ账号和密码的木马病毒。“网游追击者”变种CD(Win32.Troj.LipGame.cd)是一个盗取多个网络游戏账号的木马病毒。一、“QQ大盗”变种AC(Win32.PSWTroj.QQPass.ac)威胁级别:★该病毒是一个盗号木马,它会潜伏在受感染的电脑系统里,监视并伺机注入到QQ进程里,创建信息勾子,记录用…

    2022年7月20日
    41
  • ue4地编教程_编绳方法

    ue4地编教程_编绳方法一、基本操作二、导入模型和贴图##(一)导入UE4设置:1、导入:2、导入设置##(二)从3DMAX出设置##(三)从Blender导出

    2026年4月14日
    3
  • 投影矩阵 视图模型矩阵「建议收藏」

    投影矩阵 视图模型矩阵「建议收藏」
        OpenGL在设置场景时,要用到两个矩阵:投影矩阵和模型视图矩阵通过glMatrixMode来指定下面的矩阵操作是针对哪一个矩阵进行的。
        gluLookatup,glTranslate,glRotate,glScale,glOrtho,gluPerspective等函数只根据其参数计算出一个矩阵M,然后与当前的栈顶元素T相乘;但这些函数本身不能自动找到应该对应的矩阵堆栈,你可以将它们放在任何矩阵堆栈操作中,比如可以将gluLookatup放在glMat

    2022年5月14日
    38
  • 无法启动IIS服务解决办法

    无法启动IIS服务解决办法无法启动 IIS 服务启动 iis 报错如下图错误 nbsp 解决办法 nbsp 原因可能是 World nbsp Wide nbsp Web nbsp Publishing nbsp Service 服务停止了 需要开启服务 如下图 找到 World nbsp Wide nbsp Web nbsp Publishing nbsp Service 服务 右键启动 然后在重启 IIS 就 ok 了 nbsp 注 请使用 administrato 身份

    2026年3月18日
    2
  • python+PIL实现图片对比

    python+PIL实现图片对比

    2021年5月24日
    128
  • ziplist、quicklist、listpack源码设计解读

    从ziplist到quicklist,再到listpack的启发介绍Redis优化设计数据结构来提升内存利用率的时候,提到可以使用压缩列表(ziplist)来保存数据。所以现在你应该也知道,ziplist的最大特点,就是它被设计成一种内存紧凑型的数据结构,占用一块连续的内存空间,以达到节省内存的目的。但是,在计算机系统中,任何一个设计都是有利有弊的。对于ziplist来说,这个道理同样成立。虽然ziplist节省了内存开销,可它也存在两个设计代价:一是不能保存过多的元素,否则访问性能会

    2022年4月9日
    48

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号