Misplaced Pages

Difference of Gaussians

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
(Redirected from DoG) Feature enhancement algorithm in imaging science

In imaging science, difference of Gaussians (DoG) is a feature enhancement algorithm that involves the subtraction of one Gaussian blurred version of an original image from another, less blurred version of the original. In the simple case of grayscale images, the blurred images are obtained by convolving the original grayscale images with Gaussian kernels having differing width (standard deviations). Blurring an image using a Gaussian kernel suppresses only high-frequency spatial information. Subtracting one image from the other preserves spatial information that lies between the range of frequencies that are preserved in the two blurred images. Thus, the DoG is a spatial band-pass filter that attenuates frequencies in the original grayscale image that are far from the band center.

Mathematics of difference of Gaussians

Comparison between the difference of Gaussians and the Mexican hat wavelet

Let Φ t : R n R {\displaystyle \Phi _{t}:\mathbb {R} ^{n}\rightarrow \mathbb {R} } denote the radial Gaussian function Φ t ( x ) = N ( x | 0 , t ) {\displaystyle \Phi _{t}(x)={\mathcal {N}}(x|0,t)} with mean 0 {\displaystyle 0} and variance t {\displaystyle t} , i.e., the multivariate Gaussian function Φ t ( x ) = N ( x | 0 , t I ) {\displaystyle \Phi _{t}(x)={\mathcal {N}}(x|0,tI)} with mean 0 {\displaystyle 0} and covariance t I {\displaystyle tI} . More explicitly, we have

Φ t ( x ) = 1 ( 2 π t ) n / 2 e x 2 2 t . {\displaystyle \Phi _{t}(x)={\frac {1}{(2\pi {}t)^{n/2}}}e^{-{\frac {\|x\|^{2}}{2t}}}.}

The difference of Gaussians with variances t 1 < t 2 {\displaystyle t_{1}<t_{2}} is the kernel function

K t 1 , t 2 = Φ t 1 Φ t 2 {\displaystyle K_{t_{1},t_{2}}=\Phi _{t_{1}}-\Phi _{t_{2}}}

obtained by subtracting the higher-variance Gaussian from the lower-variance Gaussian. The difference of Gaussian operator is the convolutional operator associated with this kernel function. So given an n-dimensional grayscale image I : R n R {\displaystyle I:\mathbb {R} ^{n}\rightarrow \mathbb {R} } , the difference of Gaussians of the image I {\displaystyle I} is the n-dimensional image

I K t 1 , t 2 = I ( Φ t 1 Φ t 2 ) = I Φ t 1 I Φ t 2 . {\displaystyle I*K_{t_{1},t_{2}}=I*(\Phi _{t_{1}}-\Phi _{t_{2}})=I*\Phi _{t_{1}}-I*\Phi _{t_{2}}.}

Because convolution is bilinear, convolving against the difference of Gaussians is equivalent to applying two different Gaussian blurs and then taking the difference. In practice, this is faster because Gaussian blur is a separable filter.

The difference of Gaussians can be thought of as an approximation of the Mexican hat kernel function used for the Laplacian of the Gaussian operator. The key observation is that the family of Gaussians Φ t {\displaystyle \Phi _{t}} is the fundamental solution of the heat equation

t Φ t ( x ) = 1 2 Δ Φ t ( x ) . {\displaystyle \partial _{t}\Phi _{t}(x)={\frac {1}{2}}\Delta \Phi _{t}(x).}

The left-hand side can be approximated by the difference quotient

Φ t + δ t ( x ) Φ t ( x ) δ t = 1 δ t K t + δ t , t ( x ) . {\displaystyle {\frac {\Phi _{t+\delta {t}}(x)-\Phi _{t}(x)}{\delta {t}}}={\frac {1}{\delta {t}}}K_{t+\delta {t},t}(x).}

Meanwhile, the right-hand side is precisely the Laplacian of the Gaussian function. Note that the Laplacian of the Gaussian can be used as a filter to produce a Gaussian blur of the Laplacian of the image because I Δ Φ t = Δ I Φ t {\displaystyle I*\Delta \Phi _{t}=\Delta {I}*\Phi _{t}} by standard properties of convolution. The relationship between the difference of Gaussians operator and the Laplacian of the Gaussian operator is explained further in Appendix A in Lindeberg (2015).

