vasp+phonopy-QHA计算材料热膨胀系数与格林奈森常数等脚本

本文主要是介绍vasp+phonopy-QHA计算材料热膨胀系数与格林奈森常数等脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

​脚本分享

通过使用QHA方法可以计算得到材料的热膨胀系数,热容和格林奈森参数等数据,这里使用的软件为vasp和phonopy。通过脚本一次计算得到相关数据。

相关参考为:

https://mp.weixin.qq.com/s/dC7btVnmTxwwhqCJpL8YvQ

http://phonopy.github.io/phonopy/examples.html

计算主要流程为:以声子计算无虚频的结构文件为基础,更改其缩放系数,在不同体积下计算其原子间受力、声子结构和热性质。以提取出的e-V的数据为基础,使用phonopy-qha计算包括热膨胀系数、热容和格林艾森参数等在内的热学性质。

首先将可计算得到无虚频的vasp输入文件放置在文件夹中,包括POSCAR、INCAR、KPOINTS和POTCAR,以及phonopy处理需要的设置文件,我这里使用vaspkit  305功能产生的KPATH.phonopy文件当作设置文件(请根据你的使用习惯更改脚本)。

KPATH.phonopy文件内容如下:

NPOINTS = 501DIM =  1 1 1     #扩胞倍数随具体情况而定BAND = 0.000000 0.000000 0.000000 0.500000 0.000000 0.500000 0.625000 0.250000 0.625000, 0.375000 0.375000 0.750000 0.000000 0.000000 0.000000 0.500000 0.500000 0.500000 0.500000 0.250000 0.750000 0.500000 0.000000 0.500000BAND_LABELS = $\Gamma$ X U K $\Gamma$ L W X#声子色散路径自行修改MP = 11 11 11TETRAHEDRON = .TRUE.#PDOS = 1, 2BAND_CONNECTION = .TRUE.FORCE_CONSTANTS = READATOM_NAME = WDIM = 1 1 1TPROP=.TRUE.TMAX=2000TSTEP=5FORCE_CONSTANTS = READ# FORCE_SETS = READ# IRREPS = 0  0  0# SHOW_IRREPS = .TRUE.# LITTLE_COGROUP = .TRUE.

计算脚本以及脚本注释如下:

#!/bin/bashmkdir QHA#建立QHA计算文件夹for i in $(seq 0.95 0.005 1.05)#对i赋值0.95到1.05之间,每隔0.005取值。domkdir $icp POSCAR  INCAR KPOINTS POTCAR KPATH.phonopy ./$icd ./$ised '2c '$i'' POSCAR > POSmv POS POSCAR#修改POSCAR中的缩放系数,并覆盖POSCARpwdmpirun -np 48 vasp_std |tee runlog#执行vasp计算pwdphonopy --fc  vasprun.xml #获得力常数phonopy -c POSCAR  -s  -p KPATH.phonopy#获得声子色散和声子态密度phonopy -t KPATH.phonopy |tee  thermo.dat#获得热学性质cp thermal_properties.yaml ../QHA/thermal_properties-$i.yaml#转移文件以便后续计算d=$(awk 'NR==3{print $1}' CONTCAR)V=$(echo `awk -v x=$i -v a=$d -v b=$d -v c=$d 'BEGIN{printf "%.14f\n",x*x*x*a*b*c}'`) #获得当前缩放系数下体积E=$(grep "TOTEN" OUTCAR | tail -1| awk '{printf "%12.6f \n", $5}')#获得当前缩放系数下能量echo $V $E >> ../QHA/v-e.datcd ..donecd ./QHA/phonopy-qha v-e.dat thermal_properties*.yaml |tee thermo.dat#执行QHA计算

注意:在笔者进行测试时发现在部分情况下会出现体积计算值为0的结果,需要根据实际情况调整相关的计算方式。

计算结果展示在终端窗口中

phonopy案例图图如下

计算得到的其它热学性质存储在以下文件中

可根据文件名查找。

另外,如果修改缩放系数声子计算结果出现虚频,phonopy-qha计算时会提醒

# Warning: thermal_properties-1.040.yaml has imaginary modes.

# Warning: thermal_properties-1.045.yaml has imaginary modes.

# Warning: thermal_properties-1.050.yaml has imaginary modes.

可根据实际情况修改缩放系数的区间。

愿有所成

IEchoQ

引喻失义   妄自菲薄

这篇关于vasp+phonopy-QHA计算材料热膨胀系数与格林奈森常数等脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/224824

相关文章

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)

《Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)》本文主要介绍了Golang分布式锁实现,采用Redis+Lua脚本确保原子性,持可重入和自动续期,用于防止超卖及重复下单,具有一定... 目录1 概念应用场景分布式锁必备特性2 思路分析宕机与过期防止误删keyLua保证原子性可重入锁自动

Java计算经纬度距离的示例代码

《Java计算经纬度距离的示例代码》在Java中计算两个经纬度之间的距离,可以使用多种方法(代码示例均返回米为单位),文中整理了常用的5种方法,感兴趣的小伙伴可以了解一下... 目录1. Haversine公式(中等精度,推荐通用场景)2. 球面余弦定理(简单但精度较低)3. Vincenty公式(高精度,

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片