qiskit.opflow.gradients.HessianBase¶
-
class
HessianBase
(hess_method='param_shift', **kwargs)[source]¶ Base class for the Hessian of an expected value.
- Parameters
hess_method (
Union
[str
,CircuitGradient
]) – The method used to compute the state/probability gradient. Can be either'param_shift'
or'lin_comb'
or'fin_diff'
. Ignored for gradients w.r.t observable parameters.kwargs (dict) – Optional parameters for a CircuitGradient
- Raises
ValueError – If method !=
fin_diff
andepsilon
is not None.
-
__init__
(hess_method='param_shift', **kwargs)[source]¶ - Parameters
hess_method (
Union
[str
,CircuitGradient
]) – The method used to compute the state/probability gradient. Can be either'param_shift'
or'lin_comb'
or'fin_diff'
. Ignored for gradients w.r.t observable parameters.kwargs (dict) – Optional parameters for a CircuitGradient
- Raises
ValueError – If method !=
fin_diff
andepsilon
is not None.
Methods
__init__
([hess_method])- type hess_method
Union
[str
,CircuitGradient
]
convert
(operator[, params])- type operator
OperatorBase
gradient_wrapper
(operator, bind_params[, …])Get a callable function which provides the respective gradient, Hessian or QFI for given parameter values.
parameter_expression_grad
(param_expr, param)Get the derivative of a parameter expression w.r.t.
Attributes
Returns
CircuitGradient
.-
abstract
convert
(operator, params=None)¶ - Parameters
operator (
OperatorBase
) – The operator we are taking the gradient, Hessian or QFI ofparams (
Union
[ParameterVector
,ParameterExpression
,List
[ParameterExpression
],None
]) – The parameters we are taking the gradient, Hessian or QFI with respect to.
- Return type
OperatorBase
- Returns
An operator whose evaluation yields the gradient, Hessian or QFI.
- Raises
ValueError – If
params
contains a parameter not present inoperator
.
-
gradient_wrapper
(operator, bind_params, grad_params=None, backend=None, expectation=None)¶ Get a callable function which provides the respective gradient, Hessian or QFI for given parameter values. This callable can be used as gradient function for optimizers.
- Parameters
operator (
OperatorBase
) – The operator for which we want to get the gradient, Hessian or QFI.bind_params (
Union
[ParameterExpression
,ParameterVector
,List
[ParameterExpression
]]) – The operator parameters to which the parameter values are assigned.grad_params (
Union
[ParameterExpression
,ParameterVector
,List
[ParameterExpression
],Tuple
[ParameterExpression
,ParameterExpression
],List
[Tuple
[ParameterExpression
,ParameterExpression
]],None
]) – The parameters with respect to which we are taking the gradient, Hessian or QFI. If grad_params = None, then grad_params = bind_paramsbackend (
Union
[Backend
,BaseBackend
,QuantumInstance
,None
]) – The quantum backend or QuantumInstance to use to evaluate the gradient, Hessian or QFI.expectation (
Optional
[ExpectationBase
]) – The expectation converter to be used. If none is set then PauliExpectation() is used.
- Return type
Callable
[[Iterable
],ndarray
]- Returns
Function to compute a gradient, Hessian or QFI. The function takes an iterable as argument which holds the parameter values.
-
property
hess_method
¶ Returns
CircuitGradient
.- Return type
CircuitGradient
- Returns
CircuitGradient
.
-
static
parameter_expression_grad
(param_expr, param)¶ Get the derivative of a parameter expression w.r.t. the given parameter.
- Parameters
param_expr (
ParameterExpression
) – The Parameter Expression for which we compute the derivativeparam (
ParameterExpression
) – Parameter w.r.t. which we want to take the derivative
- Return type
Union
[ParameterExpression
,float
]- Returns
ParameterExpression representing the gradient of param_expr w.r.t. param