24小时热门版块排行榜    

查看: 2294  |  回复: 9
【奖励】 本帖被评价8次,作者hakuna增加金币 6.8

hakuna

木虫 (知名作家)


[资源] 【分享】code for ploting VASP output__from Panda Blog已有1人参与

此内容转自panda的博客,尽量保持原形,有兴趣的话自己研究吧

Plotting the EIGNEVAL file
Now that we have written the module we simply import it like this:
import eigenval_reader as er
Now the entirety of the source code is simply import statements and matplotlib directives. In other words, all of the programming logic is self-contained within the module, which can be used again and again, from the command line or within your ide of choice. See how much cleaner things are when the logic is separated on a lower-level and the plotting is handled on a higher level? Modules are a really nice way to accomplish whatever task you wish to accomplish in Python. In fact, matplotlib, numpy, and scipy are just huge modules that we interact with in Python at a higher level just as the very simple module given in the previous post that we interact with in the source code below!
**************
CODE:
#!/usr/bin/python  
import sys  
from math import *
import numpy  
from numpy import *
from numpy import dot  
import csv  
import re  
from matplotlib import *
from pylab import plot, show, ylim, xlim, yticks, xlabel, ylabel  
import matplotlib.path as mpath  
import matplotlib.patches as mpatches  
import matplotlib.pyplot as plt  
from matplotlib.font_manager import FontProperties  
import matplotlib  
import eigenval_reader as er  
if (__name__ == '__main__'):  
     filename = 'EIGENVAL'
     if len(sys.argv) == 2:  
        filename = sys.argv[1]  
     else:  
         print("Defaulting filename to 'EIGENVAL', if you wish to specify another filename on the command prompt do it like this: plot_eigenval.py myfilename")  
   
    parser = er.EigenvalParser()  
    kpoints = parser.parse(filename)  
    rcParams['lines.linewidth'] = 4.0
    rcParams['font.weight'] = "heavy"
    rcParams['axes.linewidth'] = 4.0

    rcParams['xtick.major.size'] = 0.0
     rcParams['xtick.minor.size'] = 0.0

     rcParams['ytick.major.size'] = 0.0

     rcParams['ytick.minor.size'] = 0.0   

    for band in er.get_bands(kpoints):  
         plot(range(0,len(band)), band, 'k')  
     xlim(0,60)  
    ylim(-8,4)  
     plt.title("Band Structure")  
     xlabel("K-Points")  
     ylabel("Energy(eV)")  
     plt.show()


****************

Writing a Python Module for the VASP EIGENVAL file
Sometimes you will have tasks that need to be performed again and again. In this case, it is oftentimes advantageous to write a module. In python, modules are imported just like libraries. By separating your code in this manner, you benefit in flexibility as well as in producing code that is reusable. I have written a module for parsing the VASP EIGENVAL file, but you can write a module for anything you wish.
***************
CODE:
import re  

02   

03 class EigenvalReader:  

04     def __init__(self):  

05         self.listeners = {}  

06   

07     def add_listener(self, event_name, callback):  

08         if (not self.listeners.has_key(event_name)):  

09             self.listeners[event_name] = []  

10         self.listeners[event_name].append(callback)  

11   

12     def __raise__(self, event_name, args):  

13         if not self.listeners.has_key(event_name):  

14             return

15   

16         callbacks = self.listeners[event_name]  

17         if callbacks != None:  

18             for c in callbacks:  

19                 c(self, args)  

20   

21     def read_file(self, eigen_file):  

22         f = open(eigen_file)  

23         for i in range(0,5):  

24             f.readline()  

25   

26         throwaway, kpoint_count, band_count = f.readline().split()  

27         self.__raise__('ON_KPOINT_COUNT', kpoint_count)  

28         self.__raise__('ON_BAND_COUNT', band_count)  

29   

30         # Blank Line  

31         f.readline()  

32   

33         # End of File (EOF)  

34         eof = False

35         while (not eof):  

36             line = f.readline()  

37             if line == None:  

38                 eof = True

39                 continue

40             try:  

41                 x,y,z,weight = line.split()  

42                 self.__raise__('ON_KPOINT', { "x": x, "y": y, "z": z, "weight": weight })  

43             except:  

