QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2832|回复: 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。
    6 o1 X& E+ g$ l$ t: v; @  F1、对角矩阵和单位阵。" P: \0 a+ X# @' y& a+ p
    例1:x <- 1:6; diag(x) #对角矩阵
    , `6 B! j- P1 f! m1 ?& ?# q5 R例2:y <- rep(1, 5); diag(y) #单位阵6 F$ U8 h: s& `

    8 ^" A: j: h/ h2 g2、矩阵下标
    2 o4 e. A4 f! v例1:xx <- matrix(1:20, 4, 5)
    4 M/ g- }6 b2 ?% H4 m3 Mxx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]% X2 J( j# U& X. V+ A
    xx[2, ]; xx[ , 2]: M4 `, }8 Z5 F5 L+ T" t
    & q  j( x$ ^$ r6 p/ `. e5 [7 x
    3、代数意义下的矩阵乘法"%*%"
    1 L4 V) \: b6 r$ u% M8 c% `例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3); H) c  e# ^0 d8 s4 }& Y
    yy %*% zz; zz %*% yy
    . A( e9 I/ a6 z6 S
    - M4 ^6 g0 ^$ h' w0 u, q4、矩阵行和列的维数
    - @+ I% Q, i/ s2 ?- z例1:xx <- matrix(1:20, 4, 5)
    4 ^! Q/ w; h- A* g/ c1 ?dim(xx) #行和列的维数
    ; B$ G2 Q7 Q: T5 O1 Gnrow(xx); ncol(xx) #行数和列数
    9 j- G+ T9 k( O3 A+ B6 x' Q! u' ~- s4 j3 d5 O* F' H' \5 `
    5、矩阵的主要运算函数+ H# L7 q) W! S% `
    例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵. F6 y7 P4 s( h7 k" u
    is.matrix(x); is.matrix(y) #判断是否矩阵
    3 U6 N& u/ T' M! L8 C, b* K* O/ b例2:   diag() #方阵对角线元素或者生成对角矩阵/ t% h+ d8 p- H5 O( l. g! L! B" V7 K
    apply() #对矩阵应用函数
    ( }1 V! x6 a- j6 Geigen() #求特征值和特征向量
    ; X& C# Q0 u0 u6 Zsolve() #求逆矩阵9 k# \/ T  `' v
    chol() #Choleski分解
    % I  U- v/ Z+ \) P' k! C, z9 msvd() #奇异值分解
    * P& i4 a4 u& q1 Qqr() #QR分解
    ( ^! d( w8 d5 z+ m" f. x# g8 t# ldet() #求行列式- m% e* B9 \2 v& O/ l
    dim() #给出行列数( X1 R2 X  Y* ^% \8 i0 p5 _4 v7 e
    t() #矩阵转置  j1 e+ ^8 [3 O: q
    ; O1 f: C' U  E5 I2 p2 |5 v5 l
    6、矩阵合并
    7 g1 S( S' d/ X( B$ i例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)- s1 `/ d; T$ m4 |
    cbind(aa, bb) #按列合并" Z+ ~4 |+ [* n9 ]$ r/ n: N5 s
    rbind(aa, bb) #按行合并. I4 e. }/ @' }  M5 B6 S5 }$ L
    , A4 G  \1 b' b. z
    7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。
    / x/ t6 O) o5 h3 P# s例1:xx <- matrix(1:20, 4, 5): j2 ?4 I6 L& E* Y' m3 e# \4 [
    colMeans(xx) #列均值7 O( w5 }: M; h7 m- g7 T4 \8 W
    colSums(xx) #列和
    2 ^) B2 H6 Y, N1 o: u( a& J- ?其余大部分都要用到apply()函数" C# m6 T- ?" ]& J
    例2:xx <- matrix(1:20, 4, 5): v% @$ [2 T# b# _" U3 d+ ^
    apply(xx, 2, mean) #列均值,等同于colMeans(xx)( m* T1 X5 ^3 ?0 J* V# A# Y
    apply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。
    # ~' y) V& Y2 W% Lapply(xx, 1, var) #行方差
    & b: m/ B& A% X% q2 n8 X( V. Mapply(xx, 2, max) #每列最大值
    4 f9 I; `# r- V9 Y# X9 g2 tapply(xx, 2, rev) #每列的数反排列
    ) ~, Z/ t! k% X/ Q
    / |! [9 c$ |9 |. ^; H+ w% T5 L) g5 {/ P7 f4 J4 B: m
    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 21:59 , Processed in 0.281672 second(s), 50 queries .

    回顶部