# Quellcode fÃ¼r qiskit.algorithms.optimizers.cg

```# This code is part of Qiskit.
#
# (C) Copyright IBM 2018, 2020.
#
# obtain a copy of this license in the LICENSE.txt file in the root directory
#
# 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.

from __future__ import annotations

from .scipy_optimizer import SciPyOptimizer

[Doku]class CG(SciPyOptimizer):

CG is an algorithm for the numerical solution of systems of linear equations whose matrices are
symmetric and positive-definite. It is an *iterative algorithm* in that it uses an initial
guess to generate a sequence of improving approximate solutions for a problem,
in which each approximation is derived from the previous ones.  It is often used to solve
unconstrained optimization problems, such as energy minimization.

Uses scipy.optimize.minimize CG.
For further detail, please refer to
https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html
"""

_OPTIONS = ["maxiter", "disp", "gtol", "eps"]

# pylint: disable=unused-argument
def __init__(
self,
maxiter: int = 20,
disp: bool = False,
gtol: float = 1e-5,
tol: float | None = None,
eps: float = 1.4901161193847656e-08,
options: dict | None = None,
max_evals_grouped: int = 1,
**kwargs,
) -> None:
"""
Args:
maxiter: Maximum number of iterations to perform.
disp: Set to True to print convergence messages.
gtol: Gradient norm must be less than gtol before successful termination.
tol: Tolerance for termination.
eps: If jac is approximated, use this value for the step size.
options: A dictionary of solver options.
max_evals_grouped: Max number of default gradient evaluations performed simultaneously.
"""
if options is None:
options = {}
for k, v in list(locals().items()):
if k in self._OPTIONS:
options[k] = v
super().__init__(
method="CG",
options=options,
tol=tol,
max_evals_grouped=max_evals_grouped,
**kwargs,
)
```