vasp安装包_vasp+VTST进行NEB过渡态计算

1、计算前的准备

  • vasp+vtst安装包,编译vasp5.4.1+VTST (见文末)

  • 下载vtstscripts (见文末),解压后export PATH到.bashrc文件中设置环境变量

2、计算流程

  • 分别对初态和末态进行结构优化

  • 使用脚本生成中间过程图像(结构)

  • NEB计算

  • 处理结果

计算的文件结构预览:

4236721464c1971d23ff2d0440a415d1.png

2.1初态末态结构优化

2.1.1) 请注意:变化的原子在POSCAR中的位置一定要一一对应

如图,体相Si中在(0.125, 0.125, 0.125)处有空位,(0, 0, 0)处的Si运动到此处 构建POSCAR时,不仅是把64个Si原子的POSCAR中对应空位的原子删除,还要调整顺序,把变化的两个位置放在POSCAR的中相同位置。

92a996b82bd032feb1f1fd7e0d0beede.png

2.1.2) 结构优化同vasp正常的结构优化一样:

>> 初态末态输入文件所在文件夹建议命名为ini和fin

>> INCAR中的EDIFFG参数使用力收敛标准,比如EDIFFG = -0.02

>> 在两个文件夹里面运行vasp任务就可以

>> 输入文件参数的设置要和之后的过渡态计算一致

2.2) 构建中间图像:

将处理脚本下载vtstscripts,解压后放在PATH路径,在ini和fin文件夹的上层文件夹

2.2.1) 检测初末结构相似度

每个对应原子的初末态距离的平方和,再开根号<5埃,即可

dist.pl ini/CONTCAR fin/CONTCAR2.03953509783509

2.2.2) 插入中间图像的POSCAR

nebmake.pl ini/CONTCAR fin/CONTCAR N
  • N为中间图像的数量,之后要在INCAR中写入这个N,本例N=4

  • 执行完命令后出现文件夹00,01,02, …,N,N+1

  • 00表示初态,里面放的是ini/CONTCAR, N+1表示末态,放的是fin/CONTCAR,01-N是插入的点

  • N+2个文件夹里面的文件名称都是POSCAR

  • 将来提交任务时,使用的CPU一定要是N的整数倍

  • 一般插点数目可取(dist.pl返回值/0.8)

2.2.3) 将ini和fin的OUTCAR分别复制到00,N+1文件夹中,便于后续分析

2.2.4) 准备INCAR KPOINTS POTCAR 文件

KPOINTS,POTCAR同初末态计算一致

INCAR非过渡态参数与初末结构优化一致

NEB参数:

  • LCLIMB=.TRUE. #通知vasp使用VTST计算

  • ICAHIN=0 #通知vasp使用VTST计算

  • IMAGES=N #之前添加的图像数量N image number

  • 结构优化算法(过渡态计算的优化器Optimizer)选择vasp或者vtst的

>> vasp优化算法:

IBRION =1 (quasi-Newton) 或3 (quick-min) (基于力的优化方法)。

POTIM = 取个合理的数值。

bbs.一般来说,如果你感觉自己插的点基本上就是反应的路径了,可以使用IBRION= 1。

bbs.如果你的初始和末态结构不是很理想,插的点也是马马虎虎,那么3则是一个很好的选择。

bbs.IBRION选择完了,我们还要设置一个合理的POTIM。个人经验0.1-1.0之间都是可以接受的。

>> vtst优化算法:

IBRION=0

POTIM=0

IOPT=优化算法,我也不知道该如何选择,VTST给的说明FORCE BASED OPTIMIZERS

725f2af48fe32e8f9a3f60715e24d54f.png

Must set IOPT = 3 or 7 when using ISIF = 3

SPRING=-5

bbs.使用多大的劲控制蚂蚱不乱跳:这个参数是干嘛的? 查阅一下VTST的官网,

The nudged elastic band (NEB) is a method for finding saddlepoints and minimum energy paths between known reactants and products. Themethod works by optimizing a number of intermediate images along the reactionpath. Each image finds the lowest energy possible while maintaining equalspacing to neighboring images. This constrained optimization is done by addingspring forces along the band between images and by projecting out the componentof the force due to the potential perpendicular to the band.

什么意思呢?打个比方,这8个IMAGES就是一条绳上的8只蚂蚱,这些蚂蚱只能在一个方向上跳,在优化的时候,蚂蚱跳的太远,或者太偏就会被拉回来。拉回来的这个力就是通过SPRING这个参数来设置的。而我们之前的优化优化计算中,一条绳上只栓一只蚂蚱,该蚂蚱则比较自由,前后左右可以随便跳,并且没有人往回拽,这也是过渡态计算和普通优化所不同的地方。具体的理论部分,大家自行查阅NEB相关的参考文献。如果你算的一个基元反应,两个原子之间的键很强,那么我们就需要将SPRING这个参数设置的更负一些,比如SPRING= -10,-15 或者-20。(不一定是-5的倍数,也可以是-6,-11 等。)如果你不知道怎么设置,一般来说默认值-5就足够用了。

