QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2840|回复: 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。
      I* B. x7 ]+ m* M- u: ^! w+ p5 S1、对角矩阵和单位阵。
    / }- _! ?* u$ k3 V% E例1:x <- 1:6; diag(x) #对角矩阵
    . D/ P  K: ^+ |2 Y2 W2 c$ Y例2:y <- rep(1, 5); diag(y) #单位阵, n' |1 D5 G/ N% d9 s

    * g8 |5 H% O& G3 C1 h+ I2、矩阵下标; q2 b! `; {7 o
    例1:xx <- matrix(1:20, 4, 5)
    % X7 W; Q$ e) b. x+ p$ t" hxx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]6 h; u5 `1 z+ B5 t
    xx[2, ]; xx[ , 2]
    - r3 S# w& @4 d) R3 b
      w# H6 M" c0 F' ^4 R/ F+ H6 y$ ]& |3、代数意义下的矩阵乘法"%*%"/ B1 O0 E' b: y9 n0 v8 ?( i" d
    例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3). f, D5 q0 ?0 @2 k4 m
    yy %*% zz; zz %*% yy; x% L& S0 k. K: J5 J* {  g  L* [( M# A

    2 E6 ^0 |4 c# [4、矩阵行和列的维数" I3 T2 k# I! D9 P7 k
    例1:xx <- matrix(1:20, 4, 5)7 {* ^! O# M- q1 k3 f) [# X
    dim(xx) #行和列的维数
    % w( X' L( j" w7 ], Tnrow(xx); ncol(xx) #行数和列数
    ' Z" ~* _4 n& L% \2 c! {5 o2 z/ L+ a; |8 i# {/ Z* J9 ^5 y
    5、矩阵的主要运算函数' n/ M4 x1 [: d0 \3 n% U
    例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵
    % c  B4 r" r. \) c* ~% Uis.matrix(x); is.matrix(y) #判断是否矩阵
    - X! V" y4 k2 ~0 F例2:   diag() #方阵对角线元素或者生成对角矩阵
    % h  R$ x, b% capply() #对矩阵应用函数
    & R/ L% ^$ y7 P$ heigen() #求特征值和特征向量
    4 P' z% u# m: ~& Ysolve() #求逆矩阵
    ) t) {7 L1 ]6 r. G/ Bchol() #Choleski分解. U: h& ^( Y' |% w6 P9 ~. f
    svd() #奇异值分解
    9 ~+ ^1 Z/ e  Oqr() #QR分解
    : @2 q& q3 @4 O, K  ~2 ~+ Kdet() #求行列式
    0 h$ f; M; I% t  ^: mdim() #给出行列数
    8 Z! e4 Z% f# x% J; Ht() #矩阵转置
    5 p5 F& ]' p/ Y6 {8 |& I2 u" G9 f6 A" f! ?! [. p2 e
    6、矩阵合并4 a" x1 G+ s) Z! M) W4 M  b  \1 Y
    例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)
    ; O' q2 I$ S4 Z& R7 ?+ ?  }0 Z% Ycbind(aa, bb) #按列合并- ]1 G5 l2 n" x) k; B
    rbind(aa, bb) #按行合并
    ( @& T1 x9 [: ~/ q
    # H- ^7 `; K; g& F' x& m- v7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。' E6 E8 ~1 z& }! U8 e: z
    例1:xx <- matrix(1:20, 4, 5)
    9 p: e9 s- l  i2 U1 H+ icolMeans(xx) #列均值
    , `5 N0 _" M6 U7 B8 A. T+ PcolSums(xx) #列和
    8 a7 n8 U6 r4 v$ \其余大部分都要用到apply()函数9 k7 o8 K6 ]/ m# ~+ l
    例2:xx <- matrix(1:20, 4, 5)2 k: @: n  p5 a# `1 j& W% z2 n
    apply(xx, 2, mean) #列均值,等同于colMeans(xx)
    # c( t% F* K- F% R% K( Capply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。- {$ Y+ r! s1 c1 N0 ^
    apply(xx, 1, var) #行方差, p/ i+ h% g/ W5 a  v
    apply(xx, 2, max) #每列最大值
    * F" ]- Z6 N% |1 M% Tapply(xx, 2, rev) #每列的数反排列
    7 `; [5 ?6 y$ t* g. p" C1 X# N
    : Z" U, T* k( x4 I4 ^: S
    8 T$ U) H- M! R/ v3 {* }
    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-17 20:10 , Processed in 0.390112 second(s), 50 queries .

    回顶部