Skip to content

Latest commit

 

History

History
48 lines (25 loc) · 4.89 KB

README.md

File metadata and controls

48 lines (25 loc) · 4.89 KB

When to Use CNNs for Inverse Problems

This repository contains a summary and in the future code for the methods described in "When to use Convolutional Neural Networks for Inverse Problems" which appeared in the CVPR 2020 procedings.

Paper: https://arxiv.org/abs/2003.13820

Abstract

Reconstruction tasks in computer vision aim fundamentally to recover an undetermined signal from a set of noisy measurements. Examples include super-resolution, image denoising, and non-rigid structure from motion, all of which have seen recent advancements through deep learning. However, earlier work made extensive use of sparse signal reconstruction frameworks (e.g convolutional sparse coding). While this work was ultimately surpassed by deep learning, it rested on a much more developed theoretical framework. Recent work by Papyan et. al provides a bridge between the two approaches by showing how a convolutional neural network (CNN) can be viewed as an approximate solution to a convolutional sparse coding (CSC) problem. In this work we argue that for some types of inverse problems the CNN approximation breaks down leading to poor performance. We argue that for these types of problems the CSC approach should be used instead and validate this argument with empirical evidence. Specifically we identify JPEG artifact reduction and non-rigid trajectory reconstruction as challenging inverse problems for CNNs and demonstrate state of the art performance on them using a CSC method. Furthermore, we offer some practical improvements to this model and its application, and also show how insights from the CSC model can be used to make CNNs effective in tasks where their naive application fails.

Summary

We are concerned with solving inverse problems where we seek to recover some original signal from a degraded set of linear measurements. This sort problem can be written in the form:

alt text

where y is the input signal which has been degraded by some known operator M, and the omega function encodes our prior on the set of signals z comes from. A naive deep learning approach to this problem would take a set of ground truth (y, z) pairs and directly learn the mapping. A different but related approach is to learn a hierarchical sparsity prior, introduced in Convolutional Neural Networks Analyzed via Convolutional Sparse Coding which explains the relationship between the two ideas. In previous work we have introduced a framework for applying this prior to real world problem by expressing the optimization as a differentiable network which can then be optimized through stochastic gradient descent. In this work we improve this method and show that the structure of the M matrix has a large effect on the efficacy of the CNN approach as compared with the convoultional sparse coding (CSC) approach. Please refer to the paper for the full details of this effort but the main finding is that when M is close to a diagonal structure, then the CNN approach dominates, but when M is of a more general structure the CSC approach is supperior. We validate this on a two real world tasks: JPEG artifact removal and trajectory reconstruction. Examples of these can be found below.

JPEG Artifact Reduction

The JPEG compression algorithm can introduce blocking artifacts when using a very low quality factor. These artifacts are fundamentally related to the compression, but just as with blurred or noisy images it should be possible to estimate the original uncompresssed image based on the statistics of natural images. In order to apply our method we need to approximate the compression algorithm with a linear operator like so:

JPEG model

We can then train our model just like a standard neural network to remove these artifacts. The following figure contains our results compared with the best deep learning based approaches.

JPEG results

Trajectory Reconstruction

In non-rigid trajectory reconstruction, one seeks to recover the 3D trajectories of points from their 2D projec-tions. This problem also has a block diagonal M structure, the blocks being the camera matricies. To be specific, in this case the signal z is the 3D trajectory of a point taken from a motion capture sequence:

z trajectory

The M matrix is composed of the cameras that image the point

M cameram

and finally y is the 2D trajectory created by the image sequence

y trajectory

We train our model on segments from the CMU motion capture dataset and shown below are some results where the ground truth is in red, our results are in blue, and a baseline CNN is in yellow.

traj1 traj2 traj3

Acknowledgments

This work was supported by the CMU Argo AI Center for Autonomous Vehicle Research.