QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 10327|回复: 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、小矩阵大运算量测试
    3 p; I+ Y* X' Y  J0 T
    % X! A7 s. F1 Z) k; {4 _Matlab 2009a代码及结果:
    1. clear all
      + ]3 r1 s2 j* J( f* Q4 q* {
    2. tic3 z: o% a) N0 L% \- Q$ ]
    3. k = zeros(5,5); % //生成5×5全0矩阵\" @7 Q* j; a$ }- T  L
    4. % 循环计算以下程序段100000次:7 C) ~2 R: d. `* w3 e, i: _* {
    5. for m = 1:100000
      ' U! J1 I\" ]: ?6 r
    6.     a = rand(5,7);
      ( X! _; Z& r$ Y
    7.     b = rand(7,5);%//生成5×7矩阵a,7×5矩阵b,用0~1之间的随机数初始化
      ( E1 o& G! J. V+ ]
    8.     k = k + a * b + a(1:5, 2:6) * b(2:6, 1:5) - a(:, 7) * b(3, :);9 P/ x1 x) e% P
    9. end4 M2 H\" C1 m' Z! d, {4 g. ^0 v
    10. k
      ' ?2 g1 ?\" O7 g3 L& n8 F
    11. toc
      9 Q1 f+ N5 h4 {: N
    12. ! K. p8 D$ S! C8 j
    13. k =  o$ p, V# P( R
    14.   k1 D& Q- d% y8 L
    15.   1.0e+005 *1 l* ~2 I8 [+ p; t8 L  W

    16.   x% o\" e0 x& R  f/ f0 N4 x3 [/ q
    17.     2.7525    2.7559    2.7481    2.7525    2.75110 U- L1 a4 m, e& Q& J+ u3 m
    18.     2.7527    2.7535    2.7430    2.7545    2.7484
      / k4 q\" o( T/ M6 I: _
    19.     2.7493    2.7553    2.7440    2.7513    2.7485
      + X8 [+ g5 |$ w: h1 o% m- m
    20.     2.7481    2.7506    2.7425    2.7457    2.7460
      + p/ Z5 Y+ p2 K6 ~
    21.     2.7506    2.7525    2.7429    2.7488    2.7451
      8 E/ g9 G: v+ w% T( W

    22. / L: X; r' `- \
    23. Elapsed time is 1.979852 seconds.
    复制代码
    ===================$ |- L- K% v$ u+ Y

    # Q9 O- U6 [/ {: l3 dForcal(OpenFC演示)代码:
    1. !using["math","sys"];
    2. 2 Z* j% U, `; R; U. u
    3. (:t0,k,i,a,b)=& w1 s$ c: S: d) P8 k0 e
    4. {
    5. ( y; ?\\" j\\" |. E- s$ e5 t& Y) H
    6.   t0=clock(),
    7.   {. b  W; W( D3 f, F8 }- ?
    8.   k=zeros[5,5],
    9. * p5 g0 j, o: L. U\\" F4 I! a0 y
    10.   i=0,(i<100000).while{  g! n) v# p' Z2 N$ P& }
    11.     oo{) J\\" [1 P% \5 L4 d7 f* P  V- F
    12.       a=rand[5,7], b=rand[7,5],5 `! b( F. g; L3 F1 O  h8 b, y
    13.       k.=k+a*b+a(0,4:1,5)*b(1,5:0,4)-a(neg:6)*b(3:neg)9 p( B% U, c, c# X# h
    14.     },
    15. 6 Y* `9 h7 U  R$ V& A1 c
    16.     i++* g( p& Z2 ^! a& F$ F/ C# {) H
    17.   },) R+ x, T2 d! g% B* S+ o: a
    18.   k.outm().delete(),
    19. & c7 I! @8 C1 P3 Z
    20.   [clock()-t0]/1000
    21. 2 I, j5 H% ^5 N- }: S! |1 l/ o
    22. };
    结果:
    1.          274978         274892         274913         274949         274953* q9 e% }1 s8 f. |/ p* Z/ K
    2.          274994         275050         275001         275037         274892/ X( ~( d! l( w\" @* P
    3.          275001         275063         275019         274963         274971
      9 X( u  S) y) p' f; C5 T
    4.          274945         274999         275017         274983         274982  Y/ n2 O+ ]5 a* A5 \
    5.          275009         274984         274971         274955         274923% ?8 g' b& e8 R
    6. ; v7 H, B0 g/ X* e) J/ H
    7. 3.516  秒
    复制代码
    此类运算Forcal的效率有Matlab的一半稍多一点。
    ' ^: g- E& d3 I. y: U  G* B4 n& [5 G$ O3 @% u0 A
    ==================  p) F8 J* ]* s! A
    ==================
    8 n; t0 h5 c1 G3 t0 g5 t0 o% F6 x" T2 j1 k. c( r
    2、大型矩阵乘. ]2 ~. F, {7 o6 X
    & L2 S8 K. H6 }) P0 P$ \
    Matlab 2009a代码及结果:
    1. clear all+ B$ u) ]1 [- r7 F
    2. a = rand(1000,1000);
      7 p) P# V- @( ]: T
    3. b = rand(1000,1000);
      \" m! u; m8 ]; T3 P
    4. tic
      * E- x$ Q$ x\" k7 B) w/ \& C4 S
    5. k = a * b;
        ?7 s' K\" H3 z! I% j# R( I: \8 W; F8 R
    6. k(1:3, 5:9)
      3 D* S) R# C2 }7 W4 N7 L$ l) m
    7. toc
      ( P2 ?2 p  }! S) c! q0 g& }) R( h' B# V
    8. 1 ?4 T/ y. r- m
    9. ans =
      ; ]0 j/ V  r! e. z  c

    10. 5 }% i/ @3 P- |0 }\" d
    11.   246.1003  244.3288  252.9674  258.1527  243.9345
      , v* f7 s* L( q; B; G
    12.   246.7404  236.1487  249.7140  251.3887  246.0294
      $ u+ ~* j1 p4 M# H. X6 }' A0 L
    13.   249.4205  240.5515  252.5847  257.0065  249.7137
      ' S6 }\" J. A8 D# `3 ^% E
    14. 0 U\" V' q2 T* V3 g4 I
    15. Elapsed time is 0.310022 seconds.
    复制代码
    ===================
    $ G# d; v1 [6 W& B8 v/ L' o% Q% K' f% u! S5 n1 }
    Forcal(OpenFC演示)代码:
    1. !using["math","sys"];
    2. . {  }. v& m. ^+ ~0 z
    3. main(:a,b,k,t0)=
    4. 6 u- `! w& x$ R' x; S# z
    5. oo{
    6. 2 l: d7 h# K\\" H$ J4 z
    7.   a=rand[1000,1000], b=rand[1000,1000],
    8. ; E) {  C1 |* x# m& ^; w! ?  \
    9.   t0=clock(),2 V2 j6 g- l1 X4 b$ C# G2 V0 ?
    10.   k=a*b,  //矩阵乘
    11. \\" H6 x+ H# I$ A
    12.   k[1,3:5,9].outm()
    13. 7 \, S7 J' ^& M( ~& c1 O6 I2 B% h\\" {
    14. },; ^5 ]: S; `! u( ?
    15. [clock()-t0]/1000;
    结果:
    1.         247.009        245.731        242.454        247.412        244.482$ Y2 Q7 K* Q/ C  J0 x
    2.         258.268        255.417        253.738        255.159        253.042+ J& ?* T  R: Z, M& y
    3.         258.088        252.324        248.927        252.392        247.731) u% \' b! G8 ^3 g8 N9 @
    4. * V/ u2 k1 w1 @- V) H; z2 f  j
    5. 2.25
    复制代码
    此类运算Matlab的速度约是Forcal的7倍多。
    & S; ?0 n: L! x( s* U
    2 n2 `( R  H+ w$ X. U9 Q; I9 f( {==================9 |1 D  ~( H, g: V1 T
    ==================! |$ o" p9 }1 E8 n2 g
    9 t6 A$ G/ e+ S, y2 ]! r
    矩阵运算是Matlab的优势。不过,个人认为,矩阵计算速度取决于算法,矩阵算法只是众多数值算法的一种,不属于语言的基本特性。然而,拥有高效的矩阵算法是matlab的骄傲,就像优化算法是1stopt的骄傲一样。$ T, Q3 m/ p4 ~+ c, Q9 G$ B! B

    6 o% L% C) e: P" T6 EForcal的矩阵乘是用普通的矩阵乘经过改进而成的,效率自然低,但所有的数值算法包括矩阵运算是由Forcal扩展库实现的,只要有高效的算法,Forcal便可大展身手,为所有这些算法提高更高效的服务。
    / D7 a2 z+ t; ]* _( v0 H' _6 F9 w
    3 a7 p& F' f8 H5 p- G除了矩阵运算,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 20:08 , Processed in 0.900151 second(s), 84 queries .

    回顶部