QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2479|回复: 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。
    9 n2 v3 A( I' f1、对角矩阵和单位阵。( l3 V6 D, \# d* q' L
    例1:x <- 1:6; diag(x) #对角矩阵- d- m& q# ?2 R  e/ N$ a  m
    例2:y <- rep(1, 5); diag(y) #单位阵
    9 n: e" I7 x" {) G! b3 T: C5 v! ]: ~
    . T& |7 z9 J( H* z0 n2、矩阵下标
    3 n  x9 l- b" T* J例1:xx <- matrix(1:20, 4, 5)
    * ]) Q" `+ m4 r8 d  dxx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]
    # \3 X0 a  J; y: Q$ d$ Yxx[2, ]; xx[ , 2]; s7 T, O6 ?" E6 g3 E8 _
    6 u" @) K7 Y' @) ~) s5 s" k
    3、代数意义下的矩阵乘法"%*%"& [7 C: \5 T( B1 g: k+ ~4 H
    例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)
    ! L/ `* [4 h2 x/ a9 tyy %*% zz; zz %*% yy
    " Y1 k4 Y9 t+ a/ c
    9 S7 H" b) R8 c# o4、矩阵行和列的维数. V& |! a7 K9 \' G. k' t! u
    例1:xx <- matrix(1:20, 4, 5)1 g( y9 W9 \% ?& F  b
    dim(xx) #行和列的维数
    $ b2 w% E7 M8 }. y; Snrow(xx); ncol(xx) #行数和列数
      L2 O5 D8 f% T/ j) x# F- Z. d
    5 T. V! b7 `8 ?( M) f9 ?/ c5、矩阵的主要运算函数, ?  c# }/ M0 |: M# b) q  @- K
    例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵
    - J' |/ z; H6 W3 f! Z! d" v" Bis.matrix(x); is.matrix(y) #判断是否矩阵( P6 h0 `# N. ^% L% \
    例2:   diag() #方阵对角线元素或者生成对角矩阵
    . g, h: p! d* i! Y. ^2 x* ~: X6 Gapply() #对矩阵应用函数
    & {: c& j  _. h: S( Weigen() #求特征值和特征向量
    6 T/ d( V( E2 Nsolve() #求逆矩阵
    5 P$ k0 W+ t: l$ x  wchol() #Choleski分解$ Q% X1 b- K+ N/ M  ]) u
    svd() #奇异值分解
    4 Q7 Z7 ^2 D  H0 rqr() #QR分解4 m& T: M1 T, @, V9 a- a1 z
    det() #求行列式4 C8 j5 _# w# b
    dim() #给出行列数5 ~9 K4 [: Q4 z) w" V5 L
    t() #矩阵转置, A5 s$ z) o2 ~# L( }; o
    0 ]" A8 E; K+ L* U, q" f
    6、矩阵合并
    / q& {) \4 d% a6 J/ O) }例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)
    & R5 S& {- a' K# o7 \3 `5 Fcbind(aa, bb) #按列合并
    & K( [5 o$ x9 B' A/ }2 e) r, M  {2 nrbind(aa, bb) #按行合并
    7 y* ]) H% O  T4 |- h
    7 M6 s' |! u% p( q) L7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。6 O: v! H, E+ ^1 X
    例1:xx <- matrix(1:20, 4, 5)
    9 `& U0 l8 t3 d" Z8 X+ bcolMeans(xx) #列均值/ z9 r4 X+ q2 @0 V; Y
    colSums(xx) #列和
    4 p% I% C1 \2 Z% _7 y/ M其余大部分都要用到apply()函数; P& h: f2 [0 f7 N  d
    例2:xx <- matrix(1:20, 4, 5)+ t, ~, ^+ y; t0 {
    apply(xx, 2, mean) #列均值,等同于colMeans(xx)
    . G4 w4 O0 j$ P# xapply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。, ^0 f0 `+ Q0 E9 u% T. L
    apply(xx, 1, var) #行方差
    2 c: ?6 F! Y. {0 F6 `apply(xx, 2, max) #每列最大值
    9 ^3 a: h2 M/ \apply(xx, 2, rev) #每列的数反排列2 F- F+ i( ~6 I4 [0 L& d* o

    4 K8 m$ m0 s6 r' T; M0 w3 Q6 `' g2 l! U) S5 F+ P* |9 `8 P7 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, 2025-7-13 04:19 , Processed in 0.351665 second(s), 50 queries .

    回顶部