QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2362|回复: 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。
    $ n1 P: J2 ]  D1、对角矩阵和单位阵。( n$ R& e& a6 N" G2 f$ S! a
    例1:x <- 1:6; diag(x) #对角矩阵
    2 d  O( u/ X. Q. m4 u+ @例2:y <- rep(1, 5); diag(y) #单位阵4 h9 o( u& ]3 s

    % x# k5 o" q; i6 ]3 B2、矩阵下标
    4 V* M) Z5 t/ i8 B" ]- C例1:xx <- matrix(1:20, 4, 5)
    - O5 Z! \- B: J& f- kxx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]
    ; G! U+ }4 ^6 t6 `xx[2, ]; xx[ , 2]/ R( j. t& O; |0 M( `& m6 M4 x/ D2 A
    + ^5 Z+ O& ~+ x9 Y1 b: P7 z
    3、代数意义下的矩阵乘法"%*%"/ u1 z' q: Y4 ?6 p* P& ?0 {3 M
    例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)) `6 ^3 c& W" B) n1 c. C* n
    yy %*% zz; zz %*% yy
    / b' R( M$ a% O  l1 b/ D+ M8 y
    0 h" w" q# n' r" f" g0 |6 L4、矩阵行和列的维数0 ?4 j/ \7 W& [
    例1:xx <- matrix(1:20, 4, 5)+ A! b+ B) p) q$ ?( R8 ]% G
    dim(xx) #行和列的维数
    6 y7 X6 N8 K6 O+ F2 h2 |: v8 F8 vnrow(xx); ncol(xx) #行数和列数
    0 \& @; @! o( O& G( P- M. C0 _% V6 _- U
    5、矩阵的主要运算函数9 w2 a' `" C* c3 {' I
    例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵! z- ^. U4 y! Z- z/ [' o8 Z+ C" h: h
    is.matrix(x); is.matrix(y) #判断是否矩阵- f9 _$ J3 ^! K* R. `
    例2:   diag() #方阵对角线元素或者生成对角矩阵
    3 W' M5 s9 u, P1 O6 x% @. G" yapply() #对矩阵应用函数; s" g2 d" P5 z1 N2 b$ g
    eigen() #求特征值和特征向量( I& u5 h8 e0 r6 ]* k
    solve() #求逆矩阵
    9 B& n4 j8 ^/ {' N  Ochol() #Choleski分解
    5 Y7 w! x" f; E( v! W% lsvd() #奇异值分解* H8 u- Y1 M, D6 I" Z2 G0 ?. b) ^
    qr() #QR分解
    + B! B; \2 _3 v5 Gdet() #求行列式# H5 @( a8 n. i& f. Y
    dim() #给出行列数+ m- t& o& U- o& ^( E8 U( U/ h
    t() #矩阵转置% [7 x; s+ l) [0 E- {
    - Y8 V0 x* K$ L& J
    6、矩阵合并
    ' V5 d, W% f, n3 ]例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)* H% G+ K, V( @4 Z
    cbind(aa, bb) #按列合并
    8 e+ Y% x- A4 x5 {  X4 N/ Z( a4 ?6 Orbind(aa, bb) #按行合并. q2 @5 B3 Y' f5 d# s% @

    ; V( a2 T* ~" t7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。
    , w  }2 q( ]" E8 B0 y3 T例1:xx <- matrix(1:20, 4, 5)
    ( d! P! }2 P- H) w+ TcolMeans(xx) #列均值" x7 j! f3 Z, H/ I+ V4 |
    colSums(xx) #列和5 m* E) _  x, a+ p% Q+ T$ h( b
    其余大部分都要用到apply()函数0 f- W5 }) A! W" N6 V0 |. `* d
    例2:xx <- matrix(1:20, 4, 5)! O3 H. s. l5 b6 U. v/ T$ u
    apply(xx, 2, mean) #列均值,等同于colMeans(xx)
    . T+ ^$ r  ~9 H$ R# Bapply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。2 L; t3 z- ~0 v, Y' R8 E- K# q
    apply(xx, 1, var) #行方差5 W8 N# g' u1 F% k
    apply(xx, 2, max) #每列最大值! g3 Z9 c( x1 ^7 o
    apply(xx, 2, rev) #每列的数反排列
    9 L7 P  p9 S# U/ ]3 H2 a2 y4 a
    3 A% W/ U* P2 G' `6 z+ j0 v& y, B
    * u) Z; `( t8 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-5-13 05:01 , Processed in 0.409565 second(s), 49 queries .

    回顶部