我得到了一个大小为[ 17935 10968 ]像素的卫星图像,我想平均切割图像并在各个部分处理我所需的算法(例如:我需要将像素范围切割成4等于部分)。
如何在不丢失中间像素的情况下分割图像?我的要求是(1到5600和5601到最终像素)。
任何人都知道如何在MATLAB中分割这么大的图像?
答案 0 :(得分:7)
如果您有图像处理工具箱,这是首选且最有效的方法。它利用了非常有用的blockproc
函数,该函数专为处理块中的大图像而设计。例如,当你的图像没有平均分成相同大小的块时,它会处理填充,并将块处理的结果连接成一个结果矩阵。
最好看一下official documentation,但是这就是你的情况:
vSize = [17935 10968];
imBig = rand([vSize 3]);
nParts = [2 2]; %means divide into 4 parts, 2 horizontal, 2 vertical
blockproc(imBig, ceil(vSize ./ nParts), @yourAlgorithm);
function res = yourAlgorithm(blockStruct)
%do your processing of the block here and
%optionally return a result in 'res'
%for example, just return the RGB vector of the first pixel
res = blockStruct.data(1,1,:);
end
如果您没有图像处理工具箱,则可以使用mat2cell
功能。 Fisrt你找出所需的块大小,然后你得到一个包含不同块的单元格数组。然而,对于如此大的图像,速度和记忆可能成为问题。该代码借鉴了this Matlab Central的答案。
vSize = [17935 10968];
imBig = rand([vSize 3]);
nParts = [2 2]; %means divide into 4 parts, 2 horizontal, 2 vertical
%figure out the size of "regular" block and the last block
vRegBlockSize = ceil(vSize ./ nParts);
vLastBlockSize = vSize - vRegBlockSize .* (nParts - 1);
%put the sizes into a vector
vSplitR = [vRegBlockSize(1)*ones(1,nParts(1)-1), vLastBlockSize(1)];
vSplitC = [vRegBlockSize(2)*ones(1,nParts(2)-1), vLastBlockSize(2)];
%split the image
C = mat2cell(imBig, vSplitR, vSplitC, 3);
%access RGB pixel (x,y) in top left {1,1} block
p = C{1,1}(x, y, :);
答案 1 :(得分:2)
upperLeft = theImage(1:5600, 1:5600, :);
upperRight = theImage(1:5600, 5601:end, :);
lowerLeft = theImage(5601:end, 1:5600, :);
lowerLeft = theImage(5601:end, 1:5601:end, :);
答案 2 :(得分:1)
您可以使用reshape
从图片中制作4个矩阵:
A=reshape(Img, 17935 , 10968/4,[]);
然后处理A(:,:,1)
等......
答案 3 :(得分:1)
使用以下代码将图像分成4个不同的图像:
A=reshape(Img, 17935 , 10968/4, 3, []);
然后A(:,:,:,1)是第一个图像。
答案 4 :(得分:0)
假设A
是您的17935x10968x3
矩阵,我认为您可以这样做:
B = reshape(A, 17935, 10968 / 4, 4, 3);
这样,最后一个维度仍代表RGB
。唯一的区别是它变成4-D
数组。