QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9344|回复: 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、小矩阵大运算量测试* p0 P# ^2 ?: X1 e6 g4 _

    " t- ~) G- {2 ]9 ^" g) qMatlab 2009a代码及结果:
    1. clear all9 l! z1 g& H  V5 l9 F8 `
    2. tic
        T1 D# R) Q7 I8 X  P) p/ y
    3. k = zeros(5,5); % //生成5×5全0矩阵9 U4 T' g! J- P6 c, \' G
    4. % 循环计算以下程序段100000次:% l. \6 r4 ?7 w' G4 Z! P
    5. for m = 1:100000
      ( f% h% f. N5 e1 q
    6.     a = rand(5,7);
      4 h5 |+ i' A# _% @, g, ^7 y7 _: f- C
    7.     b = rand(7,5);%//生成5×7矩阵a,7×5矩阵b,用0~1之间的随机数初始化
      2 x/ e% `1 {  U- B3 O
    8.     k = k + a * b + a(1:5, 2:6) * b(2:6, 1:5) - a(:, 7) * b(3, :);
      / @) n! p+ D9 X2 r% K\" @
    9. end8 T/ y- A8 {2 E; T* G6 j* U6 R
    10. k! n& e( g; X; n\" b
    11. toc
      : a, g1 v; @1 x3 c4 n9 c
    12. & o+ \3 C( C! V% i! [) c
    13. k =
      * [0 o( K6 U( M  t7 f) n

    14. 6 @: i9 H, d1 t8 E% o( Y\" x
    15.   1.0e+005 *3 B' V6 x# T: ]. {7 r

    16. - B$ l/ d( i* R, X) ]# g7 J3 @' Y
    17.     2.7525    2.7559    2.7481    2.7525    2.7511
      2 n7 u6 O' _: x+ T# n- t& P' D9 d
    18.     2.7527    2.7535    2.7430    2.7545    2.7484
      0 f\" e7 V/ D0 l\" W3 {
    19.     2.7493    2.7553    2.7440    2.7513    2.74859 D. q0 Q) O% ?8 H% a
    20.     2.7481    2.7506    2.7425    2.7457    2.7460' L- j) Z6 M, Y
    21.     2.7506    2.7525    2.7429    2.7488    2.74517 K0 E7 B8 }- W7 D1 w

    22. . A3 L% I: |; _1 j/ [
    23. Elapsed time is 1.979852 seconds.
    复制代码
    ===================
    # \# y0 ^" c9 L0 }
    + Q; b% i6 P8 @+ G0 y& @- NForcal(OpenFC演示)代码:
    1. !using["math","sys"];
    2. 4 O6 I& @7 T5 |. W, X
    3. (:t0,k,i,a,b)=
    4. % K5 T; \; m& _7 N$ j
    5. {( N6 ^% Y, h# j\\" s4 `. O4 k1 q3 t
    6.   t0=clock(),
    7. * c! }3 @. R2 L4 \. _
    8.   k=zeros[5,5],) B1 w$ C1 N& j
    9.   i=0,(i<100000).while{\\" J6 k$ Q7 d* z( I0 b/ P6 x
    10.     oo{
    11. 1 t: x9 f0 Y\\" L+ O\\" l
    12.       a=rand[5,7], b=rand[7,5],  V' F8 K, V* `9 @0 M, E2 V2 b
    13.       k.=k+a*b+a(0,4:1,5)*b(1,5:0,4)-a(neg:6)*b(3:neg)
    14. ) V/ x' p6 y* p6 f
    15.     },$ K# n# N7 k5 D) a* Q
    16.     i++
    17.   W& a$ o1 h7 x1 s
    18.   },
    19. : }+ L/ X# R) l5 ~/ D2 @& F
    20.   k.outm().delete(),
    21. 0 g6 \5 z# H. `3 o
    22.   [clock()-t0]/1000
    23. \\" y8 P5 J& X, m3 a# `& @
    24. };
    结果:
    1.          274978         274892         274913         274949         274953+ g! X9 [; }, e% |
    2.          274994         275050         275001         275037         274892
      9 @& \/ ~4 ]0 J6 I( w) r
    3.          275001         275063         275019         274963         274971
      8 {3 o/ S& r3 L8 `0 [
    4.          274945         274999         275017         274983         274982
      7 c- A3 U& ^; ^
    5.          275009         274984         274971         274955         274923
      ) G; h: F5 Y8 V. U* M& R) A
    6. ) W; }\" Y\" ~( d5 P2 D
    7. 3.516  秒
    复制代码
    此类运算Forcal的效率有Matlab的一半稍多一点。' c; Z0 h' ]. Y
    $ d+ S& B  S" T2 O
    ==================
      z! Q4 H5 i! K% f! H==================
    . Q) F0 [1 k3 n% S
    3 W3 e; o/ z/ T2、大型矩阵乘
    " L& T" x: H1 B% R& N" v7 u3 K9 e  N8 {3 i- Y! E
    Matlab 2009a代码及结果:
    1. clear all
      ( S* G* @. C4 H5 f0 _\" O2 J
    2. a = rand(1000,1000);
      . S; V9 u  G+ q3 {2 w\" @
    3. b = rand(1000,1000);
      - ~: Q! ^# ?* [/ \5 e
    4. tic
      3 g9 Q  N5 V; @) \0 H! p
    5. k = a * b;9 X; |% G3 a8 L# _- F) C: i
    6. k(1:3, 5:9)
      . d1 Q) j/ A+ t: j5 o- J& \, l: X& y
    7. toc4 A+ K6 h8 y: c
    8. + {1 a0 C% }/ l1 g4 v
    9. ans =
      + L5 j5 ]7 s! P, l

    10. 0 x  W/ u+ ]4 f
    11.   246.1003  244.3288  252.9674  258.1527  243.9345) R( Z! w( U0 A9 p
    12.   246.7404  236.1487  249.7140  251.3887  246.02948 l) M7 T! A# X* u# M7 v2 u0 L
    13.   249.4205  240.5515  252.5847  257.0065  249.71374 W9 g1 C& E+ \& z& l2 e3 L. x: `4 o
    14. * r: E1 k- S\" @1 C! m7 p) W+ B6 S
    15. Elapsed time is 0.310022 seconds.
    复制代码
    ===================/ t: |4 r2 |3 Y4 b# R* z: _( I
    ) _  E' a+ C  o9 s
    Forcal(OpenFC演示)代码:
    1. !using["math","sys"];
    2. . e# S: q* ]. v6 o1 z9 I
    3. main(:a,b,k,t0)=4 U& r9 A% O: s# ^* y6 O0 ~\\" B
    4. oo{' J$ U4 u3 k0 x5 X' H
    5.   a=rand[1000,1000], b=rand[1000,1000],3 I& _# C  M4 K
    6.   t0=clock(),
    7. # {* q, d& S+ {( a$ _
    8.   k=a*b,  //矩阵乘$ H4 U1 z4 \& |8 {$ Y& ?1 }3 L
    9.   k[1,3:5,9].outm()
    10. 8 r) P! K, P2 g9 q) k
    11. },3 _5 A+ H7 o+ U- F, h: H
    12. [clock()-t0]/1000;
    结果:
    1.         247.009        245.731        242.454        247.412        244.482( q* s! B/ u. k+ A. X
    2.         258.268        255.417        253.738        255.159        253.042
        |: w3 C2 _0 E2 Q, ~
    3.         258.088        252.324        248.927        252.392        247.731
      ( U# K3 H2 ?% P
    4. ; M0 @# G! F5 j$ t
    5. 2.25
    复制代码
    此类运算Matlab的速度约是Forcal的7倍多。
    . y# I* b$ h5 |1 c( R, O  k. D# X0 [! A( c1 q+ D
    ==================. P9 Y5 T+ @* K6 f7 t/ \9 f! M
    ==================
    6 @, [# B5 u" ~0 L: f2 o) A8 f( ]4 r6 H2 e
    矩阵运算是Matlab的优势。不过,个人认为,矩阵计算速度取决于算法,矩阵算法只是众多数值算法的一种,不属于语言的基本特性。然而,拥有高效的矩阵算法是matlab的骄傲,就像优化算法是1stopt的骄傲一样。) F* n: A: z7 w4 H

    " y& @3 v" H, s, m, ^0 qForcal的矩阵乘是用普通的矩阵乘经过改进而成的,效率自然低,但所有的数值算法包括矩阵运算是由Forcal扩展库实现的,只要有高效的算法,Forcal便可大展身手,为所有这些算法提高更高效的服务。
    * E- m+ }1 v) }' L5 e" M: ~9 ]9 i
    除了矩阵运算,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-6-11 11:44 , Processed in 0.657806 second(s), 84 queries .

    回顶部