DataFidelity#
- class deepinv.optim.DataFidelity(d=None)[source]#
Bases:
Potential
Base class for the data fidelity term \(\distance{A(x)}{y}\) where \(A\) is the forward operator, \(x\in\xset\) is a variable and \(y\in\yset\) is the data, and where \(d\) is a distance function, from the class
deepinv.optim.Distance
.- Parameters:
d (Callable) – distance function \(d(x, y)\) between a variable \(x\) and an observation \(y\). Default None.
- fn(x, y, physics, *args, **kwargs)[source]#
Computes the data fidelity term \(\datafid{x}{y} = \distance{\forw{x}}{y}\).
- Parameters:
x (torch.Tensor) – Variable \(x\) at which the data fidelity is computed.
y (torch.Tensor) – Data \(y\).
physics (deepinv.physics.Physics) – physics model.
- Returns:
(
torch.Tensor
) data fidelity \(\datafid{x}{y}\).
- grad(x, y, physics, *args, **kwargs)[source]#
Calculates the gradient of the data fidelity term \(\datafidname\) at \(x\).
The gradient is computed using the chain rule:
\[\nabla_x \distance{\forw{x}}{y} = \left. \frac{\partial A}{\partial x} \right|_x^\top \nabla_u \distance{u}{y},\]where \(\left. \frac{\partial A}{\partial x} \right|_x\) is the Jacobian of \(A\) at \(x\), and \(\nabla_u \distance{u}{y}\) is computed using
grad_d
with \(u = \forw{x}\). The multiplication is computed using theA_vjp
method of the physics.- Parameters:
x (torch.Tensor) – Variable \(x\) at which the gradient is computed.
y (torch.Tensor) – Data \(y\).
physics (deepinv.physics.Physics) – physics model.
- Returns:
(
torch.Tensor
) gradient \(\nabla_x \datafid{x}{y}\), computed in \(x\).
- grad_d(u, y, *args, **kwargs)[source]#
Computes the gradient \(\nabla_u\distance{u}{y}\), computed in \(u\).
Note that this is the gradient of \(\distancename\) and not \(\datafidname\). This function directly calls
deepinv.optim.Potential.grad()
for the specific distance function \(\distancename\).- Parameters:
u (torch.Tensor) – Variable \(u\) at which the gradient is computed.
y (torch.Tensor) – Data \(y\) of the same dimension as \(u\).
- Returns:
(
torch.Tensor
) gradient of \(d\) in \(u\), i.e. \(\nabla_u\distance{u}{y}\).
- prox_d(u, y, *args, **kwargs)[source]#
Computes the proximity operator \(\operatorname{prox}_{\gamma\distance{\cdot}{y}}(u)\), computed in \(u\).
Note that this is the proximity operator of \(\distancename\) and not \(\datafidname\). This function directly calls
deepinv.optim.Potential.prox()
for the specific distance function \(\distancename\).- Parameters:
u (torch.Tensor) – Variable \(u\) at which the gradient is computed.
y (torch.Tensor) – Data \(y\) of the same dimension as \(u\).
- Returns:
(
torch.Tensor
) gradient of \(d\) in \(u\), i.e. \(\nabla_u\distance{u}{y}\).
- prox_d_conjugate(u, y, *args, **kwargs)[source]#
Computes the proximity operator of the convex conjugate of the distance function \(\distance{u}{y}\).
This function directly calls
deepinv.optim.Potential.prox_conjugate()
for the specific distance function \(\distancename\).
Examples using DataFidelity
:#
data:image/s3,"s3://crabby-images/21fbb/21fbb1346df0656c8ce78bf27c2c54f5a5a5b009" alt=""
Random phase retrieval and reconstruction methods.
data:image/s3,"s3://crabby-images/b6c47/b6c47bc116bf7234bcaa495f6702a59f92c4b197" alt=""
Patch priors for limited-angle computed tomography
data:image/s3,"s3://crabby-images/17ce3/17ce3e3bad7337aa43c8989ee4cf904c3e7badde" alt=""
PnP with custom optimization algorithm (Condat-Vu Primal-Dual)
data:image/s3,"s3://crabby-images/ceef2/ceef217d87a2effbe835fdfaa6b770746ecb8fa1" alt=""
Plug-and-Play algorithm with Mirror Descent for Poisson noise inverse problems.
data:image/s3,"s3://crabby-images/035f8/035f831e913a51b4952c29c95d4c8d00dc62e447" alt=""
Regularization by Denoising (RED) for Super-Resolution.
data:image/s3,"s3://crabby-images/5f62f/5f62f72ad870fa706b6db0485c72a7db831541b0" alt=""
Deep Equilibrium (DEQ) algorithms for image deblurring
data:image/s3,"s3://crabby-images/36803/36803229c0bf4ec02d7c776a01c37800325ad245" alt=""
Learned Iterative Soft-Thresholding Algorithm (LISTA) for compressed sensing
data:image/s3,"s3://crabby-images/b490f/b490f00945216f379bac87f795d8119f6cc8bc69" alt=""
Unfolded Chambolle-Pock for constrained image inpainting