【应用多元统计分析】--数据矩阵及R语言表示

        在多元分析中,数据通常以矩阵的形式出现,下面结合R语言介绍基本的矩阵运算。主要包括:创建矩阵向量,矩阵加减、乘积,矩阵的逆,行列式的值,特征值与特征向量,QR分解,奇异值分解,取矩阵的上下三角元素,向量化算子等。

1.创建一个向量(随机变量、一维数组)

用函数c()来创建一个向量

#创建向量
x1=c(171,175,159,155,152,158,154,164,168,166,159,164)
x2=c(57,64,41,38,35,44,41,51,57,49,47,46)length(x1)#返回向量长度
length(x2)mode(x1)#返回向量的数据类型

2.创建一个矩阵(二维数组)

1)合并命令

可以用rbind()、cbind()将两个或两个以上的向量或矩阵合并起来,rbind()表示按行合并,cbind()按列合并。

#创建矩阵
rbind(x1,x2)#按行合并
cbind(x1,x2)#按列合并

2)生成矩阵

matrix(data=NA,nrow=1,ncol=1,byrow=FALSE,dimnames=NULL)
#data为必要的矩阵元素,nrow为行数,ncol为列数,这俩乘积应为矩阵元素个数
#byrow控制排列元素是否按行进行
#dimnames给定行和列的名称
matrix(x1,nrow=3,ncol=4)#生成矩阵,matrix(x1,nrow=4,ncol=3)

3.矩阵转置

A为m*n矩阵,A'为其转置矩阵,求A’在R中可用函数t()或transpose()

#矩阵转置
A=matrix(1:12,nrow=3,ncol=4)
t(A)#用函数t()或transpose()转置

4.矩阵相加减 

#矩阵相加减
A=B=matrix(1:12,nrow=3,ncol=4)
A+B

5.矩阵相乘

A为m*n矩阵,B为n*k矩阵,在R 中求AB可用符号“%*%” 

#矩阵相乘
A=matrix(1:12,nrow=3,ncol=4)
B=matrix(1:12,nrow=4,ncol=3)
A%*%B

6.矩阵对角元素相关运算  

#矩阵对角元素相关运算
A=matrix(1:16,nrow=4,ncol = 4)
diag(A)#产生以这个向量为对角元素的对角矩阵
#对一个正整数k应用diag()函数将产生k维单位矩阵
diag(diag(A))
diag(3)

7.矩阵求逆

矩阵求逆可用函数solve(),应用solve(A,b)运算结果可解线性方程组Ax=b,
若b缺省,则系统默认为单位矩阵,因此可用其进行矩阵求逆

#矩阵求逆
A=matrix(rnorm(16),4,4);A
solve(A)
#矩阵求逆可用函数solve(),应用solve(A,b)运算结果可解线性方程组Ax=b,
#若b缺省,则系统默认为单位矩阵,因此可用其进行矩阵求逆

8.矩阵的特征值与特征向量

矩阵A的谱分解为A=U^U',其中^是由A的特征值组成的对角矩阵,
U的列为A的特征值对应的特征向量,可以用函数eigen()得到U和A
eigen(x,symmetric,only.values=FALSE,EISPACK = FALSE)
其中x为矩阵,symmetric项指定矩阵x是否为对称矩阵,不指定则系统自动检测

#矩阵特征值与特征向量
A=diag(4)+1
A
A.e=eigen(A,symmetric = T)
A.e
#矩阵A的谱分解为A=U^U',其中^是由A的特征值组成的对角矩阵,
#U的列为A的特征值对应的特征向量,可以用函数eigen()得到U和A
#eigen(x,symmetric,only.values=FALSE,EISPACK = FALSE)
#其中x为矩阵,symmetric项指定矩阵x是否为对称矩阵,不指定则系统自动检测
A.e$vectors%*%diag(A.e$values)%*%t(A.e$vectors)

9.矩阵的Choleskey分解

对于正定矩阵A,可对其进行Choleskey分解,A=P'P,P为上三角矩阵
在R中可以用chol()函数进行Choleskey分解

#矩阵的Choleskey分解
#对于正定矩阵A,可对其进行Choleskey分解,A=P'P,P为上三角矩阵
#在R中可以用chol()函数进行Choleskey分解
A.e=chol(A)
A.e
t(A.e)%*%A.e

10.矩阵奇异值分解

A为m*n矩阵,rank(A)=r,可以分解为A=UDV',其中U'U=V'V=I
在R中可以用函数svd()进行奇异值分解

