当前位置: 首页 > news >正文

协方差矩阵及其计算方法

协方差矩阵(Covariance Matrix)是一个描述多维数据特征之间相互关系的矩阵,广泛应用于统计学和机器学习中。它用于表示各个特征之间的协方差,是分析多维数据分布和特征依赖性的重要工具。

什么是协方差矩阵?

协方差矩阵是一个方阵,其每个元素 σ i j \sigma_{ij} σij 代表第 i i i 个特征与第 j j j 个特征之间的协方差。协方差本质上是衡量两个变量是否相关以及它们的相关程度:

  • 如果协方差为正,说明这两个特征具有正相关关系,即当一个特征增大时,另一个特征也倾向于增大。
  • 如果协方差为负,说明这两个特征具有负相关关系,即当一个特征增大时,另一个特征倾向于减小。
  • 如果协方差接近零,说明这两个特征之间几乎没有线性关系。

协方差矩阵是一个对称矩阵,因为 σ i j = σ j i \sigma_{ij} = \sigma_{ji} σij=σji。协方差矩阵的对角线元素是每个特征的方差,而非对角线元素则是特征之间的协方差。

协方差矩阵的计算

假设我们有一个包含 n n n 个样本和 m m m 个特征的数据集 X \mathbf{X} X,其中每个样本 x i = ( x i 1 , x i 2 , … , x i m ) \mathbf{x_i} = (x_{i1}, x_{i2}, \dots, x_{im}) xi=(xi1,xi2,,xim) 是一个 m m m-维向量。为了计算协方差矩阵,我们通常按照以下步骤操作:

1. 计算每个特征的均值

首先,计算每个特征的均值。假设数据集的第 i i i 列是特征 x i x_i xi,其均值 x i ˉ \bar{x_i} xiˉ 为:

x i ˉ = 1 n ∑ k = 1 n x k i \bar{x_i} = \frac{1}{n} \sum_{k=1}^{n} x_{ki} xiˉ=n1k=1nxki

2. 中心化数据

对于每个特征,减去该特征的均值,得到中心化的数据:

x k i ′ = x k i − x i ˉ x_{ki}^\prime = x_{ki} - \bar{x_i} xki=xkixiˉ

3. 计算协方差矩阵

协方差矩阵的元素 σ i j \sigma_{ij} σij 代表第 i i i 个特征与第 j j j 个特征之间的协方差,计算公式如下:

σ i j = 1 n − 1 ∑ k = 1 n ( x k i ′ ) ( x k j ′ ) \sigma_{ij} = \frac{1}{n-1} \sum_{k=1}^{n} (x_{ki}^\prime)(x_{kj}^\prime) σij=n11k=1n(xki)(xkj)

协方差矩阵是对称的,因此计算出来的矩阵是一个 m × m m \times m m×m 的对称矩阵,其中对角线上的元素是特征的方差,非对角线元素是特征之间的协方差。

协方差矩阵的示例

假设我们有以下数据集,其中每行表示一个样本,每列表示一个特征:

X = ( 1 2 2 3 3 4 4 5 ) \mathbf{X} = \begin{pmatrix} 1 & 2 \\ 2 & 3 \\ 3 & 4 \\ 4 & 5 \end{pmatrix} X= 12342345

这是一个包含 4 个样本和 2 个特征的数据集,特征分别为 “特征 1” 和 “特征 2”。

第一步:计算每个特征的均值
  • 对于特征 1:
    x 1 ˉ = 1 + 2 + 3 + 4 4 = 2.5 \bar{x_1} = \frac{1 + 2 + 3 + 4}{4} = 2.5 x1ˉ=41+2+3+4=2.5

  • 对于特征 2:
    x 2 ˉ = 2 + 3 + 4 + 5 4 = 3.5 \bar{x_2} = \frac{2 + 3 + 4 + 5}{4} = 3.5 x2ˉ=42+3+4+5=3.5

第二步:中心化数据

将每个特征的均值从每个数据点中减去,得到中心化的数据集:

X ′ = ( 1 − 2.5 2 − 3.5 2 − 2.5 3 − 3.5 3 − 2.5 4 − 3.5 4 − 2.5 5 − 3.5 ) = ( − 1.5 − 1.5 − 0.5 − 0.5 0.5 0.5 1.5 1.5 ) \mathbf{X^\prime} = \begin{pmatrix} 1 - 2.5 & 2 - 3.5 \\ 2 - 2.5 & 3 - 3.5 \\ 3 - 2.5 & 4 - 3.5 \\ 4 - 2.5 & 5 - 3.5 \end{pmatrix} = \begin{pmatrix} -1.5 & -1.5 \\ -0.5 & -0.5 \\ 0.5 & 0.5 \\ 1.5 & 1.5 \end{pmatrix} X= 12.522.532.542.523.533.543.553.5 = 1.50.50.51.51.50.50.51.5

