QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2987|回复: 0
打印 上一主题 下一主题

[转帖]加速matlab运行的三重境界

[复制链接]
字体大小: 正常 放大
god        

206

主题

2

听众

882

积分

升级  70.5%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-1-20 10:27 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
信人: fork (撒哈拉沙漠的沙), 信区: Matlab
6 ^8 {3 p. B+ L/ X. }标 题: 加速matlab运行的三重境界# e+ i  J  [! x1 h& K
发信站: BBS 哈工大紫丁香站 (Thu Jul 1 14:27:30 2004)7 h  X1 F5 G, m  ]1 @+ [
' y$ c1 A2 N$ u9 k+ u; Y4 s5 Y
加速matlab运行的三重境界
) W8 o0 h) `) U9 O
" ]% ?; u8 |7 U% g%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
$ v% E9 k" [  l& J%%%%%%%%%%%%%%%%%%%%%%%8 G& ~' U3 w% |7 u* e' ^
一、 遵守Performance Acceleration的规则  x) G% \! @) k8 a5 [
二、 遵守三条规则
4 _/ f0 X$ j; f% q" S三、 绝招
( j6 u8 a1 {& `' m/ R7 ]% b3 [- F
2 W4 i" f! O8 L" P; M%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%) M- W2 E3 q% y8 k0 S6 l9 b" g
%%%%%%%%%%%%%%%%%%%%%%%+ @% R0 J3 X% a9 i6 l7 c
一、 遵守Performance Acceleration的规则/ g! b" J4 r8 b2 F  K

