DecomposablePhysics#
- class deepinv.physics.DecomposablePhysics(U=lambda x: ..., U_adjoint=lambda x: ..., V=lambda x: ..., V_adjoint=lambda x: ..., mask=1.0, **kwargs)[source]#
Bases:
LinearPhysics
Parent class for linear operators with SVD decomposition.
The singular value decomposition is expressed as
\[A = U\text{diag}(s)V^{\top} \in \mathbb{R}^{m\times n}\]where \(U\in\mathbb{C}^{n\times n}\) and \(V\in\mathbb{C}^{m\times m}\) are orthonormal linear transformations and \(s\in\mathbb{R}_{+}^{n}\) are the singular values.
- Parameters:
U (Callable) – orthonormal transformation
U_adjoint (Callable) – transpose of U
V (Callable) – orthonormal transformation
V_adjoint (Callable) – transpose of V
params (torch.nn.parameter.Parameter, float) – Singular values of the transform
- Examples:
Recreation of the Inpainting operator using the DecomposablePhysics class:
>>> from deepinv.physics import DecomposablePhysics >>> seed = torch.manual_seed(0) # Random seed for reproducibility >>> tensor_size = (1, 1, 3, 3) # Input size >>> mask = torch.tensor([[1, 0, 1], [1, 0, 1], [1, 0, 1]]) # Binary mask >>> U = lambda x: x # U is the identity operation >>> U_adjoint = lambda x: x # U_adjoint is the identity operation >>> V = lambda x: x # V is the identity operation >>> V_adjoint = lambda x: x # V_adjoint is the identity operation >>> mask_svd = mask.float().unsqueeze(0).unsqueeze(0) # Convert the mask to torch.Tensor and adjust its dimensions >>> physics = DecomposablePhysics(U=U, U_adjoint=U_adjoint, V=V, V_adjoint=V_adjoint, mask=mask_svd)
Apply the operator to a random tensor:
>>> x = torch.randn(tensor_size) >>> with torch.no_grad(): ... physics.A(x) # Apply the masking tensor([[[[ 1.5410, -0.0000, -2.1788], [ 0.5684, -0.0000, -1.3986], [ 0.4033, 0.0000, -0.7193]]]])
- A(x, mask=None, **kwargs)[source]#
Applies the forward operator \(y = A(x)\).
If a mask/singular values is provided, it is used to apply the forward operator, and also stored as the current mask/singular values.
- Parameters:
x (torch.Tensor) – input tensor
mask (torch.nn.parameter.Parameter, float) – singular values.
- Returns:
output tensor
- Return type:
- A_A_adjoint(y, mask=None, **kwargs)[source]#
A helper function that computes \(A A^{\top}y\).
Using the SVD decomposition, we have \(A A^{\top} = U\text{diag}(s^2)U^{\top}\).
- Parameters:
y (torch.Tensor) – measurement.
- Returns:
(
torch.Tensor
) the product \(AA^{\top}y\).
- A_adjoint(y, mask=None, **kwargs)[source]#
Computes the adjoint of the forward operator \(\tilde{x} = A^{\top}y\).
If a mask/singular values is provided, it is used to apply the adjoint operator, and also stored as the current mask/singular values.
- Parameters:
y (torch.Tensor) – input tensor
mask (torch.nn.parameter.Parameter, float) – singular values.
- Returns:
output tensor
- Return type:
- A_adjoint_A(x, mask=None, **kwargs)[source]#
A helper function that computes \(A^{\top} A x\).
Using the SVD decomposition, we have \(A^{\top}A = V\text{diag}(s^2)V^{\top}\).
- Parameters:
x (torch.Tensor) – signal/image.
- Returns:
(
torch.Tensor
) the product \(A^{\top}Ax\).
- A_dagger(y, mask=None, **kwargs)[source]#
Computes \(A^{\dagger}y = x\) in an efficient manner leveraging the singular vector decomposition.
- Parameters:
y (torch.Tensor) – a measurement \(y\) to reconstruct via the pseudoinverse.
- Returns:
(
torch.Tensor
) The reconstructed image \(x\).
- U(x)[source]#
Applies the \(U\) operator of the SVD decomposition.
Note
This method should be overwritten by the user to define its custom
DecomposablePhysics
operator.- Parameters:
x (torch.Tensor) – input tensor
- U_adjoint(x)[source]#
Applies the \(U^{\top}\) operator of the SVD decomposition.
Note
This method should be overwritten by the user to define its custom
DecomposablePhysics
operator.- Parameters:
x (torch.Tensor) – input tensor
- V(x)[source]#
Applies the \(V\) operator of the SVD decomposition.
Note
This method should be overwritten by the user to define its custom
DecomposablePhysics
operator.- Parameters:
x (torch.Tensor) – input tensor
- V_adjoint(x)[source]#
Applies the \(V^{\top}\) operator of the SVD decomposition.
Note
This method should be overwritten by the user to define its custom
DecomposablePhysics
operator.- Parameters:
x (torch.Tensor) – input tensor
- prox_l2(z, y, gamma, **kwargs)[source]#
Computes proximal operator of \(f(x)=\frac{\gamma}{2}\|Ax-y\|^2\) in an efficient manner leveraging the singular vector decomposition.
- Parameters:
z (torch.Tensor, float) – signal tensor
y (torch.Tensor) – measurements tensor
gamma (float) – hyperparameter \(\gamma\) of the proximal operator
- Returns:
(
torch.Tensor
) estimated signal tensor
Examples using DecomposablePhysics
:#
data:image/s3,"s3://crabby-images/96704/96704cf21de7af43adeb6a818f52f53320eea355" alt=""
Reconstructing an image using the deep image prior.
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/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/5f62f/5f62f72ad870fa706b6db0485c72a7db831541b0" alt=""
Deep Equilibrium (DEQ) algorithms for image deblurring
data:image/s3,"s3://crabby-images/b490f/b490f00945216f379bac87f795d8119f6cc8bc69" alt=""
Unfolded Chambolle-Pock for constrained image inpainting