EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
看Matlab的help文档讲得不是清楚。
( g' _) o6 J5 Y* }2 K1 a' F2 r先给上一段代码:6 q* X! J: D! }, M
>> a=[1 2 3;4 5 6;7 8 9;10 11 12];, Z0 C+ m2 _6 ]& M
>> b=reshape(a,2,6);5 _9 s4 e% Q2 j6 M/ |. ?5 c( l
. G* z8 _; V3 u4 H) z
这段代码的结果是这样的:% h) R. N3 X2 _& L7 u
>> a( A- S/ x* v0 g& C
1 2 30 P4 l+ Z$ a4 |3 B' ~* @6 q. ]
4 5 6
: O+ R: m8 i; q7 u5 l$ r+ }. z9 H 7 8 9% u! l% @5 E/ h7 V. ]/ Q
10 11 12
" B1 x f% z7 @0 }
9 H9 S) h8 u) Q>> b
) L- e0 D- f3 X( Z- v 1 7 2 8 3 9
5 I& g: L9 w0 e* \& D 4 10 5 11 6 12) x, L2 v$ X$ ^$ b Q
% R1 O6 E2 n8 `8 ^对于 b=reshape(a,m,n);
& {/ n ?8 s# E- ?9 S7 x( w1 L3 @其中的规律是这样的,先把矩阵a按列拆分,然后拼接成一个大小为m*n的向量。然后对这个向量每隔m间隔取一个元素组成一个向量b_i,之后的向量b_i+1也是这样生成,只不过第一个元素往下移一位。这样做完之后得到m个大小为n的行向量,将这些行向量拼接即可得到矩阵b。/ e; P( P4 a- x' m8 l
1 e- @# I; v" M. d$ | ) E( d: w: |$ c$ a* ~! @
后记:毕业设计中用到一个向量变换,一开始比较纠结,用循环实现的。迭代1000多次要用到2秒。后来用reshape函数,总共才用了0.03秒,对于我这个深度强迫症患者来说,这两秒时间我还是看得比较宝贵的,哈哈。 以后写matlab要引以为鉴,尽量少用for循环,多用矩阵或者向量的方式来处理。; F, A. t1 Y) t$ J, T/ Z
R8 j% T/ H( o# e$ e. m
|