第三步:计算协方差矩阵

接下来,我们计算协方差矩阵的元素。由于数据集中有 2 个特征,我们需要计算以下协方差:

  1. 协方差 σ 11 \sigma_{11} σ11(特征 1 的方差)
    σ 11 = 1 3 [ ( − 1.5 ) 2 + ( − 0.5 ) 2 + ( 0.5 ) 2 + ( 1.5 ) 2 ] = 1 3 [ 2.25 + 0.25 + 0.25 + 2.25 ] = 5 3 ≈ 1.6667 \sigma_{11} = \frac{1}{3} [(-1.5)^2 + (-0.5)^2 + (0.5)^2 + (1.5)^2] = \frac{1}{3} [2.25 + 0.25 + 0.25 + 2.25] = \frac{5}{3} \approx 1.6667 σ11=31[(1.5)2+(0.5)2+(0.5)2+(1.5)2]=31[2.25+0.25+0.25+2.25]=351.6667

  2. 协方差 σ 12 \sigma_{12} σ12(特征 1 和特征 2 的协方差)
    σ 12 = 1 3 [ ( − 1.5 ) ( − 1.5 ) + ( − 0.5 ) ( − 0.5 ) + ( 0.5 ) ( 0.5 ) + ( 1.5 ) ( 1.5 ) ] = 1 3 [ 2.25 + 0.25 + 0.25 + 2.25 ] = 5 3 ≈ 1.6667 \sigma_{12} = \frac{1}{3} [(-1.5)(-1.5) + (-0.5)(-0.5) + (0.5)(0.5) + (1.5)(1.5)] = \frac{1}{3} [2.25 + 0.25 + 0.25 + 2.25] = \frac{5}{3} \approx 1.6667 σ12=31[(1.5)(1.5)+(0.5)(0.5)+(0.5)(0.5)+(1.5)(1.5)]=31[2.25+0.25+0.25+2.25]=351.6667

  3. 协方差 σ 22 \sigma_{22} σ22(特征 2 的方差)
    σ 22 = 1 3 [ ( − 1.5 ) 2 + ( − 0.5 ) 2 + ( 0.5 ) 2 + ( 1.5 ) 2 ] = 5 3 ≈ 1.6667 \sigma_{22} = \frac{1}{3} [(-1.5)^2 + (-0.5)^2 + (0.5)^2 + (1.5)^2] = \frac{5}{3} \approx 1.6667 σ22=31[(1.5)2+(0.5)2+(0.5)2+(1.5)2]=351.6667

因此,协方差矩阵为:

Σ = ( 1.6667 1.6667 1.6667 1.6667 ) \Sigma = \begin{pmatrix} 1.6667 & 1.6667 \\ 1.6667 & 1.6667 \end{pmatrix} Σ=(1.66671.66671.66671.6667)

协方差矩阵的意义

从协方差矩阵中我们可以得出以下结论:

  • 方差:特征 1 和特征 2 的方差都是 1.6667,这说明数据在这两个特征上的离散程度是相同的。
  • 协方差:特征 1 和特征 2 之间的协方差是 1.6667,表示这两个特征之间有正相关关系。

总结

协方差矩阵是分析多维数据的重要工具,它能够描述数据集中各个特征之间的关系。在机器学习中,协方差矩阵常用于主成分分析(PCA)等技术中,以帮助理解数据的内在结构。通过计算协方差矩阵,我们可以更好地了解特征之间的相关性和数据的分布特性。

相关文章:

协方差矩阵及其计算方法

协方差矩阵(Covariance Matrix)是一个描述多维数据特征之间相互关系的矩阵,广泛应用于统计学和机器学习中。它用于表示各个特征之间的协方差,是分析多维数据分布和特征依赖性的重要工具。 什么是协方差矩阵? 协方差矩…...

【OH】openHarmony开发环境搭建(基于windows子系统WSL)

前言 本文主要介绍基于windows子系统WSL搭建openHarmony开发环境。 WSL与Vmware虚拟机的区别,可以查看WSL与虚拟机的区别 更详细的安装配置过程可参考微软官网: ​安装 WSL 前提 以下基于windows 111专业版进行配置,windows 10应该也是可以…...

Visual Studio Code 端口转发功能详解

Visual Studio Code 端口转发功能详解 引言 Visual Studio Code(简称 VS Code)是一个功能强大的源代码编辑器,它支持多种编程语言的语法高亮、智能代码补全、自定义快捷键、代码重构等特性。除了这些基本功能外,VS Code 还提供了…...

Android Framework AMS(14)ContentProvider分析-1(CP组件应用及开机启动注册流程解读)

该系列文章总纲链接:专题总纲目录 Android Framework 总纲 本章关键点总结 & 说明: 说明:本章节主要解读ContentProvider组件的基本知识。关注思维导图中左上侧部分即可。 有了前面activity组件分析、service组件分析、广播组件分析的基…...

