qiskit.chemistry.applications.MolecularGroundStateEnergy¶
-
class
MolecularGroundStateEnergy
(driver, solver=None, transformation=<TransformationType.FULL: 'full'>, qubit_mapping=<QubitMappingType.PARITY: 'parity'>, two_qubit_reduction=True, freeze_core=False, orbital_reduction=None, z2symmetry_reduction=None)[source]¶ Molecular ground state energy chemistry application
- Paramètres
driver (
FermionicDriver
) – Chemistry driversolver (
Optional
[MinimumEigensolver
]) – An Aqua MinimumEigensolver. This can be provided on the constructor or via the solver property, or via the callback oncompute_energy()
transformation (
TransformationType
) – full or particle_holequbit_mapping (
QubitMappingType
) – jordan_wigner, parity or bravyi_kitaevtwo_qubit_reduction (
bool
) – Whether two qubit reduction should be used, when parity mapping onlyfreeze_core (
bool
) – Whether to freeze core orbitals when possibleorbital_reduction (
Optional
[List
[int
]]) – Orbital list to be frozen or removedz2symmetry_reduction (
Union
[str
,List
[int
],None
]) – If z2 symmetry reduction should be applied to the qubit operators that are computed. Setting “auto” will use an automatic computation of the correct sector. If from other experiments, with the z2symmetry logic, the sector is known, then the tapering values of that sector can be provided (a list of int of values -1, and 1). The default is None meaning no symmetry reduction is done. See alsoHamiltonian
which has the core processing behind this class.
-
__init__
(driver, solver=None, transformation=<TransformationType.FULL: 'full'>, qubit_mapping=<QubitMappingType.PARITY: 'parity'>, two_qubit_reduction=True, freeze_core=False, orbital_reduction=None, z2symmetry_reduction=None)[source]¶ - Paramètres
driver (
FermionicDriver
) – Chemistry driversolver (
Optional
[MinimumEigensolver
]) – An Aqua MinimumEigensolver. This can be provided on the constructor or via the solver property, or via the callback oncompute_energy()
transformation (
TransformationType
) – full or particle_holequbit_mapping (
QubitMappingType
) – jordan_wigner, parity or bravyi_kitaevtwo_qubit_reduction (
bool
) – Whether two qubit reduction should be used, when parity mapping onlyfreeze_core (
bool
) – Whether to freeze core orbitals when possibleorbital_reduction (
Optional
[List
[int
]]) – Orbital list to be frozen or removedz2symmetry_reduction (
Union
[str
,List
[int
],None
]) – If z2 symmetry reduction should be applied to the qubit operators that are computed. Setting “auto” will use an automatic computation of the correct sector. If from other experiments, with the z2symmetry logic, the sector is known, then the tapering values of that sector can be provided (a list of int of values -1, and 1). The default is None meaning no symmetry reduction is done. See alsoHamiltonian
which has the core processing behind this class.
Methods
__init__
(driver[, solver, transformation, …])- type driver
FermionicDriver
compute_energy
([callback])Compute the ground state energy of the molecule that was supplied via the driver
get_default_solver
(quantum_instance)Get the default solver callback that can be used with
compute_energy()
:type quantum_instance:Union
[QuantumInstance
,Backend
,BaseBackend
] :param quantum_instance: A Backend/Quantum Instance for the solver to run onAttributes
Returns chemistry driver
Returns minimum eigen solver
-
compute_energy
(callback=None)[source]¶ Compute the ground state energy of the molecule that was supplied via the driver
- Paramètres
callback (
Optional
[Callable
[[List
,int
,str
,bool
,Z2Symmetries
],MinimumEigensolver
]]) – If not None will be called with the following values num_particles, num_orbitals, qubit_mapping, two_qubit_reduction, z2_symmetries in that order. This information can then be used to setup chemistry specific component(s) that are needed by the chosen MinimumEigensolver. The MinimumEigensolver can then be built and returned from this callback for use as the solver here.- Type renvoyé
MolecularGroundStateResult
- Renvoie
A molecular ground state result
- Lève
QiskitChemistryError – If no MinimumEigensolver was given and no callback is being used that could supply one instead.
-
property
driver
¶ Returns chemistry driver
- Type renvoyé
FermionicDriver
-
static
get_default_solver
(quantum_instance)[source]¶ Get the default solver callback that can be used with
compute_energy()
:type quantum_instance:Union
[QuantumInstance
,Backend
,BaseBackend
] :param quantum_instance: A Backend/Quantum Instance for the solver to run on- Type renvoyé
Optional
[Callable
[[List
,int
,str
,bool
,Z2Symmetries
],MinimumEigensolver
]]- Renvoie
Default solver callback
-
property
solver
¶ Returns minimum eigen solver
- Type renvoyé
MinimumEigensolver