Кажется, в вашем коде есть несколько ошибок. Вот как бы я это сделал, если бы использовал двойной цикл:
M = someNumber;
N = size(big_mat,1); %# I assume big_mat is square here
%# you need different variables for maxCornerCoord and nSubMatrices (your I)
%# otherwise, you are going to index outside the image in the loops!
maxCornerCoord = N-M+1;
nSubMatrices = maxCornerCoord^2;
%# if you want a vector of submatrices, you have to use a cell array...
block_set = cell(nSubMatrices,1);
%# ...or a M-by-M-by-nSubMatrices array...
block_set = zeros(M,M,nSubMatrices);
%# ...or a nSubMatrices-by-M^2 array
block_set = zeros(nSubMatrices,M^2);
for y = 1:maxCornerCoord
for x = 1:maxCornerCoord
index = (y - 1) * maxCornerCoord + x;
%# use this line if block_set is a cell array
block_set{index} = big_mat(x:x+M-1, y:y+M-1);
%# use this line if block_set is a M-by-M-by-nSubMatrices array
block_set(:,:,index) = big_mat(x:x+M-1, y:y+M-1);
%# use this line if block_set is a nSubMatrices-by-M^2 array
block_set(index,:) = reshape(big_mat(x:x+M-1, y:y+M-1),1,M^2);
endfor
endfor
EDIT
Я только что увидел, что есть реализация im2col для Octave. Таким образом, вы можете переписать двойной цикл как
%# block_set is a M^2-by-nSubMatrices array
block_set = im2col(big_mat,[M,M],'sliding');
%# if you want, you can reshape the result to a M-by-M-by-nSubMatrices array
block_set = reshape(block_set,M,M,[]);
Это, вероятно, быстрее и экономит много цифровых деревьев.