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

离线安装OpenMolcas-v22.06

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

本文适用于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),本文不再重复介绍。

相关推荐

【常识】如何优化Windows 7

优化Windows7可以让这个经典系统运行更流畅,特别是在老旧硬件上。以下是经过整理的实用优化方案,分为基础优化和进阶优化两部分:一、基础优化(适合所有用户)1.关闭不必要的视觉效果右键计算机...

系统优化!Windows 11/10 必做的十个优化配置

以下是为Windows10/11用户整理的10个必做优化配置,涵盖性能提升、隐私保护和系统精简等方面,操作安全且无需第三方工具:1.禁用不必要的开机启动项操作路径:`Ctrl+S...

最好用音频剪辑的软件,使用方法?

QVE音频剪辑是一款简单实用的软件,功能丰富,可编辑全格式音频。支持音频转换、合并、淡入淡出、变速、音量调节等,无时长限制,用户可自由剪辑。剪辑后文件音质无损,支持多格式转换,便于存储与跨设备播放,满...

Vue2 开发总踩坑?这 8 个实战技巧让代码秒变丝滑

前端开发的小伙伴们,在和Vue2打交道的日子里,是不是总被各种奇奇怪怪的问题搞得头大?数据不响应、组件传值混乱、页面加载慢……别慌!今天带来8个超实用的Vue2实战技巧,每一个都能直击痛...

Motion for Vue:为Vue量身定制的强大动画库

在前端开发中,动画效果是提升用户体验的重要手段。Vue生态系统中虽然有许多动画库,但真正能做到高性能、易用且功能丰富的并不多。今天,我们要介绍的是MotionforVue(motion-v),...

CSS view():JavaScript 滚动动画的终结

前言CSSview()方法可能会标志着JavaScript在制作滚动动画方面的衰落。如何用5行CSS代码取代50多行繁琐的JavaScript,彻底改变网页动画每次和UI/U...

「大数据」 hive入门

前言最近会介入数据中台项目,所以会推出一系列的跟大数据相关的组件博客与文档。Hive这个大数据组件自从Hadoop诞生之日起,便作为Hadoop生态体系(HDFS、MR/YARN、HIVE、HBASE...

青铜时代的终结:对奖牌架构的反思

作者|AdamBellemare译者|王强策划|Tina要点运维和分析用例无法可靠地访问相关、完整和可信赖的数据。需要一种新的数据处理方法。虽然多跳架构已经存在了几十年,并且可以对...

解析IBM SQL-on-Hadoop的优化思路

对于BigSQL的优化,您需要注意以下六个方面:1.平衡的物理设计在进行集群的物理设计需要考虑数据节点的配置要一致,避免某个数据节点性能短板而影响整体性能。而对于管理节点,它虽然不保存业务数据,但作...

交易型数据湖 - Apache Iceberg、Apache Hudi和Delta Lake的比较

图片由作者提供简介构建数据湖最重要的决定之一是选择数据的存储格式,因为它可以大大影响系统的性能、可用性和兼容性。通过仔细考虑数据存储的格式,我们可以增强数据湖的功能和性能。有几种不同的选择,每一种都有...

深入解析全新 AWS S3 Tables:重塑数据湖仓架构

在AWSre:Invent2024大会中,AWS发布了AmazonS3Tables:一项专为可扩展存储和管理结构化数据而设计的解决方案,基于ApacheIceberg开放表格...

Apache DataFusion查询引擎简介

简介DataFusion是一个查询引擎,其本身不具备存储数据的能力。正因为不依赖底层存储的格式,使其成为了一个灵活可扩展的查询引擎。它原生支持了查询CSV,Parquet,Avro,Json等存储格式...

大数据Hadoop之——Flink Table API 和 SQL(单机Kafka)

一、TableAPI和FlinkSQL是什么TableAPI和SQL集成在同一套API中。这套API的核心概念是Table,用作查询的输入和输出,这套API都是批处理和...

比较前 3 名Schema管理工具

关注留言点赞,带你了解最流行的软件开发知识与最新科技行业趋势。在本文中,读者将了解三种顶级schema管理工具,如AWSGlue、ConfluentSchemaRegistry和Memph...

大数据技术之Flume

第1章概述1.1Flume定义Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集、聚合和传输的系统。Flume基于流式架构,灵活简单。1.2Flume的优点1.可以和...