计算化学公社

 找回密码 Forget password
 注册 Register
Views: 710|回复 Reply: 5
打印 Print 上一主题 Last thread 下一主题 Next thread

[ORCA] ORCA 5.0.4 中结合xtb计算NEB会调用数值频率计算

[复制链接 Copy URL]

12

帖子

0

威望

885

eV
积分
897

Level 4 (黑子)

各位老师好,最近想使用ORCA中的NEB模块结合xtb中的GFN2-xTB方法对批量的反应物-产物对进行反应路径的搜索,但是在计算过程中发现ORCA的计算效率并不高。经过观察计算过程发现ORCA在计算NEB时会调用orca_numfreq模块计算数值频率,但是NEB方法理论上是不需要频率信息的,想了解下orca做数值频率计算的原因是什么?是否由于做了数值频率计算,导致计算效率较低?希望有老师能为学生解惑。

输入文件内容如下:

orca调用numfreq


1万

帖子

0

威望

7396

eV
积分
18151

Level 6 (一方通行)

2#
发表于 Post on 2024-3-6 23:08:30 | 只看该作者 Only view this author
orca_numfreq虽然名字里带numfreq,但其功能并不止计算数值频率。
数值频率和NEB都需要并行计算若干个结构的能量和梯度,因此程序就调用orca_numfreq去计算NEB需要的各个image的能量和梯度了,而没有另写一套专门用于NEB的代码。
另外,对于比较好收敛的过渡态,NEB本来就是不如OptTS等传统方法快的,NEB的主要优点第一在于获得反应路径(而非只有过渡态),第二是对于OptTS难收敛的体系可以比较好收敛。所以如果你认为计算效率不高是根据你做OptTS计算的经验得来的结论,那么这不是ORCA的问题,而是NEB的问题。如果你的结论是和其他支持NEB的程序比较而来的,那可以讨论一下ORCA慢的原因,或许我们ORCA这边也可以改进。
BDF(https://bdf-manual.readthedocs.io/zh_CN/latest/Introduction.html)、ORCA(https://orcaforum.kofo.mpg.de/index.php)开发团队成员

12

帖子

0

威望

885

eV
积分
897

Level 4 (黑子)

3#
 楼主 Author| 发表于 Post on 2024-3-7 16:41:55 | 只看该作者 Only view this author
wzkchem5 发表于 2024-3-6 23:08
orca_numfreq虽然名字里带numfreq,但其功能并不止计算数值频率。
数值频率和NEB都需要并行计算若干个结构 ...

老师好,我这边是使用python的ash包(https://github.com/RagnarB83/ash)进行的neb计算,选择这个包的原因是因为它同样实现了 10.1021/acs.jctc.1c00462 中提到的 energy-weighted springs,但在计算中发现同样使用单核计算,ASH的计算速度是比ORCA快很多的,我这边选择了一个反应,复现了这个结果,python安装和ORCA调用的xTB均为6.5.1版本。
slurm作业提交脚本如下:

ASH运行时间:

ORCA运行时间:

所有输入输出文件已经打包在附件中上传,感谢老师解答!

test_xtb2_neb.tar.gz

1.99 MB, 下载次数 Times of downloads: 4

1万

帖子

0

威望

7396

eV
积分
18151

Level 6 (一方通行)

4#
发表于 Post on 2024-3-7 17:58:58 | 只看该作者 Only view this author
921927965 发表于 2024-3-7 09:41
老师好,我这边是使用python的ash包(https://github.com/RagnarB83/ash)进行的neb计算,选择这个包的原 ...

由输出文件可以看出,ORCA和ASH调用xtb的次数估计是差不多的,因为NEB迭代次数差不多。
所以ORCA计算慢应该是因为ORCA调用xtb有额外的overhead。ORCA不管做什么计算,基本都会产生gbw文件,我刚才试了一下用GFN2-xTB算水分子,产生的gbw文件有1.5MB大。而产生gbw文件的内容(例如ORCA的各种默认计算设置,包括当前计算会用到的和不会用到的)本身也要花一点时间。可想而知把这些事情重复做几百遍,肯定会花不少时间的。
本质上讲,ORCA的程序逻辑是围绕DFT计算来设计的,或者说ORCA假设计算时间起码也是分钟级的,所以耗时1秒左右的冗余操作就没有太花精力去优化。对于大批量调用xtb等极其便宜的方法算小分子的应用场景,直接调用xtb比通过ORCA这层壳子去调用xtb确实会更快。

评分 Rate

参与人数
Participants 1
eV +5 收起 理由
Reason
921927965 + 5 谢谢

查看全部评分 View all ratings

BDF(https://bdf-manual.readthedocs.io/zh_CN/latest/Introduction.html)、ORCA(https://orcaforum.kofo.mpg.de/index.php)开发团队成员

12

帖子

0

威望

885

eV
积分
897

Level 4 (黑子)

5#
 楼主 Author| 发表于 Post on 2024-3-7 19:14:59 | 只看该作者 Only view this author
wzkchem5 发表于 2024-3-7 17:58
由输出文件可以看出,ORCA和ASH调用xtb的次数估计是差不多的,因为NEB迭代次数差不多。
所以ORCA计算慢 ...

原来是这个原因,现在明白了,感谢老师的耐心解答!

1万

帖子

0

威望

7396

eV
积分
18151

Level 6 (一方通行)

6#
发表于 Post on 2024-3-7 20:20:04 | 只看该作者 Only view this author
921927965 发表于 2024-3-7 12:14
原来是这个原因,现在明白了,感谢老师的耐心解答!

另外,我刚和ORCA团队负责NEB的人确认过了,新版ORCA的NEB已经基本上解决了这个问题,对于你这个例子相比ORCA 5.0.4有40倍的加速,也就是不比ASH慢太多。所以ORCA 6推出以后,这个问题会有很大改善。这个问题主要是因为xtb和ORCA的接口的overhead,因此DFT的NEB计算不会因为这个问题而多花时间。
新版ORCA其他的涉及大规模调用xtb的计算(例如xtb数值频率)也有不小的加速

评分 Rate

参与人数
Participants 1
eV +5 收起 理由
Reason
921927965 + 5 牛!

查看全部评分 View all ratings

BDF(https://bdf-manual.readthedocs.io/zh_CN/latest/Introduction.html)、ORCA(https://orcaforum.kofo.mpg.de/index.php)开发团队成员

本版积分规则 Credits rule

手机版 Mobile version|北京科音自然科学研究中心 Beijing Kein Research Center for Natural Sciences|京公网安备 11010502035419号|计算化学公社 — 北京科音旗下高水平计算化学交流论坛 ( 京ICP备14038949号-1 )|网站地图

GMT+8, 2024-11-25 10:55 , Processed in 0.328559 second(s), 24 queries , Gzip On.

快速回复 返回顶部 返回列表 Return to list