qiskit-documentation/docs/api/qiskit/0.46/qiskit.opflow.gradients.Gra...

85 lines
4.7 KiB
Plaintext
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

---
title: Gradient
description: API reference for qiskit.opflow.gradients.Gradient
in_page_toc_min_heading_level: 1
python_api_type: class
python_api_name: qiskit.opflow.gradients.Gradient
---
# Gradient
<Class id="qiskit.opflow.gradients.Gradient" isDedicatedPage={true} github="https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/gradient.py" signature="qiskit.opflow.gradients.Gradient(grad_method='param_shift', **kwargs)" modifiers="class">
Bases: [`GradientBase`](qiskit.opflow.gradients.GradientBase "qiskit.opflow.gradients.gradient_base.GradientBase")
Deprecated: Convert an operator expression to the first-order gradient.
<Admonition title="Deprecated since version 0.24.0" type="danger">
The class `qiskit.opflow.gradients.gradient.Gradient` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration).
</Admonition>
## Attributes
### grad\_method
<Attribute id="qiskit.opflow.gradients.Gradient.grad_method">
Returns `CircuitGradient`.
**Returns**
`CircuitGradient`.
</Attribute>
## Methods
### convert
<Function id="qiskit.opflow.gradients.Gradient.convert" signature="convert(operator, params=None)">
**Parameters**
* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) The operator we are taking the gradient of.
* **params** ([*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] | None*) The parameters we are taking the gradient with respect to. If not explicitly passed, they are inferred from the operator and sorted by name.
**Returns**
An operator whose evaluation yields the Gradient.
**Raises**
* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") If `params` contains a parameter not present in `operator`.
* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") If `operator` is not parameterized.
**Return type**
[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")
</Function>
### get\_gradient
<Function id="qiskit.opflow.gradients.Gradient.get_gradient" signature="get_gradient(operator, params)">
Get the gradient for the given operator w\.r.t. the given parameters
**Parameters**
* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) Operator w\.r.t. which we take the gradient.
* **params** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]*) Parameters w\.r.t. which we compute the gradient.
**Returns**
Operator which represents the gradient w\.r.t. the given params.
**Raises**
* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") If `params` contains a parameter not present in `operator`.
* [**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") If the coefficient of the operator could not be reduced to 1.
* [**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") If the differentiation of a combo\_fn requires JAX but the package is not installed.
* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") If the operator does not include a StateFn given by a quantum circuit
* [**Exception**](https://docs.python.org/3/library/exceptions.html#Exception "(in Python v3.12)") Unintended code is reached
* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") jax not installed
**Return type**
[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")
</Function>
</Class>