2.3 过渡态计算

准备好输入文件后,就可以提交计算任务了,如果一运行就终止了,查看01文件夹下面的OUTCAR,最后一行,可能会给出原因。

2.3.1) 检查是否收敛

nebef.pl
7dc9d067747ca0c2388da1df4b8b5336.png
  • 第二列即为最大受力force of images in the neb,(有些结构,由于天然的对称性,受力为0)

  • 我的INCAR中EDIFFG设置为-0.02,当所有结构最大力小于0.02eV/A时,结束计算

  • 上图中的力都小于0.02,此时已经完全收敛,计算结束。

  • 第三列为相应结构的能量。

  • 第四列为与初始结构的能量差

2.3.2) 检查切向力

nebbarrier.pl cat neb.dat
1abf4ec4f358048e99e4f807d2b8164b.png
  • 该命令没有输出到屏幕的内容,而是生成neb.dat文件。

  • 第二列表示距离(即临近两结构的dist.pl的计算结果),

  • 第三列表示能量(以初态能量为参考值),

  • 第四列为切向力(forces along the neb)

注:过渡态附近切向力会正负变号,而且接近0,如图中图像3对应的图像,就很可能是过渡态,将其CONTCAR取出,在其附近结构优化一下应该可以找到过渡态,过渡态能量是极大值,也可以确认过渡态另一特征是有且仅有一个虚频,对找到的过渡态计算一下振动频率可以进一步确认。

2.3.3) 结果打包

先修改一下这个程序nebresults.pl再使用,将57到71行注释掉:如果不注释它就把你的OUTCAR文件压缩,如果正在计算的时候执行,VASP找不到OUTCAR,计算终止 。

cc07c0598544d79c7576edaf13dad5aa.png

另:这个命令需要使用gunplot进行画图,没有安装也没问题,忽视报错,可以用其他软件画图,这个打包也就是依次执行了这几个程序,并用gunplot画了eps格式的图。

nebresults.plUnziping the OUTCARs ... doneDo nebbarrier.pl ; nebspline.plDo nebef.plDo nebmovie.plDo nebjmovie.plDo nebconverge.pl

上面命令做了这些事情:

  • nebbarrier.pl, 生成neb.dat,包含,收敛情况,NEB方向力,能量,上面已说明

  • nebspline.pl, 生成的spline.dat文件是对neb.dat里 能量v距离的关系进行插值,用来画mep.eps

  • mep.eps是以dist.pl距离为横坐标,能量为纵坐标画出的能势垒图,可用EPS/PS viewer打开

  • 我们也可以使用neb.dat的数据用自己喜欢的画图软件插值画图

  • nebef.pl, 上面已分析收敛 受力,能量,结果在nebef.dat

  • nebmovie.pl, 生成结构变化

  • nebjmovie.pl,

  • nebconverge.pl

  • 还有对各文件夹中的OUTCAR打包压缩。生成了很多文件。

    生成的vaspgr文件夹内是各个插点结构的收敛图

我计算的一个mep.eps图为:

08627e98253ff3eacdbc67623fe7a86c.png

图中在00-02之间数据不足,我又在00-02之间插值模拟,这次使用origin读取neb.dat画图,如图:

80b4f49d95d73680ea2b7b9bca6db4f8.png

3、更多案例请参考下面链接:

参考DFT-EXERCISES里面solution.pdf里面的第6章的过渡态计算内容。

https://github.com/cndaqiang/DFT-EXERCISES

4、本教程提到的下载资源和相关教程:

https://cndaqiang.github.io/2018/12/07/NEB-compile/

http://theory.cm.utexas.edu/code/vtstscripts.tgz

http://blog.sina.com.cn/s/blog_b364ab230102vghk.html#cmt_5BD3168D-2A316DE7-1318DF001-81F-8A8

http://agrh1209.blogspot.com/2016/11/vaspneb.html

https://www.bigbrosci.com/2018/11/16/ex76_01_check_inputs/

5、友情链接:

vasp-vtst计算过渡态--NEB方法

http://blog.wangruixing.cn/2019/08/19/cineb/

VASP计算过渡态常见问题总结

http://blog.wangruixing.cn/2019/05/01/transitionstate/

注:本教程来源于湖南大学cndaqiang童鞋,欢迎关注他的个人博客:

31311746410e56e75f0fb4aa7ccebc5e.png

https://cndaqiang.github.io/archive/

  • 2
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值