Details and applications

Example before difference of Gaussians
After difference of Gaussians filtering in black and white

As a feature enhancement algorithm, the difference of Gaussians can be utilized to increase the visibility of edges and other detail present in a digital image. A wide variety of alternative edge sharpening filters operate by enhancing high frequency detail, but because random noise also has a high spatial frequency, many of these sharpening filters tend to enhance noise, which can be an undesirable artifact. The difference of Gaussians algorithm removes high frequency detail that often includes random noise, rendering this approach one of the most suitable for processing images with a high degree of noise. A major drawback to application of the algorithm is an inherent reduction in overall image contrast produced by the operation.

When utilized for image enhancement, the difference of Gaussians algorithm is typically applied when the size ratio of kernel (2) to kernel (1) is 4:1 or 5:1. In the example images, the sizes of the Gaussian kernels employed to smooth the sample image were 10 pixels and 5 pixels.

The algorithm can also be used to obtain an approximation of the Laplacian of Gaussian when the ratio of size 2 to size 1 is roughly equal to 1.6. The Laplacian of Gaussian is useful for detecting edges that appear at various image scales or degrees of image focus. The exact values of sizes of the two kernels that are used to approximate the Laplacian of Gaussian will determine the scale of the difference image, which may appear blurry as a result.

Differences of Gaussians have also been used for blob detection in the scale-invariant feature transform. In fact, the DoG as the difference of two Multivariate normal distribution has always a total null sum and convolving it with a uniform signal generates no response. It approximates well a second derivate of Gaussian (Laplacian of Gaussian) with K~1.6 and the receptive fields of ganglion cells in the retina with K~5. It may easily be used in recursive schemes and is used as an operator in real-time algorithms for blob detection and automatic scale selection.

More information

In its operation, the difference of Gaussians algorithm is believed to mimic how neural processing in the retina of the eye extracts details from images destined for transmission to the brain.

See also

References

  1. ^ "Molecular Expressions Microscopy Primer: Digital Image Processing – Difference of Gaussians Edge Enhancement Algorithm", Olympus America Inc., and Florida State University Michael W. Davidson, Mortimer Abramowitz
  2. Lindeberg, Tony (2015). "Image Matching Using Generalized Scale-Space Interest Points". Journal of Mathematical Imaging and Vision. 52: 3–36. doi:10.1007/s10851-014-0541-0. S2CID 254657377.
  3. D. Marr; E. Hildreth (29 February 1980). "Theory of Edge Detection". Proceedings of the Royal Society of London. Series B, Biological Sciences. 207 (1167): 215–217. Bibcode:1980RSPSB.207..187M. doi:10.1098/rspb.1980.0020. JSTOR 35407. PMID 6102765. S2CID 2150419. — A difference of Gaussians of any scale is an approximation to the laplacian of the Gaussian (see the entry for difference of Gaussians under Blob detection). However, Marr and Hildreth recommend the ratio of 1.6 because of design considerations balancing bandwidth and sensitivity. The url for this reference may only make the first page and abstract of the article available depending on if you are connecting through an academic institution or not.
  4. Christina Enroth-Cugell; J. G. Robson (1966). "The Contrast Sensitivity of Retinal Ganglion Cells of the Cat". Journal of Physiology. 187 (3): 517–552. doi:10.1113/jphysiol.1966.sp008107. PMC 1395960. PMID 16783910.
  5. Matthew J. McMahon; Orin S. Packer; Dennis M. Dacey (April 14, 2004). "The Classical Receptive Field Surround of Primate Parasol Ganglion Cells Is Mediated Primarily by a Non-GABAergic Pathway" (PDF). Journal of Neuroscience. 24 (15): 3736–3745. doi:10.1523/JNEUROSCI.5252-03.2004. PMC 6729348. PMID 15084653.
  6. Young, Richard (1987). "The Gaussian derivative model for spatial vision: I. Retinal mechanisms". Spatial Vision. 2 (4): 273–293(21). doi:10.1163/156856887X00222. PMID 3154952.

Further reading

Categories: