Note
New to DeepInverse? Get started with the basics with the 5 minute quickstart tutorial..
Poisson denoising using Poisson2Sparse#
This code shows how to restore a single image corrupted by Poisson noise using Poisson2Sparse, without requiring external training or knowledge of the noise level.
This method is based on the paper βPoisson2Sparseβ Ta et al.[1] and restores an image by learning a sparse non-linear dictionary parametrized by a neural network using a combination of Neighbor2Neighbor Huang et al.[2], of the negative log Poisson likelihood, of the \(\ell^1\) pixel distance and of a sparsity-inducing \(\ell^1\) regularization function on the weights.
import deepinv as dinv
import torch
Load a Poisson corrupted image#
This example uses an image from the microscopy dataset FMD Zhang et al.[3].
# Seed the RNGs for reproducibility
torch.manual_seed(0)
torch.cuda.manual_seed(0)
device = dinv.utils.get_freer_gpu() if torch.cuda.is_available() else "cpu"
physics = dinv.physics.Denoising(dinv.physics.PoissonNoise(gain=0.01, normalize=True))
x = dinv.utils.demo.load_example(
"FMD_TwoPhoton_MICE_R_gt_12_avg50.png", img_size=(256, 256)
).to(device)
x = x[:, 0:1, :64, :64]
x = x.clamp(0, 1)
y = physics(x)
Selected GPU 0 with 1143.125 MiB free memory
Define the Poisson2Sparse model
backbone = dinv.models.ConvLista(
in_channels=1,
out_channels=1,
kernel_size=3,
num_filters=512,
num_iter=10,
stride=2,
threshold=0.01,
)
model = dinv.models.Poisson2Sparse(
backbone=backbone,
lr=1e-4,
num_iter=200,
weight_n2n=2.0,
weight_l1_regularization=1e-5,
verbose=True,
).to(device)
Run the model#
Note that we do not pass in the physics model as Poisson2Sparse assumes a Poisson noise model internally and does not depend on the noise level.
x_hat = model(y)
# Compute and display PSNR values
learning_free_psnr = dinv.metric.PSNR()(y, x).item()
model_psnr = dinv.metric.PSNR()(x_hat, x).item()
print(f"Measurement PSNR: {learning_free_psnr:.1f} dB")
print(f"Poisson2Sparse PSNR: {model_psnr:.1f} dB")
# Plot results
dinv.utils.plot(
[y, x_hat, x],
titles=["Measurement", "Poisson2Sparse", "Ground truth"],
subtitles=[f"{learning_free_psnr:.1f} dB", f"{model_psnr:.1f} dB", ""],
)

0%| | 0/200 [00:00<?, ?it/s]
2%|β | 4/200 [00:00<00:05, 34.93it/s]
4%|β | 9/200 [00:00<00:04, 39.98it/s]
7%|β | 14/200 [00:00<00:04, 41.24it/s]
10%|β | 19/200 [00:00<00:04, 41.75it/s]
12%|ββ | 24/200 [00:00<00:04, 41.89it/s]
14%|ββ | 29/200 [00:00<00:04, 41.61it/s]
17%|ββ | 34/200 [00:00<00:04, 41.39it/s]
20%|ββ | 39/200 [00:00<00:03, 41.26it/s]
22%|βββ | 44/200 [00:01<00:03, 41.24it/s]
24%|βββ | 49/200 [00:01<00:03, 41.17it/s]
27%|βββ | 54/200 [00:01<00:03, 41.21it/s]
30%|βββ | 59/200 [00:01<00:03, 41.16it/s]
32%|ββββ | 64/200 [00:01<00:03, 41.13it/s]
34%|ββββ | 69/200 [00:01<00:03, 41.03it/s]
37%|ββββ | 74/200 [00:01<00:03, 40.76it/s]
40%|ββββ | 79/200 [00:01<00:02, 40.38it/s]
42%|βββββ | 84/200 [00:02<00:02, 40.30it/s]
44%|βββββ | 89/200 [00:02<00:02, 40.23it/s]
47%|βββββ | 94/200 [00:02<00:02, 40.20it/s]
50%|βββββ | 99/200 [00:02<00:02, 40.19it/s]
52%|ββββββ | 104/200 [00:02<00:02, 40.19it/s]
55%|ββββββ | 109/200 [00:02<00:02, 40.17it/s]
57%|ββββββ | 114/200 [00:02<00:02, 40.17it/s]
60%|ββββββ | 119/200 [00:02<00:02, 40.17it/s]
62%|βββββββ | 124/200 [00:03<00:01, 40.19it/s]
64%|βββββββ | 129/200 [00:03<00:01, 40.15it/s]
67%|βββββββ | 134/200 [00:03<00:01, 40.15it/s]
70%|βββββββ | 139/200 [00:03<00:01, 40.17it/s]
72%|ββββββββ | 144/200 [00:03<00:01, 40.16it/s]
74%|ββββββββ | 149/200 [00:03<00:01, 40.13it/s]
77%|ββββββββ | 154/200 [00:03<00:01, 40.14it/s]
80%|ββββββββ | 159/200 [00:03<00:01, 40.15it/s]
82%|βββββββββ | 164/200 [00:04<00:00, 40.14it/s]
84%|βββββββββ | 169/200 [00:04<00:00, 40.14it/s]
87%|βββββββββ | 174/200 [00:04<00:00, 40.05it/s]
90%|βββββββββ | 179/200 [00:04<00:00, 39.84it/s]
92%|ββββββββββ| 183/200 [00:04<00:00, 39.87it/s]
94%|ββββββββββ| 188/200 [00:04<00:00, 39.96it/s]
96%|ββββββββββ| 193/200 [00:04<00:00, 40.03it/s]
99%|ββββββββββ| 198/200 [00:04<00:00, 40.05it/s]
100%|ββββββββββ| 200/200 [00:04<00:00, 40.42it/s]
Measurement PSNR: 27.5 dB
Poisson2Sparse PSNR: 30.5 dB
- References:
Total running time of the script: (0 minutes 6.139 seconds)