qiskit.chemistry.components.variational_forms.CHC¶
-
class
CHC
(num_qubits=None, reps=1, ladder=False, excitations=None, entanglement='full', initial_state=None)[código fonte]¶ 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.
Nota
It is not particle number conserving and the accuracy of the approximation decreases with the number of excitations.
- Parâmetros
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 (
Union
[QuantumCircuit
,InitialState
,None
]) – an initial state to prepend to the variational form
-
__init__
(num_qubits=None, reps=1, ladder=False, excitations=None, entanglement='full', initial_state=None)[código fonte]¶ - Parâmetros
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 (
Union
[QuantumCircuit
,InitialState
,None
]) – an initial state to prepend to the variational form
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)[código fonte]¶ Construct the variational form, given its parameters.
- Parâmetros
parameters (
Union
[ndarray
,List
[Parameter
],ParameterVector
]) – circuit parametersq (
Optional
[QuantumRegister
]) – Quantum Register for the circuit.
- Retorna
a quantum circuit with given parameters
- Tipo de retorno
- Levanta
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.
- Retorna
An integer indicating the number of parameters.
- Tipo de retorno
int
-
property
num_qubits
¶ Number of qubits of the variational form.
- Retorna
An integer indicating the number of qubits.
- Tipo de retorno
int
-
property
parameter_bounds
¶ Parameter bounds.
- Retorna
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.
- Tipo de retorno
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.
- Retorna
indicate the sub-class support parameterized circuit
- Tipo de retorno
boolean
-
static
validate_entangler_map
(entangler_map, num_qubits)¶ validate entangler map