44                 print('failed to split line: ' + line)  

45   

46             for i in range(0, int(band_count)):  

47                 line = f.readline()  

48                 try:  

49                     id, energy = line.split()  

50                     self.__raise__('ON_BAND', { 'id': id, 'energy': float(energy) })  

51                 except:  

52                     print('failed to get band info from: ' + line)  

53   

54             line = f.readline()  

55             if line == '':  

56                 eof = True

57   

58 class EigenvalParser:  

59     def parse(self, filename):  

60         self.kpoints = []  

61         reader = EigenvalReader()  

62         reader.add_listener('ON_KPOINT', self.__on_kpoint__)  

63         reader.add_listener('ON_BAND', lambda reader, band: self.kpoints[-1]['bands'].append(band))  

64   

65         reader.read_file(filename)  

66   

67         return self.kpoints  

68   

69     def __on_kpoint__(self, reader, kpoint):  

70         kpoint['bands'] = []  

71         self.kpoints.append(kpoint)  

72   

73 def get_bands(kpoints):  

74     bands = [[] for b in range(0,len(kpoints[0]['bands']))]  

75   

76     for kp in kpoints:  

77         kp_bands = kp['bands']  

78         for kp_band in kp_bands:  

79             bands[int(kp_band['id']) - 1].append(kp_band['energy'])  

80   

81     return bands


*****************
In this example, first the re module in imported, as regular expression pattern matching is typically the easiest way to parse a file in Python. After that a class is defined. In that class, we define an event handler. After that, the file is opened and parsed using the re module. The “try” “except” clauses are included so that if the arrays are not loaded into memory then an exception is thrown and an error is printed. It is always a good idea to add break points like this in your code. The class EignevalReader reads the file and the class EignevalParser parses the file and splits the file data neatly into arrays. The next post will deal with using this module to plot the EIGENVAL file.


Parsing VASP PROCAR file
CODE:
#!/usr/bin/python  

002 import sys  

003 from math import *

004 import numpy  

005 from numpy import *

006 from numpy import dot  

007 import csv  

008 import re  

009 from matplotlib import *

010 from pylab import plot, show, ylim, xlim, yticks, xlabel, ylabel  

011 import matplotlib.path as mpath  

012 import matplotlib.patches as mpatches  

013 import matplotlib.pyplot as plt  

014 from matplotlib.font_manager import FontProperties  

015 import matplotlib  

016   

017 def getMeta(line):  

018  metaMatcher = re.compile("#[^:]+:([^#]+)#[^:]+:([^#]+)#[^:]+:(.+)$")  

019  m = metaMatcher.match(line)  

020  kpointsCount = int(m.group(1))  

021  bandsCount = int(m.group(2))  

022  ionsCount = int(m.group(3))  

023  return (kpointsCount, bandsCount, ionsCount)  

024   

025 def readKPoint(stream, bandsCount, ionsCount):  

026  kpointHeaderMatcher = re.compile("\s*k-point[^:]+:\s*([^\s]+)\s*([^\s]+)\s*([^\s]+)")  

027  line = stream.readline()  

028  while (not kpointHeaderMatcher.match(line)):  

029  line = stream.readline()  

030  kpointHeaderLine = line  

031  m = kpointHeaderMatcher.match(kpointHeaderLine)  

032  kpoint_x = float(m.group(1))  

033  kpoint_y = float(m.group(2))  

034  kpoint_z = float(m.group(3))  

035   

036  bandHeaderMatcher = re.compile(".+energy\s+([^#]+)# occ\.\s(.+)$")  

037   

038  bands = []  

039  for i in range(0,bandsCount):  

040  line = stream.readline()  

041  while (not bandHeaderMatcher.match(line)):  

042  line = stream.readline()  

043  bandHeaderLine = line  

044  energy = float(bandHeaderMatcher.match(line).group(1))  

045   

046  orbitalHeaderMatcher = re.compile("ion\s+s.+tot$")  

047  line = stream.readline()  

048  while (not orbitalHeaderMatcher.match(line)):  

049  line = stream.readline()  

050  orbitalHeaderLine = line  

051   

052  orbitals = []  

053  for j in range(0,ionsCount):  

054  line = stream.readline()  

