QQ登录

只需要一步,快速开始

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

极限测试之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、小矩阵大运算量测试
    ) L, H0 @" U! I: U2 R; r- U( x* h5 \9 O( s) A
    Matlab 2009a代码及结果:
    1. clear all- L* O; I- G4 {
    2. tic
      1 {3 }( _\" d% J+ g8 B' l
    3. k = zeros(5,5); % //生成5×5全0矩阵
      7 v+ h5 K6 u6 j5 Y
    4. % 循环计算以下程序段100000次:
      1 r# u: l- X) j& d- `2 V, ~- m4 `
    5. for m = 1:100000
      ( W& N\" s0 g) B* y9 E3 v2 |. \
    6.     a = rand(5,7);
      . W! d& y3 u+ s\" R
    7.     b = rand(7,5);%//生成5×7矩阵a,7×5矩阵b,用0~1之间的随机数初始化2 \+ b: F9 Q& K
    8.     k = k + a * b + a(1:5, 2:6) * b(2:6, 1:5) - a(:, 7) * b(3, :);
      % ]9 F9 X! n) V8 \; B
    9. end
      & s6 r; q! w- H0 w& H
    10. k- X/ Q% f) v; H& o! O% G
    11. toc. n3 M5 `. Q4 n0 r+ n3 P2 q
    12. 2 }4 r2 @4 [. C( A% d5 l
    13. k =
      - \6 ]4 `; S( I( Y( F- _
    14. ( h) a+ j2 t6 ~2 j
    15.   1.0e+005 *) R8 M' B. u4 }# G
    16. ( n7 J: V, @7 x, z9 W. q
    17.     2.7525    2.7559    2.7481    2.7525    2.75111 X% b: @0 i6 u& Z$ H; I
    18.     2.7527    2.7535    2.7430    2.7545    2.7484
      - b\" [& @2 |4 [$ }
    19.     2.7493    2.7553    2.7440    2.7513    2.7485
      * B$ h, F- |; Z& Z  O, R8 {# T8 y
    20.     2.7481    2.7506    2.7425    2.7457    2.7460  Z% w: r' x4 \2 \0 e) Q
    21.     2.7506    2.7525    2.7429    2.7488    2.7451
      9 I/ X: q8 h+ y4 L9 E

    22. + e0 z( _: |& v; c1 N1 [( a
    23. Elapsed time is 1.979852 seconds.
    复制代码
    ===================/ Y; ~/ E& O# W; j# s
    ! y; K9 y! _3 O; o( D: s7 D
    Forcal(OpenFC演示)代码:
    1. !using["math","sys"];
    2. ( {: k! }4 X\\" x, ~* F
    3. (:t0,k,i,a,b)=
    4. : ]9 C* O3 H: u! p& K% [9 Q
    5. {
    6. 7 q- r( `- n9 B) i
    7.   t0=clock(),
    8. / Q1 X0 Q+ S3 d: o
    9.   k=zeros[5,5],
    10. . t& E3 u6 Q9 M6 \2 r0 l
    11.   i=0,(i<100000).while{
    12. 9 j8 E* g& P8 a9 w) S& _
    13.     oo{- r) w$ @\\" t, R
    14.       a=rand[5,7], b=rand[7,5],
    15. 2 ]- p; u% M0 j5 E6 T2 a
    16.       k.=k+a*b+a(0,4:1,5)*b(1,5:0,4)-a(neg:6)*b(3:neg). K; s  X# ?, j, I6 X6 p' P
    17.     },
    18. $ Y: ~6 i& ^\\" A+ w
    19.     i++
    20. % u3 j! |% j; X6 b
    21.   },\\" P* }# x  `( w) d2 H$ a# Z
    22.   k.outm().delete(),& l! E5 C- X/ j9 ~; K2 d
    23.   [clock()-t0]/10002 O* D  j: O6 b+ j
    24. };
    结果:
    1.          274978         274892         274913         274949         2749533 k6 _\" n$ p$ ]* p$ U
    2.          274994         275050         275001         275037         274892
      ; x. S% M2 V5 F2 m/ a' }
    3.          275001         275063         275019         274963         274971* B% F3 W6 Q: `9 z
    4.          274945         274999         275017         274983         274982. V4 K! y+ a4 C4 z0 p% F
    5.          275009         274984         274971         274955         274923: F! T\" z' ~' G9 D, o* c% j

    6. : W6 x7 k: x  b, ]. L: u
    7. 3.516  秒
    复制代码
    此类运算Forcal的效率有Matlab的一半稍多一点。
    $ J* g7 H1 A$ U& V& q& [8 X4 ^, ]1 u
    ==================- v" g. |" d" I( R# @; W# H6 h6 _  q
    ==================
    8 G5 {( r* e* r# V* z: A3 u8 K! G/ F+ e
    2、大型矩阵乘
    % E$ O, p9 M% B0 d- f- e! i; ^9 B; m( j% A+ c1 y
    Matlab 2009a代码及结果:
    1. clear all7 M$ ^, M! _' K
    2. a = rand(1000,1000);
      + Z# B* k6 s) q% \& Z9 R, J
    3. b = rand(1000,1000);: M; c) z* ]! W  P  u
    4. tic) ?0 l0 I, R8 w4 m5 r- a( E
    5. k = a * b;
      , u2 I2 T8 a# V! Z0 K! c* O) q7 f
    6. k(1:3, 5:9)
      / f3 X6 m* Y) L2 b0 V& J\" b# n
    7. toc
      \" m; T) y+ @6 Z
    8. 5 }! k5 k( W9 y1 S7 Q: y8 V) n
    9. ans =
      + \7 q* E& {8 F1 n/ e

    10. 0 _* f0 X: h! E# q
    11.   246.1003  244.3288  252.9674  258.1527  243.9345
      ! Q& w, M) y5 q6 l9 L
    12.   246.7404  236.1487  249.7140  251.3887  246.0294
      \" J6 A, |# |: U\" I4 O3 M1 s\" A
    13.   249.4205  240.5515  252.5847  257.0065  249.7137, a/ ~9 y* k/ `& W6 Y6 p3 Z

    14. & M3 K4 W4 Y/ k) C/ s
    15. Elapsed time is 0.310022 seconds.
    复制代码
    ===================2 X/ E4 }' e* n9 b% T
    3 g6 b: N- p. m4 h# ^/ }4 i' M
    Forcal(OpenFC演示)代码:
    1. !using["math","sys"];
    2. ; T- e' E( o, d+ n, u. |% B
    3. main(:a,b,k,t0)=
    4. 8 F% \, S! x! @, }
    5. oo{
    6. ( s- ?) d% @) h  e- @
    7.   a=rand[1000,1000], b=rand[1000,1000],; X. q' L. `% `, d) m$ J3 b) Z
    8.   t0=clock(),
    9. 8 {  s( d/ f7 E; B/ J4 k4 R
    10.   k=a*b,  //矩阵乘
    11. ! u/ t6 |$ Z! Z4 }) _
    12.   k[1,3:5,9].outm(), X; b2 z1 {6 ^0 r. }8 S' m# W
    13. },! b4 ]) G3 h+ M# w4 O
    14. [clock()-t0]/1000;
    结果:
    1.         247.009        245.731        242.454        247.412        244.482# Q) D: U) T. \- H# x3 ~
    2.         258.268        255.417        253.738        255.159        253.042  _  j) D, V) l0 g\" _& |. N) r
    3.         258.088        252.324        248.927        252.392        247.731% U* V  Y1 O5 t2 b

    4. % r# N' _0 j, L  N( i
    5. 2.25
    复制代码
    此类运算Matlab的速度约是Forcal的7倍多。
    , d& K- ^1 {4 q: G1 z/ S" I: Z8 z
    ; A; M( }1 u$ F: k- M$ |" H: c  i==================
    5 c, Z2 l* e3 p( n4 k==================- ^5 ], _6 N* @1 g/ Q% Z( A9 g
      c, S+ E# \0 l0 M! J8 O! E6 T
    矩阵运算是Matlab的优势。不过,个人认为,矩阵计算速度取决于算法,矩阵算法只是众多数值算法的一种,不属于语言的基本特性。然而,拥有高效的矩阵算法是matlab的骄傲,就像优化算法是1stopt的骄傲一样。
    ! J' l, w, z& Q: ~# i' Y/ p
    " ~* R  e8 a' q5 rForcal的矩阵乘是用普通的矩阵乘经过改进而成的,效率自然低,但所有的数值算法包括矩阵运算是由Forcal扩展库实现的,只要有高效的算法,Forcal便可大展身手,为所有这些算法提高更高效的服务。" i) [. X0 B' c

    % b# R; n% ?6 S& h1 x! H除了矩阵运算,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

    回复

    使用道具 举报

    5#
    无效楼层,该帖已经被删除
    alair005        
    头像被屏蔽

    0

    主题

    4

    听众

    782

    积分

    升级  45.5%

  • TA的每日心情

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

    [LV.2]偶尔看看I

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

    使用道具 举报

    7#
    无效楼层,该帖已经被删除

    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, 2026-4-21 06:22 , Processed in 0.588729 second(s), 95 queries .

    回顶部