QQ登录

只需要一步,快速开始

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

极限测试之Matlab与Forcal矩阵运算效率测试

[复制链接]
字体大小: 正常 放大
forcal 实名认证       

45

主题

3

听众

282

积分

升级  91%

  • TA的每日心情
    难过
    2012-8-27 18:22
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2011-8-1 08:00 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    1、小矩阵大运算量测试: C* [) H, _2 y3 E' n& l1 e0 t0 y% f

    ! D  P& H/ w' O5 o2 l0 MMatlab 2009a代码及结果:
    1. clear all
      ! Q1 B+ L) z1 L& E7 S
    2. tic
      * {& H: b* a: D, L0 E\" S/ `$ X: [
    3. k = zeros(5,5); % //生成5×5全0矩阵
      , o8 K/ n6 G7 \7 I) ^
    4. % 循环计算以下程序段100000次:
      * k9 K* C- Z$ z/ U) J- q; ]
    5. for m = 1:100000+ b5 ?' {1 K; K* T* x( e% ~
    6.     a = rand(5,7);% \9 b$ B! o0 K- U6 L2 ~
    7.     b = rand(7,5);%//生成5×7矩阵a,7×5矩阵b,用0~1之间的随机数初始化
      ! R0 y7 a0 p* l1 q  @& w) `
    8.     k = k + a * b + a(1:5, 2:6) * b(2:6, 1:5) - a(:, 7) * b(3, :);
      $ ?& T5 }) R9 s
    9. end+ V* p0 d$ V2 X5 d! E% C3 [  J
    10. k+ t% M$ g9 t' w( w
    11. toc# Q, L5 n$ e  E
    12. ' r/ F' q9 v2 n5 b  K
    13. k =
      3 j0 @7 h* ?8 y1 E: H4 r/ {

    14. ) s$ n: l0 C( S) |. Q* {9 s0 Z
    15.   1.0e+005 *
      5 B* p( E7 F& ^$ J* L# v
    16. 6 q+ j* ]( y# U$ s7 R' L
    17.     2.7525    2.7559    2.7481    2.7525    2.7511
      1 h& v& W1 X  w; o! K
    18.     2.7527    2.7535    2.7430    2.7545    2.7484
      * S\" O/ k\" S, G5 s; g' f$ r
    19.     2.7493    2.7553    2.7440    2.7513    2.7485
      / s* O% `3 {/ R( A- x- ]
    20.     2.7481    2.7506    2.7425    2.7457    2.7460. o- k! p7 Z: r: |
    21.     2.7506    2.7525    2.7429    2.7488    2.7451
      2 t8 ]0 T! t8 d# y0 c  w
    22. ( X, |2 Y3 o) P6 ^  \( b; b
    23. Elapsed time is 1.979852 seconds.
    复制代码
    ===================
    & j! n+ A1 E4 i1 H& V- B9 W- s, b8 M9 V
    Forcal(OpenFC演示)代码:
    1. !using["math","sys"];) N* r: ]/ P  n2 `
    2. (:t0,k,i,a,b)=
    3. 4 [\\" E8 ?# U! [, @) |0 y
    4. {! W: j, d- s: ^' @
    5.   t0=clock(),! j  g6 v+ z% B# s1 L5 a\\" ^
    6.   k=zeros[5,5],% T; x2 X; Q. Y: Y6 i3 A' g
    7.   i=0,(i<100000).while{3 Y3 ?  }+ e% x0 K. z\\" O* a4 j3 e
    8.     oo{
    9. 5 J  z* X/ T. o+ I' A/ W
    10.       a=rand[5,7], b=rand[7,5],6 ^& P) b7 V9 J% h9 j; j/ H, I+ T
    11.       k.=k+a*b+a(0,4:1,5)*b(1,5:0,4)-a(neg:6)*b(3:neg)
    12. 4 B7 E( u0 D7 S- e' N2 C\\" C
    13.     },
    14.   `/ J# j, F& l0 t* C) {
    15.     i++5 s/ T0 s2 G2 d$ [: n! Z
    16.   },, x) ^% j\\" a6 d, F2 ?  b
    17.   k.outm().delete(),% J2 L% ?1 q3 R! `& |& D! n
    18.   [clock()-t0]/1000
    19. 4 K+ H6 ~  v1 R! F9 N  a# c% ^* T
    20. };
    结果:
    1.          274978         274892         274913         274949         274953  ^  a- c* D! `* ?
    2.          274994         275050         275001         275037         274892
      3 z. u# l9 x' |# R: m% L+ s% `
    3.          275001         275063         275019         274963         274971$ V9 w+ \4 f6 G
    4.          274945         274999         275017         274983         274982
      , E4 Z5 n7 E% _. h
    5.          275009         274984         274971         274955         274923, \. C( Y7 H1 G* Z7 ^8 J+ ]/ n3 C
    6. * s% ^& e* p2 H5 n
    7. 3.516  秒
    复制代码
    此类运算Forcal的效率有Matlab的一半稍多一点。
    8 O1 e$ G- K; x9 Q4 t
    , T! G. M8 a8 V6 r& ^2 I==================- d4 r% }( w9 r# p$ }4 i2 B; ?
    ==================! q+ @# _, @5 L* X3 a7 `. z! c

    7 M1 F$ E, E$ t0 P& l; y1 v- S2、大型矩阵乘: u, f3 a6 z9 c) u( Q
    2 u" j8 W  f  O8 f
    Matlab 2009a代码及结果:
    1. clear all# ^. a  K  X# z( B
    2. a = rand(1000,1000);
      $ Q5 N8 l) d6 r, p, s1 a. Z
    3. b = rand(1000,1000);# @) o: [1 O) y( f$ |
    4. tic  A/ z. j5 K\" M9 {* t
    5. k = a * b;
      1 X0 f8 `, P) r( k
    6. k(1:3, 5:9)
      4 j  D+ S7 ]: i2 f  q
    7. toc0 C, s+ J4 Z% N$ D' g' y' U* ?

    8. 9 m) }; `5 u  R9 H4 X. J
    9. ans =
      / p; @0 \! z7 x& y  S5 A

    10. 6 t( k; E3 N; g
    11.   246.1003  244.3288  252.9674  258.1527  243.93459 \+ P* M3 ]2 g
    12.   246.7404  236.1487  249.7140  251.3887  246.0294
      1 ^. _# D+ y* m5 l& ]! ]0 T) \
    13.   249.4205  240.5515  252.5847  257.0065  249.7137% n# A) H8 `7 M! K/ Z; O. ]  a
    14.   o* N6 T6 K# G$ D
    15. Elapsed time is 0.310022 seconds.
    复制代码
    ===================0 w* o) X6 T3 A( l1 t

    : s( u$ S, u: A0 |: eForcal(OpenFC演示)代码:
    1. !using["math","sys"];\\" y2 I3 u0 `, o5 r0 l. z
    2. main(:a,b,k,t0)=
    3. 4 o0 I7 \$ B0 [3 Y
    4. oo{
    5. 0 a8 }) i& E9 l3 f8 \' f7 v
    6.   a=rand[1000,1000], b=rand[1000,1000],$ @; }\\" e\\" |+ A) Q+ n
    7.   t0=clock(),
    8. 4 x' b- {+ f2 x, H6 `* s6 ?- S
    9.   k=a*b,  //矩阵乘
    10. ; _/ U& u) t* X8 E  j$ j5 f
    11.   k[1,3:5,9].outm()
    12. 8 _1 Q( V6 ?\\" S2 e, @\\" M
    13. },
    14. 6 ^1 T5 o& ]$ |8 i( K! ~
    15. [clock()-t0]/1000;
    结果:
    1.         247.009        245.731        242.454        247.412        244.482
      + ?8 b) e4 J6 F
    2.         258.268        255.417        253.738        255.159        253.042# m2 y4 b$ H, b* o/ K* e
    3.         258.088        252.324        248.927        252.392        247.731
      / m* N( }9 [, [- d( W
    4. 0 i; j  V! s! ~& S+ h$ Z9 v
    5. 2.25
    复制代码
    此类运算Matlab的速度约是Forcal的7倍多。
    + d( A  {7 R9 |+ f" x* `4 I' d
      m/ O; o) A( Y" M% r==================0 ]& H$ \- B. X$ ?! o$ a: H2 o6 I+ N; n
    ==================
    7 _) p4 N( q. p" a! ?
    ; `- k& g. C& R- Q' ]矩阵运算是Matlab的优势。不过,个人认为,矩阵计算速度取决于算法,矩阵算法只是众多数值算法的一种,不属于语言的基本特性。然而,拥有高效的矩阵算法是matlab的骄傲,就像优化算法是1stopt的骄傲一样。
    4 f, ?- m  q' C( m8 f: s, T( l( s/ P+ e7 ^6 p1 B. t
    Forcal的矩阵乘是用普通的矩阵乘经过改进而成的,效率自然低,但所有的数值算法包括矩阵运算是由Forcal扩展库实现的,只要有高效的算法,Forcal便可大展身手,为所有这些算法提高更高效的服务。
    , z; v/ s# f* H# Z
    ' \; l7 M3 l- a) ]3 f* d  i' G, P除了矩阵运算,Matlab还有许多非语言特性的优势,例如函数图形功能(不包括其GUI,Forcal是嵌入式脚本,C/C++、Delphi等的GUI就是Forcal的GUI)、符号计算功能、控制仿真、金融建模等等。这些实用方便的算法模块使matlab获得了广大用户的青睐。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    chairong 实名认证       

    0

    主题

    3

    听众

    761

    积分

    升级  40.25%

  • TA的每日心情
    无聊
    2012-6-23 22:06
  • 签到天数: 207 天

    [LV.7]常住居民III

    自我介绍
    抬头吃太阳

    群组岩土力学与地下工程

    群组中国矿业大学数模培训

    回复

    使用道具 举报

    8

    主题

    2

    听众

    145

    积分

    升级  22.5%

  • TA的每日心情
    郁闷
    2011-9-17 10:59
  • 签到天数: 25 天

    [LV.4]偶尔看看III

    回复

    使用道具 举报

    0

    主题

    3

    听众

    56

    积分

    升级  53.68%

  • TA的每日心情
    开心
    2011-12-23 20:56
  • 签到天数: 12 天

    [LV.3]偶尔看看II

    回复

    使用道具 举报

    alair005        
    头像被屏蔽

    0

    主题

    4

    听众

    782

    积分

    升级  45.5%

  • TA的每日心情

    2012-2-7 08:08
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    提示: 作者被禁止或删除 内容自动屏蔽
    回复

    使用道具 举报

    0

    主题

    0

    听众

    5

    积分

    升级  0%

    该用户从未签到

    自我介绍
    888888
    济南夜场招聘,济南翰林商务会所招聘夜场模特佳丽13156404415,400每台,小费日结无押金。qlktv.net
    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2024-4-27 11:44 , Processed in 0.630263 second(s), 89 queries .

    回顶部