Physics#
- class deepinv.physics.Physics(A=lambda x, **kwargs: ..., noise_model=lambda x, **kwargs: ..., sensor_model=lambda x: ..., solver='gradient_descent', max_iter=50, tol=1e-4)[source]#
Bases:
Module
Parent class for forward operators
It describes the general forward measurement process
\[y = N(A(x))\]where \(x\) is an image of \(n\) pixels, \(y\) is the measurements of size \(m\), \(A:\xset\mapsto \yset\) is a deterministic mapping capturing the physics of the acquisition and \(N:\yset\mapsto \yset\) is a stochastic mapping which characterizes the noise affecting the measurements.
- Parameters:
A (Callable) – forward operator function which maps an image to the observed measurements \(x\mapsto y\).
noise_model (deepinv.physics.NoiseModel, Callable) – function that adds noise to the measurements \(N(z)\). See the noise module for some predefined functions.
sensor_model (Callable) – function that incorporates any sensor non-linearities to the sensing process, such as quantization or saturation, defined as a function \(\eta(z)\), such that \(y=\eta\left(N(A(x))\right)\). By default, the
sensor_model
is set to the identity \(\eta(z)=z\).max_iter (int) – If the operator does not have a closed form pseudoinverse, the gradient descent algorithm is used for computing it, and this parameter fixes the maximum number of gradient descent iterations.
tol (float) – If the operator does not have a closed form pseudoinverse, the gradient descent algorithm is used for computing it, and this parameter fixes the absolute tolerance of the gradient descent algorithm.
solver (str) – least squares solver to use. Only gradient descent is available for non-linear operators.
- A(x, **kwargs)[source]#
Computes forward operator \(y = A(x)\) (without noise and/or sensor non-linearities)
- Parameters:
x (torch.Tensor,list[torch.Tensor]) – signal/image
- Returns:
(
torch.Tensor
) clean measurements
- A_dagger(y, x_init=None)[source]#
Computes an inverse as:
\[x^* \in \underset{x}{\arg\min} \quad \|\forw{x}-y\|^2.\]This function uses gradient descent to find the inverse. It can be overwritten by a more efficient pseudoinverse in cases where closed form formulas exist.
- Parameters:
y (torch.Tensor) – a measurement \(y\) to reconstruct via the pseudoinverse.
x_init (torch.Tensor) – initial guess for the reconstruction.
- Returns:
(
torch.Tensor
) The reconstructed image \(x\).
- A_vjp(x, v)[source]#
Computes the product between a vector \(v\) and the Jacobian of the forward operator \(A\) evaluated at \(x\), defined as:
\[A_{vjp}(x, v) = \left. \frac{\partial A}{\partial x} \right|_x^\top v.\]By default, the Jacobian is computed using automatic differentiation.
- Parameters:
x (torch.Tensor) – signal/image.
v (torch.Tensor) – vector.
- Returns:
(
torch.Tensor
) the VJP product between \(v\) and the Jacobian.
- __mul__(other)[source]#
Concatenates two forward operators \(A = A_1\circ A_2\) via the mul operation
The resulting operator keeps the noise and sensor models of \(A_1\).
- Parameters:
other (deepinv.physics.Physics) – Physics operator \(A_2\)
- Returns:
(
deepinv.physics.Physics
) concatenated operator
- forward(x, **kwargs)[source]#
Computes forward operator
\[y = N(A(x), \sigma)\]- Parameters:
x (torch.Tensor, list[torch.Tensor]) – signal/image
- Returns:
(
torch.Tensor
) noisy measurements
- noise(x, **kwargs)[source]#
Incorporates noise into the measurements \(\tilde{y} = N(y)\)
- Parameters:
x (torch.Tensor) – clean measurements
noise_level (None, float) – optional noise level parameter
- Returns:
noisy measurements
- Return type:
- sensor(x)[source]#
Computes sensor non-linearities \(y = \eta(y)\)
- Parameters:
x (torch.Tensor,list[torch.Tensor]) – signal/image
- Returns:
(
torch.Tensor
) clean measurements
- set_ls_solver(solver, max_iter=None, tol=None)[source]#
Change default solver for computing the least squares solution:
\[x^* \in \underset{x}{\arg\min} \quad \|\forw{x}-y\|^2.\]- Parameters:
solver (str) – solver to use. If the physics are non-linear, the only available solver is
'gradient_descent'
. For linear operators, the options are'CG'
,'lsqr'
and'BiCGStab'
(seedeepinv.optim.utils.least_squares()
for more details).max_iter (int) – maximum number of iterations for the solver.
tol (float) – relative tolerance for the solver, stopping when \(\|A(x) - y\| < \text{tol} \|y\|\).
- set_noise_model(noise_model, **kwargs)[source]#
Sets the noise model
- Parameters:
noise_model (Callable) – noise model
- stack(other)[source]#
Stacks two forward operators \(A(x) = \begin{bmatrix} A_1(x) \\ A_2(x) \end{bmatrix}\)
The measurements produced by the resulting model are
deepinv.utils.TensorList
objects, where each entry corresponds to the measurements of the corresponding operator.Returns a
deepinv.physics.StackedPhysics
object.See Combining Physics for more information.
- Parameters:
other (deepinv.physics.Physics) – Physics operator \(A_2\)
- Returns:
(
deepinv.physics.StackedPhysics
) stacked operator
Examples using Physics
:#
data:image/s3,"s3://crabby-images/ebc20/ebc207c3f9efef708721094f38febf93763bc4a4" alt=""
Imaging inverse problems with adversarial networks
data:image/s3,"s3://crabby-images/96704/96704cf21de7af43adeb6a818f52f53320eea355" alt=""
Reconstructing an image using the deep image prior.
data:image/s3,"s3://crabby-images/21fbb/21fbb1346df0656c8ce78bf27c2c54f5a5a5b009" alt=""
Random phase retrieval and reconstruction methods.
data:image/s3,"s3://crabby-images/c52f7/c52f7bb0271ddea625e3ea3109a483333d03846a" alt=""
Expected Patch Log Likelihood (EPLL) for Denoising and Inpainting
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/d7afc/d7afc03c8eecf55186146aa64fc9b8b8c6ae6314" alt=""
Self-supervised MRI reconstruction with Artifact2Artifact
data:image/s3,"s3://crabby-images/fa0fd/fa0fd65c41a28e3bb54cda3177d7bd8a45e03396" alt=""
Self-supervised learning with Equivariant Imaging for MRI.
data:image/s3,"s3://crabby-images/a59c4/a59c498054ae0e1acd00ec3c811b84cf81c1e173" alt=""
Self-supervised learning from incomplete measurements of multiple operators.
data:image/s3,"s3://crabby-images/3fb11/3fb1104d51813e92cbd32d26ad78993b05b7cbb0" alt=""
Self-supervised denoising with the Neighbor2Neighbor loss.
data:image/s3,"s3://crabby-images/51e94/51e9442f735a289d0e78d88128899b092037e096" alt=""
Self-supervised denoising with the Generalized R2R loss.
data:image/s3,"s3://crabby-images/084da/084da02f7012d8d5d050e6a8c363cd9d8c3e4ea2" alt=""
Self-supervised learning with measurement splitting
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