Skip to content

A benchmark for non-blind deconvolution methods: classical algorithms vs SOTA neural models

Notifications You must be signed in to change notification settings

OlgaChaganova/non-blind-deconvolution-benchmark

Repository files navigation

Non-blind deconvolution methods benchmark

A benchmark for non-blind deconvolution methods: classical algorithms vs SOTA neural models.


Installation

  1. Install requirements (python >= 3.9):
make install
  1. Download prepared data:
TODO

or

Download raw data:

TODO

and unpack it:

make prepare_raw_data

Validation

Just simply run:

make test

Sources of data

Kernels:

  1. Motion blur:

    1.1 Levin et al. Understanding and evaluating blind deconvolution algorithms. Paper, data source. Total: 8 kernels.

    1.2 Sun et al. Edge-based Blur Kernel Estimation Using Patch Priors. Paper & data source. Total: 8 kernels (img_1_kernel{i}_OurNat5x5_kernel.png).

    1.3 Generated with simulator taken from RGDN. Source code: src/data/generate/motion_blur.py.

  2. Eye PSF:

    2.1 90 kernels (30 big, 30 medium, 30 small) taken from SCA-2023 dataset.

  3. Gauss:

    3.1 Generated with this script.

Ground truth images

  1. Sun et al. Images are taken from here.

  2. SCA-2023 dataset (539 images in 6 categories: animals, city, faces, texts, icons, nature).

Discretization

There only two types of image in these datasets: PNG with floating points and JPEG with uint8 dtype. Both are stored in sRGB. To properly model the blurring process, the convolution with PSF must be done in linear space, so the first step is to convert the sRGB to floating linear. The following pipeline is described here.


Models and algorithms

  1. Wiener filter (as baseline): source code in src/deconv/classic/wiener.py;

  2. USRNet: source code in src/deconv/neural/usrnet;

  3. DWDN: source code in src/deconv/neural/dwdn;

  4. KerUnc: source code in src/deconv/neural/kerunc;

  5. RGDN: source code in src/deconv/neural/rgdn.

Example of each model inference can be found here.

Testing robustness to kernels errors

Testing was done with an algorithm from a paper Deep Learning for Handling Kernel/model Uncertainty in Image Deconvolution:

image.png


Tips

SQL

  • If you work in VS Code, you can use this extention for SQLLite to make your work easier.

  • To calculate statistics (e.g. std and median), this extention is used here. Just download precompiled binaries suitable for your OS and unpack them to a folder (sqlean in my case). That's it!

  • SQL queries to analyze benchmarking results can be found here.

Running the code

  • If old torch version (we use 1.7.1 since we took the source code for neural models as is) is not compatible with your CUDA version, you can run this code in Docker container. Instructures are below.

How to run docker container

  1. Build image:
make build
  1. Run container:
make run
  1. Execute inside the container:
make exec
  1. Run inside the container:
make test

Benchmarking results

TBA

About

A benchmark for non-blind deconvolution methods: classical algorithms vs SOTA neural models

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages