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

相关文章

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

XTU 1237 计算几何

题面: Magic Triangle Problem Description: Huangriq is a respectful acmer in ACM team of XTU because he brought the best place in regional contest in history of XTU. Huangriq works in a big compa

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显

centos6一键安装vsftpd脚本

centos6一键安装vsftpd脚本 手动安装vsftpd参考教程:Centos下安装Vsftpd的图文教程 vsftpd脚本功能: 1.安装 (命令执行:sh xxx.sh)2.添加ftp用户 (命令执行:sh xxx.sh add)3.卸载vsftpd (命令执行:sh xxx.sh uninstall) 测试环境:centos6 x64 centos6 x86(测试centos7以

计算数组的斜率,偏移,R2

模拟Excel中的R2的计算。         public bool fnCheckRear_R2(List<double[]> lRear, int iMinRear, int iMaxRear, ref double dR2)         {             bool bResult = true;             int n = 0;             dou

Android逆向(反调,脱壳,过ssl证书脚本)

文章目录 总结 基础Android基础工具 定位关键代码页面activity定位数据包参数定位堆栈追踪 编写反调脱壳好用的脚本过ssl证书校验抓包反调的脚本打印堆栈bilibili反调的脚本 总结 暑假做了两个月的Android逆向,记录一下自己学到的东西。对于app渗透有了一些思路。 这两个月主要做的是代码分析,对于分析完后的持久化等没有学习。主要是如何反编译源码,如何找到

Lua 脚本在 Redis 中执行时的原子性以及与redis的事务的区别

在 Redis 中,Lua 脚本具有原子性是因为 Redis 保证在执行脚本时,脚本中的所有操作都会被当作一个不可分割的整体。具体来说,Redis 使用单线程的执行模型来处理命令,因此当 Lua 脚本在 Redis 中执行时,不会有其他命令打断脚本的执行过程。脚本中的所有操作都将连续执行,直到脚本执行完成后,Redis 才会继续处理其他客户端的请求。 Lua 脚本在 Redis 中原子性的原因