mirror of
https://github.com/triqs/dft_tools
synced 2025-01-05 10:59:34 +01:00
Update Unit-Tests to new gfstruct
This commit is contained in:
parent
c2a53ab835
commit
507fe32308
@ -54,11 +54,11 @@ SK.symm_deg_gf(G_new_symm, 0)
|
|||||||
assert_block_gfs_are_close(G_new[0], G_new_symm)
|
assert_block_gfs_are_close(G_new[0], G_new_symm)
|
||||||
|
|
||||||
|
|
||||||
assert SK.gf_struct_sumk == [[('ud', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9])], [('ud', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9])]],\
|
assert SK.gf_struct_sumk == [[('ud', 10)], [('ud', 10)]],\
|
||||||
"wrong gf_struct_sumk"
|
"wrong gf_struct_sumk"
|
||||||
for i in range(5):
|
for i in range(5):
|
||||||
assert 'ud_{}'.format(i) in SK.gf_struct_solver[0], "missing block"
|
assert 'ud_{}'.format(i) in SK.gf_struct_solver[0], "missing block"
|
||||||
assert SK.gf_struct_solver[0]['ud_{}'.format(i)] == list(range(2)), "wrong block size"
|
assert SK.gf_struct_solver[0]['ud_{}'.format(i)] == 2, "wrong block size"
|
||||||
for i in range(10):
|
for i in range(10):
|
||||||
assert SK.sumk_to_solver[0]['ud',i] == ('ud_{}'.format(i//2), i%2), "wrong mapping"
|
assert SK.sumk_to_solver[0]['ud',i] == ('ud_{}'.format(i//2), i%2), "wrong mapping"
|
||||||
|
|
||||||
@ -98,11 +98,11 @@ G_new_symm = G_new[0].copy()
|
|||||||
SK.symm_deg_gf(G_new_symm, 0)
|
SK.symm_deg_gf(G_new_symm, 0)
|
||||||
assert_block_gfs_are_close(G_new[0], G_new_symm)
|
assert_block_gfs_are_close(G_new[0], G_new_symm)
|
||||||
|
|
||||||
assert SK.gf_struct_sumk == [[('ud', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9])], [('ud', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9])]],\
|
assert SK.gf_struct_sumk == [[('ud', 10)], [('ud', 10)]],\
|
||||||
"wrong gf_struct_sumk"
|
"wrong gf_struct_sumk"
|
||||||
for i in range(5):
|
for i in range(5):
|
||||||
assert 'ud_{}'.format(i) in SK.gf_struct_solver[0], "missing block"
|
assert 'ud_{}'.format(i) in SK.gf_struct_solver[0], "missing block"
|
||||||
assert SK.gf_struct_solver[0]['ud_{}'.format(i)] == list(range(2)), "wrong block size"
|
assert SK.gf_struct_solver[0]['ud_{}'.format(i)] == 2, "wrong block size"
|
||||||
for i in range(10):
|
for i in range(10):
|
||||||
assert SK.sumk_to_solver[0]['ud',i] == ('ud_{}'.format(i//2), i%2), "wrong mapping"
|
assert SK.sumk_to_solver[0]['ud',i] == ('ud_{}'.format(i//2), i%2), "wrong mapping"
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
from tkinter import W
|
||||||
from triqs.utility.comparison_tests import *
|
from triqs.utility.comparison_tests import *
|
||||||
from triqs_dft_tools.sumk_dft import *
|
from triqs_dft_tools.sumk_dft import *
|
||||||
import numpy as np
|
import numpy as np
|
||||||
@ -92,7 +93,7 @@ BS.transformation = [{'up':np.array([[1,0,0],[0,1/np.sqrt(2),1/np.sqrt(2)],[0,1/
|
|||||||
H3 = BS.convert_operator(h_int_slater(spin_names=['up','down'], orb_names=[0,1,2], U_matrix=U3x3, off_diag=True))
|
H3 = BS.convert_operator(h_int_slater(spin_names=['up','down'], orb_names=[0,1,2], U_matrix=U3x3, off_diag=True))
|
||||||
for op in H3:
|
for op in H3:
|
||||||
for c_op in op[0]:
|
for c_op in op[0]:
|
||||||
assert(BS.gf_struct_solver_dict[0][c_op[1][0]][c_op[1][1]] is not None) # This crashes with a key error if the operator structure is not the solver structure
|
assert(BS.solver_to_sumk[0][(c_op[1][0], c_op[1][1])] is not None) # This crashes with a key error if the operator structure is not the solver structure
|
||||||
|
|
||||||
U_trafod = transform_U_matrix(U3x3, BS.transformation[0]['up'].conjugate()) # The notorious .conjugate()
|
U_trafod = transform_U_matrix(U3x3, BS.transformation[0]['up'].conjugate()) # The notorious .conjugate()
|
||||||
H4 = h_int_slater(spin_names=['up','down'], orb_names=range(3), U_matrix=U_trafod, map_operator_structure=BS.sumk_to_solver[0])
|
H4 = h_int_slater(spin_names=['up','down'], orb_names=range(3), U_matrix=U_trafod, map_operator_structure=BS.sumk_to_solver[0])
|
||||||
|
@ -174,11 +174,9 @@ cmp(m2,
|
|||||||
|
|
||||||
# check full_structure
|
# check full_structure
|
||||||
full = BlockStructure.full_structure(
|
full = BlockStructure.full_structure(
|
||||||
[{'up_0': [0, 1], 'up_1': [0], 'down_1': [0], 'down_0': [0, 1]}], None)
|
[{'up_0': 2, 'up_1': 1, 'down_1': 1, 'down_0': 2}], None)
|
||||||
|
|
||||||
print(original_bs.gf_struct_sumk[0])
|
G_sumk = BlockGf(mesh=G1.mesh, gf_struct=original_bs.gf_struct_sumk[0])
|
||||||
print(gf_struct_flatten(original_bs.gf_struct_sumk[0]))
|
|
||||||
G_sumk = BlockGf(mesh=G1.mesh, gf_struct=gf_struct_flatten(original_bs.gf_struct_sumk[0]))
|
|
||||||
for i in range(3):
|
for i in range(3):
|
||||||
G_sumk['up'][i, i] << SemiCircular(1 if i < 2 else 2)
|
G_sumk['up'][i, i] << SemiCircular(1 if i < 2 else 2)
|
||||||
G_sumk['down'][i, i] << SemiCircular(4 if i < 2 else 3)
|
G_sumk['down'][i, i] << SemiCircular(4 if i < 2 else 3)
|
||||||
@ -204,13 +202,13 @@ G_bT = transformed_bs.convert_gf(G_T, None, space_from='sumk',
|
|||||||
assert_block_gfs_are_close(G1, G_bT)
|
assert_block_gfs_are_close(G1, G_bT)
|
||||||
|
|
||||||
assert original_bs.gf_struct_sumk_list ==\
|
assert original_bs.gf_struct_sumk_list ==\
|
||||||
[[('up', [0, 1, 2]), ('down', [0, 1, 2])]]
|
[[('up', 3), ('down', 3)]]
|
||||||
assert original_bs.gf_struct_solver_dict ==\
|
assert original_bs.gf_struct_solver_dict ==\
|
||||||
[{'up_0': [0, 1], 'up_1': [0], 'down_1': [0], 'down_0': [0, 1]}]
|
[{'up_0': 2, 'up_1': 1, 'down_1': 1, 'down_0': 2}]
|
||||||
assert original_bs.gf_struct_sumk_dict ==\
|
assert original_bs.gf_struct_sumk_dict ==\
|
||||||
[{'down': [0, 1, 2], 'up': [0, 1, 2]}]
|
[{'down': 3, 'up': 3}]
|
||||||
assert original_bs.gf_struct_solver_list ==\
|
assert original_bs.gf_struct_solver_list ==\
|
||||||
[[('down_0', [0, 1]), ('down_1', [0]), ('up_0', [0, 1]), ('up_1', [0])]]
|
[[('down_0', 2), ('down_1', 1), ('up_0', 2), ('up_1', 1)]]
|
||||||
|
|
||||||
# check __eq__
|
# check __eq__
|
||||||
assert full == full, 'equality not correct (equal structures not equal)'
|
assert full == full, 'equality not correct (equal structures not equal)'
|
||||||
|
Loading…
Reference in New Issue
Block a user