EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
看Matlab的help文档讲得不是清楚。
5 g) d& N- C" O; ~9 m6 v先给上一段代码:
* h3 w% R) D4 I5 n. a8 g; i: D( Z# V; N>> a=[1 2 3;4 5 6;7 8 9;10 11 12];
/ E' q4 Z+ ?) `, t# K5 g0 S>> b=reshape(a,2,6);
" p" Y& i* Z0 T* o5 A/ F) b% Z; x5 K6 z0 c
这段代码的结果是这样的:
% q5 g" T3 d- [1 H, ]7 ~, ]>> a& ^; H) _) Z) _& x1 y
1 2 35 W/ r# l+ T1 }7 C& C
4 5 6/ m! l8 }1 x$ q& X; _ F
7 8 9+ {. X5 w1 H4 n
10 11 12
& M; Y1 O1 k; q% J3 A) b' u
5 X0 z9 ?. d3 _1 k>> b
3 U# m @9 o# T* D8 u5 m 1 7 2 8 3 9
% {6 F @" _" ` B 4 10 5 11 6 12- p" W: X. _& J/ D+ Q$ i/ R. q$ m
0 x$ w6 m5 ?* t' t. T对于 b=reshape(a,m,n);' L2 A' G7 v9 }1 l4 e @& J6 k
其中的规律是这样的,先把矩阵a按列拆分,然后拼接成一个大小为m*n的向量。然后对这个向量每隔m间隔取一个元素组成一个向量b_i,之后的向量b_i+1也是这样生成,只不过第一个元素往下移一位。这样做完之后得到m个大小为n的行向量,将这些行向量拼接即可得到矩阵b。/ V/ A% m5 X1 e! F
- Z: p& R. v+ m; T ( o1 O4 d) f6 R! R7 U& \1 d4 g
后记:毕业设计中用到一个向量变换,一开始比较纠结,用循环实现的。迭代1000多次要用到2秒。后来用reshape函数,总共才用了0.03秒,对于我这个深度强迫症患者来说,这两秒时间我还是看得比较宝贵的,哈哈。 以后写matlab要引以为鉴,尽量少用for循环,多用矩阵或者向量的方式来处理。* `2 d# r/ G G4 u% T5 }+ W7 s- P
9 j( \- K% i& k! Z) T |