"khoo" <email@example.com> wrote in message <firstname.lastname@example.org>... > > Why are you histogramming im8? which should be the correlation that you are looking for - just plot im8 and if everything else is correct then you should have one dimensional distribution reaching a peak at the position corresponding to the relative rotation angle of the 2 images. > > > > Regards > > > > Dave Robinson > > Bro Dave, this is the im8 graph after i plot out..but why the peak will at left side?? izit my inverse FFt do wrong? > > http://i278.photobucket.com/albums/kk119/khoo011/grapg.jpg > > and this is the part of code after i change..jz the below part of the code > > im7=hist(im22222(:),256); > im77=conj(fft(im7)); > im8=real(ifft(im66.*im77)); > plot(im8)
Had you considered that the results just might be right? Think about it - when you rotated the image, do the the actual image boundaries rotate?. You had some almost circular details toward the centre of the image, rotating a circle will generate exactly the same angle image irrespective of the amount of twist. If your image contains aliasing (digital stepping in the image), these will always generate detail usually at 0 and 90 degrees. Remember that your x scale needs to be rescaled such that 0 -> 256 actually maps to 0 ->360 degrees.
Meanwhile do the other spikes bear any relationship to the actual rotation angle between your images?
If the zero degree spike offends you why not set it to zero - if you know that the two images do have a valid rotation