Skip to content

Commit

Permalink
replace qiskit.algorithms with qiskit_algorithms
Browse files Browse the repository at this point in the history
  • Loading branch information
t-imamichi committed Aug 21, 2023
1 parent 5e8bc0f commit c8952b5
Show file tree
Hide file tree
Showing 12 changed files with 66 additions and 35 deletions.
11 changes: 6 additions & 5 deletions qiskit_optimization/__init__.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# This code is part of Qiskit.
#
# (C) Copyright IBM 2019, 2022.
# (C) Copyright IBM 2019, 2023.
#
# This code is licensed under the Apache License, Version 2.0. You may
# obtain a copy of this license in the LICENSE.txt file in the root directory
Expand All @@ -26,10 +26,11 @@
A uniform interface as well as automatic conversion between different problem representations
allows users to solve problems using a large set of algorithms, from variational quantum algorithms,
such as the Quantum Approximate Optimization Algorithm
(:class:`~qiskit.algorithms.minimum_eigensolver.QAOA`), to
(:class:`~qiskit_algorithms.minimum_eigensolver.QAOA`), to
`Grover Adaptive Search <https://arxiv.org/abs/quant-ph/9607014>`_
(:class:`~algorithms.GroverOptimizer`), leveraging
fundamental :mod:`~qiskit.algorithms.minimum_eigensolver` provided by Qiskit Terra.
fundamental :mod:`~qiskit_algorithms.minimum_eigensolver` provided by
`Qiskit Algorithms <https://github.com/qiskit-community/qiskit-algorithms>`_.
Furthermore, the modular design
of the optimization module allows it to be easily extended and facilitates rapid development and
testing of new algorithms. Compatible classical optimizers are also provided for testing,
Expand Down Expand Up @@ -85,9 +86,9 @@
"""

from .version import __version__
from .infinity import INFINITY # must be at the top of the file
from .exceptions import QiskitOptimizationError
from .infinity import INFINITY # must be at the top of the file
from .problems.quadratic_program import QuadraticProgram
from .version import __version__

__all__ = ["__version__", "QuadraticProgram", "QiskitOptimizationError", "INFINITY"]
4 changes: 2 additions & 2 deletions qiskit_optimization/algorithms/admm_optimizer.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
from typing import List, Optional, Tuple, cast

import numpy as np
from qiskit.algorithms.minimum_eigensolvers import NumPyMinimumEigensolver
from qiskit_algorithms.minimum_eigensolvers import NumPyMinimumEigensolver

from ..converters import MaximizeToMinimize
from ..problems.constraint import Constraint
Expand Down Expand Up @@ -220,7 +220,7 @@ def __init__(
Args:
qubo_optimizer: An instance of OptimizationAlgorithm that can effectively solve
QUBO problems. If not specified then :class:`MinimumEigenOptimizer` initialized
with an instance of :class:`NumPyMinimumEigensolver` will be used.
with an instance of ``NumPyMinimumEigensolver`` will be used.
continuous_optimizer: An instance of OptimizationAlgorithm that can solve
continuous problems. If not specified then :class:`SlsqpOptimizer` will be used.
params: An instance of ADMMParameters.
Expand Down
6 changes: 3 additions & 3 deletions qiskit_optimization/algorithms/grover_optimizer.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,13 @@

import numpy as np
from qiskit import QuantumCircuit, QuantumRegister
from qiskit.algorithms import AmplificationProblem
from qiskit.algorithms.amplitude_amplifiers.grover import Grover
from qiskit.circuit.library import QuadraticForm
from qiskit.primitives import BaseSampler
from qiskit.providers import Backend
from qiskit.quantum_info import partial_trace
from qiskit.utils import QuantumInstance, algorithm_globals
from qiskit_algorithms import AmplificationProblem
from qiskit_algorithms.amplitude_amplifiers.grover import Grover

from qiskit_optimization.algorithms.optimization_algorithm import (
OptimizationAlgorithm,
Expand Down Expand Up @@ -168,7 +168,7 @@ def is_good_state(measurement):
return oracle, is_good_state

def solve(self, problem: QuadraticProgram) -> OptimizationResult:
"""Tries to solves the given problem using the grover optimizer.
"""Tries to solve the given problem using the grover optimizer.
Runs the optimizer to try to solve the optimization problem. If the problem cannot be,
converted to a QUBO, this optimizer raises an exception due to incompatibility.
Expand Down
43 changes: 35 additions & 8 deletions qiskit_optimization/algorithms/minimum_eigen_optimizer.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,19 @@
SamplingMinimumEigensolverResult,
)
from qiskit.quantum_info import SparsePauliOp
from qiskit_algorithms.minimum_eigensolvers import VQE as TerraVQE
from qiskit_algorithms.minimum_eigensolvers import (
NumPyMinimumEigensolver as TerraNumPyMinimumEigensolver,
)
from qiskit_algorithms.minimum_eigensolvers import (
NumPyMinimumEigensolverResult as TerraNumPyMinimumEigensolverResult,
)
from qiskit_algorithms.minimum_eigensolvers import (
SamplingMinimumEigensolver as TerraSamplingMinimumEigensolver,
)
from qiskit_algorithms.minimum_eigensolvers import (
SamplingMinimumEigensolverResult as TerraSamplingMinimumEigensolverResult,
)

from ..converters.quadratic_program_to_qubo import QuadraticProgramConverter, QuadraticProgramToQubo
from ..exceptions import QiskitOptimizationError
Expand All @@ -38,10 +51,18 @@
)

MinimumEigensolver = Union[
SamplingMinimumEigensolver, NumPyMinimumEigensolver, LegacyMinimumEigensolver
SamplingMinimumEigensolver,
NumPyMinimumEigensolver,
LegacyMinimumEigensolver,
TerraSamplingMinimumEigensolver,
TerraNumPyMinimumEigensolver,
]
MinimumEigensolverResult = Union[
SamplingMinimumEigensolverResult, NumPyMinimumEigensolverResult, LegacyMinimumEigensolverResult
SamplingMinimumEigensolverResult,
NumPyMinimumEigensolverResult,
LegacyMinimumEigensolverResult,
TerraSamplingMinimumEigensolverResult,
TerraNumPyMinimumEigensolverResult,
]


Expand Down Expand Up @@ -152,20 +173,26 @@ def __init__(
TypeError: When one of converters has an invalid type.
QiskitOptimizationError: When the minimum eigensolver does not return an eigenstate.
"""
if isinstance(min_eigen_solver, VQE):
if isinstance(min_eigen_solver, (VQE, TerraVQE)):
raise TypeError(
"MinimumEigenOptimizer does not support this VQE. You can use "
"qiskit.algorithms.minimum_eigensolvers.SamplingVQE instead."
"qiskit_algorithms.minimum_eigensolvers.SamplingVQE instead."
)
if not isinstance(
min_eigen_solver,
(SamplingMinimumEigensolver, NumPyMinimumEigensolver, LegacyMinimumEigensolver),
(
SamplingMinimumEigensolver,
NumPyMinimumEigensolver,
LegacyMinimumEigensolver,
TerraSamplingMinimumEigensolver,
TerraNumPyMinimumEigensolver,
),
):
raise TypeError(
"MinimumEigenOptimizer supports "
"qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver, "
"qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver, and "
"qiskit.algorithms.minimum_eigen_solvers.MinimumEigensolver. "
"qiskit_algorithms.minimum_eigensolvers.SamplingMinimumEigensolver, "
"qiskit_algorithms.minimum_eigensolvers.NumPyMinimumEigensolver, and "
"qiskit_algorithms.minimum_eigen_solvers.MinimumEigensolver. "
f"But {type(min_eigen_solver)} is given."
)
if not min_eigen_solver.supports_aux_operators():
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# This code is part of Qiskit.
#
# (C) Copyright IBM 2020, 2022.
# (C) Copyright IBM 2020, 2023.
#
# This code is licensed under the Apache License, Version 2.0. You may
# obtain a copy of this license in the LICENSE.txt file in the root directory
Expand All @@ -17,7 +17,7 @@
from typing import Dict, List, Optional, Tuple, Union, cast

