如何处理图像范围错误?

时间:2014-04-04 17:08:59

标签: matlab image-processing raster bounding-box

以下matlab脚本将较大的蒙版图像剪切到较小灰度图像的边界框,并遮盖较小图像的区域。只要较小的图像在较大图像的范围内,这就可以很好地工作。但是,如果较小的图像超出较大图像的范围(附加屏幕截图),我会收到以下错误:

Index exceeds matrix dimensions.

Error in createMask (line 33) 
In = I(NI(1):NI(2),NI(3):NI(4));  % clipped binary

我想将较大图像范围之外的小图像的任何像素值转换为0. 我可以使用哪些方法来处理此图像范围错误?


enter image description here


%% this program clips a larger image using the extent of a smaller image..
% resample the images to match the pixel size and multiply with each other
%This program requires that the clip image is entirely within the larger image

[I B] = geotiffread('MASK.tif'); % larger image
[Ic R] = geotiffread('NDVI.tif'); % clip image
infoNDVI = geotiffinfo('NDVI.tif'); % geoinfo of clip layer
infoMASK = geotiffinfo('MASK.tif'); % geoinfo of larger layer

ncolsMASK = infoMASK.Width; 
nrowsMASK = infoMASK.Height;
nrowsNDVI = infoNDVI.Height;
ncolsNDVI = infoNDVI.Width;

B1 = infoMASK.BoundingBox;
Bm = infoNDVI.BoundingBox;

res = infoMASK.PixelScale(1); % res is the pixel dimension 

% Calculate the X and Y distances of the four corners of the clipping image from the origin of the larger image

d1 = fix([ (Bm(1) -B1(1)) (Bm(3) -B1(3))]/res);
d2 = fix([ (Bm(1) -B1(1)) (Bm(4) -B1(3))]/res);
d3 = fix([ (Bm(2) -B1(1)) (Bm(4) -B1(3))]/res);
d4 = fix([ (Bm(2) -B1(1)) (Bm(3) -B1(3))]/res);

% calculate row column indices of the clip layer and extract values for the clip extent
% Downscale resolution of the larger image to match the clip image
% Multiply the binary images and write that output as a geotiff file

NI = [ (nrowsMASK - d3(2)) (nrowsMASK - d1(2))  d1(1) d3(1) ];    
In = I(NI(1):NI(2),NI(3):NI(4));  % clipped binary

resampledIn = imresize(In, [nrowsNDVI, ncolsNDVI]);  % resample the binary layer to the size of clipped layer
intersected = immultiply(resampledIn,Ic);
outfilename = ['clipIntersect1'  '.tif'];
geotiffwrite('OUTPUT.tif', intersected, R, 'GeoKeyDirectoryTag', infoC.GeoTIFFTags.GeoKeyDirectoryTag);

1 个答案:

答案 0 :(得分:1)

我能想到的最简单的方法是使用逻辑索引来检查索引的有效性。这里有一个小例子来展示如何做到这一点:

I = ones(10);
NI = [-2 3 8 12];

% Get your rows and columns
iRows = NI(1):NI(2);
iCols = NI(3):NI(4);
desiredSize = [numel(iRows), numel(iCols)];

% Check validity
ilValidRows = iRows > 0 & iRows <= size(I, 1);
ilValidCols = iCols > 0 & iCols <= size(I, 2);

% set everything to zero
In = zeros(desiredSize);

% assign the values based on logical indexing
In(ilValidRows, ilValidCols) = I(iRows(ilValidRows), iCols(ilValidCols));

您最终得到In

的以下值
In =

     0     0     0     0     0
     0     0     0     0     0
     0     0     0     0     0
     1     1     1     0     0
     1     1     1     0     0
     1     1     1     0     0