Contents
- Some examples of digital filters for images
- notation
- Linear Filters
- shift filter
- Gaussian Filters
- The impulse response of a filter can be computed as the convolution against a Dirac
- Generating a noisy image as an image corrupted by additive Gaussian white noise
- denoising via smoothing (see slides and possibly LASIP package)
Some examples of digital filters for images
Giacomo Boracchi
close all
clear
clc
notation
% I original image % h LTI discrete filter % G convolution output % n noise % z noisy observation
Linear Filters
FILTER_SIZE = 21; % load image check the filename!! I = im2double(imread('image_lena512.png')); figure(1), imshow(I, []), title('I, original image') % have a look at the image size whos I % create averaging filter h = ones(FILTER_SIZE)/(FILTER_SIZE^2); % generate "averaged" image G = conv2(I, h); % have a look at size of convolution whos G G = conv2(I, h, 'same'); % use the option same to keep image size constant whos G % display the original image and the distribution of pixel intensities figure(1), imshow(I,[]),title('input original') figure(2), imshow(G,[]),title('convolved output') % generate "averaged" image z2 = conv2(h, I, 'same'); % display the original image and the distribution of pixel intensities figure(1), imshow(I,[]),title('input original') figure(2), imshow(G,[]),title('convolved output')
Name Size Bytes Class Attributes I 512x512 2097152 double Name Size Bytes Class Attributes G 532x532 2264192 double Name Size Bytes Class Attributes G 512x512 2097152 double
data:image/s3,"s3://crabby-images/94379/9437954e82db902fd4f671e918b3b63af03c5720" alt=""
data:image/s3,"s3://crabby-images/ff603/ff6030a279c7e4a1cb36f2a973aa4cf6323dc790" alt=""
While intensities of I are values like {i/255, i = 0,.., 255} there are much more values in G thanks to the local smoothing
figure(4), subplot(2,1,1), hist(I(:) , 1000), title('intensities on I'), axis([0 1 0 3000]) subplot(2,1,2), hist(G(:) , 1000), title('intensities on G'), axis([0 1 0 3000])
data:image/s3,"s3://crabby-images/542a3/542a37a932b5ab0fe3677072a56a116f02311d6f" alt=""
shift filter
FILTER_SIZE = 21; h=zeros(FILTER_SIZE ); h((FILTER_SIZE - 1) / 2 + 1 ,1) = 1; G=conv2(I, h, 'same'); % display figure(1), imshow(I),title('original') figure(2), imshow(G),title('observation') figure(3), bar3(h),title('kernel')
data:image/s3,"s3://crabby-images/4163d/4163de41bb83963ba5994fc2da5f73d24328dfdc" alt=""
data:image/s3,"s3://crabby-images/2e66f/2e66f195a7676a6274acd6e56451cab291cfed07" alt=""
data:image/s3,"s3://crabby-images/24d8c/24d8cb9e685ff44d33c6ca6f7f806c82ad1b4982" alt=""
Gaussian Filters
h_size = 51; sigma_gauss = 5; h = fspecial('gaussian' , h_size , sigma_gauss); figure(3),bar3(h),title('kernel') G=conv2(I , h , 'same'); % display figure(1), imshow(I),title('original') figure(2), imshow(G),title('observation') figure(3), bar3(h),title('kernel')
data:image/s3,"s3://crabby-images/1e45d/1e45d405c4472f36456f7ce430cc5ccf87a3ff82" alt=""
data:image/s3,"s3://crabby-images/9812f/9812f42d04569375c63d57b0fe129f2319c4ba13" alt=""
data:image/s3,"s3://crabby-images/602b9/602b95bffede625818051c6d3c419aaaed0354a9" alt=""
The impulse response of a filter can be computed as the convolution against a Dirac
close all I = zeros(51); I(26 , 26) = 1; G=conv2(I , h , 'same'); % display figure(1), imshow(I),title('original image (Dirac)') figure(2), imshow(G, []), title('observation (output of the convolution)') figure(3), bar3(G),title('observation (output of the convolution)'), axis tight % check that it corresponds to the kernel figure(4), bar3(h),title('kernel'), axis tight
data:image/s3,"s3://crabby-images/89e48/89e48d22b4c8ba68cc069bc94bbc4af649a67d43" alt=""
data:image/s3,"s3://crabby-images/93585/9358532e5888d9e0ac0edd4c11120e0b7c96eff3" alt=""
data:image/s3,"s3://crabby-images/97d1d/97d1dc387610bf4257aacc62402e6eb8d49977cd" alt=""
data:image/s3,"s3://crabby-images/eaf5d/eaf5d707bdcf96bf0e32ff7099db3fcf9b341925" alt=""
Generating a noisy image as an image corrupted by additive Gaussian white noise
I=im2double(imread('image_lena512.png')); figure(1), imshow(I,[]),title('I, original image') sigma_noise = 0.1; % the noise is a matrix having the same sizes of the original image n = sigma_noise * randn(size(I)); figure(4), imshow(n, []) % Additive White Gaussian Noise (AWGN): the noisy observation is given by z = I + n; figure(5),imshow(G);
data:image/s3,"s3://crabby-images/646d1/646d1ae9dedc95ca9c859ce19282e94c48a6e793" alt=""
data:image/s3,"s3://crabby-images/81f38/81f3865be3affa13ec9045d86af951a9b2a8e840" alt=""
data:image/s3,"s3://crabby-images/4932e/4932efaf46165257592350b3b9e153b4fba9ece7" alt=""
denoising via smoothing (see slides and possibly LASIP package)
% suppress noise by averaging: each pixel is replaced by the average over a 7x7 neighboor, uniform weight figure(6),imshow(conv2(z, ones(5)/(5^2)),[]) % suppress noise by averaging: each pixel is replaced by the average over a neighbor defined by the Gaussian kernel, % which also defines the averaging weights figure(7),imshow(conv2(z, h),[])
data:image/s3,"s3://crabby-images/f85c3/f85c361f7bc7b4b38b9af346db1b99f90b7fc9cf" alt=""
data:image/s3,"s3://crabby-images/25bde/25bde79268b2fff1d33aed7fbed63cbf64441abc" alt=""