mirror of
https://github.com/triqs/dft_tools
synced 2025-01-09 04:43:11 +01:00
Tidy up of symmetry
*changed map -> orb_map in symmetry to avoid using python keyword
This commit is contained in:
parent
628f774234
commit
b672839f83
@ -8,6 +8,7 @@ Substitutions:
|
|||||||
* read_symmetry_input -> convert_symmetry_input
|
* read_symmetry_input -> convert_symmetry_input
|
||||||
* Symm_corr -> symmcorr
|
* Symm_corr -> symmcorr
|
||||||
* gf_struct_corr -> gf_struct_sumk
|
* gf_struct_corr -> gf_struct_sumk
|
||||||
|
* n_s -> n_symm
|
||||||
|
|
||||||
internal substitutions:
|
internal substitutions:
|
||||||
Symm_par --> symmpar
|
Symm_par --> symmpar
|
||||||
|
@ -374,26 +374,26 @@ class Wien2kConverter(ConverterTools):
|
|||||||
R = ConverterTools.read_fortran_file(self,symm_file,self.fortran_to_replace)
|
R = ConverterTools.read_fortran_file(self,symm_file,self.fortran_to_replace)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
n_s = int(R.next()) # Number of symmetry operations
|
n_symm = int(R.next()) # Number of symmetry operations
|
||||||
n_atoms = int(R.next()) # number of atoms involved
|
n_atoms = int(R.next()) # number of atoms involved
|
||||||
perm = [ [int(R.next()) for i in xrange(n_atoms)] for j in xrange(n_s) ] # list of permutations of the atoms
|
perm = [ [int(R.next()) for i in xrange(n_atoms)] for j in xrange(n_symm) ] # list of permutations of the atoms
|
||||||
if SP:
|
if SP:
|
||||||
time_inv = [ int(R.next()) for j in xrange(n_s) ] # timeinversion for SO xoupling
|
time_inv = [ int(R.next()) for j in xrange(n_symm) ] # time inversion for SO coupling
|
||||||
else:
|
else:
|
||||||
time_inv = [ 0 for j in xrange(n_s) ]
|
time_inv = [ 0 for j in xrange(n_symm) ]
|
||||||
|
|
||||||
# Now read matrices:
|
# Now read matrices:
|
||||||
mat = []
|
mat = []
|
||||||
for in_s in xrange(n_s):
|
for i_symm in xrange(n_symm):
|
||||||
|
|
||||||
mat.append( [ numpy.zeros([orbits[orb][3], orbits[orb][3]],numpy.complex_) for orb in xrange(n_orbits) ] )
|
mat.append( [ numpy.zeros([orbits[orb][3], orbits[orb][3]],numpy.complex_) for orb in xrange(n_orbits) ] )
|
||||||
for orb in range(n_orbits):
|
for orb in range(n_orbits):
|
||||||
for i in xrange(orbits[orb][3]):
|
for i in xrange(orbits[orb][3]):
|
||||||
for j in xrange(orbits[orb][3]):
|
for j in xrange(orbits[orb][3]):
|
||||||
mat[in_s][orb][i,j] = R.next() # real part
|
mat[i_symm][orb][i,j] = R.next() # real part
|
||||||
for i in xrange(orbits[orb][3]):
|
for i in xrange(orbits[orb][3]):
|
||||||
for j in xrange(orbits[orb][3]):
|
for j in xrange(orbits[orb][3]):
|
||||||
mat[in_s][orb][i,j] += 1j * R.next() # imaginary part
|
mat[i_symm][orb][i,j] += 1j * R.next() # imaginary part
|
||||||
|
|
||||||
mat_tinv = [numpy.identity(orbits[orb][3],numpy.complex_)
|
mat_tinv = [numpy.identity(orbits[orb][3],numpy.complex_)
|
||||||
for orb in range(n_orbits)]
|
for orb in range(n_orbits)]
|
||||||
@ -419,6 +419,6 @@ class Wien2kConverter(ConverterTools):
|
|||||||
# Save it to the HDF:
|
# Save it to the HDF:
|
||||||
ar=HDFArchive(self.hdf_file,'a')
|
ar=HDFArchive(self.hdf_file,'a')
|
||||||
if not (symm_subgrp in ar): ar.create_group(symm_subgrp)
|
if not (symm_subgrp in ar): ar.create_group(symm_subgrp)
|
||||||
things_to_save = ['n_s','n_atoms','perm','orbits','SO','SP','time_inv','mat','mat_tinv']
|
things_to_save = ['n_symm','n_atoms','perm','orbits','SO','SP','time_inv','mat','mat_tinv']
|
||||||
for it in things_to_save: ar[symm_subgrp][it] = locals()[it]
|
for it in things_to_save: ar[symm_subgrp][it] = locals()[it]
|
||||||
del ar
|
del ar
|
||||||
|
@ -20,15 +20,12 @@
|
|||||||
#
|
#
|
||||||
################################################################################
|
################################################################################
|
||||||
|
|
||||||
|
|
||||||
import copy,numpy
|
import copy,numpy
|
||||||
import string
|
|
||||||
from types import *
|
from types import *
|
||||||
from pytriqs.gf.local import *
|
from pytriqs.gf.local import *
|
||||||
from pytriqs.archive import *
|
from pytriqs.archive import *
|
||||||
import pytriqs.utility.mpi as mpi
|
import pytriqs.utility.mpi as mpi
|
||||||
|
|
||||||
|
|
||||||
class Symmetry:
|
class Symmetry:
|
||||||
"""This class provides the routines for applying symmetry operations for the k sums.
|
"""This class provides the routines for applying symmetry operations for the k sums.
|
||||||
It contains the permutations of the atoms in the unti cell, and the corresponding
|
It contains the permutations of the atoms in the unti cell, and the corresponding
|
||||||
@ -38,18 +35,19 @@ class Symmetry:
|
|||||||
"""Initialises the class.
|
"""Initialises the class.
|
||||||
Reads the permutations and rotation matrizes from the file, and constructs the mapping for
|
Reads the permutations and rotation matrizes from the file, and constructs the mapping for
|
||||||
the given orbitals. For each orbit a matrix is read!!!
|
the given orbitals. For each orbit a matrix is read!!!
|
||||||
SO: Flag for SO coupled calculations.
|
SO: Flag for spin-orbit coupling.
|
||||||
SP: Spin polarisation yes/no
|
SP: Flag for spin polarisation.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
assert type(hdf_file)==StringType,"hdf_file must be a filename"; self.hdf_file = hdf_file
|
assert type(hdf_file) == StringType, "hdf_file must be a filename"
|
||||||
things_to_read = ['n_s','n_atoms','perm','orbits','SO','SP','time_inv','mat','mat_tinv']
|
self.hdf_file = hdf_file
|
||||||
|
things_to_read = ['n_symm','n_atoms','perm','orbits','SO','SP','time_inv','mat','mat_tinv']
|
||||||
for it in things_to_read: setattr(self,it,0)
|
for it in things_to_read: setattr(self,it,0)
|
||||||
|
|
||||||
if (mpi.is_master_node()):
|
if mpi.is_master_node():
|
||||||
#Read the stuff on master:
|
#Read the stuff on master:
|
||||||
ar = HDFArchive(hdf_file,'a')
|
ar = HDFArchive(hdf_file,'a')
|
||||||
if (subgroup is None):
|
if subgroup is None:
|
||||||
ar2 = ar
|
ar2 = ar
|
||||||
else:
|
else:
|
||||||
ar2 = ar[subgroup]
|
ar2 = ar[subgroup]
|
||||||
@ -62,81 +60,68 @@ class Symmetry:
|
|||||||
for it in things_to_read: setattr(self,it,mpi.bcast(getattr(self,it)))
|
for it in things_to_read: setattr(self,it,mpi.bcast(getattr(self,it)))
|
||||||
|
|
||||||
# now define the mapping of orbitals:
|
# now define the mapping of orbitals:
|
||||||
# self.map[iorb]=jorb gives the permutation of the orbitals as given in the list, when the
|
# self.orb_map[iorb] = jorb gives the permutation of the orbitals as given in the list, when the
|
||||||
# permutation of the atoms is done:
|
# permutation of the atoms is done:
|
||||||
self.n_orbits = len(self.orbits)
|
self.n_orbits = len(self.orbits)
|
||||||
|
self.orb_map = [ [0 for iorb in range(self.n_orbits)] for i_symm in range(self.n_symm) ]
|
||||||
self.map = [ [0 for iorb in range(self.n_orbits)] for in_s in range(self.n_s) ]
|
for i_symm in range(self.n_symm):
|
||||||
for in_s in range(self.n_s):
|
|
||||||
for iorb in range(self.n_orbits):
|
for iorb in range(self.n_orbits):
|
||||||
|
|
||||||
srch = copy.deepcopy(self.orbits[iorb])
|
srch = copy.deepcopy(self.orbits[iorb])
|
||||||
srch[0] = self.perm[in_s][self.orbits[iorb][0]-1]
|
srch[0] = self.perm[i_symm][self.orbits[iorb][0]-1]
|
||||||
self.map[in_s][iorb] = self.orbits.index(srch)
|
self.orb_map[i_symm][iorb] = self.orbits.index(srch)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def symmetrize(self,obj):
|
def symmetrize(self,obj):
|
||||||
|
|
||||||
assert isinstance(obj,list),"obj has to be a list of objects!"
|
assert isinstance(obj,list), "symmetry: obj has to be a list of objects."
|
||||||
assert len(obj)==self.n_orbits,"obj has to be a list of the same length as defined in the init"
|
assert len(obj) == self.n_orbits, "symmetry: obj has to be a list of the same length as defined in the init."
|
||||||
|
|
||||||
if (isinstance(obj[0],BlockGf)):
|
if isinstance(obj[0],BlockGf):
|
||||||
symm_obj = [ obj[i].copy() for i in range(len(obj)) ] # here the result is stored, it is a BlockGf!
|
symm_obj = [ obj[i].copy() for i in range(len(obj)) ] # here the result is stored, it is a BlockGf!
|
||||||
for iorb in range(self.n_orbits): symm_obj[iorb].zero() # set to zero
|
for iorb in range(self.n_orbits): symm_obj[iorb].zero() # set to zero
|
||||||
else:
|
else:
|
||||||
# if not a BlockGf, we assume it is a matrix (density matrix), has to be complex since self.mat is complex!
|
# if not a BlockGf, we assume it is a matrix (density matrix), has to be complex since self.mat is complex!
|
||||||
#symm_obj = [ numpy.zeros([self.orbits[iorb][3],self.orbits[iorb][3]],numpy.complex_) for iorb in range(self.n_orbits) ]
|
|
||||||
symm_obj = [ copy.deepcopy(obj[i]) for i in range(len(obj)) ]
|
symm_obj = [ copy.deepcopy(obj[i]) for i in range(len(obj)) ]
|
||||||
|
|
||||||
for iorb in range(self.n_orbits):
|
for iorb in range(self.n_orbits):
|
||||||
if (type(symm_obj[iorb])==DictType):
|
if type(symm_obj[iorb]) == DictType:
|
||||||
for ii in symm_obj[iorb]: symm_obj[iorb][ii] *= 0.0
|
for ii in symm_obj[iorb]: symm_obj[iorb][ii] *= 0.0
|
||||||
else:
|
else:
|
||||||
symm_obj[iorb] *= 0.0
|
symm_obj[iorb] *= 0.0
|
||||||
|
|
||||||
|
for i_symm in range(self.n_symm):
|
||||||
for in_s in range(self.n_s):
|
|
||||||
|
|
||||||
for iorb in range(self.n_orbits):
|
for iorb in range(self.n_orbits):
|
||||||
|
|
||||||
l = self.orbits[iorb][2] # s, p, d, or f
|
l = self.orbits[iorb][2] # s, p, d, or f
|
||||||
dim = self.orbits[iorb][3]
|
dim = self.orbits[iorb][3]
|
||||||
jorb = self.map[in_s][iorb]
|
jorb = self.orb_map[i_symm][iorb]
|
||||||
|
|
||||||
|
if isinstance(obj[0],BlockGf):
|
||||||
if (isinstance(obj[0],BlockGf)):
|
|
||||||
|
|
||||||
tmp = obj[iorb].copy()
|
tmp = obj[iorb].copy()
|
||||||
if (self.time_inv[in_s]): tmp << tmp.transpose()
|
if self.time_inv[i_symm]: tmp << tmp.transpose()
|
||||||
for bname,gf in tmp: tmp[bname].from_L_G_R(self.mat[in_s][iorb],tmp[bname],self.mat[in_s][iorb].conjugate().transpose())
|
for bname,gf in tmp: tmp[bname].from_L_G_R(self.mat[i_symm][iorb],tmp[bname],self.mat[i_symm][iorb].conjugate().transpose())
|
||||||
tmp *= 1.0/self.n_s
|
tmp *= 1.0/self.n_symm
|
||||||
symm_obj[jorb] += tmp
|
symm_obj[jorb] += tmp
|
||||||
|
|
||||||
else:
|
else:
|
||||||
|
|
||||||
if (type(obj[iorb])==DictType):
|
if type(obj[iorb]) == DictType:
|
||||||
|
|
||||||
for ii in obj[iorb]:
|
for ii in obj[iorb]:
|
||||||
if (self.time_inv[in_s]==0):
|
if self.time_inv[i_symm] == 0:
|
||||||
symm_obj[jorb][ii] += numpy.dot(numpy.dot(self.mat[in_s][iorb],obj[iorb][ii]),
|
symm_obj[jorb][ii] += numpy.dot(numpy.dot(self.mat[i_symm][iorb],obj[iorb][ii]),
|
||||||
self.mat[in_s][iorb].conjugate().transpose()) / self.n_s
|
self.mat[i_symm][iorb].conjugate().transpose()) / self.n_symm
|
||||||
else:
|
else:
|
||||||
symm_obj[jorb][ii] += numpy.dot(numpy.dot(self.mat[in_s][iorb],obj[iorb][ii].conjugate()),
|
symm_obj[jorb][ii] += numpy.dot(numpy.dot(self.mat[i_symm][iorb],obj[iorb][ii].conjugate()),
|
||||||
self.mat[in_s][iorb].conjugate().transpose()) / self.n_s
|
self.mat[i_symm][iorb].conjugate().transpose()) / self.n_symm
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
else:
|
else:
|
||||||
if (self.time_inv[in_s]==0):
|
if self.time_inv[i_symm] == 0:
|
||||||
symm_obj[jorb] += numpy.dot(numpy.dot(self.mat[in_s][iorb],obj[iorb]),self.mat[in_s][iorb].conjugate().transpose()) / self.n_s
|
symm_obj[jorb] += numpy.dot(numpy.dot(self.mat[i_symm][iorb],obj[iorb]),
|
||||||
|
self.mat[i_symm][iorb].conjugate().transpose()) / self.n_symm
|
||||||
else:
|
else:
|
||||||
symm_obj[jorb] += numpy.dot(numpy.dot(self.mat[in_s][iorb],obj[iorb].conjugate()),
|
symm_obj[jorb] += numpy.dot(numpy.dot(self.mat[i_symm][iorb],obj[iorb].conjugate()),
|
||||||
self.mat[in_s][iorb].conjugate().transpose()) / self.n_s
|
self.mat[i_symm][iorb].conjugate().transpose()) / self.n_symm
|
||||||
|
|
||||||
|
|
||||||
# Markus: This does not what it is supposed to do, check how this should work (keep for now)
|
# Markus: This does not what it is supposed to do, check how this should work (keep for now)
|
||||||
# if ((self.SO==0) and (self.SP==0)):
|
# if (self.SO == 0) and (self.SP == 0):
|
||||||
# # add time inv:
|
# # add time inv:
|
||||||
#mpi.report("Add time inversion")
|
#mpi.report("Add time inversion")
|
||||||
# for iorb in range(self.n_orbits):
|
# for iorb in range(self.n_orbits):
|
||||||
@ -148,7 +133,7 @@ class Symmetry:
|
|||||||
# symm_obj[iorb] /= 2.0
|
# symm_obj[iorb] /= 2.0
|
||||||
#
|
#
|
||||||
# else:
|
# else:
|
||||||
# if (type(symm_obj[iorb])==DictType):
|
# if type(symm_obj[iorb]) == DictType:
|
||||||
# for ii in symm_obj[iorb]:
|
# for ii in symm_obj[iorb]:
|
||||||
# symm_obj[iorb][ii] += numpy.dot(numpy.dot(self.mat_tinv[iorb],symm_obj[iorb][ii].conjugate()),
|
# symm_obj[iorb][ii] += numpy.dot(numpy.dot(self.mat_tinv[iorb],symm_obj[iorb][ii].conjugate()),
|
||||||
# self.mat_tinv[iorb].transpose().conjugate())
|
# self.mat_tinv[iorb].transpose().conjugate())
|
||||||
@ -158,9 +143,4 @@ class Symmetry:
|
|||||||
# self.mat_tinv[iorb].transpose().conjugate())
|
# self.mat_tinv[iorb].transpose().conjugate())
|
||||||
# symm_obj[iorb] /= 2.0
|
# symm_obj[iorb] /= 2.0
|
||||||
|
|
||||||
|
|
||||||
return symm_obj
|
return symm_obj
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -17,6 +17,7 @@ If you encounter any problem please report it on github!
|
|||||||
filename = sys.argv[1]
|
filename = sys.argv[1]
|
||||||
A = h5py.File(filename)
|
A = h5py.File(filename)
|
||||||
|
|
||||||
|
# Rename groups
|
||||||
old_to_new = {'SumK_LDA':'lda_input', 'SumK_LDA_ParProj':'lda_parproj_input',
|
old_to_new = {'SumK_LDA':'lda_input', 'SumK_LDA_ParProj':'lda_parproj_input',
|
||||||
'SymmCorr':'lda_symmcorr_input', 'SymmPar':'lda_symmpar_input', 'SumK_LDA_Bands':'lda_bands_input'}
|
'SymmCorr':'lda_symmcorr_input', 'SymmPar':'lda_symmpar_input', 'SumK_LDA_Bands':'lda_bands_input'}
|
||||||
|
|
||||||
@ -26,6 +27,7 @@ for old, new in old_to_new.iteritems():
|
|||||||
A.copy(old,new)
|
A.copy(old,new)
|
||||||
del(A[old])
|
del(A[old])
|
||||||
|
|
||||||
|
# Move output items from lda_input to lda_output
|
||||||
move_to_output = ['gf_struct_solver','map_inv','map',
|
move_to_output = ['gf_struct_solver','map_inv','map',
|
||||||
'chemical_potential','dc_imp','dc_energ','deg_shells',
|
'chemical_potential','dc_imp','dc_energ','deg_shells',
|
||||||
'h_field']
|
'h_field']
|
||||||
@ -36,6 +38,14 @@ for obj in move_to_output:
|
|||||||
A.copy('lda_input/'+obj,'lda_output/'+obj)
|
A.copy('lda_input/'+obj,'lda_output/'+obj)
|
||||||
del(A['lda_input'][obj])
|
del(A['lda_input'][obj])
|
||||||
|
|
||||||
|
# Rename variables
|
||||||
|
groups = ['lda_symmcorr_input','lda_symmpar_input']
|
||||||
|
|
||||||
|
for group in groups:
|
||||||
|
if group not in A.keys(): continue
|
||||||
|
print "Changing n_s to n_symm ..."
|
||||||
|
A[group].move('n_s','n_symm')
|
||||||
|
|
||||||
A.close()
|
A.close()
|
||||||
|
|
||||||
# Repack to reclaim disk space
|
# Repack to reclaim disk space
|
||||||
|
BIN
test/SrVO3.h5
BIN
test/SrVO3.h5
Binary file not shown.
Binary file not shown.
Loading…
Reference in New Issue
Block a user