#矩阵奇异值分解
#A为m*n矩阵,rank(A)=r,可以分解为A=UDV',其中U'U=V'V=I
#在R中可以用函数svd()进行奇异值分解
A=matrix(1:18,3,6)
A
A.s=svd(A)
A.s
A.s$u%*%diag(A.s$d)%*%t(A.s$v)

11.矩阵QR分解

A为m*n矩阵时可以进行QR分解,A=QR
其中Q'Q=I,在R中可以用函数qr()进行QR分解

#矩阵QR分解
#A为m*n矩阵时可以进行QR分解,A=QR
#其中Q'Q=I,在R中可以用函数qr()进行QR分解
A=matrix(1:16,4,4)
qr(A)

12.矩阵kronecker积

n*m矩阵A与h*k矩阵B的kronecker积为一个nh*mk维矩阵
在R中,kronecker积可以用函数kronecker()来计算

#矩阵kronecker积
#n*m矩阵A与h*k矩阵B的kronecker积为一个nh*mk维矩阵
#在R中,kronecker积可以用函数kronecker()来计算
A=matrix(1:4,2,2)
A
B=matrix(rep(1,4),2,2)
B
kronecker(A,B)

13.矩阵的维数

函数dim()将返回一个矩阵的维数
nrow()返回行数,ncol()返回列数

#矩阵的维数
#函数dim()将返回一个矩阵的维数
#nrow()返回行数,ncol()返回列数
A=matrix(1:12,3,4)
A
dim(A)
nrow(A)
ncol(A)

14.矩阵的行和、列和、行平均数与列平均

#矩阵的行和、列和、行平均数与列平均
rowSums(A)
rowMeans(A)
colSums(A)
colMeans(A)
#还可以用apply()函数实现:apply(X,MARGIN,FUN,......)
#x为矩阵,MARGIN指定对行还是对列操作,1表示行运算,2为对列运算
#FUN用来指定运算函数,“...”用来指定FUN中需要的其他参数
apply(A,1,sum)
apply(A,1,mean)
apply(A,2,sum)
apply(A,2,mean)A=matrix(rnorm(100),20,5)
apply(A,2,var)#计算每一列的方差
apply(A,2,function(x,a)x*a,a=2)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/715617.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微前端-乾坤《》

微前端 一个应用,当不断迭代的时候,功能会越来越多,代码量随着也会变得越来越大。进而代码之间的耦合性会变高,这样导致开发和维护很糟心,动一发而牵全身。于是有了微前端来解这个问题,按功能可以将这个应…

day02-JavaScript-Vue

文章目录 1 JavaScript1.1 介绍 1.2 引入方式1.3 基础语法1.3.1 书写语法1.3.2 变量1.3.3 数据类型和运算符 1.4 函数1.4.1 第一种定义格式1.4.2 第二种定义格式 1.5 JavaScript对象1.5.1 基本对象1.5.1.1 Array对象语法格式特点属性和方法 1.5.1.2 String对象语法格式属性和方…

17.来自Sora的夺舍妄想——享元模式详解

OpenAI 的 Sora 模型面世之后,可以说人类抵御AI的最后阵地也沦陷了。 在此之前,人们面对AI交互式对话,AI制图,AI建模之类的奇迹时,还可以略微放肆的说:“的确很神奇,这毕竟还是比人类世界低了一…

Redis基本知识

一、什么是Redis Redis是一种基于内存的数据库,对数据的读写操作都是在内存中完成,因此读写速度非常快,用于存储键值对、缓存、消息队列、分布式锁等。 二、Redis和mencached的区别 相同:都是基于内存的数据库,读写都…

2024年腾讯云部署幻兽帕鲁服务器,如何选择合适的服务器配置套餐畅玩游戏?

选择合适的服务器配置套餐以畅玩《幻兽帕鲁》游戏,首先需要考虑的是玩家数量和对服务器性能的需求。根据腾讯云提供的配置推荐,对于4到8人的玩家,推荐配置为4核16G12M;而10到20人的玩家则建议选择8核32G22M配置。这是因为《幻兽帕…

小程序页面指定区域局部滚动,做上拉和触底刷新

