After having seen the low level components of image processing, we can now move to mid level elements that utilize the tools seen so far, and by combining them create more advanced features for image processing.
data:image/s3,"s3://crabby-images/ee232/ee2327ee8e606e9a6cf6f3a781ecad64071f1b35" alt="mid-level-introduction Mid level processing"
We’ll look into:
- Edge detection
- Line detection
Edge detectors
Edge detectors highlight edges in an image. Specifically, an edge can be caused by a variety of factors, for example
data:image/s3,"s3://crabby-images/d5571/d5571eddde436a206cf57d41cfcacb2c4f43bca2" alt="types-of-discontinuities Types of discontinuities"
We will use derivatives, specifically gradients and Laplacians. We’ll use them to find different features of the edges
data:image/s3,"s3://crabby-images/6cc0b/6cc0b48bf24e49f278039c135d9500fb1572ece0" alt="first-and-second-order-derivatives First and second order derivatives"
For example
data:image/s3,"s3://crabby-images/a2a02/a2a02f9a87c024649d35eaae8e1be3dc175a4480" alt="first-and-second-order-derivatives-examples First and second order derivatives examples"
We can furthermore divide the edges into different kinds with respect to the gradient shape
data:image/s3,"s3://crabby-images/e6f18/e6f1813b71e36fdbc63418e73026e629ea4fc041" alt="step-ramp-roof Step versus ramp versus roof"
Note: derivatives amplify the noise—2nd derivatives more than 1st.
data:image/s3,"s3://crabby-images/78edc/78edcab922c922e1508bfb0fe4d968ce05754d4b" alt="noise-amplification Noise amplification"
Detecting edges using first order derivatives
What is a gradient and first order derivatives: In the continuous case
\nabla f(x, \, y) = \left[\dfrac{\partial f}{\partial x}, \, \dfrac{\partial f}{\partial y}\right] := [g_x, \, g_y]
While in the discrete case
g_x = f(x+1, \, y) - f(x, \, y)\\ g_y = f(x, \, y+1) - f(x, \, y)
The gradient points towards the fastest varying direction.
By considering the magnitude and the phase of the gradient, we can infer information about edge features
\begin{aligned} &\text{Magnitude:}&&||\nabla f(x, \, y)|| = \sqrt{g_x^2+g_y^2}\\[10pt] &\text{Phase:} && \alpha := \theta = \tan^{-1}\left(\dfrac{g_y}{g_x}\right) \end{aligned}
data:image/s3,"s3://crabby-images/974f4/974f4d4a08ee18eed057582a0fc88aecca32f388" alt="gradients-and-edge-directions Gradients and edge directions"
By using gradient masks and the Sobel operator, we can detect edges in multiple directions. The Sobel edge detector is named after its inventor, Irwin Sobel, this operator utilizes convolution with a pair of small, separable filters to compute the gradient magnitude of an image, effectively pinpointing regions of significant intensity variation. By detecting abrupt changes in pixel intensity, the Sobel edge detector offers valuable insights into the structure and boundaries of objects within an image.
data:image/s3,"s3://crabby-images/b3eba/b3eba8f0b25f55e2b39215fffafcfbb8c39f175d" alt="sobel-filters-and-edge-direction Sobel filters and edge direction"
Through the usage of Sobel filters we can therefore detect edges along x and y directions, as well as in the diagonal directions. An example usage is shown below using the magnitude as the edge detection
data:image/s3,"s3://crabby-images/41326/41326bd7dd3f7d9c8a0fb7102c5ef04cef17f5d2" alt="magnitude-edge-detection Magnitude edge detection"
If we were to use the angle we would get the following image
data:image/s3,"s3://crabby-images/eb377/eb377706a2f2e0aeed0300f2924fa0edd8021af4" alt="angle-edge-detection Angle edge detection"
In which areas with the same intensity have similar features.
Detecting edges with second order derivatives
What is a Laplacian and second order derivatives: In the continuous case, the Laplacian is
\nabla^2 f(x, \, y) = \dfrac{\partial^2f}{\partial x^2} + \dfrac{\partial^2 f}{\partial y^2}
Where
\dfrac{\partial^2 f(x, \, y)}{\partial x^2} = f(x+1, \, y) + f(x-1, \, y) - 2f(x, \, y)
In the discrete domain
\nabla^2 f(x, \, y) = f(x+1, \, y) + f(x-1, \, y) + f(x, \, y+1) + f(x, \, y-1) -4f(x, \, y)
Visually, applying the Laplacian to detect edges, we get
data:image/s3,"s3://crabby-images/13c29/13c2963c00b364a260d3bc3914c8fbbee6f14231" alt="laplacian-to-detect-edges Laplacian filter can be used to detect edges"
From the Laplacian, we can derive the anisotropic detectors, which offer four available directions
data:image/s3,"s3://crabby-images/ac261/ac2614ea9f4dd01ed66d6a222ef59c23dfccd32d" alt="anisotropic-detectors Anisotopic detectors"
And can be used to detect edges in a certain direction. In the following example at 45 degrees.
data:image/s3,"s3://crabby-images/58cf0/58cf03668c3c961c621b66b61fb9a80636afadb5" alt="anisotropic-detectors-irl Anisotropic detectors"
Note: images in the middle are zoomed in views of the top left and bottom right region, while image on the bottom left has all negative values set to 0 and image on the bottom right has some points set to white that are above a certain threshold given by the other image next to it.
Writing an edge detection algorithm
- Apply low-pass filter for noise removal
- Calculate gradient
- Apply gradient thresholding, specifically |\nabla f| > T
The final result is shown in the bottom right image:
data:image/s3,"s3://crabby-images/389ab/389aba1eed0d88e07a2be746023e14c1a36ef1c8" alt="edge-detection-algo Edge detection algorithm"
Notes:
The effect of smoothing is often useful prior to the computation of the gradient to minimize the amount of “wrong edges” that are detected
data:image/s3,"s3://crabby-images/7aa7f/7aa7fcc98da16150e257bcddd59c63b75007373c" alt="wrong-edged rong edged"
By applying thresholding we can separate the stronger edged from the others. The final effect depends on the amount of smoothing applied as well
data:image/s3,"s3://crabby-images/f3319/f331947871b2c6cef5268ceab974611c5801f443" alt="thresholding Thresholding"
We can then calculate the diagonal edges by using Sobel filters
data:image/s3,"s3://crabby-images/b28c7/b28c7604b7751f9e57131e47eafa2a1c47506806" alt="diagonal-edges-with-sobel Detecting diagonal edges with sobel filter"