QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2831|回复: 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。
    ( I5 }6 |  H! x4 {1、对角矩阵和单位阵。1 a# ~# j6 i; A  `/ }! D& m
    例1:x <- 1:6; diag(x) #对角矩阵  u+ E4 c7 ]3 M) K
    例2:y <- rep(1, 5); diag(y) #单位阵
    0 k$ n* z* `3 x2 e' c" g: d$ b  u
    ! g% `3 j8 O* O4 S9 v- D, R; y2、矩阵下标! L* J( Y2 L: U8 j! X7 V* x8 |
    例1:xx <- matrix(1:20, 4, 5): r6 j& X# f" b6 [% w
    xx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]
    7 u- W, G' r% W( rxx[2, ]; xx[ , 2]
    0 Y$ Y4 B2 `, P5 P4 t8 `/ J
    - o6 x, m( {! L3、代数意义下的矩阵乘法"%*%"( {: E9 s' _2 t
    例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)! I* l3 T( K5 p" h/ ]; A- C: v
    yy %*% zz; zz %*% yy7 w, b0 p9 L& j# c2 N" i

    % P: W" _2 s0 I3 |2 d4、矩阵行和列的维数
    + M: \; D2 v3 E' }9 @# L' ~9 t例1:xx <- matrix(1:20, 4, 5)% [9 i* L, w& G. O* g
    dim(xx) #行和列的维数
    0 ?, ~7 i& g$ Znrow(xx); ncol(xx) #行数和列数, d- O  d: J- X6 [3 T3 A. ~9 }% I# n

    4 q- c. f3 z6 ^; D; X9 N* k8 J5、矩阵的主要运算函数8 x; m2 }9 m$ B) M0 @
    例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵
      C% v# u* E$ ~, c- `( T! Dis.matrix(x); is.matrix(y) #判断是否矩阵/ E' t1 p3 h- v5 E
    例2:   diag() #方阵对角线元素或者生成对角矩阵
    6 _# y3 h, O' ]4 e, V1 bapply() #对矩阵应用函数$ k6 L3 y$ ?4 d+ F) v
    eigen() #求特征值和特征向量$ D8 C; x/ ]) R* ^+ ~4 D. b7 u6 g3 i
    solve() #求逆矩阵6 b; D, ~; z3 p/ R9 t2 n" X/ a# D
    chol() #Choleski分解
    ) f+ \$ `6 \# B- c9 l* Q8 D1 q' xsvd() #奇异值分解
    * \# r' I9 N/ t8 N, Y, C3 H" q% Iqr() #QR分解
    ) o& i1 }' _* k2 N2 V; W. xdet() #求行列式' ?1 s3 E/ J0 |1 N4 M* O' q
    dim() #给出行列数
    / Z: s; F' o: n4 |* v4 bt() #矩阵转置
    . {4 h3 E" S! N& f7 F8 [
    * a8 J  f' S* h) ^6、矩阵合并; f7 f# s. J/ s, g  ^+ J
    例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2). T& n" @  w+ q5 Y' G" a
    cbind(aa, bb) #按列合并
    ( t7 z, q3 h* d9 O( n+ H! ^rbind(aa, bb) #按行合并
    3 P/ {' H, U4 Z  U, S* q; U0 Q
    - h/ S- q, G) Z# u3 B7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。. `7 z+ H+ s7 z# H
    例1:xx <- matrix(1:20, 4, 5)
    3 M" p6 e, ~. S9 P- k/ S8 YcolMeans(xx) #列均值
    8 J4 G$ H- @' [: GcolSums(xx) #列和
    ) A5 ]& S: ?! P* f/ F其余大部分都要用到apply()函数; [, G  g2 E/ v
    例2:xx <- matrix(1:20, 4, 5)9 l( o* p1 t( I; d* i1 Q  x
    apply(xx, 2, mean) #列均值,等同于colMeans(xx), Y1 M- M: O0 t) U
    apply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。
    7 G5 H5 Q( F/ d( b- japply(xx, 1, var) #行方差
    4 @* `( V! e- E5 Gapply(xx, 2, max) #每列最大值5 j7 U8 r  W' l: {8 T/ n
    apply(xx, 2, rev) #每列的数反排列6 R! k4 c8 k4 n, b) M; Y
    - N$ s. `  v, L5 X5 i* F

    3 a/ ~) W0 w  N. x/ F+ A+ z
    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-5-25 20:29 , Processed in 0.432306 second(s), 50 queries .

    回顶部