Three.js PBR材质

本文将详细介绍Three.js中的PBR(Physically Based Rendering)材质,包括PBR的基本概念、适用场景、PBR材质的构建以及一些高级应用技巧。 1. PBR(Physically Based Rendering)基本概念 PBR,即Physically B…...

智谱AI清影升级:引领AI视频进入音效新时代

前几天智谱推出了新清影,该版本支持4k、60帧超高清画质、任意尺寸,并且自带音效的10秒视频,让ai生视频告别了"哑巴时代"。 智谱AI视频腾空出世,可灵遭遇强劲挑战!究竟谁是行业翘楚?(附测评案例)之前智谱出世那时体验了一…...

嵌入式硬件电子电路设计(五)MOS管详解(NMOS、PMOS、三极管跟mos管的区别)

引言:在我们的日常使用中,MOS就是个纯粹的电子开关,虽然MOS管也有放大作用,但是几乎用不到,只用它的开关作用,一般的电机驱动,开关电源,逆变器等大功率设备,全部使用MOS管…...

Centos 9 安装 PostgreSQL 16 并支持远程访问

仅列出核心操作,可以解决使用过程中遇到的访问问题。 1 安装 使用dnf源安装 sudo dnf module -y install postgresql:16 2 配置文件夹权限 使用root权限操作 sudo chown postgres:postgres /var/lib/pgsql/datasudo chmod -R 0750 /var/lib/pgsql/data 3 初…...

Dubbo源码解析(三)

一、Dubbo整合Spring启动流程 Dubbo的使用可以不依赖Spring,但是生产环境中Dubbo都是整合到Spring中一起使用,所以本章就解析Dubbo整合Spring的启动流程 一、传统的xml解析方式 一、Dubbo配置解析流程 在Java 中,一切皆对象。在JDK 中使用…...

HarmonyOS Next星河版笔记--界面开发(5)

1.字符串 1.1.字符串拼接 作用:把两个或多个字符串,拼成一个字符串。(通常是用来拼接字符串和变量) hello world > helloworld 加好作用:拼接 let name:string 小明 console.log(简介信息,名字是 name) …...

Spring Boot3 实战案例合集上线了

Spring Boot3实战案例合集...

在Ubuntu 24.04 LTS上安装飞桨PaddleX

前面我们介绍了《在Windows用远程桌面访问Ubuntu 24.04.1 LTS》本文接着介绍安装飞桨PaddleX。 PaddleX 3.0 是基于飞桨框架构建的一站式全流程开发工具,它集成了众多开箱即用的预训练模型,可以实现模型从训练到推理的全流程开发,支持国内外多…...

Homebrew 命令大全

Homebrew 是 macOS 和 Linux 系统上的一个流行的包管理器,它可以帮助用户轻松地安装、更新和管理软件包。以下是一些常用的 Homebrew 命令: 安装 Homebrew 如果你还没有安装 Homebrew,可以使用以下命令在 macOS 上进行安装: /b…...

Docker+Django项目部署-从Linux+Windows实战

一、概述 1. 什么是Docker Docker 是一个开源的应用容器引擎,支持在win、mac、Linux系统上进行安装。可以帮助我们在一台电脑上创建出多个隔离的环境,比传统的虚拟机极大的节省资源 。 为什么要创建隔离的环境? 假设你先在有一个centos7.…...

前端 JS 实用操作总结

