qiskit.optimization.algorithms.ADMMOptimizer¶
-
class
ADMMOptimizer
(qubo_optimizer=None, continuous_optimizer=None, params=None)[código fonte]¶ An implementation of the ADMM-based heuristic.
This algorithm is introduced in [1].
References:
- [1] Gambella, C., & Simonetto, A. (2020). Multi-block ADMM Heuristics for Mixed-Binary
Optimization on Classical and Quantum Computers. arXiv preprint arXiv:2001.02069.
- Parâmetros
qubo_optimizer (
Optional
[OptimizationAlgorithm
]) – An instance of OptimizationAlgorithm that can effectively solve QUBO problems. If not specified thenMinimumEigenOptimizer
initialized with an instance ofNumPyMinimumEigensolver
will be used.continuous_optimizer (
Optional
[OptimizationAlgorithm
]) – An instance of OptimizationAlgorithm that can solve continuous problems. If not specified thenSlsqpOptimizer
will be used.params (
Optional
[ADMMParameters
]) – An instance of ADMMParameters.
-
__init__
(qubo_optimizer=None, continuous_optimizer=None, params=None)[código fonte]¶ - Parâmetros
qubo_optimizer (
Optional
[OptimizationAlgorithm
]) – An instance of OptimizationAlgorithm that can effectively solve QUBO problems. If not specified thenMinimumEigenOptimizer
initialized with an instance ofNumPyMinimumEigensolver
will be used.continuous_optimizer (
Optional
[OptimizationAlgorithm
]) – An instance of OptimizationAlgorithm that can solve continuous problems. If not specified thenSlsqpOptimizer
will be used.params (
Optional
[ADMMParameters
]) – An instance of ADMMParameters.
Methods
__init__
([qubo_optimizer, …])- type qubo_optimizer
Optional
[OptimizationAlgorithm
]
get_compatibility_msg
(problem)Checks whether a given problem can be solved with the optimizer implementing this method.
is_compatible
(problem)Checks whether a given problem can be solved with the optimizer implementing this method.
solve
(problem)Tries to solves the given problem using ADMM algorithm.
Attributes
Returns current parameters of the optimizer.
-
get_compatibility_msg
(problem)[código fonte]¶ Checks whether a given problem can be solved with the optimizer implementing this method.
- Parâmetros
problem (
QuadraticProgram
) – The optimization problem to check compatibility.- Tipo de retorno
Optional
[str
]- Retorna
Returns True if the problem is compatible, otherwise raises an error.
- Levanta
QiskitOptimizationError – If the problem is not compatible with the ADMM optimizer.
-
is_compatible
(problem)¶ Checks whether a given problem can be solved with the optimizer implementing this method.
- Parâmetros
problem (
QuadraticProgram
) – The optimization problem to check compatibility.- Tipo de retorno
bool
- Retorna
Returns True if the problem is compatible, False otherwise.
-
property
parameters
¶ Returns current parameters of the optimizer.
- Tipo de retorno
ADMMParameters
- Retorna
The parameters.
-
solve
(problem)[código fonte]¶ Tries to solves the given problem using ADMM algorithm.
- Parâmetros
problem (
QuadraticProgram
) – The problem to be solved.- Tipo de retorno
ADMMOptimizationResult
- Retorna
The result of the optimizer applied to the problem.
- Levanta
QiskitOptimizationError – If the problem is not compatible with the ADMM optimizer.