在MATLAB中制作两个相同尺寸的图像

时间:2012-04-16 04:30:02

标签: matlab

我正在尝试应用SURF算法,这是算法找到关键点并匹配相应的两个图像,但问题是在我的情况下,我想用两个图像应用那个算法,但它们是不同的尺寸,所以它无法工作,你能告诉我该怎么办,使两个图像的尺寸相等。

2 个答案:

答案 0 :(得分:2)

这取决于你的问题。如果图像具有相同的分辨率,我建议你裁剪一个图像或者扩展一个图像(用零?)来匹配像素数。

否则我建议您插入图像,以便在相同的点定义它们,例如使用interp2

你能给出你想要做的最低工作代码示例吗?

编辑:

您提供的code example开始加载到图片。

% Example 2, Corresponding points
% Load images
I1=imread('TestImages/lena1.png');
I2=imread('TestImages/testc2.png');

以下是一些如何使图像匹配的示例。在你的情况下,你必须决定哪一个是有意义的。

方法1:裁剪两个图像

nrows = min(size(I1,1), size(I2,1));
ncols = min(size(I1,2), size(I2,2));

% The + floor( ... ) is only for centering the bounding box
croppedI1 = I1( (1:nrows) + floor((size(I1,1)-nrows)/2), ...
  (1:ncols)+floor((size(I1,2)-ncols)/2), ...
  :);

croppedI2 = I2( (1:nrows) + floor((size(I2,1)-nrows)/2, ...
  (1:ncols) + floor((size(I2,2)-ncols)/2), ...
  :);

I1=croppedI1;
I2=croppedI2;

方法2:用零扩展图像直到匹配

nrows = max(size(I1,1), size(I2,1));
ncols = max(size(I1,2), size(I2,2));
nchannels = size(I1,3);

extendedI1 = [ I1, zeros(size(I1,1), ncols-size(I1,2), nchannels); ...
  zeros(nrows-size(I1,1), ncols, nchannels)];

extendedI2 = [ I2, zeros(size(I2,1), ncols-size(I2,2), nchannels); ...
  zeros(nrows-size(I2,1), ncols, nchannels)];

I1=extendedI1;
I2=extendedI2;

方法3:将第二张图像缩放到第一张图像的大小(会破坏宽高比)

% Scale the coordinates so that they range from 0 to 1 each.
[X1, Y1]=meshgrid( linspace(0, 1, size(I1,2)), linspace(0, 1, size(I1,1)));
[X2, Y2]=meshgrid( linspace(0, 1, size(I2,2)), linspace(0, 1, size(I2,1)));
nchannels = size(I1,3);

% interpolate each color plane separately
for k=1:nchannels
  scaledI2(:,:,k)=interp2(X2, Y2, double(I2(:,:,k)), X1, Y1); 
end

%I1=I1;
I2=scaledI2;

答案 1 :(得分:0)

% code for to play the images or to take same size images into array

r=0;c=0;

a1=imread(filename1);    

[r c]=size(a1);

b=imread(filename2);

a2= imresize(b, [r c/3]); 

% re-sized second image according to 1st one if u have specific   
 row col number then you can give like that 

a=cat(4,a1,a2);       % "a" array having a1 a2 images       

implay(a,framerate );   % to play images