QQ登录

只需要一步,快速开始

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

R语言入门基础之矩阵

[复制链接]
字体大小: 正常 放大

320

主题

15

听众

1335

积分

升级  33.5%

  • TA的每日心情
    奋斗
    2013-6-15 16:58
  • 签到天数: 24 天

    [LV.4]偶尔看看III

    群组第四届数学中国美赛实

    跳转到指定楼层
    1#
    发表于 2012-12-24 14:04 |只看该作者 |正序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定

    矩阵(matrix)

    矩阵生成函数matrix():matrix(data, nrow = , ncol = , byrow = F),其中,数据data是必须的,其他都是选择参数,可以不选。byrow = F默认为按列来排列数据,如果想要按行排列,令byrow = T。3 R4 w5 O- U- c; s
    1、对角矩阵和单位阵。0 c1 P- q6 @5 ?6 i3 X
    例1:x <- 1:6; diag(x) #对角矩阵& L0 q" ~3 S- T7 F2 n5 @! U. y' q
    例2:y <- rep(1, 5); diag(y) #单位阵$ l, I: Z* M: ~+ x% K7 G

    ( r& Z1 q, q) D) C2、矩阵下标
    % S) ^- t9 [' W) u例1:xx <- matrix(1:20, 4, 5)+ G4 ?4 t8 L: M- M( Z
    xx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]
    4 t- k) N* f; }! B  ~- b. Bxx[2, ]; xx[ , 2]% F0 O9 O0 c  a1 z
    9 Q( \) l4 C8 n$ G: ^4 h, ^
    3、代数意义下的矩阵乘法"%*%"  J& ?% \* d( C! K$ P, S
    例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3). c- ~. A( t2 S; l
    yy %*% zz; zz %*% yy
    4 D2 d6 K% Y7 m: l8 d, F/ @! i- ?, r+ }
    4、矩阵行和列的维数3 g& n) `6 s9 r& p3 o& Q
    例1:xx <- matrix(1:20, 4, 5)' S. N2 W' W5 |; f+ @% k' n/ S5 X9 C
    dim(xx) #行和列的维数+ ^7 e) j' Z: N  R/ V+ O$ X
    nrow(xx); ncol(xx) #行数和列数$ W1 n3 z0 Y6 J. Y% e' U

    - G# g9 s: H& U; r. |$ J5、矩阵的主要运算函数
    5 G$ u# i: Y' j$ |例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵6 z* j0 V. Q) I# {: o
    is.matrix(x); is.matrix(y) #判断是否矩阵
    ) P, ^/ z* Q) U2 ~, i例2:   diag() #方阵对角线元素或者生成对角矩阵
    ) l$ S% T  V! ?5 u' Zapply() #对矩阵应用函数
    ' Z9 `% y* t" q- Z. m2 _eigen() #求特征值和特征向量, ]6 |0 [0 T& I5 D0 e2 D1 Z8 q4 ]2 c
    solve() #求逆矩阵+ q  s) W, b: A0 V. m
    chol() #Choleski分解( l! \/ F! o" J( R
    svd() #奇异值分解) T: q7 M/ c/ e% p( T. R
    qr() #QR分解
    3 a6 r. I8 M6 T8 Ldet() #求行列式# M0 ?: v  N9 o8 E7 B- r6 i1 p
    dim() #给出行列数+ Y, |8 V" [* M: \1 t4 s
    t() #矩阵转置% N3 I0 E$ B1 c

    / e7 Z8 k: P0 n8 W2 e6、矩阵合并+ \2 \1 r7 k( g4 [% W1 |/ ?
    例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)* r, }& q! r$ y: T" K, ~7 d* E
    cbind(aa, bb) #按列合并
    3 a' I8 H$ a$ u* b6 Yrbind(aa, bb) #按行合并0 G3 ^( S$ {) T- c; g2 B( h
    0 }1 R1 P; w- P5 V2 V& r
    7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。
    2 d  S3 P! q5 F" m例1:xx <- matrix(1:20, 4, 5)4 A/ ~7 ^' q. u' \) L. e/ o. P
    colMeans(xx) #列均值! Z- C, C9 ?. Y9 I3 R0 }* h) `
    colSums(xx) #列和
    3 a! _- o! V- |' {" h0 g) h( P0 j其余大部分都要用到apply()函数2 y6 z+ r4 R' o5 o2 s5 K' G2 f
    例2:xx <- matrix(1:20, 4, 5)
    ' z0 R8 E. z. s. G/ k5 [/ w3 Capply(xx, 2, mean) #列均值,等同于colMeans(xx)2 l8 @# E6 c4 p8 g+ C
    apply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。
    8 I% H& L# }2 dapply(xx, 1, var) #行方差
    % @! u. j& v% g  H; n0 Bapply(xx, 2, max) #每列最大值
    ) \$ a  {$ w2 D& R: I& ~apply(xx, 2, rev) #每列的数反排列( G% p  [+ r! }

    ) t6 g# {6 Z# A' ?6 x) G6 b# A
    * P$ H& K2 u, e  {! @- f$ z! A
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-12 11:01 , Processed in 0.411756 second(s), 51 queries .

    回顶部