How can I apply an auto-correlation to a Radon Transformation?

I have the following code
I = imread('img.jpg');
I = rgb2gray(I);
theta = 1:180;
[R,xp] = radon(I,theta);
how can I apply auto-correlation on this radon transformation on an image?
I have the following formula for auto-correlation which I want to apply:
where g(s,0) is the radon transformation. How can I implement this in Matlab? or is there an equivalent function that I can use?
Thank you in advance!

 Accepted Answer

Matt J
Matt J on 10 Oct 2013
Edited: Matt J on 10 Oct 2013
Just apply conv() or xcorr(), if you have it, to each of the columns of R. A simple for-loop will do.

More Answers (1)

You can also use Fourier methods, something like
c=ifft( fft(R).*conj(fft(R)) )
c=bsxfun(@rdivide,c,sum(R.^2,1));

3 Comments

should there be a difference between this method and the one above? I'm getting different results.
Just shooting from the hip on this one. In principal the results should be the same, within numerical accuracies- but if you use xcorr it might give you some default weigthing of the different lags.
The correlation/convolution, when implemented using ffts, is circulant. You will have to zero pad to make it equivalent to linear convolution.

Sign in to comment.

Asked:

on 10 Oct 2013

Commented:

on 14 Oct 2013

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!