How can I convolve my image with small patch of size 16 X 16 of same image? My kernel is the patch of that image
    5 vues (au cours des 30 derniers jours)
  
       Afficher commentaires plus anciens
    
    Sangamithirai S
 le 8 Juil 2014
  
    
    
    
    
    Réponse apportée : Chris Turnes
    
 le 4 Août 2014
            Hi all
I am working with convolution now.
I tried to convolve two images but it is taking more time to work with.
Also I want to convolve my image with the kernel which is the small patch of the same image of size 16 X 16.
How can I perform this?
Can anyone help me out?
0 commentaires
Réponse acceptée
  Chris Turnes
    
 le 4 Août 2014
        What type of convolution are you trying to do? If you want a circular convolution, you should use the FFT to calculate it (see the documentation on fftn and ifftn for more details). For example:
A = phantom(256);  % image source
B = randn(16);   % "patch" or "kernel"
N = max([size(A); size(B)]); % get the correct FFT size
C = ifftn(fftn(A,N) .* fftn(B,N)); % do the convolution
If you want linear convolution, you can use the conv2 function from the Image Processing Toolbox ( see documentation ):
D = conv2(A,B); % 2-D linear convolution
Since the patch is probably much smaller than the image, this should be the most efficient option.
If you do not have conv2 or if you use a larger patch, you can still use the FFT to do linear convolution, but you will need to increase the FFT size. For the example above, the linear convolution of A and B would be
N = size(A) + size(B) - 1; % linear conv. FFT size
E = ifftn(fftn(A, N) .* fftn(B,N));  % do the convolution
If you are not sure which type of convolution you need, see the article Linear and Circular Convolution. You might also want to look into the imfilter function (see the documentation).
0 commentaires
Plus de réponses (0)
Voir également
Catégories
				En savoir plus sur Read, Write, and Modify Image dans Help Center et File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

