Skip to content

Commit

Permalink
Merge pull request #308 from QunaSys/uccsd_fix
Browse files Browse the repository at this point in the history
Uccsd fix
  • Loading branch information
toru4838 authored Jan 30, 2024
2 parents 07cd1a6 + 7701461 commit c2f10a4
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 11 deletions.
33 changes: 24 additions & 9 deletions packages/openfermion/quri_parts/openfermion/ansatz/uccsd.py
Original file line number Diff line number Diff line change
Expand Up @@ -36,10 +36,12 @@
class TrotterUCCSD(ImmutableLinearMappedUnboundParametricQuantumCircuit):
r"""Unitary coupled-cluster singles and doubles (UCCSD) ansatz. The ansatz
consists of the exponentials of single excitation and double excitation
operator decomposed by first-order Trotter product formula. Note that the ansatz
only supports singlet state and the occupied orbitals are the lowest
:attr:`n_fermions` spin orbitals. The decomposition using Trotter product formula
is executed for each qubit operators obtained by mapping excitation operators.
operator decomposed by first-order Trotter product formula. Note that the
occupied orbitals are the lowest :attr:`n_fermions` spin orbitals. The
decomposition using Trotter product formula is executed for each qubit
operators obtained by mapping excitation operators. The excitation operator
involved in the UCCSD ansatz will be determined by (n_spin_orbitals,
n_fermions, delta_sz).
Args:
n_spin_orbitals: Number of spin orbitals.
Expand All @@ -49,7 +51,15 @@ class TrotterUCCSD(ImmutableLinearMappedUnboundParametricQuantumCircuit):
trotter_number: Number for first-order Trotter product formula.
use_singles: If ``True``, single-excitation gates are applied.
delta_sz: The spin difference of the molecule before and after the transition.
singlet_excitation: If ``True``, the ansatz will be spin symmetric.
If delta_sz = 0, the excitation operator T present in the ansatz respects
the symmetry condition :math:`[T, S_z] = 0`.
singlet_excitation:
If ``True``, certain circuit parameters that corresponds to the excitation
amplitude will be identified according to the symmetry condition:
:math:`[S_x, T] = [S_y, T] = [S_z, T] = 0`. Please check out the note below
for information about how circuit parameters are identified by the
symmetry condition.
Parameters for the spin symmetric ansatz are named according to the spatial
transition amplitude.
Expand All @@ -60,22 +70,25 @@ class TrotterUCCSD(ImmutableLinearMappedUnboundParametricQuantumCircuit):
from occupied spin orbital (i, ↑), (j, ↓) to virtual spin orbitals
(a, ↑), (b, ↓).
Note:
Singlets excitation ansatz:
When singlet_excitation = True:
1. Certain excitation operators will share the same circuit parameters.
- For single excitation:
:math:`c_{a↑}^† c_{i↑}` and :math:`c_{a↓}^† c_{i↓}` share the same
transition amplitude :math:`t_i^a`,
thus sharing the same circuit parameter s_i_a.
- For mixed spin double excitation:
- :math:`c_{a↑}^† c_{b↓}^† c_{j↓} c_{i↑}` and
:math:`c_{a↓}^† c_{b↑}^† c_{j↑} c_{i↓}` share the same excitaion
amplitude :math:`t_{i↑, j↓}^{a↑, b↓}`, thus sharing the same
circuit parameter d_i_j_a_b.
- All the circuit parameters for double excitation are fixed by
the mixed spin double excitation mode.
the mixed spin double excitation mode.
- For same spin double excitation:
:math:`c_{a↑}^† c_{b↑}^† c_{j↑} c_{i↑}` and
Expand Down Expand Up @@ -119,8 +132,10 @@ def __init__(
), "n_spin_orbitals and n_fermions must not be None for ansatz construction."
n_vir_sorbs = n_spin_orbitals - n_fermions

if n_fermions % 2:
raise ValueError("Number of electrons must be even for SingletUCCSD.")
if n_fermions % 2 and singlet_excitation:
raise ValueError(
"Singlet excitation is not supported when " "number of electron is odd."
)

if n_vir_sorbs <= 0:
raise ValueError("Number of virtual orbitals must be a non-zero integer.")
Expand Down
9 changes: 7 additions & 2 deletions packages/openfermion/tests/openfermion/ansatz/test_uccsd.py
Original file line number Diff line number Diff line change
Expand Up @@ -398,8 +398,13 @@ def test_trotter_singlet_uccsd_scbk_trotter2(self) -> None:
assert bound_ansatz == expected_bound_ansatz

def test_singlet_uccsd_invalid_input(self) -> None:
with pytest.raises(ValueError):
TrotterUCCSD(4, 3)
with pytest.raises(
ValueError,
match=(
"Singlet excitation is not supported when " "number of electron is odd."
),
):
TrotterUCCSD(4, 3, singlet_excitation=True)
with pytest.raises(ValueError):
TrotterUCCSD(4, 4)
with pytest.raises(AssertionError):
Expand Down

1 comment on commit c2f10a4

@github-actions
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.