QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9202|回复: 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、小矩阵大运算量测试
    - q, c! ?1 G# g0 v& S% i6 K' t6 a' q/ m
    Matlab 2009a代码及结果:
    1. clear all
      ) s! H: p# J* V' N
    2. tic) c' s* a6 \3 Q- o2 ]( n
    3. k = zeros(5,5); % //生成5×5全0矩阵
      $ w; m7 e) F' e1 e) x3 k5 d
    4. % 循环计算以下程序段100000次:\" C& m! x7 ~( S; B9 Q  U
    5. for m = 1:100000
      6 D. W: D% g, V0 z\" ]
    6.     a = rand(5,7);
      3 ]+ ^& g$ h7 i3 z. s8 t- y
    7.     b = rand(7,5);%//生成5×7矩阵a,7×5矩阵b,用0~1之间的随机数初始化
      5 F\" i# @. Q$ ?, S3 ~7 s
    8.     k = k + a * b + a(1:5, 2:6) * b(2:6, 1:5) - a(:, 7) * b(3, :);
      ! Y+ t- e& W  B/ ^
    9. end# T3 {0 a: L4 a\" G$ P' b+ l
    10. k
      + D3 x) e. d3 U( W7 u  O
    11. toc
      ' Q/ R\" j- c# p1 C+ Q

    12. 6 m7 D  w- s+ m; V; F
    13. k =8 {( A% G3 i2 k8 F8 a0 F+ F6 f

    14. 4 Z6 J7 k2 s: ^) ^; n
    15.   1.0e+005 *
      3 }. X0 n; o% J# O0 ~
    16. % T; `3 R4 n' |% {
    17.     2.7525    2.7559    2.7481    2.7525    2.75110 U+ }7 O) G: p$ u+ J$ G\" w
    18.     2.7527    2.7535    2.7430    2.7545    2.74848 e6 B9 `: E/ V* q
    19.     2.7493    2.7553    2.7440    2.7513    2.7485! M( i! g  A$ S
    20.     2.7481    2.7506    2.7425    2.7457    2.7460# Z: N8 d# f- n5 ~1 @
    21.     2.7506    2.7525    2.7429    2.7488    2.7451& B3 L# [; h) G% r$ ]/ f
    22. \" O( A# y; h5 u1 c; V# L7 J/ i
    23. Elapsed time is 1.979852 seconds.
    复制代码
    ===================! E5 \1 W6 |7 W/ P- K
    $ B/ R( n; d7 O7 z' x2 s# |
    Forcal(OpenFC演示)代码:
    1. !using["math","sys"];
    2. & H1 T% L& O. U4 v4 a8 F\\" i
    3. (:t0,k,i,a,b)=
    4. 9 u; M0 M/ m: V- i; ]
    5. {4 {5 L: B4 N' g
    6.   t0=clock(),
    7. 0 e& M. h' o1 E+ o3 T  y
    8.   k=zeros[5,5],0 X& C6 E! l- n; `2 ~& U
    9.   i=0,(i<100000).while{
    10. ; H' B\\" S. Q% E+ R  c5 v
    11.     oo{0 M8 z: b- Z9 H+ e- }. ?
    12.       a=rand[5,7], b=rand[7,5],
    13. ; H& H: L) }6 |, p6 c$ m& d
    14.       k.=k+a*b+a(0,4:1,5)*b(1,5:0,4)-a(neg:6)*b(3:neg)3 x) Y\\" p/ B; z  M: F4 q
    15.     },- ?* ~, F' @$ ~8 g
    16.     i++
    17. 2 I- D+ W( j. w8 W( ]6 ^
    18.   },
    19. , F/ M& l7 v) ?: X: p$ m& ~
    20.   k.outm().delete(),
    21. + p$ W8 W: ?' n4 [  k# A( g4 _\\" V( M' |
    22.   [clock()-t0]/1000
    23. ; t+ n+ _% l8 Z7 Q8 X
    24. };
    结果:
    1.          274978         274892         274913         274949         274953
      ' J1 G+ I. w. r
    2.          274994         275050         275001         275037         274892* E6 D; Z5 V6 C  l
    3.          275001         275063         275019         274963         274971
      / X+ A: i2 u* K9 @+ v$ z/ K
    4.          274945         274999         275017         274983         2749825 Z& f9 C, c( J9 o8 s: Y
    5.          275009         274984         274971         274955         274923
      \" q, |! s7 C& |$ S; W
    6. / q5 L( P# r/ N$ h1 k/ e
    7. 3.516  秒
    复制代码
    此类运算Forcal的效率有Matlab的一半稍多一点。- B" Y) P- B- @0 E
    ; U- t2 }0 T) W2 f" l  P' L
    ==================2 O, G! `4 `/ t9 A3 W4 [; e0 ~$ m; U
    ==================) i6 {2 ~2 P8 l, n6 V  y- H
    2 X! c5 U& I: p- h4 Y, P, V
    2、大型矩阵乘
    * b8 ]8 j: y( u% z/ [& d
    # T8 x4 f) X0 [. z+ |0 a" L5 s3 |Matlab 2009a代码及结果:
    1. clear all
      1 s  e2 g2 X5 R+ U* `: y( K# X- Q  V
    2. a = rand(1000,1000);
      . n4 \! T5 N# V
    3. b = rand(1000,1000);
      $ F2 |/ t& b& [; E6 [, Z8 D# e
    4. tic( H\" N0 b+ B1 I9 ?+ a( j2 y
    5. k = a * b;
      - U- w6 ]5 k3 U3 L* u7 i
    6. k(1:3, 5:9)
        ?; u. l: H) a\" Q$ p
    7. toc9 j  D& g7 Q\" C

    8. ' b& K0 R3 s8 [% u6 O
    9. ans =; |% Z) j$ m8 X, N) `/ u
    10. % ]) W: H7 l! f
    11.   246.1003  244.3288  252.9674  258.1527  243.93456 I) O8 ?  U, R- q1 c2 D$ D, g
    12.   246.7404  236.1487  249.7140  251.3887  246.0294) v; e9 T$ X0 M. A# k( `
    13.   249.4205  240.5515  252.5847  257.0065  249.7137
      # b, z; X* L9 C# X9 G
    14. . J* q/ z9 g4 x: i% k  Y+ y; }
    15. Elapsed time is 0.310022 seconds.
    复制代码
    ===================
    8 q+ r- [& \+ I* p) E  f9 Q/ w' Y0 T- i6 G' ?, g! E
    Forcal(OpenFC演示)代码:
    1. !using["math","sys"];
    2. ! G7 D; U0 i9 E\\" q7 P$ b
    3. main(:a,b,k,t0)=
    4. 5 ~6 \4 K2 f5 z1 t& ^
    5. oo{7 c4 v: C% X, j0 ]
    6.   a=rand[1000,1000], b=rand[1000,1000],
    7. ) C- S/ d# ?0 u# Q$ O9 l
    8.   t0=clock(),% ~8 J/ h$ G( f0 ~1 k4 ~) K( u
    9.   k=a*b,  //矩阵乘
    10. * \0 U4 p  `% {! H0 R( L
    11.   k[1,3:5,9].outm()3 D+ S6 N8 b7 @- W* |  I
    12. },\\" R( Z% ?/ U2 p# z% g$ M
    13. [clock()-t0]/1000;
    结果:
    1.         247.009        245.731        242.454        247.412        244.4821 ~3 y% |1 f2 O( E( {5 G
    2.         258.268        255.417        253.738        255.159        253.0422 b0 z& W* V( n( c0 l; M
    3.         258.088        252.324        248.927        252.392        247.731& p5 O$ W# ~5 ?9 H9 {+ e8 a

    4. \" I+ Q( x$ e+ L# m
    5. 2.25
    复制代码
    此类运算Matlab的速度约是Forcal的7倍多。6 q9 e6 k% {8 G# l# U

    ( N6 J; S5 V/ w. C# ~==================
    - m1 _9 A5 Q5 f( s==================
    ( f2 A( H# }- |- [7 ^$ R1 d8 h" [& G9 j) K4 H: ~
    矩阵运算是Matlab的优势。不过,个人认为,矩阵计算速度取决于算法,矩阵算法只是众多数值算法的一种,不属于语言的基本特性。然而,拥有高效的矩阵算法是matlab的骄傲,就像优化算法是1stopt的骄傲一样。
    , U- }6 C2 y* z9 ?5 t$ [
    ) ?" c& j8 Y3 N: @/ {+ u  ]8 g* [% tForcal的矩阵乘是用普通的矩阵乘经过改进而成的,效率自然低,但所有的数值算法包括矩阵运算是由Forcal扩展库实现的,只要有高效的算法,Forcal便可大展身手,为所有这些算法提高更高效的服务。# ?" d* u, T: d4 t. K. C
    % h: t1 L9 ]5 S2 w; [
    除了矩阵运算,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-5-2 03:19 , Processed in 0.478039 second(s), 84 queries .

    回顶部