Source code for qiskit.aqua.components.eigs.eigs

# -*- coding: utf-8 -*-

# This code is part of Qiskit.
#
# (C) Copyright IBM 2018, 2020.
#
# 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
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
#
# Any modifications or derivative works of this code must retain this
# copyright notice, and modified files need to carry a notice indicating
# that they have been altered from the originals.

"""
This module contains the definition of a base class for eigenvalue estimators.
"""

from abc import ABC, abstractmethod


[docs]class Eigenvalues(ABC): """Base class for eigenvalue estimation. This method should initialize the module and use an exception if a component of the module is not available. """ @abstractmethod def __init__(self) -> None: super().__init__() self._inverse = None
[docs] @abstractmethod def get_register_sizes(self): """ get register sizes """ raise NotImplementedError()
[docs] @abstractmethod def get_scaling(self): """ get scaling """ raise NotImplementedError()
[docs] @abstractmethod def construct_circuit(self, mode, register=None): """Construct the eigenvalue estimation quantum circuit. Args: mode (str): 'matrix' or 'circuit' register (QuantumRegister): register for circuit construction where eigenvalues will be stored. Returns: QuantumCircuit: object for the eigenvalue estimation circuit. Raises: NotImplementedError: not implemented """ raise NotImplementedError()
[docs] def construct_inverse(self, mode, circuit): """Construct the inverse eigenvalue estimation quantum circuit. Args: mode (str): construction mode, 'matrix' not supported circuit (QuantumCircuit): the quantum circuit to invert Returns: QuantumCircuit: object for of the inverted eigenvalue estimation circuit. Raises: NotImplementedError: not implemented for matrix mode ValueError: Circuit was not constructed beforehand """ if mode == 'matrix': raise NotImplementedError('The matrix mode is not supported.') if circuit is None: raise ValueError('Circuit was not constructed beforehand.') # TODO: need to check if circuit is empty, now, it enforce to put a barrier in evolution # instruction self._inverse = circuit.inverse() return self._inverse