QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 10331|回复: 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、小矩阵大运算量测试
    8 {+ E/ W7 t8 v% x) R
    1 a6 D4 }) J: V' n3 T* HMatlab 2009a代码及结果:
    1. clear all
      ) a) g- e+ \/ ]8 X( r' F$ o
    2. tic* O+ w# p\" B; c8 s# ]8 r
    3. k = zeros(5,5); % //生成5×5全0矩阵
      1 O0 P. S+ q9 a4 N; C
    4. % 循环计算以下程序段100000次:
      ; A4 X5 d. f3 L/ H$ J\" l
    5. for m = 1:100000
      + z; j0 Q8 I9 X; U! |
    6.     a = rand(5,7);
      9 n5 u3 W! r3 n8 c5 V3 q& k
    7.     b = rand(7,5);%//生成5×7矩阵a,7×5矩阵b,用0~1之间的随机数初始化
      * P4 k, X4 \& q2 K  P
    8.     k = k + a * b + a(1:5, 2:6) * b(2:6, 1:5) - a(:, 7) * b(3, :);
      3 y, J) y/ V: C+ D& g- x
    9. end: N8 f/ Q9 `+ P, Y0 }
    10. k$ o$ [3 u8 k& N% s3 `
    11. toc) S% C: w1 l* A4 K: R. ?
    12. 7 d$ ?( x, t1 d\" ]7 u# n2 U$ r! ]
    13. k =2 H9 C5 U5 o: J6 S2 R

    14. 0 m( Q2 z! j% I  e  g\" `
    15.   1.0e+005 *- X\" o' C1 I- _. k# z9 k

    16.   b4 U: C6 j5 s( K5 P$ H2 R% c# U
    17.     2.7525    2.7559    2.7481    2.7525    2.7511, l& k3 D4 }/ V, P2 N) k0 G1 A
    18.     2.7527    2.7535    2.7430    2.7545    2.7484+ J\" Q! s: O2 a+ K/ P! X
    19.     2.7493    2.7553    2.7440    2.7513    2.7485
      . R: g, v* ^* M4 g7 Y1 V
    20.     2.7481    2.7506    2.7425    2.7457    2.7460* Y% ?. a, f, K
    21.     2.7506    2.7525    2.7429    2.7488    2.7451
      - T$ ^0 h$ f, A7 _& y  |+ @7 q
    22. ) z- O. D; l\" y, q/ M5 T
    23. Elapsed time is 1.979852 seconds.
    复制代码
    ===================% e2 M9 X/ u3 N
    2 o6 G" B" A# a
    Forcal(OpenFC演示)代码:
    1. !using["math","sys"];7 Y$ g9 L  ~$ s' i* y# O7 `( V; E
    2. (:t0,k,i,a,b)=
    3. ' E* [1 b3 o) i/ H6 j
    4. {$ A7 t( h0 Y; Z0 L# P; P  ?
    5.   t0=clock(),\\" r- p3 _1 N1 S' |
    6.   k=zeros[5,5],5 ~+ ?% g# D+ v7 J% h( x( }0 b
    7.   i=0,(i<100000).while{2 \5 |' Y2 }. s8 s2 C
    8.     oo{
    9. ) j9 w. j- `7 I3 n; s) l
    10.       a=rand[5,7], b=rand[7,5],
    11. 3 ^: d, v$ Z6 |' z, Z4 E/ X/ u3 v
    12.       k.=k+a*b+a(0,4:1,5)*b(1,5:0,4)-a(neg:6)*b(3:neg)3 X% N: z- H. y9 ?+ T
    13.     },
    14. ( _  f# x! Q! h% O# V2 L
    15.     i++
    16. 2 P8 f7 w4 C% E( j) s' {0 P
    17.   },
    18. , b! Q) |6 F$ q) A  s\\" S
    19.   k.outm().delete(),( a) G- S$ ^% y
    20.   [clock()-t0]/10001 Y. q. x7 M0 G  \
    21. };
    结果:
    1.          274978         274892         274913         274949         274953) O% A& T0 r( {
    2.          274994         275050         275001         275037         274892- w0 q) ~, \; w$ M! l. E
    3.          275001         275063         275019         274963         274971
      7 U' P9 k6 K: Q+ i
    4.          274945         274999         275017         274983         274982
      $ R* x0 C, y& b5 h: y/ G
    5.          275009         274984         274971         274955         274923
      ; c( _2 [* g2 q2 i

    6. 8 P- K% u4 c0 X\" S9 l5 W1 E+ O+ t+ W
    7. 3.516  秒
    复制代码
    此类运算Forcal的效率有Matlab的一半稍多一点。
    . B/ q/ p& E4 H* Z, O# H4 j5 B7 y- E0 `! m7 ?) ~. }1 @# B6 B
    ==================
    $ \0 H. R7 t% w! \& U1 w$ A" N==================  n3 }2 W6 I2 c5 ~1 K/ i) c# ~

    ! w3 p1 m7 a+ }8 C% n) g# X2、大型矩阵乘
      T" e- C  c3 ]# m6 j& [6 {6 Y; O  {* X$ |
    Matlab 2009a代码及结果:
    1. clear all0 e( w& S\" P+ }: J- `' e
    2. a = rand(1000,1000);
      ' P/ J. |$ V$ s2 f
    3. b = rand(1000,1000);: c# |5 B5 g4 ^\" o/ U- X
    4. tic
      $ _+ G6 s. p/ K, ^9 E* X, P
    5. k = a * b;
      % H; P! [. j2 Q% }. w- ?$ r4 v
    6. k(1:3, 5:9)# S- c\" q% h* I2 V0 o
    7. toc& J: L% z: V# V0 b
    8. . l\" B1 F, C\" h
    9. ans =' C9 |3 F: j( F* {% K
    10. 3 h  }0 I1 Y4 o2 g
    11.   246.1003  244.3288  252.9674  258.1527  243.9345+ [) t, k, J) O$ A
    12.   246.7404  236.1487  249.7140  251.3887  246.0294
      1 R; ]% d4 h4 i4 _; r8 J\" w6 \
    13.   249.4205  240.5515  252.5847  257.0065  249.7137' k. Y# b; D3 _6 @
    14. 4 Y7 \9 }+ n- ?5 n
    15. Elapsed time is 0.310022 seconds.
    复制代码
    ===================
    / X/ H1 o5 X7 w5 P
    3 `& \5 Q( z' A! P# @: `8 V: F3 wForcal(OpenFC演示)代码:
    1. !using["math","sys"];
    2. & \\\" ]( J% P/ E9 |* C
    3. main(:a,b,k,t0)=2 h) J6 h+ M& r
    4. oo{/ T4 G, c  O3 H
    5.   a=rand[1000,1000], b=rand[1000,1000],
    6. 9 t+ [3 `$ T& i; y7 ?# i
    7.   t0=clock(),4 H* I7 \, p: T, Y
    8.   k=a*b,  //矩阵乘
    9. + x, C# H4 E: l6 ^3 ]/ s
    10.   k[1,3:5,9].outm()( \- G, \6 v. N7 n
    11. },
    12.   ~\\" i9 N4 O+ b5 e# t6 Y
    13. [clock()-t0]/1000;
    结果:
    1.         247.009        245.731        242.454        247.412        244.4826 K* B7 f3 C, p2 k% ~9 Z2 s
    2.         258.268        255.417        253.738        255.159        253.0426 R. o# W6 @: h# c% m
    3.         258.088        252.324        248.927        252.392        247.731
      - @2 j6 |\" w6 N- o- j! S

    4. 7 I3 U9 j9 a$ V8 e0 s8 j
    5. 2.25
    复制代码
    此类运算Matlab的速度约是Forcal的7倍多。
    . r( q0 Z4 M. c/ c: C' q2 _- G2 o" W! b
    ==================- e' c* l) d; A% a( q8 N1 }
    ==================
    , u6 \$ D* E# H& S  W% |( `) a* r( L2 l) @0 ~" g
    矩阵运算是Matlab的优势。不过,个人认为,矩阵计算速度取决于算法,矩阵算法只是众多数值算法的一种,不属于语言的基本特性。然而,拥有高效的矩阵算法是matlab的骄傲,就像优化算法是1stopt的骄傲一样。7 R3 ~. V: l7 N* }& i  i

    , J- `5 {: g- K) C; y4 p( SForcal的矩阵乘是用普通的矩阵乘经过改进而成的,效率自然低,但所有的数值算法包括矩阵运算是由Forcal扩展库实现的,只要有高效的算法,Forcal便可大展身手,为所有这些算法提高更高效的服务。
      O3 ^' Q/ D- ]; K
    6 v$ i0 n, {9 b( B1 b0 W) k除了矩阵运算,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, 2025-11-15 22:14 , Processed in 0.663889 second(s), 84 queries .

    回顶部