Matlab 之 im2col 函数用法
2017-11-03 15:08
351 查看
函数原型:B = im2col(A,[m n],block_type)
功 能:将矩阵A分为m×n的子矩阵,再将每个子矩阵作为B的一列。
(1)当block_type为distinct时,将A分解为互不重叠的子矩阵,并转换成列。若不足m×n,以0补足。
例: A=
15 36 42 40 67 88 32 50
59 74 27 81 44 59 53 15
26 39 20 76 83 15 9 5
4 68 82 38 77 20 11 85
75 70 43 22 17 41 14 56
24 44 89 79 86 75 68 93
44 2 39 95 99 83 50 70
69 33 77 33 51 79 19 58
B=im2col(A, [3, 3], 'distinct')为:
15 4 44 40 38 95 32 11 50
59 75 69 81 22 33 53 14 19
26 24 0 76 79 0 9 68 0
36 68 2 67 77 99 50 85 70
74 70 33 44 17 51 15 56 58
39 44 0 83 86 0 5 93 0
42 82 39 88 20 83 0 0 0
27 43 77 59 41 79 0 0 0
20 89 0 15 75 0 0 0 0
(2)当block_type为sliding时,将A分解平移一行(列)的mxn的子矩阵,并转换成列。
例: A=
21 11 62
95 14 57
8 17 5
B=im2col(A, [2, 2], 'sliding')为
21 95 11 14
95 8 14 17
11 14 62 57
14 17 57 5
A的红色对应于B的第1列,A的红色第2行和橙色对应与B的第2列。根据A为3×3和子块为2×2,最多可构成B的列数为((3-2)+1)×((3-2)+1)=4,列长(行数)为2×2=4。
注: 对于‘sliding’类型,如果设A为mxn的,[p q]的block 块,则最后矩阵的行(或列)的大小为:
(m-p+1) x (n-q+1)
应用实例——对矩阵进行m×n分块,用子块的和生成新矩阵。
B = im2col(A,[m n],'sliding');
C = reshape(sum(B),mm-m+1,nn-n+1);
功 能:将矩阵A分为m×n的子矩阵,再将每个子矩阵作为B的一列。
(1)当block_type为distinct时,将A分解为互不重叠的子矩阵,并转换成列。若不足m×n,以0补足。
例: A=
15 36 42 40 67 88 32 50
59 74 27 81 44 59 53 15
26 39 20 76 83 15 9 5
4 68 82 38 77 20 11 85
75 70 43 22 17 41 14 56
24 44 89 79 86 75 68 93
44 2 39 95 99 83 50 70
69 33 77 33 51 79 19 58
B=im2col(A, [3, 3], 'distinct')为:
15 4 44 40 38 95 32 11 50
59 75 69 81 22 33 53 14 19
26 24 0 76 79 0 9 68 0
36 68 2 67 77 99 50 85 70
74 70 33 44 17 51 15 56 58
39 44 0 83 86 0 5 93 0
42 82 39 88 20 83 0 0 0
27 43 77 59 41 79 0 0 0
20 89 0 15 75 0 0 0 0
(2)当block_type为sliding时,将A分解平移一行(列)的mxn的子矩阵,并转换成列。
例: A=
21 11 62
95 14 57
8 17 5
B=im2col(A, [2, 2], 'sliding')为
21 95 11 14
95 8 14 17
11 14 62 57
14 17 57 5
A的红色对应于B的第1列,A的红色第2行和橙色对应与B的第2列。根据A为3×3和子块为2×2,最多可构成B的列数为((3-2)+1)×((3-2)+1)=4,列长(行数)为2×2=4。
注: 对于‘sliding’类型,如果设A为mxn的,[p q]的block 块,则最后矩阵的行(或列)的大小为:
(m-p+1) x (n-q+1)
应用实例——对矩阵进行m×n分块,用子块的和生成新矩阵。
B = im2col(A,[m n],'sliding');
C = reshape(sum(B),mm-m+1,nn-n+1);
相关文章推荐
- matlab中“执行字符串”函数eval在不同情况下的用法(二)
- Matlab自带排序函数sort用法
- matlab中textread函数用法
- MATLAB中unique()函数的用法
- Matlab 的fspecial函数用法
- matlab中的灰度共生矩阵相关函数用法
- 简述Matlab中size()函数的用法
- matlab中zeros 和 ones 这两个函数的用法以及size的用法,princomp,pcacov,pcares,barttest四大分析函数用法
- matlab 中 mvnrnd 函数用法及举例
- matlab 函数meshgrid的用法
- MATLAB中repmat函数用法
- 几个MATLAB函数的用法
- 学习matlab中遇到的一些函数及其用法
- MATLAB中padarray函数用法
- 总结整理Matlab的plot函数用法
- matlab中的size(),length(),ndims()函数的用法
- matlab中size()函数的用法
- Matlab中的im2col函数
- matlab 中的sum 函数的用法
- MATLAB中nargin函数的用法nargin是用来判断输入变量个数的函数,这样就可以针对不同的情况执行不同的功能。通常可以用它来设定一些默认值。如下例所示: 函数文件 examp.m