[][src]Function opencv::photo::denoise_tvl1

pub fn denoise_tvl1(
    observations: &Vector<Mat>,
    result: &mut Mat,
    lambda: f64,
    niters: i32
) -> Result<()>

Primal-dual algorithm is an algorithm for solving special types of variational problems (that is, finding a function to minimize some functional). As the image denoising, in particular, may be seen as the variational problem, primal-dual algorithm then can be used to perform denoising and this is exactly what is implemented.

It should be noted, that this implementation was taken from the July 2013 blog entry MA13 , which also contained (slightly more general) ready-to-use source code on Python. Subsequently, that code was rewritten on C++ with the usage of openCV by Vadim Pisarevsky at the end of July 2013 and finally it was slightly adapted by later authors.

Although the thorough discussion and justification of the algorithm involved may be found in ChambolleEtAl, it might make sense to skim over it here, following MA13 . To begin with, we consider the 1-byte gray-level images as the functions from the rectangular domain of pixels (it may be seen as set inline formula for some inline formula) into inline formula. We shall denote the noised images as inline formula and with this view, given some image inline formula of the same size, we may measure how bad it is by the formula

block formula

inline formula here denotes inline formula-norm and as you see, the first addend states that we want our image to be smooth (ideally, having zero gradient, thus being constant) and the second states that we want our result to be close to the observations we've got. If we treat inline formula as a function, this is exactly the functional what we seek to minimize and here the Primal-Dual algorithm comes into play.

Parameters

  • observations: This array should contain one or more noised versions of the image that is to be restored.
  • result: Here the denoised image will be stored. There is no need to do pre-allocation of storage space, as it will be automatically allocated, if necessary.
  • lambda: Corresponds to inline formula in the formulas above. As it is enlarged, the smooth (blurred) images are treated more favorably than detailed (but maybe more noised) ones. Roughly speaking, as it becomes smaller, the result will be more blur but more sever outliers will be removed.
  • niters: Number of iterations that the algorithm will run. Of course, as more iterations as better, but it is hard to quantitatively refine this statement, so just use the default and increase it if the results are poor.

C++ default parameters

  • lambda: 1.0
  • niters: 30