QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2839|回复: 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。
    0 m& T$ [* W5 T+ z1、对角矩阵和单位阵。$ p. W" {% o& q, [- ~; @( w' O
    例1:x <- 1:6; diag(x) #对角矩阵
    / e- T- }5 r' j( I例2:y <- rep(1, 5); diag(y) #单位阵
    4 o) ?; ?; x. x8 O) }
    ) y5 w2 F& C3 Q2、矩阵下标' W$ e* S1 i. `4 K7 f$ n
    例1:xx <- matrix(1:20, 4, 5). i* [" M: {, C: \' V
    xx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]
    . C9 c+ N5 q' u; P6 y: yxx[2, ]; xx[ , 2]
    ) @5 y+ j- q. @- B# n8 X3 m6 F
    : m4 L+ x" I8 W' w3、代数意义下的矩阵乘法"%*%"6 I' T/ f. s! R0 q) b$ v5 @
    例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)$ W+ z. Z7 f- q2 U
    yy %*% zz; zz %*% yy- |/ \& I# l+ |$ ~, |
    " [# L7 u' f- G) w) [; }: O
    4、矩阵行和列的维数
    ' X+ N' T# D4 ]* Y$ @# A例1:xx <- matrix(1:20, 4, 5)
    ( G( U* p; p3 {2 B# Gdim(xx) #行和列的维数* O7 n1 O  M' V" R& c
    nrow(xx); ncol(xx) #行数和列数
    + L* \8 O: j6 |) A$ U
    ) x, ]% P9 j* x( S/ K5、矩阵的主要运算函数
    & H7 I! @- Q9 F% f例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵- f6 y' F2 w1 }4 |# ~# b/ T) {
    is.matrix(x); is.matrix(y) #判断是否矩阵5 T* F1 a( W. ?6 q) G2 j$ [, c3 z
    例2:   diag() #方阵对角线元素或者生成对角矩阵6 ~9 w5 J  {4 f+ c6 P- W
    apply() #对矩阵应用函数$ W4 B5 K: m, I3 D- s- E- Y
    eigen() #求特征值和特征向量1 ^" H( h* V: X* W: e
    solve() #求逆矩阵2 z# v. g7 f% O+ E. R' ?% `/ c
    chol() #Choleski分解! W% z; R* V6 n( J9 g# m
    svd() #奇异值分解7 r( u' h' f8 w) t4 u. W
    qr() #QR分解
    : J3 y7 J/ Z! J8 H* H! k2 edet() #求行列式
    3 F7 M2 S* j8 Y* j, y! ^dim() #给出行列数
    ( y. q: a$ s' `5 A! g5 T# }t() #矩阵转置
    ' o2 n$ T0 I: Z
    4 g0 i9 R+ r0 a, m# [) T$ E6、矩阵合并
    & h+ `7 Y; k& s% i例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)
    9 s4 i3 K+ r- B  [8 o* ocbind(aa, bb) #按列合并
    8 ^/ e1 ~6 e$ L9 l- }rbind(aa, bb) #按行合并
    5 y7 P( `$ i' c* F1 h
    7 l+ b# a  X4 }. p7 Z+ e; ~7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。
    . }/ z9 A4 {2 l# E4 z& V例1:xx <- matrix(1:20, 4, 5)! E: O9 Z  b) U- x) u& H
    colMeans(xx) #列均值
    + T; T1 b8 ~5 c, _5 hcolSums(xx) #列和  `) Y1 U  q! T! O" V: d7 k
    其余大部分都要用到apply()函数
    / O, x4 e) n: R' V" R4 {3 ]2 o  {例2:xx <- matrix(1:20, 4, 5), y$ y0 Z* ^+ m5 W" h
    apply(xx, 2, mean) #列均值,等同于colMeans(xx)
    ( Y& T4 l3 q- f0 ]5 Z6 R1 m9 @3 Mapply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。
    ( e: |! C3 ^% }8 r6 O  L: `* r; aapply(xx, 1, var) #行方差
    3 F* D. t( f2 R' p" m' g/ ?) Oapply(xx, 2, max) #每列最大值
    3 S5 m  k( F: M/ B) [; f5 ^apply(xx, 2, rev) #每列的数反排列, Q) v% i! a4 K8 Y5 g" d. {/ i/ q. N
    ) @9 K+ @* W9 \' R8 k4 C5 P; H
    9 l& u- s* Z+ p% l+ Q) d2 _
    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-17 18:39 , Processed in 0.289810 second(s), 50 queries .

    回顶部