From b8f35fbf0c9321ba0f7a5f6207c331d094ade9b1 Mon Sep 17 00:00:00 2001 From: bartandrews Date: Fri, 8 Nov 2024 09:49:14 +0100 Subject: [PATCH] fix final_orbital_rotation bug --- python/ffsim/tenpy/circuits/lucj_circuit.py | 8 ++-- tests/python/tenpy/lucj_circuit_test.py | 46 ++++++++++++++------- 2 files changed, 34 insertions(+), 20 deletions(-) diff --git a/python/ffsim/tenpy/circuits/lucj_circuit.py b/python/ffsim/tenpy/circuits/lucj_circuit.py index 931a73b7e..e4e614786 100644 --- a/python/ffsim/tenpy/circuits/lucj_circuit.py +++ b/python/ffsim/tenpy/circuits/lucj_circuit.py @@ -60,9 +60,9 @@ def lucj_circuit_as_mps( apply_orbital_rotation( ucj_op.orbital_rotations[i], psi, eng, chi_list, norm_tol ) - if ucj_op.final_orbital_rotation is not None: - apply_orbital_rotation( - ucj_op.final_orbital_rotation, psi, eng, chi_list, norm_tol - ) + if ucj_op.final_orbital_rotation is not None: + apply_orbital_rotation( + ucj_op.final_orbital_rotation, psi, eng, chi_list, norm_tol + ) return psi, chi_list diff --git a/tests/python/tenpy/lucj_circuit_test.py b/tests/python/tenpy/lucj_circuit_test.py index 6b7fc2888..3e955b89b 100644 --- a/tests/python/tenpy/lucj_circuit_test.py +++ b/tests/python/tenpy/lucj_circuit_test.py @@ -38,23 +38,37 @@ def _interaction_pairs_spin_balanced_( @pytest.mark.parametrize( - "norb, nelec, connectivity", + "norb, nelec, n_reps, connectivity", [ - (4, (2, 2), "square"), - (4, (1, 2), "square"), - (4, (0, 2), "square"), - (4, (0, 0), "square"), - (4, (2, 2), "hex"), - (4, (1, 2), "hex"), - (4, (0, 2), "hex"), - (4, (0, 0), "hex"), - (4, (2, 2), "heavy-hex"), - (4, (1, 2), "heavy-hex"), - (4, (0, 2), "heavy-hex"), - (4, (0, 0), "heavy-hex"), + (4, (2, 2), 1, "square"), + (4, (1, 2), 1, "square"), + (4, (0, 2), 1, "square"), + (4, (0, 0), 1, "square"), + (4, (2, 2), 1, "hex"), + (4, (1, 2), 1, "hex"), + (4, (0, 2), 1, "hex"), + (4, (0, 0), 1, "hex"), + (4, (2, 2), 1, "heavy-hex"), + (4, (1, 2), 1, "heavy-hex"), + (4, (0, 2), 1, "heavy-hex"), + (4, (0, 0), 1, "heavy-hex"), + (4, (2, 2), 2, "square"), + (4, (1, 2), 2, "square"), + (4, (0, 2), 2, "square"), + (4, (0, 0), 2, "square"), + (4, (2, 2), 2, "hex"), + (4, (1, 2), 2, "hex"), + (4, (0, 2), 2, "hex"), + (4, (0, 0), 2, "hex"), + (4, (2, 2), 2, "heavy-hex"), + (4, (1, 2), 2, "heavy-hex"), + (4, (0, 2), 2, "heavy-hex"), + (4, (0, 0), 2, "heavy-hex"), ], ) -def test_lucj_circuit_as_mps(norb: int, nelec: tuple[int, int], connectivity: str): +def test_lucj_circuit_as_mps( + norb: int, nelec: tuple[int, int], n_reps: int, connectivity: str +): """Test LUCJ circuit MPS construction.""" rng = np.random.default_rng() @@ -71,7 +85,7 @@ def test_lucj_circuit_as_mps(norb: int, nelec: tuple[int, int], connectivity: st # generate a random LUCJ ansatz n_params = ffsim.UCJOpSpinBalanced.n_params( norb=norb, - n_reps=1, + n_reps=n_reps, interaction_pairs=_interaction_pairs_spin_balanced_( connectivity=connectivity, norb=norb ), @@ -81,7 +95,7 @@ def test_lucj_circuit_as_mps(norb: int, nelec: tuple[int, int], connectivity: st lucj_op = ffsim.UCJOpSpinBalanced.from_parameters( params, norb=norb, - n_reps=1, + n_reps=n_reps, interaction_pairs=_interaction_pairs_spin_balanced_( connectivity=connectivity, norb=norb ),