业务需求:在页面某个固定区域滑动 思路:滑动高度 页面高度 - 自定义导航高度(不是自己自定义的导航可以省略)- 按钮高度 - 单词数高度 实现 : 1.数据展示区内使用scroll-view,设置y轴滚动(…

swoole

php是单线程。php是靠多进程来处理任务,任何后端语言都可以采用多进程处理方式。如我们常用的php-fpm进程管理器。线程与协程,大小的关系是进程>线程>协程,而我们所说的swoole让php实现了多线程,其实在这里来说,就是好比让php创建了多个进程,每个进程执行一条…

初阶数据结构:二叉树

目录 1. 树的相关概念1.1 简述:树1.2 树的概念补充 2. 二叉树2.1 二叉树的概念2.2 二叉树的性质2.3 二叉树的存储结构与堆2.3.1 存储结构2.3.2 堆的概念2.3.3 堆的实现2.3.3.1 堆的向上调整法2.3.3.2 堆的向下调整算法2.3.3.3 堆的实现 1. 树的相关概念 1.1 简述&a…

域名及地址正确外,若依后台无法正常加载页面和退出报404问题

写小程序退出的时候,另外写了一个自定义退出处理类,里面的响应浏览器的代码每次都走。因为原来也有个退出处理类,所以先后走了2次,因为就出现了问题。 LogoutSuccessHandlerImpl类里的: ServletUtils.renderString(r…

【C++ AVL树】

文章目录 AVL树AVL树的概念AVL树节点的定义AVL树的插入AVL树的旋转右单旋左单旋左右双旋右左双旋 代码实现 总结 AVL树 AVL树的概念 二叉搜索树在顺序有序或接近有序的情况下,而插入搜索树将退化为单叉树,此时查找的时间复杂度为O(n),效率低…

鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:颜色渐变)

设置组件的颜色渐变效果。 说明: 从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 linearGradient linearGradient(value: { angle?: number | string; direction?: GradientDirection; colors: Array; repea…

mamba-ssm安装building wheel卡着不动后error...避坑解决方法

文章目录 方法1、下载whl文件到本地后pip install安装成功后验证: 方法2、拉取Docker镜像 对于项目中用到MambaIR的小伙伴,需要pip安装 causal_conv1d和 mamba-ssm两个包及其依赖: torch packing transformersMambaIR-Github主页&#xff0…

【C++】vector的使用及其模拟实现

这里写目录标题 一、vector的介绍及使用1. vector的介绍2. 构造函数3. 遍历方式4. 容量操作及空间增长问题5. 增删查改6. vector二维数组 二、vector的模拟实现1. 构造函数2. 迭代器和基本接口3. reserve和resize4. push_back和pop_back5. insert和erase5. 迭代器失效问题5. 浅…

【Java】基础算法练习题

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ 目录 基础算法练习题🚀1. 两数之和…

Django 管网项目 三

Django 官网文档 ​​Writing your first Django app, part 2 | Django documentation | Django 本文内容涉及创建视图 View,路由,和模版。并对内容进行渲染。 创建视图 在我们的投票应用中,我们需要下列几个视图: 问题索引页—…

ChatGPT支持下的PyTorch机器学习与深度学习技术应用

近年来,随着AlphaGo、无人驾驶汽车、医学影像智慧辅助诊疗、ImageNet竞赛等热点事件的发生,人工智能迎来了新一轮的发展浪潮。尤其是深度学习技术,在许多行业都取得了颠覆性的成果。另外,近年来,Pytorch深度学习框架受…

相关知识1111

一、 店铺编号和相关负责人 1、天猫兄弟、锦格 京东凡越 福林哥 如萍姐 2、京东锦格 天猫凡越 林森 雷佳华 3、天猫从简 京东从简 孔哥 4、抖音锦格 拼多多凡越 鸿哥 不知道哪个店铺编号:0 二、天猫京东聊天界面快捷搜索商品 1、 天猫只能根据标题搜索 2、京东是…

神经网络之万能定理python-pytorch实现,可以拟合任意曲线

神经网络之万能定理python-pytorch实现,可以拟合任意曲线 博主,这几天一直在做这个曲线拟合的实验,讲道理,网上可能也有很多这方面的资料,但是博主其实试了很多,效果只能对一般的曲线还行,稍微…

java之抽象类

什么是抽象类? 抽象就是不能具体化,不能实例化 作为父类,让子类去实现 abstract修饰类就是抽象类 abstract修饰方法就是抽象方法修饰符 abstract class 类名{修饰符 abstract 返回值类型 方法名(形参列表); }public abstract class A {//不…

CTFHUB--文件包含漏洞--RCE

文件包含漏洞 文件包含漏洞也是一种注入型漏洞,其本质就是输入一段用户能够控制的脚本或者代码,并让服务端执行。有时候由于网站功能需求,会让前端用户选择要包含的文件,而开发人员又没有对要包含的文件进行安全考虑,…