目录 1、重构解构 1、数组解构 2、对象解构 3、...展开 2、箭头函数 1、简写 2、this指向 3、没有arguments 4、普通函数this的指向 3、数组实用方法 1、map和filter 2、find 3、reduce 1、重构解构 1、数组解构 const arr ["唐僧", "孙悟空&quo…...

11.15 机器学习-集成学习方法-随机森林

# 机器学习中有一种大类叫**集成学习**(Ensemble Learning),集成学习的基本思想就是将多个分类器组合,从而实现一个预测效果更好的集成分类器。集成算法可以说从一方面验证了中国的一句老话: # 三个臭皮匠&#xff0c…...

【SQL】E-R模型(实体-联系模型)

目录 一、介绍 1、实体集 定义和性质 属性 E-R图表示 2. 联系集 定义和性质 属性 E-R图表示 一、介绍 实体-联系数据模型(E-R数据模型)被开发来方便数据库的设计,它是通过允许定义代表数据库全局逻辑结构的企业模式&#xf…...

C/C++静态库引用过程中出现符号未定义的处理方式

问题背景: 在接入新库(静态库)时遇到了符号未定义问题,并发现改变静态库的链接顺序可以解决问题。 问题根源: 静态库是由 .o 文件拼接而成的,链接静态库时,链接器以 .o 文件为单位进行处理。链接…...

『VUE』27. 透传属性与inheritAttrs(详细图文注释)

目录 什么是透传属性(Forwarding Attributes)使用条件唯一根节点禁用透传属性继承总结 欢迎关注 『VUE』 专栏,持续更新中 欢迎关注 『VUE』 专栏,持续更新中 什么是透传属性(Forwarding Attributes) 在 V…...

借助Excel实现Word表格快速排序

实例需求:Word中的表格如下图所示,为了强化记忆,希望能够将表格内容随机排序,表格第一列仍然按照顺序编号,即编号不跟随表格行内容调整。 乱序之后的效果如下图所示(每次运行代码的结果都不一定相同&#x…...

情感漏洞经纪:倒卖AI崩溃瞬间年入百万

新兴暴利职业的崛起在人工智能技术高速发展的今天,一种名为“情感漏洞经纪”的灰色产业悄然兴起,从业者通过倒卖AI系统崩溃瞬间的数据年入百万。这些经纪人专门捕捉AI模型在情感交互中的故障时刻——如系统宕机前的“遗言”、未完成的情感回应或异常输出…...

TouchGal:打造纯净Galgame社区的5个简单步骤

TouchGal:打造纯净Galgame社区的5个简单步骤 【免费下载链接】kun-touchgal-next TouchGAL是立足于分享快乐的一站式Galgame文化社区, 为Gal爱好者提供一片净土! 项目地址: https://gitcode.com/gh_mirrors/ku/kun-touchgal-next TouchGal是一个专为视觉小说…...

三相三电平Vienna整流器:SPWM与SVPWM调制仿真及控制策略对比分析

三相三电平vienna整流器SPWM和SVPWM调制仿真 基于plecs搭建 温度场分析 双PI控制 锁相环控制 中点电压平衡控制 功率因数为1 SPWM和SVPWM调制对比 谐波畸变率对比分析 电压利用率对比分析 电压平衡和不平衡控制对比 图1 仿真模型 图2 温度场分析 图3 交流电压电流三电平…...

Alexa Skills Kit SDK SMAPI 集成:自动化技能管理和部署的完整流程

Alexa Skills Kit SDK SMAPI 集成:自动化技能管理和部署的完整流程 【免费下载链接】alexa-skills-kit-sdk-for-nodejs The Alexa Skills Kit SDK for Node.js helps you get a skill up and running quickly, letting you focus on skill logic instead of boilerp…...

Windows Auto Dark Mode:智能主题切换工具的全面应用指南

Windows Auto Dark Mode:智能主题切换工具的全面应用指南 【免费下载链接】Windows-Auto-Night-Mode Automatically switches between the dark and light theme of Windows 10 and Windows 11 项目地址: https://gitcode.com/gh_mirrors/wi/Windows-Auto-Night-M…...

Cursor试用限制终极解决方案:一篇文章彻底解决你的AI编程困境

Cursor试用限制终极解决方案:一篇文章彻底解决你的AI编程困境 【免费下载链接】go-cursor-help 解决Cursor在免费订阅期间出现以下提示的问题: Youve reached your trial request limit. / Too many free trial accounts used on this machine. Please upgrade to p…...

从拒稿到录用:一个生物医学工程研究生的UMB投稿实战复盘(含完整时间线与避坑点)

从拒稿到录用:一个生物医学工程研究生的UMB投稿实战复盘 第一次收到CIBM编辑部的秒拒邮件时,我正在实验室熬夜跑数据。屏幕上的"reject"字样像一盆冷水浇下来——这个被我寄予厚望的期刊,从投稿到拒稿只用了17天。作为生物医学工程…...

ComfyUI-TeaCache:基于时间步感知缓存的扩散模型推理加速技术实现1.5-3倍性能提升

ComfyUI-TeaCache:基于时间步感知缓存的扩散模型推理加速技术实现1.5-3倍性能提升 【免费下载链接】ComfyUI-TeaCache 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-TeaCache 在AI图像与视频生成领域,扩散模型的推理速度一直是制约创作…...

SillyTavern角色卡片系统全解析:从技术原理到实战应用

SillyTavern角色卡片系统全解析:从技术原理到实战应用 【免费下载链接】SillyTavern LLM Frontend for Power Users. 项目地址: https://gitcode.com/GitHub_Trending/si/SillyTavern 技术原理:PNG元数据驱动的角色存储机制 SillyTavern角色卡片…...

隐私优先方案:OpenClaw+Qwen3-32B-RTX4090D离线处理医疗记录

隐私优先方案:OpenClawQwen3-32B-RTX4090D离线处理医疗记录 1. 为什么医疗数据必须留在本地? 去年协助某诊所搭建病历管理系统时,我亲历了一次数据泄露恐慌。当诊所负责人发现云端OCR服务商要求上传患者检查报告时,他立即叫停了…...