EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
看Matlab的help文档讲得不是清楚。1 Y1 z5 [8 \+ |' R7 e4 j8 X
先给上一段代码:$ J+ r w* Z" z1 I9 H8 M) Z. n9 y4 I
>> a=[1 2 3;4 5 6;7 8 9;10 11 12];. l) P5 d" Q5 ]
>> b=reshape(a,2,6);
" `7 G' e9 e$ \6 R0 q+ C
' X* A1 {2 Y+ k1 s5 X7 x这段代码的结果是这样的:9 x$ v$ z' @5 M; a! ?! ~% j% T5 H N
>> a
$ s+ _+ H/ b- [* ]2 n5 t$ q 1 2 3' Z# x# O8 s9 F9 A, z, b- O
4 5 6. d9 c+ b* b. i0 ~' U
7 8 95 h" S z: A# m( j6 v, z
10 11 12
9 ~- Z# Y& Y7 {: {( n7 g% t, n% D& r) E3 b0 W6 r
>> b
5 w& n- A/ ^: _: B5 i) W# W 1 7 2 8 3 9
0 v% B: C0 W2 x! Z0 _ 4 10 5 11 6 12
. E4 F, C, y2 ^% z* b4 i( A/ u1 J0 z( h, z; t
对于 b=reshape(a,m,n);5 M. D1 ]) {' s* H' F1 \. N0 n
其中的规律是这样的,先把矩阵a按列拆分,然后拼接成一个大小为m*n的向量。然后对这个向量每隔m间隔取一个元素组成一个向量b_i,之后的向量b_i+1也是这样生成,只不过第一个元素往下移一位。这样做完之后得到m个大小为n的行向量,将这些行向量拼接即可得到矩阵b。+ e$ Y. D# B% l% C
8 G) S9 o% w* `6 }, D
, `7 W5 u& P/ _/ X0 p后记:毕业设计中用到一个向量变换,一开始比较纠结,用循环实现的。迭代1000多次要用到2秒。后来用reshape函数,总共才用了0.03秒,对于我这个深度强迫症患者来说,这两秒时间我还是看得比较宝贵的,哈哈。 以后写matlab要引以为鉴,尽量少用for循环,多用矩阵或者向量的方式来处理。, N, c7 D+ R0 t% q c7 j
& A4 [ R1 i3 ~1 ]4 m1 D |