QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2843|回复: 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。& U9 J; e$ g: e1 A
    1、对角矩阵和单位阵。
    # u8 O: C0 `: P  ?$ s例1:x <- 1:6; diag(x) #对角矩阵  r; n' |4 K. B+ u& }5 b; U
    例2:y <- rep(1, 5); diag(y) #单位阵
    9 M- P$ F2 a1 A# q, g+ n
    6 I% W. V9 ^. c. n& T0 h$ Q2、矩阵下标1 r, k" t  f0 p
    例1:xx <- matrix(1:20, 4, 5)
    . l$ _: R; }( ?0 d: s% ~xx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]
    1 D1 Y6 G# W' U- ?4 ^# z" H& [- Jxx[2, ]; xx[ , 2]9 f$ \9 A. _8 `. t( p
    ! _  h0 u5 m" i! S" k. z! p
    3、代数意义下的矩阵乘法"%*%"2 I. e$ [" e% F4 ^% C
    例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)5 R( U7 M. m) m$ l, R% E) Y
    yy %*% zz; zz %*% yy3 f% X/ J. V$ j( u
      i4 K/ ^# a( a; D8 U  |0 ~
    4、矩阵行和列的维数
    % @6 c2 M' _5 @- ]4 ~+ w  W9 c4 P例1:xx <- matrix(1:20, 4, 5)8 H" U: L% f% G% i- c" ]
    dim(xx) #行和列的维数" A# J) e- D! H$ m1 ~7 U+ j
    nrow(xx); ncol(xx) #行数和列数
    ; O  u2 ]9 _) v+ D+ ^$ Q7 F# d: ^% w% }/ @5 S. c
    5、矩阵的主要运算函数. ]7 r8 J* f3 E& P0 a' D
    例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵  z1 Y6 J1 `: L! M, G1 C! y+ @7 ^( e
    is.matrix(x); is.matrix(y) #判断是否矩阵1 U# @+ d* G& ]5 D- l# S
    例2:   diag() #方阵对角线元素或者生成对角矩阵
    1 W) ^: D5 n0 U( f. V! G4 Uapply() #对矩阵应用函数
    % Z- R2 f) }9 Peigen() #求特征值和特征向量% `" B1 b, V, t- |( _
    solve() #求逆矩阵, v: `, c, k/ m9 C' Y
    chol() #Choleski分解
    2 ~8 v* i. ~/ d% l* zsvd() #奇异值分解6 d0 q5 O, [2 I
    qr() #QR分解
    2 i. {8 X- `8 z3 }- c/ ?+ `* ]+ ?- ~det() #求行列式
    2 J% t1 N8 d- D- J8 n9 b) jdim() #给出行列数
    0 u3 e: ~, F0 O9 r+ c: {0 St() #矩阵转置
    7 ]* S' ~0 O3 Q. ^1 n5 T( `( V4 `! {
    6、矩阵合并
    7 `. w: ?8 M8 O4 J  S# ^例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)
    & j" D, b4 y0 Q- {7 acbind(aa, bb) #按列合并
    0 U2 q3 E* H, E* M3 a' G8 }rbind(aa, bb) #按行合并9 _$ Y% s, ~% f0 B! m
    8 Z- l( L  e% o) S& I6 h
    7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。
    2 K9 ]# s) R, A例1:xx <- matrix(1:20, 4, 5)
    : i' O2 j/ `8 K1 |4 ]% Z1 B; icolMeans(xx) #列均值
    # \# F3 f# _1 j1 y. J* V% _colSums(xx) #列和# k6 s0 f" |" d4 i2 r
    其余大部分都要用到apply()函数
    7 P% R# v7 o3 K( m- i5 A例2:xx <- matrix(1:20, 4, 5)  W; h- k' [) b# s* |  z& S1 |3 b
    apply(xx, 2, mean) #列均值,等同于colMeans(xx)6 E7 J1 o* r' S9 v; E0 ]( ^$ A, J
    apply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。9 i* M/ G' _0 z) |* U6 \3 l! t4 i
    apply(xx, 1, var) #行方差" j1 P  G5 C+ d
    apply(xx, 2, max) #每列最大值" S  j6 N; @, X# I' O8 W
    apply(xx, 2, rev) #每列的数反排列$ `7 G  u: _4 [$ R0 C" K; n
    * _( y4 }9 T' W7 v  k: H9 E4 t
    8 A: d! @% B$ H6 A# 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-20 04:08 , Processed in 0.351580 second(s), 50 queries .

    回顶部