EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
看Matlab的help文档讲得不是清楚。5 o% s$ |" |4 n
先给上一段代码:& E* O6 l ]2 V. F/ p5 B* J# A/ Z
>> a=[1 2 3;4 5 6;7 8 9;10 11 12];' T8 j; d- i. C
>> b=reshape(a,2,6);; t! x& Q% I3 v, l1 n
2 S$ m+ P/ [+ O2 Y这段代码的结果是这样的:
$ Y3 l5 ]/ i2 t: o, y>> a S' y: e2 d' ]' n9 q, b
1 2 3; l4 |" ]# L+ ~- z0 ]+ P% a
4 5 6
2 V, O9 f5 @8 c 7 8 9
1 n+ @1 B3 r' h6 Y" G 10 11 12! \2 W% Y- R; B% I9 N2 u
0 |/ x0 Y, ` n- i# e6 E ]
>> b$ m6 ~6 |5 {1 {8 A$ @9 d5 ?
1 7 2 8 3 9
" F$ Y+ C, A3 K$ g; H 4 10 5 11 6 12
, |/ K. j: Y/ X% E8 C5 G4 w0 _, O" Q& @8 J
对于 b=reshape(a,m,n);
* E. s' T1 i& j( h) M( Y' S其中的规律是这样的,先把矩阵a按列拆分,然后拼接成一个大小为m*n的向量。然后对这个向量每隔m间隔取一个元素组成一个向量b_i,之后的向量b_i+1也是这样生成,只不过第一个元素往下移一位。这样做完之后得到m个大小为n的行向量,将这些行向量拼接即可得到矩阵b。
0 a! U/ |! Q9 d2 W+ K) l: G; ]0 `: O# g
9 p- {+ m( y# u! N1 _: E8 c后记:毕业设计中用到一个向量变换,一开始比较纠结,用循环实现的。迭代1000多次要用到2秒。后来用reshape函数,总共才用了0.03秒,对于我这个深度强迫症患者来说,这两秒时间我还是看得比较宝贵的,哈哈。 以后写matlab要引以为鉴,尽量少用for循环,多用矩阵或者向量的方式来处理。
6 X3 u" h# }8 \! Z$ v, k
9 m; G+ ?' [, M: K |