055  orbitalAssignmentText = line.split()  

056  orbitals.append(orbitalAssignmentText)  

057   

058  bands.append({ "energy": energy,"orbitals": orbitals })  

059  return { "kpoint_x": kpoint_x, "kpoint_y": kpoint_y, "kpoint_z": kpoint_z, "bands": bands }  

060   

061 def readFile(procar):  

062  f = open(procar, "r")  

063  f.readline() # throwaway  

064  metaLine = f.readline() # metadata  

065  kpointsCount, bandsCount, ionsCount = getMeta(metaLine)  

066  kpoints = []  

067  for i in range(0,kpointsCount):  

068  kpoint = readKPoint(f, bandsCount, ionsCount)  

069  kpoints.append(kpoint)  

070  return (kpoints, bandsCount, ionsCount)  

071   

072 kpoints, bandsCount, ionsCount = readFile("/Working/Eclipse/plotting/Molecule2/PROCAR")  

073 kpointsCount = len(kpoints)  

074   

075 orbitalNames = ["s","py","pz","px","dxy","dyz","dz2","dxz","dx2-y2"]  

076   

077 #print "band,ion,s,py,pz,px,dxy,dyz,dz2,dxz,dx2,tot,energy,kpoint_x,kpoint_y,kpoint_z"  

078 print "kpoint,band,ion,energy,character"

079   

080 energies = []  

081 kpointNums = []  

082 Ef = -4.41823711

083   

084 for i in range(0,bandsCount):  

085  energies.append([])  

086   

087 kpointNum = 1

088 for kpoint in kpoints:  

089  bandNum = 0

090  for band in kpoint["bands"]:  

091  for ion in band["orbitals"]:  

092  character = ""  

093  for i in range(1,9):  

094  if float(ion[i]) > 0:  

095  character += orbitalNames[i-1] + " "

096  kpointNums.append(kpointNum)  

097  energies[bandNum].append(band["energy"]-Ef)  

098  bandNum += 1

099  kpointNum += 1

100   

101 rcParams['lines.linewidth'] = 4.0

102 rcParams['font.weight'] = "heavy"

103 rcParams['axes.linewidth'] = 4.0

104 rcParams['xtick.major.size'] = 0.0

105 rcParams['xtick.minor.size'] = 0.0

106 rcParams['ytick.major.size'] = 0.0

107 rcParams['ytick.minor.size'] = 0.0

108   

109 for i in range(0,bandsCount):  

110  plot(range(0,len(energies[i])),energies[i], 'k')  

111 xlim(0,60)  

112 ylim(-8,4)  

113 plt.title("Band Structure")  

114 xlabel("K-Points")  

115 ylabel("Energy(eV)")  

116 plt.show()

******************
VASP (Vienna Ab-Initio Simulation Package) is a plane wave density functional theory code. When the tag LORBIT is set in the INCAR file, the PROCAR file is generated. The PROCAR file contains the site-projected character of the orbitals (spherical harmonics used). The code above illustrates how to parse and plot the PROCAR file using Python and matplotlib.
Again, the first few lines of code are just the import statements and formatting for matplotlib. The re module is used, in which regular expression pattern matching searches the file for matching characters. More information regarding Python’s re module can be found here. The code could be cleaned up a bit, currently you must manually enter the Fermi energy (it is not parsed from the DOSCAR file), you must manually enter the working directory in which the file resides, etc. Overall though it gets the job done quite nicely with very little coding.
One thing to remember is that depending on which direction you are integrating in the Brillouin Zone, because depending on the crystal structure a scaling length may have to be implemented. You could do this programmatically, but I find it easier to apply the scaling length via pixel scaling, using an image manipulation program like GIMP.

[ Last edited by hakuna on 2010-10-22 at 10:16 ]
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hakuna

木虫 (知名作家)


接上贴——GW Band Structure Plots


zxzj05(金币+1):奖励交流!! 2010-10-22 14:27:03
To obtain band structure plots from the GW method, first you have to perform a DFT calculation. The INCAR file I used for DFT on Si looks like this:

ISTART = 0
ISYM = 0
ICHARG = 2
ISMEAR = 0
SIGMA = 0.1
LORBIT = 11
NSW = 200
IBRION = 2
ISIF = 3
EDIFF = 0.0001
EDIFFG = -0.01


