Professional Documents
Culture Documents
DIP Class2 Filters
DIP Class2 Filters
PROCESSING
Lecture 2
Basics of Image Processing
Tammy Riklin Raviv
Electrical and Computer Engineering
Ben-Gurion University of the Negev
The Makeover of My First Image
The Makeover of My First Image
The Makeover of My First Image
The Makeover of My First Image
The Makeover of My First Image
The Makeover of My First Image
The Makeover of My First Image
The Makeover of My First Image
The Makeover of My First Image
The Makeover of My First Image
Image processing vs. Image detection
The basics of image Processing
Not• inCoordinates
this class based operation
• Euclidean, Affine, Perspective, Non-Parametric
This class
Zisserman
Image Processing – Why?
• Main Objective: Image Enhancement
• Why?
• Further processing
• Aesthetic
What is image enhancement?
https://leegihan.wordpress.com/category/the-best-noise-reduction/
What is image enhancement?
h[m, n] f [k , l ] I [m k , n l ]
k ,l
James Hays
Image filtering
f [ , ]
1 1 1
Example: box 1 1 1
filter 1 1 1
Image Filtering f [ , ] 1 1 1
1 1 1
I [.,.] h[.,.]
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0
0 0
0 0
0 90
90 0
0 90
90 90
90 90
90 0
0 0
0
0
0 0
0 0
0 90
90 90
90 90
90 90
90 90
90 0
0 0
0
0
0 0
0 0
0 0
0 0
0 0
0 0
0 0
0 0
0 0
0
0
0 0
0 90
90 0
0 0
0 0
0 0
0 0
0 0
0 0
0
0
0 0
0 0
0 0
0 0
0 0
0 0
0 0
0 0
0 0
0
h[m, n] f [k , l ] I [m k , n l ]
k ,l Credit: S. Seitz
1 1 1
Image filtering f [ , ] 1
1
1
1
1
I [.,.] h[.,.]
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 10
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 0 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 0 0 0 0 0 0 0
0 0 90 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
h[m, n] f [k , l ] I [m k , n l ]
k ,l Credit: S. Seitz
1 1 1
Image Filtering f [ , ] 1
1
1
1
1
I [.,.] h[.,.]
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 10 20
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 0 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 0 0 0 0 0 0 0
0 0 90 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
h[m, n] f [k , l ] I [m k , n l ]
k ,l Credit: S. Seitz
1 1 1
Image Filtering f [ , ] 1 1 1
1 1 1
I [.,.] h[.,.]
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 10 20 30
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 0 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 0 0 0 0 0 0 0
0 0 90 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
h[m, n] f [k , l ] I [m k , n l ]
k ,l Credit: S. Seitz
1 1 1
Image Filtering f [ , ] 1
1
1
1
1
I [.,.] h[.,.]
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 10 20 30 30
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 0 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 0 0 0 0 0 0 0
0 0 90 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
h[m, n] f [k , l ] I [m k , n l ]
k ,l Credit: S. Seitz
1 1 1
Image filtering f [ , ] 1
1
1
1
1
I [.,.] h[.,.]
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 10 20 30 30
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 0 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
?
0 0 0 0 0 0 0 0 0 0
0 0 90 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
h[m, n] f [k , l ] I [m k , n l ]
k ,l Credit: S. Seitz
1 1 1
Image filtering f [ , ] 1 1 1
1 1 1
I [.,.] h[.,.]
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 10 20 30 30
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0
?
0 0 0 90 0 90 90 90 0 0
0 0 0 90 90 90 90 90 0 0 50
0 0 0 0 0 0 0 0 0 0
0 0 90 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
h[m, n] f [k , l ] I [m k , n l ]
k ,l Credit: S. Seitz
f [ , ] 1 1 1
Image filtering 1 1 1
1 1 1
I [.,.] h[.,.]
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 10 20 30 30 30 20 10
0 0 0 90 90 90 90 90 0 0 0 20 40 60 60 60 40 20
0 0 0 90 90 90 90 90 0 0 0 30 60 90 90 90 60 30
0 0 0 90 90 90 90 90 0 0 0 30 50 80 80 90 60 30
0 0 0 90 0 90 90 90 0 0 0 30 50 80 80 90 60 30
0 0 0 90 90 90 90 90 0 0 0 20 30 50 50 60 40 20
0 0 0 0 0 0 0 0 0 0 10 20 30 30 30 30 20 10
0 0 90 0 0 0 0 0 0 0 10 10 10 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
h[m, n] f [k , l ] I [m k , n l ]
k ,l Credit: S. Seitz
Box Filter
f [ , ]
What does it do?
• Replaces each pixel with 1 1 1
an average of its
neighborhood 1 1 1
1 1 1
• Achieve smoothing effect
(remove sharp features)
f [ , ]
What does it do?
• Replaces each pixel with 1 1 1
an average of its
neighborhood 1 1 1
1 1 1
• Achieve smoothing effect
(remove sharp features)
h[m, n] f [k , l ] I [m k , n l ]
k ,l
• Really important!
• Enhance images
• Denoise, resize, increase contrast, etc.
• Extract information from images
• Texture, edges, distinctive points, etc.
• Detect patterns
• Template matching
James Hays
Linear Filters 0 0 0
1. 0 1 0
0 0 0
0 0 0
2. 0 0 1
0 0 0
1 0 -1
3. 2 0 -2
1 0 -1
-
0 0 0 1 1 1
4. 0 2 0 1 1 1
0 0 0 1 1 1
1. Practice with linear filters
?
0 0 0
0 1 0
0 0 0
Original
Source: D. Lowe
1. Practice with linear filters
0 0 0
0 1 0
0 0 0
Original Filtered
(no change)
Source: D. Lowe
2. Practice with linear filters
?
0 0 0
0 0 1
0 0 0
Original
Source: D. Lowe
2. Practice with linear filters
0 0 0
0 0 1
0 0 0
Source: D. Lowe
3. Practice with linear filters
1 0 -1
2 0 -2
1 0 -1
Sobel
Vertical Edge
(absolute value)
David Lowe
3. Practice with linear filters
1 2 1
0 0 0
-1 -2 -1
Sobel
Horizontal Edge
(absolute value)
David Lowe
4. Practice with linear filters
-
0 0 0 1 1 1
0
0
2
0
0
0
1
1
1
1
1
1
?
(Note that filter sums to 1)
Original
Source: D. Lowe
4. Practice with linear filters
-
0 0 0 1 1 1
0 2 0 1 1 1
0 0 0 1 1 1
Source: D. Lowe
4. Practice with linear filters
Sharpening
Source: D. Lowe
Filtering: Correlation vs. Convolution
• 2d correlation
h=filter2(f,I); or h=imfilter(I,f);
h[m, n] f [k , l ] I [m k , n l ]
k ,l
James Hays
Filtering: Correlation vs. Convolution
• 2d correlation
h=filter2(f,I); or h=imfilter(I,f);
h[m, n] f [k , l ] I [m k , n l ]
k ,l
• 2d convolution
h=conv2(f,I);
h[m, n] f [k , l ] I [m k , n l ]
k ,l
Source: S. Lazebnik
Convolution properties
• Commutative: a * b = b * a
• Conceptually no difference between filter and signal
• But particular filtering implementations might break this
equality, e.g., image edges
• Associative: a * (b * c) = (a * b) * c
• Often apply several filters one after another: (((a * b1) * b2) *
b3)
• This is equivalent to applying one filter: a * (b1 * b2 * b3)
• Correlation is _not_ associative (rotation effect)
• Why important?
Source: S. Lazebnik
Convolution properties
• Commutative: a * b = b * a
• Conceptually no difference between filter and signal
• But particular filtering implementations might break this equality,
e.g., image edges
• Associative: a * (b * c) = (a * b) * c
• Often apply several filters one after another: (((a * b1) * b2) * b3)
• This is equivalent to applying one filter: a * (b1 * b2 * b3)
• Correlation is _not_ associative (rotation effect)
• Why important?
x 5 x 5, = 1
y
Source: K. Grauman
Separability of the Gaussian filter
Source: D. Lowe
Separability example
2D convolution =
(center location only)
Perform convolution =
along rows: *
Followed by convolution
along the remaining column: =
*
Source: K. Grauman
Separability
• Why is separability useful in practice?
Separability
• Why is separability useful in practice?
• If K is width of convolution kernel:
• 2D convolution = K2 multiply-add operations
• 2x 1D convolution: 2K multiply-add operations
Practical matters
How big should the filter be?
• Values at edges should be near zero
• Gaussians have infinite extent…
• Rule of thumb for Gaussian: set filter half-width to
about 3 σ
James Hays
Practical matters
• 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
Source: S. Marschner
Computing Derivatives using Linear
Filters
Computing Derivatives using Linear
Filters
Computing Derivatives using Linear
Filters
Solution?
Computing Derivatives using Linear
Filters
Computing Derivatives using Linear
Filters
Computing Derivatives using Linear
Filters
Computing Derivatives using Linear
Filters
Computing Derivatives using Linear
Filters
Computing Derivatives using Linear
Filters
Computing Derivatives using Linear
Filters
Computing Derivatives using Linear
Filters
A note about the Divergence
Let be a 2D Cartesian coordinates
We can notice that while the diffusion process blurs the image
considerably as the number of iterations increases, the edge
information progressively degrades as well.
Anisotropic Diffusion: Perona-Malik
Perona & Malik introduce the flux function as a means to
constrain the diffusion process to contiguous
homogeneous regions, but not cross region boundaries.
The heat equation (after appropriate expansion of terms)
is thus modified to:
Colors
Frequency