% h; |4 f* ^6 B8 S7 Z关于什么是“Performance Acceleration”请参阅matlab的帮助文件。我只简要的将8 ?) j( }9 i. O& o2 n! B/ s+ e
其规则总结如下7条:2 f3 {5 e: w% }4 \
1、只有使用以下数据类型,matlab才会对其加速:
( `8 l% ^) F9 H3 Q9 S" W0 w$ _logical,char,int8,uint8,int16,uint16,int32,uint32,double
, w6 ?- r, y- }3 G, d; h, }( N而语句中如果使用了非以上的数据类型则不会加速,如:numeric,cell,structu3 {5 m1 C$ G, ]! f; N1 k% S
re,single,- w2 o1 [, P3 Q  K' z' C  Y4 A6 F  \
1 k7 `! }% J) r$ K
function handle,java classes,user classes,int64,uint646 Q( |& J' k; s1 [
2、matlab不会对超过三维的数组进行加速。) i+ ]* Z3 J2 o# }# ^# T
3、当使用for循环时,只有遵守以下规则才会被加速:a、for循环的范围只用标量值: j1 ?; L- o) h$ ]
来表示;2 O7 \4 |" i, k3 ~1 u/ Q6 t& i8 r& N
b、for循环内部的每一条语句都要满足上面的两条规则,即只使用支持加速的数
$ v4 _6 e5 n: `: z* y1 k2 O$ u* I8 D据类型,只使用
& m0 I* P" j& u9 O, W5 f# ?( Z& r三维以下的数组;c、循环内只调用了内建函数(build-in function)。
! g$ K1 O) S, ]& J4、当使用if、elseif、while和switch时,其条件测试语句中只使用了标量值时,将8 q# D8 @3 O8 s+ B1 L' ~, e1 o9 T. D0 F
加速运行。
/ P+ x1 n: m) L0 z5、不要在一行中写入多条操作,这样会减慢运行速度。即不要有这样的语句:. e8 t" I8 [8 D9 b
x = a.name; for k=1:10000, sin(A(k)), end;0 T5 K8 C% ?5 J8 c3 n) I- h
6、当某条操作改变了原来变量的数据类型或形状(大小,维数)时将会减慢运行速+ o: y- a- O; r" u1 ~
度。
7 ]; s: h/ D- i2 K+ j" Z7、应该这样使用复常量x = 7 + 2i,而不应该这样使用:x = 7 + 2*i,后者会降低' r" ^# ]3 N9 I0 \
运行速度。) ^+ Y8 f" M$ d; X+ x- E- Z

% f! ?$ |+ ~  O% k5 B. N. v) I! c%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%* Q  L4 i0 ^9 O$ E" Z
%%%%%%%%%%%%%%%%%%%%%%%
8 k3 p5 Y4 ~' S8 t二、 遵守三条规则  _; y0 |7 ^, O
/ `" l' f5 o2 ~! [* \+ \% ^
1、尽量避免使用循环,MATLAB的文档中写到“MATLAB is a matrix language, whic" U4 @/ y5 S0 o, }
h means it is designed
; Z" h% R3 [- N  Z/ M) z8 c5 R
: f# Y) Z: ~3 q% zfor vector and matrix operations. You can often speed up your M-file c
5 P' ?9 C7 ?  f2 y, m6 Kode by using
1 y) E! \5 n& S6 y! B2 }vectorizing algorithms that take advantage of this design. Vectorizati
. E: j, Q8 F, K3 q! v& [* aon means converting
* x6 B+ `) R: ]: rfor and while loops to equivalent vector or matrix operations.”。改进/ w* H& C6 H& n, O5 b- ~% W$ v
这样的状况有两种方法:0 a4 O# \! x5 @( i
2 C: [, I  l- X: t7 ~$ E
a、尽量用向量化的运算来代替循环操作。如将下面的程序:
8 U! C! v# ~( g) R; V' y
7 g* E, P' ^% Ni=0;4 L9 h& h3 i% P7 K. o
for t = 0:.01:10
8 y) I3 T: V5 zi = i+1;  v, C; e" y) k8 B) _
y(i) = sin(t);
# d3 q% t; \: gend7 G) w3 I/ a  F8 `( x3 F! M7 L9 Z& A
替换为:
/ e" e& j' D! U6 [, }t = 0:.01:10;
9 T$ \. V; p7 L" c% b3 e1 ky = sin(t);
) v3 V, V+ B4 I( S6 x9 e速度将会大大加快。最常用的使用vectorizing技术的函数有:All、diff、i0 D2 D% t, P+ b
permute、permute、& X) Q9 b: h# y  P
reshape、squeeze、any、find、logical、prod、shiftdim、sub2ind、cums) k5 D: e$ u% ^8 g" U" W& z
um、ind2sub、
% P5 _5 w. u) v$ Q, Gndgrid、repmat、sort、sum 等。
: U+ X" q8 d, x# d4 F& b9 B8 z% h  k+ Z
请注意matlan文档中还有这样一句补充:“Before taking the time to
1 h7 N. S2 _: K- i- j: h8 b, l+ a3 d! C. e2 |) e4 I
vectorize your code, read the section on Performance Acceleration.5 `4 k( l! i* c6 v% r2 _: S
You may be able to& ~, p8 |0 [$ E1 ^1 O0 b
speed up your program by just as much using the MATLAB JIT Accelera
2 [& K6 e' H3 h! J, itor instead of3 ^/ |2 H! D, v) \9 R& E( B, z) |/ j
vectorizing.”。何去何从,自己把握。5 z4 ^" _$ \4 |5 v
& m2 d# t) Z' J0 t5 n
b、在必须使用多重循环时下,如果两个循环执行的次数不同,则在循环的外环执- H1 o0 B, R5 T) m% B0 j6 P& p, M
行循环次数少的,
/ A% v# Q8 i8 D2 d内环执行循环次数多的。这样可以显著提高速度。5 B# Q6 d0 R2 ]7 N% Z

2 h7 e# R3 l4 U4 l2、a、预分配矩阵空间,即事先确定变量的大小,维数。这一类的函数有zeros、on
" y' ]- r1 g1 t1 Ies、cell、struct、; g: o, k$ i, ], U6 ]- C
repmat等。% b4 o; B2 ]: M8 G! d
b、当要预分配一个非double型变量时使用repmat函数以加速,如将以下代码:
: r- P4 d  H$ Z1 c; {. ~7 ]4 r2 g2 Q
A = int8(zeros(100));% w" A. H( w0 _3 t* Q! U' {) o
换成:
3 p; c; X" ~- S0 D3 NA = repmat(int8(0), 100, 100);
6 ]. K  C/ `; D; {, K/ q$ Vc、当需要扩充一个变量的大小、维数时使用repmat函数。
" u& ]6 h8 z4 ~) A1 m' A! [0 r  {8 G: h  D' R. u
3、a、优先使用matlab内建函数,将耗时的循环编写进MEX-File中以获得加速。
. S- M; C3 j- h3 w$ {$ _b、使用Functions而不是Scripts 。+ i' Y: _( T9 S2 w" u
; O9 w8 o: ~& J0 M: A0 y0 o
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
- W* d. N  `7 p& a%%%%%%%%%%%%%%%%%%%%%%%2 y- e8 H: Q3 L, o! z) O. V
三、 绝招: Z, `$ s( Y6 o# y: @% c

+ t. j8 M5 K% E9 v$ d你也许觉得下面两条是屁话,但有时候它真的是解决问题的最好方法。/ s3 o3 `' ?' E1 I2 z) `
1、改用更有效的算法
) }& r  U: N8 w6 d2、采用Mex技术,或者利用matlab提供的工具将程序转化为C语言、Fortran语言。( M& j; Q6 G; P
! ?; I& w. _6 Y  l  `0 S2 ~' Q, i
关于如何将M文件转化为C语言程序运行,可以参阅本版帖子:“总结:m文件转化为c/c++2 \# a# `+ F6 j
语言文件,VC编译
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
如果我没给你翅膀,你要学会用理想去飞翔!!!
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-14 12:12 , Processed in 0.395152 second(s), 52 queries .

回顶部