R语言中矩阵的常规操作

 

001、

mat <- matrix(1:16, 4, 4)             ## 生成矩阵        
mat                                   ## 显示矩阵

 

 

 

002、提取矩阵的对角线

mat
diag(mat)                    ## 提取矩阵的对角线

 

 

 

003、利用diag生成单位矩阵

diag(5)           ## 生成单位矩阵

 

 

 

004、提取矩阵的上三角矩阵及下三角矩阵

mat
lower.tri(mat)            ## 返回下三角矩阵的索引
mat[lower.tri(mat)]       ## 提取下三角矩阵的元素
upper.tri(mat)            ## 返回上三角矩阵的索引
mat[upper.tri(mat)]       ## 提取上三角矩阵的元素

 

 

005、利用矩阵的下三角构建对称矩阵

mat
mat1 <- mat
mat1[upper.tri(mat1)] <- t(mat1)[upper.tri(mat1)]          ## 以下三角矩阵构建对称矩阵
mat1

 

利用矩阵的上三角构建对称矩阵:

mat
mat2 <- mat
mat2[lower.tri(mat2)] <- t(mat2)[lower.tri(mat2)]   ## 利用矩阵的上三角矩阵构建对称矩阵
mat2

 

006、将矩阵转换为行列的形式

mat
rows <- rep(1:nrow(mat), times = ncol(mat))            ## 生成行序号
rows
cols <- rep(1:ncol(mat), each = nrow(mat))             ## 生成列序号
cols
values <- as.numeric(mat)                              ## 返回矩阵的元素
result <- data.frame(rows, cols, values)               ## 生成数据框

 

 

 

 

007、将三列的形式转换为矩阵

result
rows <- max(result[,1])               ## 提取行数
cols <- max(result[,2])               ## 提取列数
values <- result[,3]                  ## 提取值
mat2 <- matrix(values, rows, cols)    ## 生成矩阵
mat2

 

 

 

008、将矩阵转置

mat
t(mat)                      ## 将矩阵转置

 

 

 

009、矩阵相加减

mat1 <- matrix(1:16,4,4)
mat2 <- mat1                          ## 矩阵相加减仅适合同维度矩阵
mat1
mat2
mat1 + mat2                           ## 矩阵相加
mat1 - mat2                           ## 矩阵相减

 

 

 

010、数与矩阵相乘除

mat <- matrix(1:16,4,4)
mat
2 * mat                         ## 数于矩阵相乘除
mat / 2

 

011、矩阵相乘(矩阵相乘的条件是左侧矩阵的列数等于右侧矩阵的行数, 矩阵相乘的结果的维度是左侧矩阵的行数,右侧矩阵的列数)

mat1 <- matrix(1:6, 2, 3)     ## 两行三列的矩阵
mat1
mat2 <- matrix(1:6, 3, 2)     ## 三行两列的矩阵
mat2
mat1 %*% mat2                 ## 左侧矩阵的列数等于右侧矩阵的行数, 矩阵相乘的符号为%*%

 

 

012、计算t(A)%*%B的方法

方法1:

A <- matrix(1:12,3,4)
B <- matrix(1:15,3,5)
t(A)
B
t(A)%*%B                       ## 转置后矩阵相乘

 

 

方法2:用crossprod函数,数据量大时效率更高

A <- matrix(1:12,3,4)
B <- matrix(1:15,3,5)
A
B
crossprod(A,B)             ## 矩阵A转置后于矩阵B相乘

 

posted @ 2022-09-10 13:30  小鲨鱼2018  阅读(1507)  评论(0编辑  收藏  举报