草庐IT

用VASP+VTST计算Raman光谱 (抛砖引玉)

zesuzesuzesu 2023-06-23 原文

鉴于目前没有找到很好的,很完整的教程由A到Z介绍如何用VASP计算Raman光谱。可能有干货的大神都留着自己用

摸索了一会儿找到了以下其中一个☝️方法,如果大神有补充或者纠正,欢迎留言

pre-requests:

  1. VASP 和 VTST 安装好,没有的可以参照一下这篇文章
  2. 将会用到VTST scripts里面 这两个code:dymselsph.pl, dymmatrix.py
  3. 会用最基本的vasp
  4. 安装好python
  5. 把github上的raman-sc下载下来,用python3.6的可以用知乎上这位大神的code。或者其实就是把原作者的code,vasp_raman.py里面的print都加上括号就可以用了
  6. 最重要的是根据原作者issues里面的这个问答,加上:
  7. except:
        from lxml import etree
        doc = etree.parse('vasprun.xml')
        values = [c.text for c in doc.xpath("/modeling/calculation/varray"[3].getchildren()]
    
    
    
    # 修改以后如下
    if "MACROSCOPIC STATIC DIELECTRIC TENSOR" in line:
        outcar_fh.readline()
        try:
            epsilon.append([float(x) for x in outcar_fh.readline().split()])
            epsilon.append([float(x) for x in outcar_fh.readline().split()])
            epsilon.append([float(x) for x in outcar_fh.readline().split()])
        except:
            #以下是预防在OUTCAR里找不到MACROSCOPIC STATIC DIELECTRIC TENSOR
            #或者有时候OUTCAR里出现了一连串超大数字和负号, 把两个数连起来了。例如
            #1287356918273.125234-12345.3453,上面那个float(x)函数看不懂。
            #程序就会直接去vasprun.xml找。 所以如果加了这句会报错找不到lxml的同学,
            #就用`conda install -c anaconda lxml`装上就好
    
            from lxml import etree
            doc = etree.parse('vasprun.xml')
            values = [c.text for c in doc.xpath("/modeling/calculation/varray"[3].getchildren()]
        return epsilon
    
    
    

     最初的两个文件夹会有这些文件:

  8. - folder_vasp_raman
    |-INCAR
    |-KPOINTS
    |-POTCAR
    |-POSCAR
    |-vasp_raman.py
    |-no_scheduler.sh  #用来交作业
    |-gnuplot.sh  #plot图
    -folder_phonon
    |-INCAR
    |-KPOINTS
    |-POTCAR
    |-POSCAR

    上面的准备好以后,具体操作顺序如下(想抄作业的同学用我的code):

  • 你需要vasp最基本的INCAR,POSCAR(或者你有自己的.cif可以用pymatgen或者VESTA转换成POSCAR), POTCAR, 和KPOINTS文件。两个不同的INCAR放在两个不同的文件夹。整个过程有两大步骤。原作者的范例,两个文件夹是一个套一个的,其实没什么关系可以平行放

  • 第一大步计算phonon:1)创建一个文件夹用作phonon计算,暂且命名phonon

  • $ mkdir phonon
    $ cd phonon

    2)放入POSCAR,POTCAR,KPOINTS,和第一个INCAR(这个是原作者的INCAR)。两个INCAR之间的主要区别在这几行(每一个参数代表算什么,强烈推荐看vaspwiki,最好的教科书):

  • # 在phonon里面得把这几行 comment in
    ! phonons
    ICHAIN = 1      ! Run the dynamical matrix code
    ! IMAGES = M     ! Number of parallel images, if desired as in step 2 above; otherwise, do not add.
    NSW = 25        ! (DOF/M)+1   Number of ionic steps
    IBRION =   3    ! Tell VASP to run dynamics,
    POTIM  = 0.0    ! with a time step of zero (ie, do nothing)
    ISYM = 0        ! Make sure that symmetry is off,
    EDIFFG = -1E-10 ! and that vasp does not quit due to low forces
    
    #然后在第二大步的时候把这几行 comment out,像这样
    ! phonons
    !ICHAIN = 1      ! Run the dynamical matrix code
    ! IMAGES = M     ! Number of parallel images, if desired as in step 2 above; otherwise, do not add.
    !NSW = 25        ! (DOF/M)+1   Number of ionic steps
    !IBRION =   3    ! Tell VASP to run dynamics,
    !POTIM  = 0.0    ! with a time step of zero (ie, do nothing)
    !ISYM = 0        ! Make sure that symmetry is off,
    !EDIFFG = -1E-10 ! and that vasp does not quit due to low forces
    
    #那个IMAGES是管平行计算的,只在单机电脑不是HPC玩一下的同学可以不用管

    3)用VTST里面的dymselsph.pl码计算DISPLACECAR:

  • $ perl <path to>/vtstscripts/dymselsph.pl POSCAR 8 3 0.001 #<path to>自己改成到.pl文件# 的地方就是了
    # 其中8是以第几个原子为中心
    # 3是半径范围可以自己调,目的是是让这个code找到在这个半径范围找到所有原子
    # 0.001是resolution <调过这个参数,对最后的光谱好像没有很大影响,大神可以留留言>

    输出如下:

  • ----------------------------------------------------------------------
    Using 1 central atom
    Central Coordinates: 0.6666669999999968 0.3333330000000032 0.3506900000000002 
    Central atom 1: 0.6666669999999968 0.3333330000000032 0.3506900000000002 
    ----------------------------------------------------------------------
    8 atoms were found within a radius of 3.87 of atom 8, 
    leading to 24 degrees of freedom selected.
    ----------------------------------------------------------------------
    
    

     4)mark下这个degrees of freedom(DOF), 去把INCAR里面的NSW改了。根据要求例如DOF=24,不平行运算,那么NSW就是DOF+1,NSW=25

     5)然后就是运行vasp:

  • $ mpirun -np 4 vasp_vtst_std

    6)结束以后用VTST script里面的dymmatrix.py,创造freq.dat, modes_sqrt_amu.dat force_constants.dat effective_masses.dat...

  • $ python <path to>/vtstscripts/dymmatrix.py DISPLACECAR OUTCAR

  • 然后是第二大步:1)把第一步的结果 *.dat和CONTCAR 复制到另外一个文件夹:

  • $ cp *dat ../ && cp CONTCAR ../POSCAR.phon #在名为phonon那个folder里运行
    
    # !!!!注意原作者的.phon是前一步的结果, 根据知乎大神

     2) cd到另外一个文件夹

  • 3)像第一步里面comment out第一步的东西和把LEPSILON = .TRUE.,这样vasp就会算static dielectric matrix, 改完如下(抄作业的同学把INCAR-outside改名为INCAR就好

  • ! phonons
    !ICHAIN = 1      ! Run the dynamical matrix code
    ! IMAGES = M     ! Number of parallel images, if desired as in step 2 above; otherwise, do not add.
    !NSW = 25        ! (DOF/M)+1   Number of ionic steps
    !IBRION =   3    ! Tell VASP to run dynamics,
    !POTIM  = 0.0    ! with a time step of zero (ie, do nothing)
    !ISYM = 0        ! Make sure that symmetry is off,
    !EDIFFG = -1E-10 ! and that vasp does not quit due to low forces
    
    LEPSILON=.TRUE.
    ISYM=0

    4) 打开freq.dat, 那些标着1的都是振模的虚部,mark一下有多少虚部和多少实部,然后去no_scheduler.sh或者其他用HPC slurm交作业的到.slurm文件里改那个VASP_RAMAN_PARAMS参数

  • export VASP_RAMAN_PARAMS='4_24_2_0.01'
    
    # 抄作业的同学看我的no_scheduler.sh里面
    # 4可以换成freq.dat里面的虚部
    # 24换成最后一个振膜,例如有24行
    # 2不能改,原作写到只支持second derivative
    # 0.01是resolution,可选改

    5)最后就是交作业

  • # 记得根据你自己的电脑改 export VASP_RAMAN_RUN='mpirun -np X vasp_vtst_std'里的X
    $ bash no_scheduler.sh

    结果在vasp_raman.dat里,计算的是峰值和位置,如果要把它变得像光谱一点 

    6)plot光谱就参照我的gnuplot.sh或者原作者另外一个文件夹里的broaden.py加上个lorentzian(做实验的知道raman光谱一般用lorentzian来fit而不是gaussian)

  • 大功告成!

  • 有错的地方希望有大臣纠正, 用这个方法算出来的数值跟实验数值比较接近,不知道那些ENCUT 和温度之类的有没有影响,在验证中,另外还有一个方法算拉曼图谱的用vasp+phonopy+phono3py算了好久都没有跟实验数据对上,希望有大神指点迷津

        *其实这一整页是可以用一个python或者bash script运行的,迟点写好了分享

