- 在线时间
- 27 小时
- 最后登录
- 2013-5-20
- 注册时间
- 2012-11-2
- 听众数
- 15
- 收听数
- 1
- 能力
- 0 分
- 体力
- 3870 点
- 威望
- 0 点
- 阅读权限
- 60
- 积分
- 1335
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 347
- 主题
- 320
- 精华
- 0
- 分享
- 0
- 好友
- 6
升级   33.5% TA的每日心情 | 奋斗 2013-6-15 16:58 |
|---|
签到天数: 24 天 [LV.4]偶尔看看III
 群组: 第四届数学中国美赛实 |
|
矩阵(matrix) 矩阵生成函数matrix():matrix(data, nrow = , ncol = , byrow = F),其中,数据data是必须的,其他都是选择参数,可以不选。byrow = F默认为按列来排列数据,如果想要按行排列,令byrow = T。
( I5 }6 | H! x4 {1、对角矩阵和单位阵。1 a# ~# j6 i; A `/ }! D& m
例1:x <- 1:6; diag(x) #对角矩阵 u+ E4 c7 ]3 M) K
例2:y <- rep(1, 5); diag(y) #单位阵
0 k$ n* z* `3 x2 e' c" g: d$ b u
! g% `3 j8 O* O4 S9 v- D, R; y2、矩阵下标! L* J( Y2 L: U8 j! X7 V* x8 |
例1:xx <- matrix(1:20, 4, 5): r6 j& X# f" b6 [% w
xx[2, 2]; xx[2, 3:5]; xx[3:4, 3:4]
7 u- W, G' r% W( rxx[2, ]; xx[ , 2]
0 Y$ Y4 B2 `, P5 P4 t8 `/ J
- o6 x, m( {! L3、代数意义下的矩阵乘法"%*%"( {: E9 s' _2 t
例1:yy <- matrix(1:6, 3, 2); zz <- matrix(1:6, 2, 3)! I* l3 T( K5 p" h/ ]; A- C: v
yy %*% zz; zz %*% yy7 w, b0 p9 L& j# c2 N" i
% P: W" _2 s0 I3 |2 d4、矩阵行和列的维数
+ M: \; D2 v3 E' }9 @# L' ~9 t例1:xx <- matrix(1:20, 4, 5)% [9 i* L, w& G. O* g
dim(xx) #行和列的维数
0 ?, ~7 i& g$ Znrow(xx); ncol(xx) #行数和列数, d- O d: J- X6 [3 T3 A. ~9 }% I# n
4 q- c. f3 z6 ^; D; X9 N* k8 J5、矩阵的主要运算函数8 x; m2 }9 m$ B) M0 @
例1:x <- 1:6; y <- as.matrix(x) #转换成矩阵
C% v# u* E$ ~, c- `( T! Dis.matrix(x); is.matrix(y) #判断是否矩阵/ E' t1 p3 h- v5 E
例2: diag() #方阵对角线元素或者生成对角矩阵
6 _# y3 h, O' ]4 e, V1 bapply() #对矩阵应用函数$ k6 L3 y$ ?4 d+ F) v
eigen() #求特征值和特征向量$ D8 C; x/ ]) R* ^+ ~4 D. b7 u6 g3 i
solve() #求逆矩阵6 b; D, ~; z3 p/ R9 t2 n" X/ a# D
chol() #Choleski分解
) f+ \$ `6 \# B- c9 l* Q8 D1 q' xsvd() #奇异值分解
* \# r' I9 N/ t8 N, Y, C3 H" q% Iqr() #QR分解
) o& i1 }' _* k2 N2 V; W. xdet() #求行列式' ?1 s3 E/ J0 |1 N4 M* O' q
dim() #给出行列数
/ Z: s; F' o: n4 |* v4 bt() #矩阵转置
. {4 h3 E" S! N& f7 F8 [
* a8 J f' S* h) ^6、矩阵合并; f7 f# s. J/ s, g ^+ J
例1:aa <- matrix(1:6, 3, 2); bb <- matrix(7:12, 3, 2). T& n" @ w+ q5 Y' G" a
cbind(aa, bb) #按列合并
( t7 z, q3 h* d9 O( n+ H! ^rbind(aa, bb) #按行合并
3 P/ {' H, U4 Z U, S* q; U0 Q
- h/ S- q, G) Z# u3 B7、矩阵apply()运算函数:语法是apply(data, dim, function),dim取1表示对行运用函数,取2表示对列运用函数。. `7 z+ H+ s7 z# H
例1:xx <- matrix(1:20, 4, 5)
3 M" p6 e, ~. S9 P- k/ S8 YcolMeans(xx) #列均值
8 J4 G$ H- @' [: GcolSums(xx) #列和
) A5 ]& S: ?! P* f/ F其余大部分都要用到apply()函数; [, G g2 E/ v
例2:xx <- matrix(1:20, 4, 5)9 l( o* p1 t( I; d* i1 Q x
apply(xx, 2, mean) #列均值,等同于colMeans(xx), Y1 M- M: O0 t) U
apply(xx, 2, sum) #列和,等同于colMeans(xx),所以矩阵行和列的运算推荐用apply()。
7 G5 H5 Q( F/ d( b- japply(xx, 1, var) #行方差
4 @* `( V! e- E5 Gapply(xx, 2, max) #每列最大值5 j7 U8 r W' l: {8 T/ n
apply(xx, 2, rev) #每列的数反排列6 R! k4 c8 k4 n, b) M; Y
- N$ s. ` v, L5 X5 i* F
3 a/ ~) W0 w N. x/ F+ A+ z |
zan
|