mirror of
https://github.com/triqs/dft_tools
synced 2025-01-03 10:05:49 +01:00
Update trans_basis for new gf_struct convention.
This commit is contained in:
parent
abf70b6ead
commit
cbeb26cc7f
@ -150,14 +150,14 @@ class TransBasis:
|
|||||||
|
|
||||||
# build a full GF
|
# build a full GF
|
||||||
gfrotated = BlockGf(name_block_generator=[(block, GfImFreq(
|
gfrotated = BlockGf(name_block_generator=[(block, GfImFreq(
|
||||||
indices=inner, mesh=gf_to_rot.mesh)) for block, inner in self.SK.gf_struct_sumk[0]], make_copies=False)
|
target_shape=(block_dim, block_dim), mesh=gf_to_rot.mesh)) for block, block_dim in self.SK.gf_struct_sumk[0]], make_copies=False)
|
||||||
|
|
||||||
# transform the CTQMC blocks to the full matrix:
|
# transform the CTQMC blocks to the full matrix:
|
||||||
# ish is the index of the inequivalent shell corresponding to icrsh
|
# ish is the index of the inequivalent shell corresponding to icrsh
|
||||||
ish = self.SK.corr_to_inequiv[0]
|
ish = self.SK.corr_to_inequiv[0]
|
||||||
for block, inner in self.gf_struct_solver[ish].items():
|
for block, block_dim in self.gf_struct_solver[ish].items():
|
||||||
for ind1 in inner:
|
for ind1 in range(block_dim):
|
||||||
for ind2 in inner:
|
for ind2 in range(block_dim):
|
||||||
gfrotated[self.SK.solver_to_sumk_block[ish][block]][
|
gfrotated[self.SK.solver_to_sumk_block[ish][block]][
|
||||||
ind1, ind2] << gf_to_rot[block][ind1, ind2]
|
ind1, ind2] << gf_to_rot[block][ind1, ind2]
|
||||||
|
|
||||||
@ -168,9 +168,9 @@ class TransBasis:
|
|||||||
|
|
||||||
gfreturn = gf_to_rot.copy()
|
gfreturn = gf_to_rot.copy()
|
||||||
# Put back into CTQMC basis:
|
# Put back into CTQMC basis:
|
||||||
for block, inner in self.gf_struct_solver[ish].items():
|
for block, block_dim in self.gf_struct_solver[ish].items():
|
||||||
for ind1 in inner:
|
for ind1 in range(block_dim):
|
||||||
for ind2 in inner:
|
for ind2 in range(block_dim):
|
||||||
gfreturn[block][ind1, ind2] << gfrotated[
|
gfreturn[block][ind1, ind2] << gfrotated[
|
||||||
self.SK.solver_to_sumk_block[0][block]][ind1, ind2]
|
self.SK.solver_to_sumk_block[0][block]][ind1, ind2]
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user