KPOINTS file for the run is:

Monkhorst Pack
0
Gamma
4 4 4
0 0 0

POSCAR file is:

Si
5.38936000000000
0.5000000000000000    0.5000000000000000    0.0000000000000000
0.0000000000000000    0.5000000000000000    0.5000000000000000
0.5000000000000000    0.0000000000000000    0.5000000000000000
2
Direct
0.0000000000000000  0.0000000000000000  0.0000000000000000
0.2500000000000000  0.2500000000000000  0.2500000000000000

POTCAR file is supplied with VASP 5.2, remember to use paw pseudopotentials so that in the band structure calculation the Wigner-Seitz radius for Si need not be directly specified in INCAR.

After this run completes you are ready to perform the HF-type (HSE06) calculation. Change the INCAR file to:

ISTART = 1
ICHARG = 2
EDIFF = 0.0001
EDIFFG = -0.01
ENCUT = 400
ENAUG = 800
LREAL = .FALSE.
LWAVE = .TRUE.
LCHARG = .TRUE.
NELM = 200
NSW = 0
IBRION = -1
LMAXMIX = 4
ISMEAR = 0
SIGMA = 0.1
NSIM = 4
IALGO = 48
ISYM = 0
LHFCALC = .TRUE.
HFSCREEN = 0.2
ALGO = Damped
TIME = 0.4
ENCUTFOCK = 0
NKRED = 2
AEXX = 0.25

Keep the other files constant for this run (e.g. KPOINTS, POSCAR, POTCAR need not be changed).

Once this run has completed, add to the bottom of the INCAR file from the HSE06 calculation:

LOPTICS = .TRUE.

This step calculates the dielectric matrix

Once this run has completed, change

ALGO = Damped

to

ALGO = GWo

and

ICHARG = 2

to

ICHARG = 11

and add:

NOMEGA = 50
ENCUTGW = 100
LORBIT = 11

and change the KPOINTS file to:

k-points along high symmetry lines
20 ! 20 intersections
Line-mode
rec
0 0 0 ! gamma
0.5 0.0 0 ! X
0.5 0.0 0 ! X
0.5 0.5 0.0 ! M
0.5 0.5 0.0 ! M
0.0 0.0 0.0 ! gamma
0.0 0.0 0.0 ! gamma
0.5 0.5 0.0 ! M
0.5 0.5 0.0 ! M
0.5 0.5 0.5 ! R
0.5 0.5 0.5 ! R
0.0 0.0 0.0 ! gamma

These values are the points of high symmetry along the lines of high symmetry within the first Brillouin Zone of the Si unit cell structure in reciprocal space. And that’s it! Once complete you can plot the PROCAR, EIGENVAL, and DOSCAR files from the output of this run as described in the previous posts. The band structure plot produced from the plotting utility is shown below.

2楼2010-10-22 10:20:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

guitar2033

至尊木虫 (职业作家)


★★★★★ 五星级,优秀推荐

good!
3楼2010-10-22 10:50:01
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

★★★★★ 五星级,优秀推荐

很好的资源!!!!
4楼2010-10-22 14:27:28
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dxblt

木虫 (小有名气)


★★★★★ 五星级,优秀推荐

VERY GOOD!
7楼2011-05-11 15:49:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiezhong

银虫 (小有名气)


★★★★★ 五星级,优秀推荐

引用回帖:
Originally posted by hakuna at 2010-10-22 10:20:37:
To obtain band structure plots from the GW method, first you have to perform a DFT calculation. The INCAR file I used for DFT on Si looks like this:

ISTART = 0
ISYM = 0
ICHARG = 2
ISMEAR = 0
...

我有个疑问,在进行一、perform a DFT calculation时
(1)为什么不进行弛豫呢?
(2)LORBIT = 11应该是在输出DOSCAR,这里应该不需要DOSCAR吧
二、在After this run completes you are ready to perform the HF-type (HSE06) calculation后
(3)ISYM = 0,为什么设置为0呢
(4)这时发现LORBIT = 11没有了
三、计算完HSE06后
(4)LORBIT = 11又有了,不是计算band的吗,为什么输出DOSCAR吗
真心感谢您,这些我真有些不明白
8楼2011-06-22 11:36:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

