百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

离线安装OpenMolcas-v22.06

liuian 2025-01-21 19:29 27 浏览

本文适用于OpenMolcas-v22.02和v22.06,对以后的版本可能适用也可能不适用。旧版OpenMolcas、与QCMaquis联用版本的安装请见文末链接。安装前我们需要确保有必要的编译器和库:

cmake >= 3.12、Intel编译器(含MKL)、python

笔者服务器上安装的分别是cmake 3.19、Intel 2019 update5和Anaconda Python3。尽管可以使用GNU编译器替代Intel,但笔者的个人使用经验表明用Intel编译器快不少。若读者未装Intel编译器,可以参看Linux下安装Intel oneAPI一文。

1.下载

到GitLab下载OpenMolcas,

https://gitlab.com/Molcas/OpenMolcas/-/releases

笔者下载的压缩包是OpenMolcas-v22.06.tar.gz。从v22.02开始,编译OpenMolcas要求有Libxc库,所以我们还需到GitLab下载Libxc,

https://gitlab.com/libxc/libxc/-/releases

笔者下载的压缩包是libxc-5.2.2.tar.gz。

2.编译和安装

进入存放压缩包的目录,解压,配置

tar -zxf OpenMolcas-v22.06.tar.gz
cd OpenMolcas-v22.06
mkdir bin build
cd build
CC=icc CXX=icpc FC=ifort cmake -DLINALG=MKL -DOPENMP=ON \
-DCMAKE_INSTALL_PREFIX=/home/$USER/software/OpenMolcas-v22.06 ..

此时不要急着执行make。我们需要把Libxc放到相应目录下,让OpenMolcas自动识别并编译它。依次执行

cd External/Libxc/tmp
rm -f Libxc-gitclone.cmake Libxc-gitupdate.cmake
touch Libxc-gitclone.cmake Libxc-gitupdate.cmake
cd ../src
cp ~/software/libxc-5.2.2.tar.gz .
tar -zxf libxc-5.2.2.tar.gz
rm -rf Libxc libxc-5.2.2.tar.gz
mv libxc-5.2.2 Libxc
cd ../../../

注意笔者将libxc-5.2.2.tar.gz压缩包放在~/software/目录下,所以是从~/software/拷贝。若读者放在其他目录下,则应从其他目录拷贝到External/Libxc/src/下。笔者的习惯是将软件放在/home/$USER/software/目录下,读者也可以放到其他位置。然后编译

make -j24
make install

24核编译仅需约1 min。正常结束后执行

cd ..
mv pymolcas bin/

即将脚本pymolcas移入我们之前新建的bin目录里。接着在~/.bashrc中写上OpenMolcas环境变量

# OpenMolcas-v22.06
export MOLCAS_WORKDIR=/scratch/$USER/molcas
export MOLCAS_MEM=32Gb
export MOLCAS=/home/$USER/software/OpenMolcas-v22.06
export PATH=$MOLCAS/bin:$PATH
export MOLCAS_PRINT=3
export MOLCAS_NPROCS=1
export OMP_NUM_THREADS=24

完成后记得执行source ~/.bashrc或退出重登。各种路径可以根据读者自己服务器的实际情况进行修改。若/scratch/$USER/molcas目录不存在则需手动创建。无论计算任务正常/异常结束,该目录都会有临时文件存在,每隔一段时间应进行清理。若一个任务算完后在相同位置再次提交,OpenMolcas默认去寻找上次的临时文件,好处是可以加速计算,坏处是万一不想要临时文件里的轨道作为初猜,就可能把自己坑了。若想每次计算完自动清空临时文件,可以再加上环境变量

export MOLCAS_KEEP_WORKDIR=NO

变量MOLCAS_PRINT=3可以让输出内容更多一些,偶尔有小伙伴向笔者反映他们的输出内容比我少,往往就是这个参数造成的。变量MOLCAS_NPROCS用于MPI并行,但本文编译的是MKL并行版,不支持MPI并行,因此设为1。笔者的节点上有24核,因此OMP并行核数设置为24。这些环境变量仅是笔者的个人推荐,并非适用于任何机器,详细的环境变量说明请阅读OpenMolcas手册

https://molcas.gitlab.io/OpenMolcas/Manual.pdf

3.测试

执行

pymolcas --version

屏幕应当显示

python driver version = py2.23
(after the original perl EMIL interpreter of Valera Veryazov)

接着测试程序自带标准示例。最好切换到其他目录进行测试

cd ~/
pymolcas verify standard