import numpy as np
from qiskit.algorithms.minimum_eigensolvers import NumPyMinimumEigensolver
from qiskit_algorithms.minimum_eigensolvers import NumPyMinimumEigensolver
from qiskit.utils.validation import validate_min

from ..converters.quadratic_program_to_qubo import QuadraticProgramConverter, QuadraticProgramToQubo
Expand Down Expand Up @@ -117,7 +117,7 @@ class RecursiveMinimumEigenOptimizer(OptimizationAlgorithm):
.. code-block:: python
from qiskit.algorithms.minimum_eigensolver import QAOA
from qiskit_algorithms.minimum_eigensolver import QAOA
from qiskit_optimization.problems import QuadraticProgram
from qiskit_optimization.algorithms import (
MinimumEigenOptimizer, RecursiveMinimumEigenOptimizer
Expand Down Expand Up @@ -161,7 +161,7 @@ def __init__(
min_num_vars_optimizer: This optimizer is used after the recursive scheme for the
problem with the remaining variables. Default value is
:class:`~qiskit_optimization.algorithms.MinimumEigenOptimizer` created on top of
:class:`~qiskit.algorithms.minimum_eigensolver.NumPyMinimumEigensolver`.
:class:`~qiskit_algorithms.minimum_eigensolver.NumPyMinimumEigensolver`.
penalty: The factor that is used to scale the penalty terms corresponding to linear
equality constraints.
history: Whether the intermediate results are stored.
Expand Down
5 changes: 3 additions & 2 deletions qiskit_optimization/algorithms/warm_start_qaoa_optimizer.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,9 @@
import numpy as np
from qiskit import QuantumCircuit
from qiskit.algorithms import QAOA as LegacyQAOA
from qiskit.algorithms.minimum_eigensolvers import QAOA
from qiskit.algorithms.minimum_eigensolvers import QAOA as TerraQAOA
from qiskit.circuit import Parameter
from qiskit_algorithms.minimum_eigensolvers import QAOA

from ..converters.quadratic_program_converter import QuadraticProgramConverter
from ..exceptions import QiskitOptimizationError
Expand Down Expand Up @@ -203,7 +204,7 @@ def __init__(
self,
pre_solver: OptimizationAlgorithm,
relax_for_pre_solver: bool,
qaoa: Union[QAOA, LegacyQAOA],
qaoa: Union[QAOA, TerraQAOA, LegacyQAOA],
epsilon: float = 0.25,
num_initial_solutions: int = 1,
warm_start_factory: Optional[WarmStartQAOAFactory] = None,
Expand Down
1 change: 1 addition & 0 deletions requirements.txt
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
qiskit-terra>=0.22.4
qiskit-algorithms>=0.1.0
scipy>=1.4
numpy>=1.17
docplex>=2.21.207,!=2.24.231
Expand Down
2 changes: 1 addition & 1 deletion test/algorithms/test_grover_optimizer.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@
import numpy as np
from ddt import data, ddt
from docplex.mp.model import Model
from qiskit.algorithms.minimum_eigensolvers import NumPyMinimumEigensolver
from qiskit.utils import QuantumInstance, algorithm_globals, optionals
from qiskit_algorithms.minimum_eigensolvers import NumPyMinimumEigensolver

from qiskit_optimization.algorithms import (
GroverOptimizer,
Expand Down
7 changes: 4 additions & 3 deletions test/algorithms/test_min_eigen_optimizer.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,13 +18,14 @@

import numpy as np
from ddt import data, ddt, unpack
from qiskit.algorithms.minimum_eigensolvers import QAOA, VQE, NumPyMinimumEigensolver, SamplingVQE
from qiskit.algorithms.optimizers import COBYLA, SPSA
from qiskit.algorithms.optimizers import SPSA as TerraSPSA
from qiskit.circuit.library import TwoLocal
from qiskit.primitives import Estimator, Sampler
from qiskit.providers.basicaer import QasmSimulatorPy
from qiskit.providers.fake_provider import FakeArmonk, FakeArmonkV2
from qiskit.utils import algorithm_globals
from qiskit_algorithms.minimum_eigensolvers import QAOA, VQE, NumPyMinimumEigensolver, SamplingVQE
from qiskit_algorithms.optimizers import COBYLA, SPSA

import qiskit_optimization.optionals as _optionals
from qiskit_optimization.algorithms import (
Expand Down Expand Up @@ -377,7 +378,7 @@ def test_runtime(self, subroutine):
@data(FakeArmonk, FakeArmonkV2)
def test_runtime_backend_versions(self, backend_cls):
"""Test the runtime client with a V1 and a V2 backend."""
optimizer = SPSA(maxiter=1, learning_rate=0.1, perturbation=0.1)
optimizer = TerraSPSA(maxiter=1, learning_rate=0.1, perturbation=0.1)
backend = backend_cls()
provider = FakeVQERuntimeProvider()
ansatz = TwoLocal(1, "ry", reps=0)
Expand Down
6 changes: 3 additions & 3 deletions test/algorithms/test_recursive_optimization.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# This code is part of Qiskit.
#
# (C) Copyright IBM 2018, 2022.
# (C) Copyright IBM 2018, 2023.
#
# This code is licensed under the Apache License, Version 2.0. You may
# obtain a copy of this license in the LICENSE.txt file in the root directory
Expand All @@ -16,10 +16,10 @@
from test import QiskitOptimizationTestCase

import numpy as np
from qiskit.algorithms.minimum_eigensolvers import QAOA, NumPyMinimumEigensolver
from qiskit.algorithms.optimizers import SLSQP
from qiskit.primitives import Sampler
from qiskit.utils import algorithm_globals
from qiskit_algorithms.minimum_eigensolvers import QAOA, NumPyMinimumEigensolver
from qiskit_algorithms.optimizers import SLSQP

import qiskit_optimization.optionals as _optionals
from qiskit_optimization.algorithms import (
Expand Down
6 changes: 3 additions & 3 deletions test/algorithms/test_warm_start_qaoa.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# This code is part of Qiskit.
#
# (C) Copyright IBM 2021, 2022.
# (C) Copyright IBM 2021, 2023.
#
# This code is licensed under the Apache License, Version 2.0. You may
# obtain a copy of this license in the LICENSE.txt file in the root directory
Expand All @@ -17,9 +17,9 @@

import numpy as np
from docplex.mp.model import Model
from qiskit.algorithms.minimum_eigensolvers import QAOA
from qiskit.algorithms.optimizers import SLSQP
from qiskit.primitives.sampler import Sampler
from qiskit_algorithms.minimum_eigensolvers import QAOA
from qiskit_algorithms.optimizers import SLSQP

import qiskit_optimization.optionals as _optionals
from qiskit_optimization.algorithms import SlsqpOptimizer
Expand Down
2 changes: 1 addition & 1 deletion test/converters/test_converters.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@

import numpy as np
from docplex.mp.model import Model
from qiskit.algorithms.minimum_eigensolvers import NumPyMinimumEigensolver
from qiskit.quantum_info import SparsePauliOp
from qiskit_algorithms.minimum_eigensolvers import NumPyMinimumEigensolver

import qiskit_optimization.optionals as _optionals
from qiskit_optimization import QiskitOptimizationError, QuadraticProgram
Expand Down

0 comments on commit c8952b5

Please sign in to comment.