QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2805|回复: 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。
      s& u3 |1 v* @. a3 |4 x7 Y6 d1、对角矩阵和单位阵。5 n$ B- j  ]0 B/ c7 M, O
    例1:x <- 1:6; diag(x) #对角矩阵6 Z+ M5 a% a3 [8 `1 z
    例2:y <- rep(1, 5); diag(y) #单位阵7 H6 B& s( A" u) s
    4 r  F4 t, W# P! Y% [) x3 ^" G/ W
    2、矩阵下标
    # z/ [: d1 T1 P6 h5 O" o例1:xx <- matrix(1:20, 4, 5)1 F& ?5 Q. j) \. l, t5 G/ b8 j9 F! a
    xx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]4 q8 U7 Q# ]) m. Z; Q. n; \1 L
    xx[2, ]; xx[ , 2]
    * q. d$ B- q; J0 V6 R
    : S5 \/ P1 J. R3 o; c  M3、代数意义下的矩阵乘法"%*%"
    ( ]% D* u6 F' L$ L例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)  ]7 g7 E0 e& a" R; v& u  R$ X. C  x
    yy %*% zz; zz %*% yy
    ; J' Z' u& ?3 y- G( @; A5 l" O+ ~( W% _5 j0 B1 g  t3 r" O' O
    4、矩阵行和列的维数& R" O# e) @9 y$ `
    例1:xx <- matrix(1:20, 4, 5)7 A2 ^; J7 g# M4 Y
    dim(xx) #行和列的维数
    5 L# @4 Z: h$ l1 f0 _. u" _nrow(xx); ncol(xx) #行数和列数
    ' m# Y; x& l% X- Q
    % Y  F9 c/ t( h+ i5、矩阵的主要运算函数" k; e5 ~. h7 \
    例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵1 X  X9 n) a" l2 n$ a) H) n
    is.matrix(x); is.matrix(y) #判断是否矩阵
    ) z; _1 t( `- P0 }7 a- ]例2:   diag() #方阵对角线元素或者生成对角矩阵
    9 f2 u8 ]" L$ v# l% P* l! {apply() #对矩阵应用函数
    * ]: L7 `+ e8 p9 x2 d8 S2 `! z7 Zeigen() #求特征值和特征向量
    ! u3 u+ X+ R2 l( S4 J6 e4 Wsolve() #求逆矩阵
    / w- w# B! p4 w3 R) ?chol() #Choleski分解
    " a: B3 ~8 K7 B6 W: B; \svd() #奇异值分解
    7 ?. v; K8 F5 Q3 E" y0 X" ~/ iqr() #QR分解3 N( O6 o9 v5 y5 t1 d- N
    det() #求行列式; S: [1 }8 _# t# f
    dim() #给出行列数  X8 T, v+ j" T( u1 ~% o
    t() #矩阵转置9 Y0 Q. h: ^1 U9 y% @3 l  ]7 M" _

    , k" S( e& C2 t1 Z$ I6、矩阵合并0 h8 ]& j6 s" a* G5 w- m
    例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)( C: T1 ?& A6 S+ g: D. h
    cbind(aa, bb) #按列合并& s  H( f* g3 s7 b( l5 m
    rbind(aa, bb) #按行合并* C/ B( M& l3 m% c8 y+ S
    9 }& L7 R9 f( D7 r
    7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。
    ; Z8 _: k7 ^( \例1:xx <- matrix(1:20, 4, 5)
    " n- L( O% N5 J, A% m+ ^) dcolMeans(xx) #列均值5 b8 ~: O! b, y
    colSums(xx) #列和1 n& ^4 }% X' F
    其余大部分都要用到apply()函数; e+ V0 O  T9 C4 m# l$ n
    例2:xx <- matrix(1:20, 4, 5)# R0 l: e! t& w6 r9 U' r+ C7 a) l- b& `
    apply(xx, 2, mean) #列均值,等同于colMeans(xx)3 H9 A9 v1 T: b
    apply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。
    5 \* b, h8 q7 F3 e* b: dapply(xx, 1, var) #行方差
    ) B1 a2 F* B8 A" V- \6 Xapply(xx, 2, max) #每列最大值
    : D4 w) `- {4 F1 h2 o# i; Tapply(xx, 2, rev) #每列的数反排列
    . s5 q: g8 k5 `& t$ N" B9 z4 I: g5 W! M) W% E
    6 @3 j. J" w/ @/ M7 i, X9 f1 F- P
    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 14:26 , Processed in 0.379414 second(s), 49 queries .

    回顶部