[Pw_forum] Plot phonon dispersion

Marcel Mohr marcel at physik.tu-berlin.de
Wed Dec 5 18:51:35 CET 2007


Dear list members,

i have written a small python /script-program to convert the matdyn output 
matdyn.freq into a two-column format that I want to share with you.
This can easily be plotted by xmgrace, gnuplot etc.

For simplicity I took the absolute value of the k-vector, so one has to 
modify the 1st column for non-cubic systems.

Best
Marcel


I just see, my email program is wrapping lines, so below has to be 
modified, the attachment works.



------> program starts here

# small program to convert freq-Output into two-column dat
# written by Marcel Mohr
# usage: python mat2agr.py freqfile > phonons.dat
# Caution:# in the output, the absolute value of k-vector is taken -> 1,1,1 
#->sqrt(3)
#
import sys,string
import os
import math
import re

#
def flatten(lst):
         for elem in lst:
                 if type(elem) in (tuple, list):
                         for i in flatten(elem):
                                 yield i
                 else:
                         yield elem

atom=[]
steps= 0
kk=0
input = open(sys.argv[1],'r')
line=input.readline()
#print line
bla=line.split()
if bla==[]:
         pass
elif bla[1]=="nbnd=":
# komma muss weg
         bla[2]=re.compile( "," ).sub( '', bla[2] )
         nbnd=string.atoi(bla[2])
#       print nbnd
         nkpt=string.atoi(bla[4])
#       print nkpt

# Anzahl der Lines sind jetzt nktp + nkpt *(nbnd/6)
lines=input.readlines()
for n, bla in enumerate(lines):
         dummy=0
# bloedes \n am Ende weg
for i in range(n+1):
         lines[i]=re.compile( "\n" ).sub( '' , lines[i] )
# Wir haben jetzt die Anzahl der Linien, Jetzt die Anzahl pro k-punkt 
#(nprok)
# 6 pro Spalte (also nbnd/6), falls nicht durch 6 teilbar, muss man plus 1 
#zahlen
if (nbnd%6)==0:
         nprok=nbnd/6
else:
         nprok=nbnd/6 + 1

kabslist=[]
freqlist=[]
for j in range(nkpt):
         klist=[]
         #linnum: only lines in which k-point info is stored
         linnum=j*(nprok+1)
         kptstr=lines[linnum].split()
         klist=[]
         for i in range(3):
                 k=string.atof(kptstr[i])
                 klist.append(k)
         kabslist.append( math.sqrt( klist[0]**2 + klist[1]**2 + 
klist[2]**2 ))
         freqK=[]
         for i in range(nprok):
                 freqK.append( lines[linnum+1+i].split())
         dummy=list(flatten(freqK))
         freqlist.append(dummy)

#output
for i in range(nbnd):
         for j in range(nkpt):
                 print ("%9.9f    %9.9f") %(kabslist[j],string.atof( 
freqlist[j][i]) )
         print " "
         print " "
-------------- next part --------------
A non-text attachment was scrubbed...
Name: mat2agr.py
Type: text/x-python
Size: 1804 bytes
Desc: 
Url : http://www.democritos.it/pipermail/pw_forum/attachments/20071205/0d15e3c5/attachment.py 


More information about the Pw_forum mailing list