QQ登录

只需要一步,快速开始

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

【转载】加速matlab运行的三个境界

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

1341

主题

738

听众

2万

积分

数学中国总编辑

  • TA的每日心情

    2016-11-18 10:46
  • 签到天数: 206 天

    [LV.7]常住居民III

    超级版主

    社区QQ达人 邮箱绑定达人 元老勋章 发帖功臣 新人进步奖 原创写作奖 最具活力勋章 风雨历程奖

    群组2011年第一期数学建模

    群组第一期sas基础实训课堂

    群组第二届数模基础实训

    群组2012第二期MCM/ICM优秀

    群组MCM优秀论文解析专题

    跳转到指定楼层
    1#
    发表于 2010-1-25 22:39 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    本帖最后由 厚积薄发 于 2010-1-25 22:54 编辑 # m& v6 h- x1 y( J: T4 T- L* A$ q* A5 M
    ( ~8 X8 B! n2 [
    加速matlab运行的三重境界

    加速matlab运行的三重境界
    / {/ q8 @2 ?9 r# C6 q%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    + s8 R+ @6 F* N# H3 W%%%%%%%%%%%%%%%%%%%%%%%
    ( l" P! W' I2 i+ T8 }# Z
    一、 遵守Performance Acceleration的规则
    8 w) X" H2 X- M; z二、 遵守三条规则; T' ], b' u/ F) G) G1 H& A
    三、 绝招
    : O: l: ~. x8 G; R% F" A% I%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%# |0 j+ m( l  u: }( V
    %%%%%%%%%%%%%%%%%%%%%%%

    一、 遵守Performance Acceleration的规则
    ( g% o7 r( |5 k: V( |0 b. y' N9 Z关于什么是“Performance Acceleration”请参阅matlab的帮助文件。我只简要的将+ D, G+ [* Y/ z- h; F
    其规则总结如下7条:& g$ b; B: m5 i4 p( S. b$ n
    1、只有使用以下数据类型,matlab才会对其加速:- Y- ~/ ?, P9 C
    logical,char,int8,uint8,int16,uint16,int32,uint32,double
      V2 N# v- ~: r
    而语句中如果使用了非以上的数据类型则不会加速,如:numeric,cell,structu
    # B4 v1 T8 J8 I+ Q( |) gre,single,; [# `3 z: t0 ?' K. X- m/ U  b
    function handle,java classes,user classes,int64,uint646 L' b, ~" l: x
    2
    matlab不会对超过三维的数组进行加速。

    5 v/ B" \, ]" F% c3、当使用for循环时,只有遵守以下规则才会被加速:afor循环的范围只用标量值/ n9 B: _! k& q
    来表示;
    " a* {5 y. g! u- @bfor循环内部的每一条语句都要满足上面的两条规则,即只使用支持加速的数
    : c3 w) y! A4 i2 [据类型,只使用
    ) l' l, ?; N9 X! i% x* o三维以下的数组;c、循环内只调用了内建函数(build-in function)。
    $ y0 V+ C" U% k# ~/ j3 @4、当使用ifelseifwhileswitch时,其条件测试语句中只使用了标量值时,将: e$ A( k3 ?) [
    加速运行。
    ) F: {) y) w- f, a5、不要在一行中写入多条操作,这样会减慢运行速度。即不要有这样的语句:. E  Y8 i3 c# t! M  d' }' h
    x = a.name; for k=1:10000, sin(A(k)), end;
    9 A2 C, C5 Y4 r- D. q& V: X6
    、当某条操作改变了原来变量的数据类型或形状(大小,维数)时将会减慢运行速7 [8 {# v* j) J& k
    度。
    2 k. E2 E5 w( d& i" ]) ]0 u5 x: v7、应该这样使用复常量x = 7 + 2i,而不应该这样使用:x = 7 + 2*i,后者会降低1 y! Z# S8 J! c  |
    运行速度。  i' V& n3 H/ r+ L
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%, N: j" _7 J5 A) C
    %%%%%%%%%%%%%%%%%%%%%%%
    6 g: T& R4 d& t* @/ m, r5 z
    二、 遵守三条规则
    # u" i9 |' q2 h* j% R  G' J8 w6 \1、尽量避免使用循环,MATLAB的文档中写到“MATLAB is a matrix language, whic
    % A5 s" t: X5 ^4 @h means it is designed
    / L, W* p% t& E% h. Efor vector and matrix operations. You can often speed up your M-file c
    3 C2 X; U5 R) V% N) M9 B5 D% Mode by using7 E0 r$ Y* B" a0 @/ C
    vectorizing algorithms that take advantage of this design. Vectorizati
    ) T* g7 Z% n7 Uon means converting1 \- {; n; k$ y! q2 L* j
    for and while loops to equivalent vector or matrix operations.”
    。改进

    ( z! R& Z0 B9 a9 z, U这样的状况有两种方法:& Y+ b, ^, C( `, I" ]/ b
    a、尽量用向量化的运算来代替循环操作。如将下面的程序:
      `# H/ i7 K! b1 ?1 @' Ai=0;4 P* a& s' \% p6 Q3 A5 T6 z2 W+ ^( ]% e
    for t = 0:.01:10; F& O+ v/ m  R
    i = i+1;
    4 X/ d+ V. Y0 p) [7 gy(i) = sin(t);. S2 i$ K6 l$ t9 F
    end
    ; ^9 E  `; H6 b( {
    替换为:) F" V9 q7 J% R6 n4 _
    t = 0:.01:10;
    ! J; s' |: Y% ]$ ]* q5 r9 Cy = sin(t);
    4 k  U; S3 @- o: k
    速度将会大大加快。最常用的使用vectorizing技术的函数有:Alldiffi0 t7 K% B" N6 l% Z0 y# m
    permute
    permute
    ) i5 f8 ~- S1 t0 G; h( c  `* P
    reshapesqueezeanyfindlogicalprodshiftdimsub2indcums
    0 O) z5 a6 A; Z  b( R6 mum
    ind2sub

    , V  |9 r/ k  i* c* D% `" lndgridrepmatsortsum 等。
    : R0 G2 c4 C' K+ _请注意matlan文档中还有这样一句补充:“Before taking the time to0 l8 i' `. U7 h+ Q
    vectorize your code, read the section on Performance Acceleration.
    $ U/ D# L* b7 r, ]3 j3 h4 _You may be able to5 S0 k3 m1 j0 @7 c+ s3 U: W
    speed up your program by just as much using the MATLAB JIT Accelera
    2 K7 l6 m9 Y. S' ctor instead of: U( M3 |( R6 e/ f  O' [
    vectorizing.”
    。何去何从,自己把握。
    1 e# F/ p* O- i# k( n, M
    b、在必须使用多重循环时下,如果两个循环执行的次数不同,则在循环的外环执  v2 R+ v* E& k8 E; a
    行循环次数少的,) j" _, E1 q# z, d. Z& L4 v
    内环执行循环次数多的。这样可以显著提高速度。
    3 q/ r2 r* l; K! A2a、预分配矩阵空间,即事先确定变量的大小,维数。这一类的函数有zeroson
    - y) ^( z, }! Q* oes
    cellstruct

    , o3 Q9 U" s# F7 O0 ~7 w* L1 o5 zrepmat等。& u% i' ~# G, _# F# E
    b、当要预分配一个非double型变量时使用repmat函数以加速,如将以下代码:$ @( k0 F- ~4 V' x" u$ y: u
    A = int8(zeros(100));- f( F& X" Z2 J" ?' K
    换成:
    * ~- C4 A! ^$ `A = repmat(int8(0), 100, 100);. p$ k* @( }: f
    c
    、当需要扩充一个变量的大小、维数时使用repmat函数。
    % z% ~$ Y! t, o( c' Q: `4 Y3a、优先使用matlab内建函数,将耗时的循环编写进MEX-File中以获得加速。
    ; O1 p1 S' N. j7 j7 ~b、使用Functions而不是Scripts
    - I2 {* @* C; P: |# M  M%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%7 d, L. c! Y0 C" Z0 j: X% I* ^
    %%%%%%%%%%%%%%%%%%%%%%%! I2 ~8 s) G' d, P+ L/ Y
    三、 绝招5 Y: r+ L8 X' l4 a7 h& _
    你也许觉得下面两条是屁话,但有时候它真的是解决问题的最好方法。4 G* q! e0 A) `6 u$ a( j
    1、改用更有效的算法
    4 M/ q8 Y, P+ \- b/ B5 u2、采用Mex技术,或者利用matlab提供的工具将程序转化为C语言、Fortran语言。


    / @5 K$ |! L& H* C" X3 A" B% e% Z5 j0 Q5 p' V  ~
      来源:iLoveMatlab" @7 p" L/ ]+ [+ d  r% y
    ( \* Y& ]9 l: N2 w+ A9 Z
    6 L1 G- k: K: s, s9 d  T6 T
    在这里本人推荐使用‘绝招’。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    XINGQIBIN 实名认证       

    0

    主题

    5

    听众

    94

    积分

    升级  93.68%

    该用户从未签到

    群组数模应用

    回复

    使用道具 举报

    HSinB 实名认证       

    0

    主题

    5

    听众

    1651

    积分

    升级  65.1%

  • TA的每日心情
    开心
    2012-2-9 17:19
  • 签到天数: 2 天

    [LV.1]初来乍到

    新人进步奖 发帖功臣

    回复

    使用道具 举报

    D-lin 实名认证       

    22

    主题

    5

    听众

    465

    积分

    升级  55%

    该用户从未签到

    自我介绍
    人称玉树临风胜潘安,一支梨花压海棠

    新人进步奖

    回复

    使用道具 举报

    leo12ok 实名认证       

    3

    主题

    4

    听众

    556

    积分

    升级  85.33%

  • TA的每日心情
    擦汗
    2012-6-14 16:31
  • 签到天数: 1 天

    [LV.1]初来乍到

    自我介绍
    200 字节以内

    不支持自定义 Discuz! 代码

    新人进步奖

    回复

    使用道具 举报

    0

    主题

    3

    听众

    95

    积分

    升级  94.74%

    该用户从未签到

    自我介绍
    嘿嘿~  可爱的我~
    回复

    使用道具 举报

    isnowfy 实名认证       

    6

    主题

    4

    听众

    473

    积分

    升级  57.67%

  • TA的每日心情
    开心
    2013-3-7 02:00
  • 签到天数: 1 天

    [LV.1]初来乍到

    自我介绍
    200 字节以内
    不支持自定义 Discuz! 代码

    新人进步奖 最具活力勋章 发帖功臣

    群组Matlab讨论组

    mark。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
    回复

    使用道具 举报

    27

    主题

    4

    听众

    196

    积分

    升级  48%

    该用户从未签到

    收藏了~~~对现在建模很有用……我上次写的程序就运行了N久都没出结果……郁闷……
    回复

    使用道具 举报

    schnee        

    0

    主题

    4

    听众

    241

    积分

    升级  70.5%

  • TA的每日心情
    开心
    2013-9-3 12:40
  • 签到天数: 18 天

    [LV.4]偶尔看看III

    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2025-8-22 06:50 , Processed in 1.086197 second(s), 99 queries .

    回顶部