qiskit.chemistry.components.variational_forms.CHC¶
-
class
CHC
(num_qubits=None, reps=1, ladder=False, excitations=None, entanglement='full', initial_state=None)[Quellcode]¶ This trial wavefunction is the Compact Heuristic for Chemistry.
The trial wavefunction is as defined in Ollitrault Pauline J., Chemical science 11 (2020): 6842-6855. It aims at approximating the UCC Ansatz for a lower CNOT count.
Bemerkung
It is not particle number conserving and the accuracy of the approximation decreases with the number of excitations.
- Parameter
num_qubits (
Optional
[int
]) – number of qubitsreps (
int
) – number of replica of basic moduleladder (
bool
) – use ladder of CNOTs between to indices in the entangling blockexcitations (
Optional
[List
[List
[int
]]]) – indices corresponding to the excitations to include in the circuitentanglement (
Union
[str
,List
[int
]]) – physical connections between the qubitsinitial_state (
Optional
[InitialState
]) – an initial state object
-
__init__
(num_qubits=None, reps=1, ladder=False, excitations=None, entanglement='full', initial_state=None)[Quellcode]¶ - Parameter
num_qubits (
Optional
[int
]) – number of qubitsreps (
int
) – number of replica of basic moduleladder (
bool
) – use ladder of CNOTs between to indices in the entangling blockexcitations (
Optional
[List
[List
[int
]]]) – indices corresponding to the excitations to include in the circuitentanglement (
Union
[str
,List
[int
]]) – physical connections between the qubitsinitial_state (
Optional
[InitialState
]) – an initial state object
Methods
__init__
([num_qubits, reps, ladder, …])- type num_qubits
Optional
[int
]
construct_circuit
(parameters[, q])Construct the variational form, given its parameters.
get_entangler_map
(map_type, num_qubits[, offset])returns entangler map
validate_entangler_map
(entangler_map, num_qubits)validate entangler map
Attributes
Number of parameters of the variational form.
Number of qubits of the variational form.
Parameter bounds.
Return preferred init points.
Whether or not the sub-class support parameterized circuit.
-
construct_circuit
(parameters, q=None)[Quellcode]¶ Construct the variational form, given its parameters.
- Parameter
parameters (
Union
[ndarray
,List
[Parameter
],ParameterVector
]) – circuit parametersq (
Optional
[QuantumRegister
]) – Quantum Register for the circuit.
- Rückgabe
a quantum circuit with given parameters
- Rückgabetyp
- Verursacht
ValueError – the number of parameters is incorrect.
ValueError – if num_qubits has not been set and is still None
ValueError – only supports single and double excitations at the moment.
-
static
get_entangler_map
(map_type, num_qubits, offset=0)¶ returns entangler map
-
property
num_parameters
¶ Number of parameters of the variational form.
- Rückgabe
An integer indicating the number of parameters.
- Rückgabetyp
int
-
property
num_qubits
¶ Number of qubits of the variational form.
- Rückgabe
An integer indicating the number of qubits.
- Rückgabetyp
int
-
property
parameter_bounds
¶ Parameter bounds.
- Rückgabe
A list of pairs indicating the bounds, as (lower, upper). None indicates an unbounded parameter in the corresponding direction. If None is returned, problem is fully unbounded.
- Rückgabetyp
list
-
property
preferred_init_points
¶ Return preferred init points.
If an initial state is provided then the variational form may provide back this set of parameters which when used on the variational form should result in the overall state being that defined by the initial state
-
property
setting
¶
-
property
support_parameterized_circuit
¶ Whether or not the sub-class support parameterized circuit.
- Rückgabe
indicate the sub-class support parameterized circuit
- Rückgabetyp
boolean
-
static
validate_entangler_map
(entangler_map, num_qubits)¶ validate entangler map