KullbackLeibler¶
- class odl.solvers.functional.default_functionals.KullbackLeibler(*args, **kwargs)[source]¶
Bases:
Functional
The Kullback-Leibler divergence functional.
See also
KullbackLeiblerConvexConj
the convex conjugate functional
KullbackLeiblerCrossEntropy
related functional
Notes
The functional with prior is given by:
Note that we use the common definition 0 log(0) := 0. KL based objectives are common in MLEM optimization problems and are often used as data-matching term when data noise governed by a multivariate Poisson probability distribution is significant.
The functional is related to the Kullback-Leibler cross entropy functional
KullbackLeiblerCrossEntropy
. The KL cross entropy is the one diescribed in this Wikipedia article, and the functional is obtained by switching place of the prior and the varialbe in the KL cross entropy functional.For a theoretical exposition, see Csiszar1991.
References
- Attributes:
adjoint
Adjoint of this operator (abstract).
convex_conj
The convex conjugate functional of the KL-functional.
domain
Set of objects on which this operator can be evaluated.
grad_lipschitz
Lipschitz constant for the gradient of the functional.
gradient
Gradient of the KL functional.
inverse
Return the operator inverse.
is_functional
True
if this operator's range is aField
.is_linear
True
if this operator is linear.prior
The prior in the Kullback-Leibler functional.
proximal
Return the
proximal factory
of the functional.range
Set in which the result of an evaluation of this operator lies.
Methods
__call__
(x[, out])Return
self(x[, out, **kwargs])
.bregman
(point, subgrad)Return the Bregman distance functional.
derivative
(point)Return the derivative operator in the given point.
norm
([estimate])Return the operator norm of this operator.
translated
(shift)Return a translation of the functional.
- __init__(space, prior=None)[source]¶
Initialize a new instance.
- Parameters:
- space
DiscretizedSpace
orTensorSpace
Domain of the functional.
- prior
space
element-like
, optional Depending on the context, the prior, target or data distribution. It is assumed to be nonnegative. Default: if None it is take as the one-element.
- space
Examples
Test that KullbackLeibler(x,x) = 0
>>> space = odl.rn(3) >>> prior = 3 * space.one() >>> func = odl.solvers.KullbackLeibler(space, prior=prior) >>> func(prior) 0.0
Test that zeros in the prior are handled correctly
>>> prior = space.zero() >>> func = odl.solvers.KullbackLeibler(space, prior=prior) >>> x = space.one() >>> func(x) 3.0