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脚本批量复制并规范命名视频文件

《通过Python脚本批量复制并规范命名视频文件》本文介绍了如何通过Python脚本批量复制并规范命名视频文件,实现自动补齐数字编号、保留原始文件、智能识别有效文件等功能,听过代码示例介绍的非常详细,... 目录一、问题场景:杂乱的视频文件名二、完整解决方案三、关键技术解析1. 智能路径处理2. 精准文件名

web网络安全之跨站脚本攻击(XSS)详解

《web网络安全之跨站脚本攻击(XSS)详解》:本文主要介绍web网络安全之跨站脚本攻击(XSS)的相关资料,跨站脚本攻击XSS是一种常见的Web安全漏洞,攻击者通过注入恶意脚本诱使用户执行,可能... 目录前言XSS 的类型1. 存储型 XSS(Stored XSS)示例:危害:2. 反射型 XSS(Re

Python3脚本实现Excel与TXT的智能转换

《Python3脚本实现Excel与TXT的智能转换》在数据处理的日常工作中,我们经常需要将Excel中的结构化数据转换为其他格式,本文将使用Python3实现Excel与TXT的智能转换,需要的可以... 目录场景应用:为什么需要这种转换技术解析:代码实现详解核心代码展示改进点说明实战演练:从Excel到

Python脚本实现图片文件批量命名

《Python脚本实现图片文件批量命名》这篇文章主要为大家详细介绍了一个用python第三方库pillow写的批量处理图片命名的脚本,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言源码批量处理图片尺寸脚本源码GUI界面源码打包成.exe可执行文件前言本文介绍一个用python第三方库pi

shell脚本自动删除30天以前的文件(最新推荐)

《shell脚本自动删除30天以前的文件(最新推荐)》该文章介绍了如何使用Shell脚本自动删除指定目录下30天以前的文件,并通过crontab设置定时任务,此外,还提供了如何使用Shell脚本删除E... 目录shell脚本自动删除30天以前的文件linux按照日期定时删除elasticsearch索引s

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

10个Python自动化办公的脚本分享

《10个Python自动化办公的脚本分享》在日常办公中,我们常常会被繁琐、重复的任务占据大量时间,本文为大家分享了10个实用的Python自动化办公案例及源码,希望对大家有所帮助... 目录1. 批量处理 Excel 文件2. 自动发送邮件3. 批量重命名文件4. 数据清洗5. 生成 PPT6. 自动化测试

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

10个Python Excel自动化脚本分享

《10个PythonExcel自动化脚本分享》在数据处理和分析的过程中,Excel文件是我们日常工作中常见的格式,本文将分享10个实用的Excel自动化脚本,希望可以帮助大家更轻松地掌握这些技能... 目录1. Excel单元格批量填充2. 设置行高与列宽3. 根据条件删除行4. 创建新的Excel工作表5

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s