You can find this article and source code at my GitHub
Three views of filtering
- Image filters in spatial domain
- Filter is a mathematical operation of a grid of numbers
- Smoothing, sharpening, measuring texture
- Image filters in the frequency domain
- Filtering is a way to modify the frequencies of images
- Denoising, sampling, image compression
- Templates and Image Pyramids
- Filtering is a way to match a template to the image
- Detection, coarse-to-fine registration
Example
Box filter
- Replaces each pixel with an average of its neighborhood
- Smoothing
data:image/s3,"s3://crabby-images/9ca1f/9ca1fe1f53bb87c2ef33319f46c215e55d3243d2" alt=""
Given a 3-by-3 box filter in the graph below
data:image/s3,"s3://crabby-images/c9b13/c9b13f4989c272aa983779b7fdb9b4022ebfffd4" alt=""
We will be able to find the filtered image, and the result looks like below (right one).
data:image/s3,"s3://crabby-images/47783/477832075e02a8adac4228c2aada8cee80d18d7d" alt=""
We also have some other popular and useful filters.
Sobel filter
data:image/s3,"s3://crabby-images/a65b6/a65b6a180d854c5880b349166f340c54aaed2c03" alt=""
data:image/s3,"s3://crabby-images/d4323/d43239f4314e326c891a1daf000a7e728b7a8be3" alt=""
Now you may think that a Sobel filter can be used to find the edge in an image. And you are right. I have tried to merge two result images from the vertical and horizontal
Properties of linear filters
Linearity:
filter(f1 + f2) = filter(f1) + filter(f2)
Shift invariance: same behavior regardless of
pixel location
filter(shift(f)) = shift(filter(f))
Any linear, shift-invariant operator can be
represented as a convolution
Important filter: Gaussian
Weight contributions of neighboring pixels by nearness
data:image/s3,"s3://crabby-images/b22da/b22da96b15f14325d99e5160e196bd37d2f188a1" alt=""
Smoothing with Gaussian filter
data:image/s3,"s3://crabby-images/4c45d/4c45d61a77a26416a8206be8073b517f05ab999b" alt=""
Smoothing with box filter
data:image/s3,"s3://crabby-images/2e2ee/2e2eecf51d11b6f6aa63975e8809a731a1c65860" alt=""
A Gaussian filter can do this better since it keeps "more information" than a box filter by weighting contributions from neighbors.
Practical matters
How big should the filter be?
- Values at edges should be near zero
- Rule of thumb for Gaussian: set filter half-width to
about 3σ
What about near the edge?
- the filter window falls off the edge of the image
- need to extrapolate
- methods:
- clip filter (black)
- wrap around
- copy edge
- reflect across edge
What is the size of the output?
data:image/s3,"s3://crabby-images/927f6/927f63987946af73958144c3681d39d8d0ff40ad" alt=""
Median filter
- A Median Filter operates over a window by
selecting the median intensity in the window. - What advantage does a median filter have over
a mean filter? (Check the picture below!) - Is a median filter a kind of convolution?
data:image/s3,"s3://crabby-images/04f42/04f42d92883870c70aee1eeb51421a5704dbef18" alt=""
Have you seen the superior advantage of applying a mean filter?
Reference:
Computer Vision: Algorithms and Applications by Richard Szeliski.
CSCI 1430: Introduction to Computer Vision
Thanks for reading. If you find any mistake / typo in this blog, please don't hesitate to let me know, you can reach me by email: jyang7[at]ualberta.ca
网友评论