QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2814|回复: 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。
    4 X7 k9 k% f8 L0 Y/ h3 |( S' v! U2 Q1、对角矩阵和单位阵。! I9 p! o' ?3 H8 G
    例1:x <- 1:6; diag(x) #对角矩阵
    ( L% i: \5 K! I9 b( b" l例2:y <- rep(1, 5); diag(y) #单位阵. o4 H9 J# y  _5 \
    % H5 p  [2 n) A7 O9 l
    2、矩阵下标8 z; b3 \0 j0 T( g/ b0 n! Z# ~
    例1:xx <- matrix(1:20, 4, 5)
    ' f4 Q8 l( k+ i( N9 t- axx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]: X/ ?* A5 Y$ o' [
    xx[2, ]; xx[ , 2]
    ( G0 S* i" N5 h* c9 Y" C4 A9 W/ S$ j1 m% p0 e: d$ z) I8 z
    3、代数意义下的矩阵乘法"%*%"
    & b- Q: E8 Y% A) O/ Z例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)7 X! L2 D" u! ?3 U/ ?; L
    yy %*% zz; zz %*% yy
    - |  K* i" G; Z6 f0 F+ x6 o7 |+ k( Z# M* d
    4、矩阵行和列的维数
    3 g7 l1 P6 L0 X+ m' _例1:xx <- matrix(1:20, 4, 5)+ Z9 C6 a2 `$ U: A* ^" s  r  a
    dim(xx) #行和列的维数# R% @, x4 R% m( G
    nrow(xx); ncol(xx) #行数和列数7 C6 H5 K, f# e
    5 y/ R( D8 V; o3 g. u
    5、矩阵的主要运算函数
    3 y& c& ]2 F& P8 G2 _; _* q例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵
    % T7 O6 i1 E, F, P* a  n7 I# gis.matrix(x); is.matrix(y) #判断是否矩阵
    & G6 P, _( B  Y" }* y例2:   diag() #方阵对角线元素或者生成对角矩阵$ ?( C- ]) p( l' h" N
    apply() #对矩阵应用函数
    5 h# z: q2 S' Jeigen() #求特征值和特征向量+ ?, {  J3 \6 c  r$ I2 s! \
    solve() #求逆矩阵5 r; h6 q7 @! r
    chol() #Choleski分解6 r" b; ]( G; U4 J0 e1 T
    svd() #奇异值分解
    * k$ s  y  R$ {+ k  e1 ^$ d, cqr() #QR分解; r) F3 V- c6 \. `5 R
    det() #求行列式
    6 ^! s  @' v- @/ H1 N5 k$ W  V, Kdim() #给出行列数
    1 z( V  ?/ X, L4 c/ Qt() #矩阵转置2 Y& s$ d/ f, ?

    ! V* O; _7 Z4 `( q2 q6、矩阵合并
    # [1 G8 n! \8 H0 D% l* c例1:aa <- matrix(1:6, 3, 2);  bb <- matrix(7:12, 3, 2)
    ; e8 h# i2 w+ o, ^# W% n7 Acbind(aa, bb) #按列合并7 t, O3 G0 M; `$ R
    rbind(aa, bb) #按行合并
    4 Z& t; c# q6 V# K/ x0 o& u: S1 g0 Q' o( x5 l& `
    7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。' V# f. g  Y% D7 q4 h& W/ ]
    例1:xx <- matrix(1:20, 4, 5)
    2 s4 Y# X+ z6 S( n* K2 zcolMeans(xx) #列均值
    + [, X" S0 _: N  YcolSums(xx) #列和" j6 b& |1 f6 ]# ^; g# X
    其余大部分都要用到apply()函数0 ^( }. b4 g& f% u7 B
    例2:xx <- matrix(1:20, 4, 5)5 P8 b9 o. l8 T0 r+ o0 g, k" N
    apply(xx, 2, mean) #列均值,等同于colMeans(xx)
    5 m. }8 n! }+ G5 E8 \& ]; Rapply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。- Q4 p7 r0 i& C9 I& A
    apply(xx, 1, var) #行方差
    ( A  T1 ~9 q& H6 U1 c# e' Japply(xx, 2, max) #每列最大值
    6 W" u, }1 r% E# tapply(xx, 2, rev) #每列的数反排列
    ( |4 j  w) P" L, N, p8 ^4 e( k* q' n) b
      m) Q5 t# [5 F* l3 g; d% I  Q  v3 H" p& K
    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-4-23 01:36 , Processed in 0.521631 second(s), 50 queries .

    回顶部