这个standard其实对应OpenMolcas-v22.06/test/standard目录,内含102个输入文件,可供自学模仿使用。测试过程中输出内容仅有一行,例如

Running test standard: 067... (68%)

测试时间可能长达1小时。如果嫌测试时间长,可以自己挑十几个文件测试,例如测试第004,005号文件的命令是

pymolcas verify standard:004,005

4.OpenMolcas与其他量化程序传递轨道

笔者开发的开源、免费程序MOKIT可以在常见量子化学程序间传递分子轨道(见文末链接1,第4节),并调用常见量子化学程序自动做多参考态计算(见文末链接3),本文不再重复介绍。

相关推荐

总结下SpringData JPA 的常用语法

SpringDataJPA常用有两种写法,一个是用Jpa自带方法进行CRUD,适合简单查询场景、例如查询全部数据、根据某个字段查询,根据某字段排序等等。另一种是使用注解方式,@Query、@Modi...

解决JPA在多线程中事务无法生效的问题

在使用SpringBoot2.x和JPA的过程中,如果在多线程环境下发现查询方法(如@Query或findAll)以及事务(如@Transactional)无法生效,通常是由于S...

PostgreSQL系列(一):数据类型和基本类型转换

自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟...

基于MCP实现text2sql

目的:基于MCP实现text2sql能力参考:https://blog.csdn.net/hacker_Lees/article/details/146426392服务端#选用开源的MySQLMCP...

ORACLE 错误代码及解决办法

ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...

从 SQLite 到 DuckDB:查询快 5 倍,存储减少 80%

作者丨Trace译者丨明知山策划丨李冬梅Trace从一开始就使用SQLite将所有数据存储在用户设备上。这是一个非常不错的选择——SQLite高度可靠,并且多种编程语言都提供了广泛支持...

010:通过 MCP PostgreSQL 安全访问数据

项目简介提供对PostgreSQL数据库的只读访问功能。该服务器允许大型语言模型(LLMs)检查数据库的模式结构,并执行只读查询操作。核心功能提供对PostgreSQL数据库的只读访问允许L...

发现了一个好用且免费的SQL数据库工具(DBeaver)

缘起最近Ai不是大火么,想着自己也弄一些开源的框架来捣腾一下。手上用着Mac,但Mac都没有显卡的,对于学习Ai训练模型不方便,所以最近新购入了一台4090的拯救者,打算用来好好学习一下Ai(呸,以上...

微软发布.NET 10首个预览版:JIT编译器再进化、跨平台开发更流畅

IT之家2月26日消息,微软.NET团队昨日(2月25日)发布博文,宣布推出.NET10首个预览版更新,重点改进.NETRuntime、SDK、libraries、C#、AS...

数据库管理工具Navicat Premium最新版发布啦

管理多个数据库要么需要使用多个客户端应用程序,要么找到一个可以容纳你使用的所有数据库的应用程序。其中一个工具是NavicatPremium。它不仅支持大多数主要的数据库管理系统(DBMS),而且它...

50+AI新品齐发,微软Build放大招:拥抱Agent胜算几何?

北京时间5月20日凌晨,如果你打开微软Build2025开发者大会的直播,最先吸引你的可能不是一场原本属于AI和开发者的技术盛会,而是开场不久后的尴尬一幕:一边是几位微软员工在台下大...

揭秘:一条SQL语句的执行过程是怎么样的?

数据库系统能够接受SQL语句,并返回数据查询的结果,或者对数据库中的数据进行修改,可以说几乎每个程序员都使用过它。而MySQL又是目前使用最广泛的数据库。所以,解析一下MySQL编译并执行...

各家sql工具,都闹过哪些乐子?

相信这些sql工具,大家都不陌生吧,它们在业内绝对算得上第一梯队的产品了,但是你知道,他们都闹过什么乐子吗?首先登场的是Navicat,这款强大的数据库管理工具,曾经让一位程序员朋友“火”了一把。Na...

详解PG数据库管理工具--pgadmin工具、安装部署及相关功能

概述今天主要介绍一下PG数据库管理工具--pgadmin,一起来看看吧~一、介绍pgAdmin4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许连接到特定的数据库,创建表和...

Enpass for Mac(跨平台密码管理软件)

还在寻找密码管理软件吗?密码管理软件有很多,但是综合素质相当优秀且完全免费的密码管理软件却并不常见,EnpassMac版是一款免费跨平台密码管理软件,可以通过这款软件高效安全的保护密码文件,而且可以...