有关用VASP+VTST计算Raman光谱 (抛砖引玉)的更多相关文章

  1. ruby-on-rails - 使用一系列等级计算字母等级 - 2

    这里是Ruby新手。完成一些练习后碰壁了。练习:计算一系列成绩的字母等级创建一个方法get_grade来接受测试分数数组。数组中的每个分数应介于0和100之间,其中100是最大分数。计算平均分并将字母等级作为字符串返回,即“A”、“B”、“C”、“D”、“E”或“F”。我一直返回错误:avg.rb:1:syntaxerror,unexpectedtLBRACK,expecting')'defget_grade([100,90,80])^avg.rb:1:syntaxerror,unexpected')',expecting$end这是我目前所拥有的。我想坚持使用下面的方法或.join,

  2. 计算机毕业设计ssm+vue基本微信小程序的小学生兴趣延时班预约小程序 - 2

    项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU

  3. ruby - 如何计算 Liquid 中的变量 +1 - 2

    我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我

  4. ruby - 使用 Ruby,计算 n x m 数组的每一列中有多少个 true 的简单方法是什么? - 2

    给定一个nxmbool数组:[[true,true,false],[false,true,true],[false,true,true]]有什么简单的方法可以返回“该列中有多少个true?”结果应该是[1,3,2] 最佳答案 使用转置得到一个数组,其中每个子数组代表一列,然后将每一列映射到其中的true数:arr.transpose.map{|subarr|subarr.count(true)}这是一个带有inject的版本,应该在1.8.6上运行,没有任何依赖:arr.transpose.map{|subarr|subarr.in

  5. arrays - 计算数组中的匹配元素 - 2

    给定两个大小相等的数组,如何找到不考虑位置的匹配元素的数量?例如:[0,0,5]和[0,5,5]将返回2的匹配项,因为有一个0和一个5共同;[1,0,0,3]和[0,0,1,4]将返回3的匹配项,因为0有两场,1有一场;[1,2,2,3]和[1,2,3,4]将返回3的匹配项。我尝试了很多想法,但它们都变得相当粗糙和令人费解。我猜想有一些不错的Ruby习惯用法,或者可能是一个正则表达式,可以很好地回答这个解决方案。 最佳答案 您可以使用count完成它:a.count{|e|index=b.index(e)andb.delete_at

  6. ruby-on-rails - 如何计算 Ruby/Rails 中 JSON 对象的数量 - 2

    Ruby中如何“一般地”计算以下格式(有根、无根)的JSON对象的数量?一般来说,我的意思是元素可能不同(例如“标题”被称为其他东西)。没有根:{[{"title":"Post1","body":"Hello!"},{"title":"Post2","body":"Goodbye!"}]}根包裹:{"posts":[{"title":"Post1","body":"Hello!"},{"title":"Post2","body":"Goodbye!"}]} 最佳答案 首先,withoutroot代码不是有效的json格式。它将没有包

  7. ruby - 如何计算自 Ruby 中给定日期以来的周数? - 2

    目标我正在尝试计算自给定日期以来周的距离,而无需跳过任何步骤。我更喜欢用普通的Ruby来做,但ActiveSupport无疑是一个可以接受的选择。我的代码我写了以下内容,这似乎可行,但对我来说似乎还有很长的路要走。require'date'DAYS_IN_WEEK=7.0defweeks_sincedate_stringdate=Date.parsedate_stringdays=Date.today-dateweeks=days/DAYS_IN_WEEKweeks.round2endweeks_since'2015-06-15'#=>32.57ActiveSupport的#weeks

  8. 最新版人脸识别小程序 图片识别 生成二维码签到 地图上选点进行位置签到 计算签到距离 课程会议活动打卡日常考勤 上课签到打卡考勤口令签到 - 2

    技术选型1,前端小程序原生MINA框架cssJavaScriptWxml2,管理后台云开发Cms内容管理系统web网页3,数据后台小程序云开发云函数云开发数据库(基于MongoDB)云存储4,人脸识别算法基于百度智能云实现人脸识别一,用户端效果图预览老规矩我们先来看效果图,如果效果图符合你的需求,就继续往下看,如果不符合你的需求,可以跳过。1-1,登录注册页可以看到登录页有注册入口,注册页如下我们的注册,需要管理员审核,审核通过后才可以正常登录使用小程序1-2,个人中心页登录成功以后,我们会进入个人中心页我们在个人中心页可以注册人脸,因为我们做人脸识别签到,需要先注册人脸才可以进行人脸比对,进

  9. ruby - 如何计算两个字符串共有的字符数? - 2

    如何计算两个字符串之间的字符交集?例如(假设我们有一个名为String.intersection的方法):"abc".intersection("ab")=2"hello".intersection("hallo")=4好的,男孩女孩们,感谢你们的大量反馈。更多示例:"aaa".intersection("a")=1"foo".intersection("bar")=0"abc".intersection("bc")=2"abc".intersection("ac")=2"abba".intersection("aa")=2一些补充说明:维基百科定义intersection如下:Int

  10. python - 如何计算文件中唯一字符的数量? - 2

    给定一个包含各种语言字符的UTF-8文件,我如何计算它包含的唯一字符的数量,同时排除选定数量的符号(例如:“!”、“@”、"#",".")从这个算起? 最佳答案 这是一个bash解决方案。:)bash$perl-CSD-ne'BEGIN{$s{$_}++forsplit//,q(!@#.)}$s{$_}++||$c++forsplit//;END{print"$c\n"}'*.utf8 关于python-如何计算文件中唯一字符的数量?,我们在StackOverflow上找到一个类似的问题

随机推荐