QQ登录

只需要一步,快速开始

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

加速matlab运行的三重境界

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

37

主题

2

听众

557

积分

先知

升级  85.67%

该用户从未签到

新人进步奖 发帖功臣

跳转到指定楼层
1#
发表于 2004-12-21 11:00 |只看该作者 |倒序浏览
|招呼Ta 关注Ta

发信人: fork (撒哈拉沙漠的沙), 信区: Matlab! r6 |( l, a- |- \ 标 题: 加速matlab运行的三重境界 , ~$ z7 Y1 y7 z+ d c发信站: BBS 哈工大紫丁香站 (Thu Jul 1 14:27:30 2004)* T! l3 B6 i* P" j) W) W# E' k / j, }) v! k7 l; _2 _2 `加速matlab运行的三重境界

% P7 Q% B% E0 k. ?& d# L + T W E9 o3 W1 t( k& n

一、 遵守Performance Acceleration的规则/ F; n7 x- U7 q 4 H7 W2 Y: b- [% c关于什么是“Performance Acceleration”请参阅matlab的帮助文件。我只简要的将% X a) Y( w2 X% ?( j" d/ @) ~$ `5 { 其规则总结如下7条:. N7 C2 l H/ ` 1、只有使用以下数据类型,matlab才会对其加速:. B6 G) b# c' [0 Y4 ` logical,char,int8,uint8,int16,uint16,int32,uint32,double ) N# N( c8 e# W& z+ m5 C" r而语句中如果使用了非以上的数据类型则不会加速,如:numeric,cell,structu! m/ K# | b8 Q; m; Z; }! t re,single,9 M. Z/ ~/ y: t9 ]0 j0 c 6 `. t! Z* D0 S& q' j( Q1 H Hfunction handle,java classes,user classes,int64,uint649 _. ? r, e; c7 R 2、matlab不会对超过三维的数组进行加速。2 _9 ^- K6 V5 k8 K 3、当使用for循环时,只有遵守以下规则才会被加速:a、for循环的范围只用标量值 9 e! X: W% N5 [& V/ c来表示; ^5 y( b5 l9 _* lb、for循环内部的每一条语句都要满足上面的两条规则,即只使用支持加速的数 5 [' m* m5 b( [7 g: J3 Y据类型,只使用 $ e$ v1 q* r* |) q) r, }三维以下的数组;c、循环内只调用了内建函数(build-in function)。 1 V- Q% P# f3 z) }7 O4、当使用if、elseif、while和switch时,其条件测试语句中只使用了标量值时,将( R/ [# J% [: {# p2 C. }. X) ^ 加速运行。 8 o* Z- P; R' |/ e5 _& U1 B/ [# n5、不要在一行中写入多条操作,这样会减慢运行速度。即不要有这样的语句: ; j+ a% c7 r- x1 [* q0 R$ ~* o( t$ w2 ox = a.name; for k=1:10000, sin(A(k)), end;! X5 H; \7 L3 G$ [2 d* M. s 6、当某条操作改变了原来变量的数据类型或形状(大小,维数)时将会减慢运行速 ) B8 q8 m1 ]% m: b4 K: m8 m度。 ; o; }5 `; }1 {7、应该这样使用复常量x = 7 + 2i,而不应该这样使用:x = 7 + 2*i,后者会降低 ( X& z$ j3 w2 A运行速度。: O# c G+ _! w# ?4 H7 P% h" F

9 R& W/ I! U' r) Y1 s. E

二、 遵守三条规则- z- H$ t( N* o * \0 h4 S) S+ K 1、尽量避免使用循环,MATLAB的文档中写到“MATLAB is a matrix language, whic2 K) I- |/ Y2 _ h means it is designed 1 b- g$ n; T5 K6 z l, O/ |9 S# m6 `3 F7 u1 d- {" Y for vector and matrix operations. You can often speed up your M-file c ; l. S0 B1 b% e/ Gode by using & {2 o8 g' N6 d( W1 _5 Evectorizing algorithms that take advantage of this design. Vectorizati3 t8 J3 j3 g' t on means converting , Y- R/ O7 h- [" {3 |for and while loops to equivalent vector or matrix operations.”。改进" W, O5 R* e H \ 这样的状况有两种方法: " {% ^1 A o8 `- h( M6 E/ G9 h a、尽量用向量化的运算来代替循环操作。如将下面的程序:: W, S' [5 T! C8 v( }+ @! L$ z* M ; o( ]: L* q3 A+ r$ L' @; U i=0; ( h, ?' T% _3 K: D3 e, v" wfor t = 0:.01:10 : l4 [- c6 q' e8 E0 T3 {3 ]) Vi = i+1; & r G* d8 e& c; X; I' z& Cy(i) = sin(t);* a. a3 c+ d" O# {& d end5 o1 {1 f2 v. q5 a% D* h* J 替换为: ! F0 B2 w. z$ _ ?t = 0:.01:10;/ t: C0 |/ G9 J) k# L7 a y = sin(t); / B" `0 I; v- U- \$ o Q5 W速度将会大大加快。最常用的使用vectorizing技术的函数有:All、diff、i, n% k* o5 o. K% E' b. V permute、permute、$ J3 Q% Y# f* Q* _2 B6 Y. F0 s reshape、squeeze、any、find、logical、prod、shiftdim、sub2ind、cums - p4 A' D# q6 _1 w* M" T @, r; D0 Eum、ind2sub、' P) v8 |* m. Z+ \' H( h- ?" v$ ` ndgrid、repmat、sort、sum 等。 6 U+ z* T8 f" p, [8 z- R5 E+ a C3 d9 u" e0 d5 \8 z( r# u 请注意matlan文档中还有这样一句补充:“Before taking the time to - k% @: j8 |& x5 O/ l/ ^; h3 K8 P6 q- S# A% \5 U9 ^' H0 j4 J vectorize your code, read the section on Performance Acceleration. : U3 D3 B# Z8 x! k! x. K8 T4 }! y) \You may be able to $ I t( q. s. I# B2 tspeed up your program by just as much using the MATLAB JIT Accelera" ?+ g6 @5 J( W O" m tor instead of: D3 e3 m1 _" R3 u4 t) c- ` vectorizing.”。何去何从,自己把握。* X% r: ]9 n( v+ V$ N' l8 v9 I ; V" c: C- `2 @, Z# s( x& l; }$ d% [b、在必须使用多重循环时下,如果两个循环执行的次数不同,则在循环的外环执 + T4 K( B, I- ~行循环次数少的, 3 I; {8 i' o" G* j0 K8 C内环执行循环次数多的。这样可以显著提高速度。. [% I( S) R+ U$ p" E# v ; {, b3 }1 L1 O) m+ B4 i 2、a、预分配矩阵空间,即事先确定变量的大小,维数。这一类的函数有zeros、on' C5 c( A5 }- s5 T! r es、cell、struct、 # n# E0 e! E2 B1 `7 _ L; c/ v; Q1 Yrepmat等。 % E- V' \' r/ y; x* Zb、当要预分配一个非double型变量时使用repmat函数以加速,如将以下代码:# e7 K5 b1 x$ H0 J' Y/ Y 6 V* {' I7 G# E" } A = int8(zeros(100)); 5 W2 x) o3 e! p' b" H- Z: {+ }换成:& ~, E6 T* s+ R0 N) o' S A = repmat(int8(0), 100, 100);7 F4 m8 \- K" D3 F c、当需要扩充一个变量的大小、维数时使用repmat函数。 2 t" D2 T# ~1 ?9 M8 s# j: n6 w$ @$ U4 h6 F4 D$ v: H: O 3、a、优先使用matlab内建函数,将耗时的循环编写进MEX-File中以获得加速。) H) M- x! c) K) o" R8 W b、使用Functions而不是Scripts 。$ P! I# w; x y* K4 u2 X

! T# `+ p: X0 q* P- K

三、 绝招 & A2 T) Y! |. D$ o+ M3 C1 M % {5 M, R6 l% h$ X2 g8 M& p: P3 T- y你也许觉得下面两条是屁话,但有时候它真的是解决问题的最好方法。 " r# j- [4 \ ?. X6 u- g1、改用更有效的算法 / A8 C0 b9 J$ B- U5 t* Z! `" Z2、采用Mex技术,或者利用matlab提供的工具将程序转化为C语言、Fortran语言。 5 i' a' G& C+ A# w/ _4 _, r7 [: V, k* A0 ~' M( M# \ 关于如何将M文件转化为C语言程序运行,可以参阅本版帖子:“总结:m文件转化为c/c++, m! ^1 P8 j7 J8 Y2 l& L 语言文件,VC编译”。

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信

这是一个关于数学、物理、英语的网站。有很多免费资源!

http://zuozw.blogcn.com

fup        

0

主题

2

听众

43

积分

升级  40%

该用户从未签到

新人进步奖

回复

使用道具 举报

ornewuser        

0

主题

2

听众

23

积分

升级  18.95%

该用户从未签到

新人进步奖

回复

使用道具 举报

zzwszj        

37

主题

2

听众

557

积分

先知

升级  85.67%

该用户从未签到

新人进步奖 发帖功臣

注意

* e8 U) n0 @. P

加速之前应该先测试7 |$ L6 O: B# z# t3 N1 N 使用profiler可以获得程序各个部分的耗时3 M4 L6 f* z g2 ~; f 如此就能高效的加速 1 v" }0 M" e: I$ F/ ~9 L

7 ?% R; E8 c5 \1 X9 g' m- T; y

因为有的时候导致速度变慢的原因是逻辑结构不合理,4 |' P! A/ G, f, O3 Y( p# c 而不涉及程序技术

% w3 ~0 M/ t2 O* \7 [

这是一个关于数学、物理、英语的网站。有很多免费资源!

http://zuozw.blogcn.com

回复

使用道具 举报

0

主题

0

听众

21

积分

升级  16.84%

该用户从未签到

新人进步奖

回复

使用道具 举报

0

主题

0

听众

21

积分

升级  16.84%

该用户从未签到

新人进步奖

回复

使用道具 举报

布赖        

4

主题

2

听众

134

积分

升级  17%

该用户从未签到

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册地址

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.482290 second(s), 91 queries .

回顶部