QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2481|回复: 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。' J7 h2 @7 Z# X5 s8 A1 {4 u
    1、对角矩阵和单位阵。
    / V/ `3 v* e% Y8 p5 S例1:x <- 1:6; diag(x) #对角矩阵: w9 o' w1 n, P' E8 y
    例2:y <- rep(1, 5); diag(y) #单位阵
    + d4 ^5 e  X. L* U3 t& C$ g7 n: R. e6 ?4 T
    2、矩阵下标
    1 T1 F& u, s& A& h* y( H例1:xx <- matrix(1:20, 4, 5)
    ) z; N- @1 v" |- `) \6 A! _xx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]* N! @' V4 K. |7 B
    xx[2, ]; xx[ , 2]
    # p7 {8 @, [: `( E, `2 d9 k$ m- b9 d/ f0 f- Q
    3、代数意义下的矩阵乘法"%*%"/ D/ @8 w/ _4 k8 l. E+ Y
    例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)
    # c) j9 }/ o. k7 o1 P  `7 Qyy %*% zz; zz %*% yy; a; }8 h. v5 C- v; P

    $ O0 q- J5 g3 r! w$ d4、矩阵行和列的维数
    / N! {# W  O" C5 B例1:xx <- matrix(1:20, 4, 5)
    4 k  Z9 }$ {( jdim(xx) #行和列的维数
    7 \8 {9 d1 m) N  E. `nrow(xx); ncol(xx) #行数和列数
    9 _! S* k% c0 \9 Q7 N, u
    / k( P1 C7 a9 ?  o5、矩阵的主要运算函数2 s( Y- O: j3 v
    例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵& c4 D4 U1 ?4 y+ `
    is.matrix(x); is.matrix(y) #判断是否矩阵
    & C3 ]- r" @2 _1 t例2:   diag() #方阵对角线元素或者生成对角矩阵5 v5 |! k+ I7 K! J" L, f, @' i- Q
    apply() #对矩阵应用函数8 ^. W  i5 f+ u' y* @4 V
    eigen() #求特征值和特征向量, x9 W- l3 j( Z# c
    solve() #求逆矩阵
    0 a$ {0 p! J! q% i5 o2 L) G+ Ychol() #Choleski分解- a. _0 U8 M# p' ~2 w
    svd() #奇异值分解
    * w8 O8 _5 f3 F6 @: k9 ?qr() #QR分解
    ) f+ S! N( Z9 l9 G! b9 Vdet() #求行列式' q; c) v0 u9 e; h& b
    dim() #给出行列数
    " [7 Q7 o3 H3 N5 i2 n0 a) Y5 R8 @: Yt() #矩阵转置" r# Q* \# A+ |% W+ p& a# G& _
    6 P! W; f7 k* G5 |. {1 M4 W
    6、矩阵合并/ o' {# `2 U# X; [, g: C0 z
    例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)
    5 c- z8 `3 D. a1 Zcbind(aa, bb) #按列合并
    4 z: k; i$ Y' C; P; R/ Prbind(aa, bb) #按行合并
    ; Y- y9 _( l2 L: E. F6 L: \! h( w! P7 ?% B% N
    7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。8 D8 Q* _% y3 G: ^, a
    例1:xx <- matrix(1:20, 4, 5)
    + w0 Q( u; l2 {0 v" u# g6 {+ ?0 VcolMeans(xx) #列均值% V) C  t/ J5 a( B1 X
    colSums(xx) #列和
    3 n( X& v1 B6 e2 |+ |% T4 N其余大部分都要用到apply()函数1 @) x9 f  ^" Z$ V. ?
    例2:xx <- matrix(1:20, 4, 5)% K2 j! Z8 a# Y: O
    apply(xx, 2, mean) #列均值,等同于colMeans(xx)+ F, _3 c4 X( z8 U
    apply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。) o5 q# d1 v) c7 A
    apply(xx, 1, var) #行方差, I# M8 W* r$ w* N! b
    apply(xx, 2, max) #每列最大值+ |9 d. [. ~0 x
    apply(xx, 2, rev) #每列的数反排列
    7 E/ d2 G3 b2 ]5 ^  F) [6 G" p0 f8 I7 x, {3 Z0 [

    4 ^& h2 z- P8 f9 V7 s7 x
    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-14 03:52 , Processed in 0.315707 second(s), 49 queries .

    回顶部