QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2842|回复: 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。
    ) v/ v; a2 ^% \7 e1 M0 n1、对角矩阵和单位阵。" I# g8 B5 \" b; ]  P" s+ [9 @
    例1:x <- 1:6; diag(x) #对角矩阵
    : m- ^8 r: }" p+ q4 I' a; J例2:y <- rep(1, 5); diag(y) #单位阵6 y6 }8 R1 ^! j1 s
    7 i( f/ K3 h2 g9 \" m/ o8 |
    2、矩阵下标
    " _) x; T, k  c; q3 T9 D例1:xx <- matrix(1:20, 4, 5)5 w# ~  B0 {& _3 _; f) S; Q+ F- Y) z
    xx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]. l1 S3 q! c& A  \/ _5 x1 Z
    xx[2, ]; xx[ , 2]
    - g" m- z" D2 L' w7 u, G1 T# F6 o; G# V- y' C
    3、代数意义下的矩阵乘法"%*%"& z3 q8 X% g$ p# \' V
    例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)- ^: y. s& O/ a, v) n8 @
    yy %*% zz; zz %*% yy
    - d" ~) a9 L, C
    5 b8 Q) e1 w6 j# E- O+ T& E( W4、矩阵行和列的维数- ?) G) W/ Q" Z# p
    例1:xx <- matrix(1:20, 4, 5)
    1 z" T% g! Y8 p' v0 ?4 Fdim(xx) #行和列的维数
    # w" I2 |) h0 |/ q/ I) hnrow(xx); ncol(xx) #行数和列数! Z2 Z6 @7 Y& K
    1 U2 k+ a9 |! G# ^! b
    5、矩阵的主要运算函数
    / @, u" G' H: _1 {( e例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵
    : l0 W5 C5 }" v* z" K9 ]is.matrix(x); is.matrix(y) #判断是否矩阵5 ^# n, Z$ x, |
    例2:   diag() #方阵对角线元素或者生成对角矩阵
    7 `! q* x' n* mapply() #对矩阵应用函数% ^6 B" O. z$ H
    eigen() #求特征值和特征向量% R8 W; A* |5 y) g5 I& R' \
    solve() #求逆矩阵. _" o0 f- O+ e" }
    chol() #Choleski分解
      Q$ {4 [& l/ S1 {4 Usvd() #奇异值分解
    " N9 ]. m* A: Q. G# H, i( I/ Gqr() #QR分解3 q, Z* E5 o& S. X# s% |
    det() #求行列式
    6 W0 }6 @2 I" |* U  T% Gdim() #给出行列数- A# [1 y+ K4 J% R0 D
    t() #矩阵转置1 H" Y$ f' a9 u; ^+ v; q2 {

    # R; F( Q9 F$ N, ~0 G6、矩阵合并
    " U' I3 H% P) @" V例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)
    ( u$ t) b+ g; kcbind(aa, bb) #按列合并
    ; c3 n# M8 H7 j" [) yrbind(aa, bb) #按行合并
    " |' J* v) v) ?$ g* U
    2 q& Y- W  g2 `/ q9 A* N+ b( u9 T1 C7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。# Q; X. q, g( J+ g0 f, B" n+ a# u+ R
    例1:xx <- matrix(1:20, 4, 5)
    ' c, t/ d& l* H5 HcolMeans(xx) #列均值
    - J7 d3 h% z" s: B# AcolSums(xx) #列和; [# }; E0 z, g) u
    其余大部分都要用到apply()函数% u) K3 T& s' n
    例2:xx <- matrix(1:20, 4, 5)
    1 ~2 F/ _. b" v( H  h+ happly(xx, 2, mean) #列均值,等同于colMeans(xx)
    8 P( X4 z; ?9 S1 c, Rapply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。( s( M3 s% K; _5 U+ D
    apply(xx, 1, var) #行方差& ]9 e1 R: j5 ^. X5 ?, y6 T5 H' B, e
    apply(xx, 2, max) #每列最大值
    # k, c% w" B6 X: Q" W5 c  ?+ napply(xx, 2, rev) #每列的数反排列
    - [3 j  m) r& X2 D# R
    9 l' z- d/ x$ |0 i3 v$ T, ~& h4 e  t, c
    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-6-18 11:14 , Processed in 0.612048 second(s), 50 queries .

    回顶部