maomao7910

金虫 (小有名气)


★★★ 三星级,支持鼓励

听说HSE06计算对半导体带隙就有一定的改善。为何我用里面的设置,没发现带隙变寬呢。什么原因?
还有就是用GW0计算时用上面的KPOINTS时,运行总提示
error in IBZKPT_HF: two k-points are equivalent           1          60
  this will cause problems in the HF routine
9楼2011-06-29 22:06:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wangdekai

禁虫 (初入文坛)

本帖内容被屏蔽

10楼2018-08-31 22:50:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
简单回复
aylayl085楼
2010-10-22 15:06   回复  
 谢谢分享
xiangzju6楼
2011-03-28 19:16   回复  
五星好评  
相关版块跳转 我要订阅楼主 hakuna 的主题更新
☆ 无星级 ★ 一星级 ★★★ 三星级 ★★★★★ 五星级
普通表情 高级回复(可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[硕博家园] 求助下载文献网站 +5 输入用户名.. 2025-01-08 9/450 2025-01-09 18:06 by ca0yan9
[考博] 寻求电化学方向博导 +3 ygj要努力 2025-01-06 6/300 2025-01-09 15:44 by Q23333Qq
[考博] 本硕双非,研究方向为动态高分子及自修复材料方向。有一篇Angew一作(已接收) +4 王氏无敌 2025-01-06 7/350 2025-01-09 13:59 by 王氏无敌
[教师之家] 咨询一下,为什么越小的学校里面的教授说话口气越大? +11 akslis2024 2025-01-06 16/800 2025-01-09 10:30 by cwwqt
[教师之家] 郁闷 +6 cwwqt 2025-01-04 9/450 2025-01-09 10:12 by cwwqt
[材料综合] 超声仪器发热怎么办 50+4 毕生所学 2025-01-06 14/700 2025-01-09 10:06 by bear2007
[论文投稿] 个人如何查询完整中科院分区表? +4 XMCMENGLI 2025-01-08 9/450 2025-01-09 09:44 by xs74101122
[论文投稿] 手稿被退回给作者了 5+3 撞了怀. 2025-01-04 12/600 2025-01-08 18:56 by zhmc
[教师之家] 高校的圈子是不是太封闭,一辈子都在比谁得到的小红花多 +10 akslis2024 2025-01-06 12/600 2025-01-08 18:34 by sunbinbin770713
[考博] 25应届生申博~环境院或者化工院 +5 九天揽月? 2025-01-04 5/250 2025-01-08 10:58 by 老王146279
[论文投稿] Mxxx, Fxxx等期刊社多个期刊被芬兰国认定不具学术水平 +6 chiangscn 2025-01-05 7/350 2025-01-08 08:46 by 六两废铜
[论文投稿] Rare metals投稿求助 10+3 hngo 2025-01-02 13/650 2025-01-07 21:46 by 蓓蕾花开
[教师之家] 咨询一下,寒假写本子过好年的概率大不大 +5 akslis2024 2025-01-05 7/350 2025-01-07 08:57 by Quakerbird
[教师之家] 如何选择研究生 +10 polairs 2025-01-04 12/600 2025-01-07 08:11 by 释弥子
[论文投稿] 论文进入proof阶段,说按照special issue处理,选择不同意,会被拒吗? 500+3 zhangxi0816 2025-01-03 14/700 2025-01-06 11:09 by 多听多看多学
[论文投稿] OSA论文投稿求助 5+3 19831613600 2025-01-04 6/300 2025-01-06 08:07 by 19831613600
[教师之家] 论文辅导咨询 +3 zzz-yy 2025-01-05 5/250 2025-01-05 17:17 by 走了002
[教师之家] 国自然结题请教各位 +6 原因在哪里 2025-01-03 6/300 2025-01-05 08:56 by Quakerbird
[论文投稿] 审稿意见回复求助 10+3 bitbing 2025-01-02 5/250 2025-01-04 11:01 by TopEdit
[论文投稿] 机床与液压投稿 1+3 buchumen 2025-01-03 3/150 2025-01-04 10:26 by nono2009
信息提示
请填处理意见