matching template with image
이전 댓글 표시
I = imread('man.bmp'); % Load initial figure
a = imcrop(I,[50 40 150 100]);
m=imrotate(a,180);
%(Convolution is equivalent to correlation if you rotate the convolution kernel by 180.) To match the template to the image, use the fft2 and ifft2 functions.
C = real(ifft2(fft2(I).* fft2(m(a,2),256,256)));
I'm getting this error: ??? Subscript indices must either be real positive integers or logicals.
how to fix it ????
답변 (2개)
Walter Roberson
2012년 6월 16일
0 개 추천
You are trying to index your rotated image at your cropped image -- m(a,2)
I do not know what you intend that to mean.
댓글 수: 5
lama riad
2012년 6월 16일
Walter Roberson
2012년 6월 16일
In that code, C = real(ifft2(fft2(bw) .* fft2(rot90(a,2),256,256)));
rot90 is not a variable, it is a function with parameters "a" and "2". The effect of rot90(a,2) is to rotate "a" by 180 degrees, which sounds like what you want, so it is not obvious why you did the imrotate() by 180 -- rot90 would be faster. Anyhow, change your code to
C = real(ifft2(fft2(I).* fft2(m,256,256)));
Walter Roberson
2012년 6월 16일
In the context of MATLAB Answers, "no one is listening" is usually because the regular volunteers do not happen to know anything about that field.
(I have tried answering people with "I do not know", in order to let them know that someone is listening but does not happen to have the answer, but the responses I received in return were less than appreciative.)
lama riad
2012년 6월 16일
lama riad
2012년 6월 16일
Image Analyst
2012년 6월 16일
0 개 추천
"a" is a matrix. So is "m" - in fact it is the rotated version of "a". So you cannot do m(a,2). The first index must be an integer number or array or a logical value or array. You cannot have a 2D or 3D matrix (an image) for an index. I haven't replied to anyone in the past 8 days because I was way out in the wilderness. I don't work for Mathworks, by the way.
카테고리
도움말 센터 및 File Exchange에서 Read, Write, and Modify Image에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!