forked from rubel75/VASPtools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprPROCAR.m
128 lines (125 loc) · 3.85 KB
/
prPROCAR.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
% Octave program for reading PROCAR file from VASP
% It plots the DOS and computes the localization (participation ratio)
%
% Oleg Rubel (Jan 2017)
%% User-defined parameters
fname1 = "PROCAR" % PDOS file
fname2 = "POSCAR" % structure file
%% Read file POSCAR
if not( exist(fname2,"file") )
msg = ["File " fname2 " not found"];
error(msg)
else
msg = ["File " fname2 " found"];
display(msg);
end
fid = fopen (fname2);
for i=1:7 % read heading
txt = fgetl (fid);
if i == 6
txt = strtrim(txt);
ionlbl = strsplit(txt) % ion lables
elseif i == 7
txt = strtrim(txt);
ionnum = str2num(txt) % number of ions
end
end
fclose (fid);
if length(ionlbl) ~= length(ionnum) % check the same number of atoms types
display(ionnum); display(ionnum);
msg = ["Number of ion lables is not equal to the number of ion types"];
error(msg);
end
%% Read file PROCAR
if not( exist(fname1,"file") )
msg = ["File " fname1 " not found"];
error(msg)
else
msg = ["File " fname1 " found"];
display(msg);
end
kptot = 0;
bntot = 0;
iontot = 0;
fid = fopen (fname1);
fid_out = fopen([fname1 "_PR"], 'w');
display("Reading the header started...");
for i=1:2 % read heading
txt = fgetl (fid)
if strfind(txt,"# of k-points:")
kptot = txt(strfind(txt,"# of k-points:")+14:strfind(txt,"# of bands:")-1);
kptot = str2num (kptot);
display("Total number of k-points:"); display(kptot);
end
if strfind(txt,"# of bands:")
bntot = txt(strfind(txt,"# of bands:")+11:strfind(txt,"# of ions:")-1);
bntot = str2num (bntot);
display("Number of bands per k-point:"); display(bntot);
end
if strfind(txt,"# of ions:")
iontot = txt(strfind(txt,"# of ions:")+11:end);
iontot = str2num (iontot);
display("Number of ions:"); display(iontot);
end
end
if any([kptot, bntot, iontot] == 0)
display([kptot, bntot, iontot]);
msg = "Error reading the heading. One of the values [kptot, bntot, iontot] not found.";
error(msg);
elseif iontot ~= sum(ionnum)
msg = "Error: number of ions in PROCAR does not correspond to the number of ions in POSCAR"
error(msg);
else
display("... reading the header done");
end
% reding k-point
kpread = 0;
bnread = 0;
bnbins = int32(linspace(1,bntot,100)); % 100 bins for weighting bar
while (! feof (fid) ) % loop untill the end of file
txt = fgetl (fid);
if strfind(txt,"k-point") % get info about kpoints
kpread = kpread+1;
kpcoord = txt(strfind(txt,":")+1:strfind(txt,"weight")-1);
kpcoord = str2num (kpcoord);
kpwgt = txt(strfind(txt,"weight =")+8:end);
kpwgt = str2num (kpwgt);
display(["K-point " num2str(kpread) " of " num2str(kptot) ": " num2str(kpcoord) ", weight " num2str(kpwgt)]);
bnread = 0; % reset number of band read
end
if strfind(txt,"band") % get eigenvalues
eig = txt(strfind(txt,"energy")+6:strfind(txt,"# occ.")-1);
eig = str2num (eig);
end
if strfind(txt,"ion") % get densities per atoms
txt = strsplit(txt); % remove trailing whitespace
ncol = length(txt); % number of columns
rho = zeros(1,iontot);
for j = 1:iontot
txt = fgetl (fid); % read probabilities if finding an electron in the vicintity of specific atoms
txt = str2num(txt);
rho(j) = txt(end); % only last (total probability) value is important (others are s-, p-, etc. projections)
end
sum2rho = (sum(rho))^2;
sumrho2 = (sum(rho.^2));
if sum2rho ~= 0 % avoid x/0
pr = sumrho2/sum2rho;
else
pr = NaN;
end
fprintf(fid_out,"%f %f %f\n", eig, kpwgt, pr);
bnread = bnread + 1;
if any(bnbins==bnread) % update waitbar
printf(" progress %d%%\n", 100*bnread/bntot);
end
end
endwhile
fclose (fid);
fclose (fid_out);
if kpread < kptot
msg = ["Read " num2str(kpread) " from total of " num2str(kptot) " k-point"];
error(msg);
elseif kpread > kptot
msg = ["Read " num2str(kpread) " from total of " num2str(kptot) " k-point"];
error(msg);
end