3
0
mirror of https://github.com/triqs/dft_tools synced 2025-01-08 20:33:16 +01:00

block_structure: add corr_to_inequiv

This commit is contained in:
Gernot J. Kraberger 2018-09-07 14:40:43 +02:00 committed by Hermann Schnait
parent 2d48119876
commit bc78560ee1
6 changed files with 48 additions and 10 deletions

View File

@ -107,6 +107,7 @@ class BlockStructure(object):
sumk_to_solver=None, sumk_to_solver=None,
solver_to_sumk_block=None, solver_to_sumk_block=None,
deg_shells=None, deg_shells=None,
corr_to_inequiv = None,
transformation=None): transformation=None):
self.gf_struct_sumk = gf_struct_sumk self.gf_struct_sumk = gf_struct_sumk
self.gf_struct_solver = gf_struct_solver self.gf_struct_solver = gf_struct_solver
@ -114,6 +115,7 @@ class BlockStructure(object):
self.sumk_to_solver = sumk_to_solver self.sumk_to_solver = sumk_to_solver
self.solver_to_sumk_block = solver_to_sumk_block self.solver_to_sumk_block = solver_to_sumk_block
self.deg_shells = deg_shells self.deg_shells = deg_shells
self.corr_to_inequiv = corr_to_inequiv
self.transformation = transformation self.transformation = transformation
@property @property
@ -187,6 +189,24 @@ class BlockStructure(object):
return [{block: indices for block, indices in gfs} return [{block: indices for block, indices in gfs}
for gfs in self.gf_struct_sumk] for gfs in self.gf_struct_sumk]
@property
def inequiv_to_corr(self):
if self.corr_to_inequiv is None:
return None
N_solver = len(np.unique(self.corr_to_inequiv))
if self.gf_struct_solver is not None:
assert N_solver == len(self.gf_struct_solver)
assert sorted(np.unique(self.corr_to_inequiv)) == range(N_solver),\
"an inequivalent shell is missing in corr_to_inequiv"
return [self.corr_to_inequiv.index(icrsh)
for icrsh in range(N_solver)]
@inequiv_to_corr.setter
def inequiv_to_corr(self, value):
if value is None:
return
assert self.inequiv_to_corr == value, "Trying to set incompatible inequiv_to_corr"
@property @property
def effective_transformation_sumk(self): def effective_transformation_sumk(self):
trans = copy.deepcopy(self.transformation) trans = copy.deepcopy(self.transformation)
@ -285,7 +305,8 @@ class BlockStructure(object):
solver_to_sumk = copy.deepcopy(solver_to_sumk), solver_to_sumk = copy.deepcopy(solver_to_sumk),
sumk_to_solver = solver_to_sumk, sumk_to_solver = solver_to_sumk,
solver_to_sumk_block = s2sblock, solver_to_sumk_block = s2sblock,
deg_shells = [[] for ish in range(len(gf_struct))]) deg_shells = [[] for ish in range(len(gf_struct))],
corr_to_inequiv = corr_to_inequiv)
def pick_gf_struct_solver(self,new_gf_struct): def pick_gf_struct_solver(self,new_gf_struct):
""" Pick selected orbitals within blocks. """ Pick selected orbitals within blocks.
@ -716,7 +737,7 @@ class BlockStructure(object):
for prop in [ "gf_struct_sumk", "gf_struct_solver", for prop in [ "gf_struct_sumk", "gf_struct_solver",
"solver_to_sumk", "sumk_to_solver", "solver_to_sumk_block", "solver_to_sumk", "sumk_to_solver", "solver_to_sumk_block",
"deg_shells","transformation"]: "deg_shells","transformation", "corr_to_inequiv"]:
if not compare(getattr(self,prop),getattr(other,prop)): if not compare(getattr(self,prop),getattr(other,prop)):
return False return False
return True return True
@ -730,8 +751,10 @@ class BlockStructure(object):
ret = {} ret = {}
for element in [ "gf_struct_sumk", "gf_struct_solver", for element in [ "gf_struct_sumk", "gf_struct_solver",
"solver_to_sumk_block","deg_shells", "solver_to_sumk_block","deg_shells",
"transformation"]: "transformation", "corr_to_inequiv"]:
ret[element] = getattr(self,element) ret[element] = getattr(self,element)
if ret[element] is None:
ret[element] = 'None'
if ret["transformation"] is None: if ret["transformation"] is None:
ret["transformation"] = "None" ret["transformation"] = "None"
@ -761,8 +784,9 @@ class BlockStructure(object):
d[ish][literal_eval(k)] = literal_eval(v) d[ish][literal_eval(k)] = literal_eval(v)
return d return d
if 'transformation' in D and D['transformation'] == "None": for elem in D:
D['transformation'] = None if D[elem]=="None":
D[elem] = None
D['solver_to_sumk']=reconstruct_mapping(D['solver_to_sumk']) D['solver_to_sumk']=reconstruct_mapping(D['solver_to_sumk'])
D['sumk_to_solver']=reconstruct_mapping(D['sumk_to_solver']) D['sumk_to_solver']=reconstruct_mapping(D['sumk_to_solver'])
@ -770,7 +794,8 @@ class BlockStructure(object):
def __str__(self): def __str__(self):
s='' s=''
s+= "gf_struct_sumk "+str( self.gf_struct_sumk)+'\n' s+= "corr_to_inequiv "+str(self.corr_to_inequiv)+'\n'
s+= "gf_struct_sumk "+str(self.gf_struct_sumk)+'\n'
s+= "gf_struct_solver "+str(self.gf_struct_solver)+'\n' s+= "gf_struct_solver "+str(self.gf_struct_solver)+'\n'
s+= "solver_to_sumk_block "+str(self.solver_to_sumk_block)+'\n' s+= "solver_to_sumk_block "+str(self.solver_to_sumk_block)+'\n'
for el in ['solver_to_sumk','sumk_to_solver']: for el in ['solver_to_sumk','sumk_to_solver']:

View File

@ -98,6 +98,8 @@ class SumkDFT(object):
self.misc_data = misc_data self.misc_data = misc_data
self.h_field = h_field self.h_field = h_field
self.block_structure = BlockStructure()
# Read input from HDF: # Read input from HDF:
things_to_read = ['energy_unit', 'n_k', 'k_dep_projection', 'SP', 'SO', 'charge_below', 'density_required', things_to_read = ['energy_unit', 'n_k', 'k_dep_projection', 'SP', 'SO', 'charge_below', 'density_required',
'symm_op', 'n_shells', 'shells', 'n_corr_shells', 'corr_shells', 'use_rotations', 'rot_mat', 'symm_op', 'n_shells', 'shells', 'n_corr_shells', 'corr_shells', 'use_rotations', 'rot_mat',
@ -123,8 +125,6 @@ class SumkDFT(object):
self.spin_names_to_ind[iso][ self.spin_names_to_ind[iso][
self.spin_block_names[iso][isp]] = isp * self.SP self.spin_block_names[iso][isp]] = isp * self.SP
self.block_structure = BlockStructure()
# GF structure used for the local things in the k sums # GF structure used for the local things in the k sums
# Most general form allowing for all hybridisation, i.e. largest # Most general form allowing for all hybridisation, i.e. largest
# blocks possible # blocks possible
@ -187,7 +187,7 @@ class SumkDFT(object):
# initialise variables on all nodes to ensure mpi broadcast works at # initialise variables on all nodes to ensure mpi broadcast works at
# the end # the end
for it in things_to_read: for it in things_to_read:
setattr(self, it, 0) setattr(self, it, None)
subgroup_present = 0 subgroup_present = 0
if mpi.is_master_node(): if mpi.is_master_node():
@ -2145,3 +2145,15 @@ class SumkDFT(object):
@property @property
def gf_struct_sumk_dict(self): def gf_struct_sumk_dict(self):
return self.block_structure.gf_struct_sumk_dict return self.block_structure.gf_struct_sumk_dict
def __get_corr_to_inequiv(self):
return self.block_structure.corr_to_inequiv
def __set_corr_to_inequiv(self, value):
self.block_structure.corr_to_inequiv = value
corr_to_inequiv = property(__get_corr_to_inequiv, __set_corr_to_inequiv)
def __get_inequiv_to_corr(self):
return self.block_structure.inequiv_to_corr
def __set_inequiv_to_corr(self, value):
self.block_structure.inequiv_to_corr = value
inequiv_to_corr = property(__get_inequiv_to_corr, __set_inequiv_to_corr)

Binary file not shown.

View File

@ -45,7 +45,8 @@ sk_pick1 = BlockStructure(gf_struct_sumk=SK.gf_struct_sumk,
solver_to_sumk=SK.solver_to_sumk, solver_to_sumk=SK.solver_to_sumk,
sumk_to_solver=SK.sumk_to_solver, sumk_to_solver=SK.sumk_to_solver,
solver_to_sumk_block=SK.solver_to_sumk_block, solver_to_sumk_block=SK.solver_to_sumk_block,
deg_shells=SK.deg_shells) deg_shells=SK.deg_shells,
corr_to_inequiv=SK.corr_to_inequiv)
assert sk_pick1 == pick1, 'constructing block structure from SumkDFT properties failed' assert sk_pick1 == pick1, 'constructing block structure from SumkDFT properties failed'
cmp(pick1.effective_transformation_sumk, cmp(pick1.effective_transformation_sumk,

Binary file not shown.