6

我有一个 N×M 矩阵m,如:

 1  2  3  4
 5  6  7  8
 9 10 11 12
13 14 15 16

我想得到所有大小为 P×Q 的子矩阵(P,Q 是奇数)w/o 使用 for 循环。

结果s应该是一个 P×Q×((N-P+1)·(M-Q+1)) 矩阵。

例如,如果 P=Q=3:

s(:,:,1) = [1 2 3;  5  6  7;  9 10 11]
s(:,:,2) = [2 3 4;  6  7  8; 10 11 12]
s(:,:,3) = [5 6 7;  9 10 11; 13 14 15]
s(:,:,4) = [6 7 8; 10 11 12; 14 15 16]
4

1 回答 1

6

im2col可以在这里为您提供帮助:

m =
     1     2     3     4
     5     6     7     8
     9    10    11    12
    13    14    15    16

>> P = 3; Q = 3;
>> columnized = im2col(m,[P Q],'sliding');
>> nMatrices = size(columnized,2);
>> s = reshape(columnized, [P Q nMatrices])

s(:,:,1) =
     1     2     3
     5     6     7
     9    10    11
s(:,:,2) =
     5     6     7
     9    10    11
    13    14    15
s(:,:,3) =
     2     3     4
     6     7     8
    10    11    12
s(:,:,4) =
     6     7     8
    10    11    12
    14    15    16

im2col使用该'sliding'选项查找所有重叠的子矩阵,并将每个子矩阵作为 (P·Q) 元素列向量返回columnized。为了将这些转换回矩阵,我们reshape将 (P·Q)×((N-P+1)·(M-Q+1)) 矩阵转换为 P×Q×((N-P+1)·(M -Q+1)) 一。

于 2012-12-05T05:19:09.973 回答