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

线性判别分析(LDA)中求协方差矩阵示例

让我们通过一个简单的例子计算协方差矩阵。假设我们有两类数据集 X 0 X_0 X0 X 1 X_1 X1,每类有两个样本,每个样本有两个特征。

数据集:

类 0 的样本:
X 0 = [ 1 2 2 3 ] X_0 = \begin{bmatrix} 1 & 2 \\ 2 & 3 \end{bmatrix} X0=[1223]

类 1 的样本:
X 1 = [ 4 5 5 6 ] X_1 = \begin{bmatrix} 4 & 5 \\ 5 & 6 \end{bmatrix} X1=[4556]

1. 计算每类的均值向量:

首先,我们需要计算每类数据的均值向量。

对于类 0,均值向量 μ 0 \mu_0 μ0
μ 0 = 1 2 [ 1 + 2 2 + 3 ] = [ 1.5 2.5 ] \mu_0 = \frac{1}{2} \begin{bmatrix} 1+2 \\ 2+3 \end{bmatrix} = \begin{bmatrix} 1.5 \\ 2.5 \end{bmatrix} μ0=21[1+22+3]=[1.52.5]

对于类 1,均值向量 μ 1 \mu_1 μ1
μ 1 = 1 2 [ 4 + 5 5 + 6 ] = [ 4.5 5.5 ] \mu_1 = \frac{1}{2} \begin{bmatrix} 4+5 \\ 5+6 \end{bmatrix} = \begin{bmatrix} 4.5 \\ 5.5 \end{bmatrix} μ1=21[4+55+6]=[4.55.5]

2. 计算协方差矩阵:

协方差矩阵的公式为:
Σ = 1 n − 1 ∑ i = 1 n ( x i − μ ) ( x i − μ ) T \Sigma = \frac{1}{n-1} \sum_{i=1}^{n} (x_i - \mu)(x_i - \mu)^T Σ=n11i=1n(xiμ)(xiμ)T

对类 0 计算协方差矩阵 Σ 0 \Sigma_0 Σ0

我们对每个样本减去均值向量 μ 0 \mu_0 μ0,并计算它们的外积。

对于第一个样本 x 1 = [ 1 , 2 ] x_1 = [1, 2] x1=[1,2]
x 1 − μ 0 = [ 1 2 ] − [ 1.5 2.5 ] = [ − 0.5 − 0.5 ] x_1 - \mu_0 = \begin{bmatrix} 1 \\ 2 \end{bmatrix} - \begin{bmatrix} 1.5 \\ 2.5 \end{bmatrix} = \begin{bmatrix} -0.5 \\ -0.5 \end{bmatrix} x1μ0=[12][1.52.5]=[0.50.5]

对于第二个样本 x 2 = [ 2 , 3 ] x_2 = [2, 3] x2=[2,3]
x 2 − μ 0 = [ 2 3 ] − [ 1.5 2.5 ] = [ 0.5 0.5 ] x_2 - \mu_0 = \begin{bmatrix} 2 \\ 3 \end{bmatrix} - \begin{bmatrix} 1.5 \\ 2.5 \end{bmatrix} = \begin{bmatrix} 0.5 \\ 0.5 \end{bmatrix} x2μ0=[23][1.52.5]=[0.50.5]

接下来,我们计算外积:
( x 1 − μ 0 ) ( x 1 − μ 0 ) T = [ − 0.5 − 0.5 ] [ − 0.5 − 0.5 ] = [ 0.25 0.25 0.25 0.25 ] (x_1 - \mu_0)(x_1 - \mu_0)^T = \begin{bmatrix} -0.5 \\ -0.5 \end{bmatrix} \begin{bmatrix} -0.5 & -0.5 \end{bmatrix} = \begin{bmatrix} 0.25 & 0.25 \\ 0.25 & 0.25 \end{bmatrix} (x1μ0)(x1μ0)T=[0.50.5][0.50.5]=[0.250.250.250.25]
( x 2 − μ 0 ) ( x 2 − μ 0 ) T = [ 0.5 0.5 ] [ 0.5 0.5 ] = [ 0.25 0.25 0.25 0.25 ] (x_2 - \mu_0)(x_2 - \mu_0)^T = \begin{bmatrix} 0.5 \\ 0.5 \end{bmatrix} \begin{bmatrix} 0.5 & 0.5 \end{bmatrix} = \begin{bmatrix} 0.25 & 0.25 \\ 0.25 & 0.25 \end{bmatrix} (x2μ0)(x2μ0)T=[0.50.5][0.50.5]=[0.250.250.250.25]

协方差矩阵为这两个外积的平均:
Σ 0 = 1 2 − 1 ( [ 0.25 0.25 0.25 0.25 ] + [ 0.25 0.25 0.25 0.25 ] ) = [ 0.5 0.5 0.5 0.5 ] \Sigma_0 = \frac{1}{2-1} \left( \begin{bmatrix} 0.25 & 0.25 \\ 0.25 & 0.25 \end{bmatrix} + \begin{bmatrix} 0.25 & 0.25 \\ 0.25 & 0.25 \end{bmatrix} \right) = \begin{bmatrix} 0.5 & 0.5 \\ 0.5 & 0.5 \end{bmatrix} Σ0=211([0.250.250.250.25]+[0.250.250.250.25])=[0.50.50.50.5]

对类 1 计算协方差矩阵 Σ 1 \Sigma_1 Σ1

同样地,对类 1 的样本进行相同的步骤。

对于第一个样本 x 1 = [ 4 , 5 ] x_1 = [4, 5] x1=[4,5]
x 1 − μ 1 = [ 4 5 ] − [ 4.5 5.5 ] = [ − 0.5 − 0.5 ] x_1 - \mu_1 = \begin{bmatrix} 4 \\ 5 \end{bmatrix} - \begin{bmatrix} 4.5 \\ 5.5 \end{bmatrix} = \begin{bmatrix} -0.5 \\ -0.5 \end{bmatrix} x1μ1=[45][4.55.5]=[0.50.5]

对于第二个样本 x 2 = [ 5 , 6 ] x_2 = [5, 6] x2=[5,6]
x 2 − μ 1 = [ 5 6 ] − [ 4.5 5.5 ] = [ 0.5 0.5 ] x_2 - \mu_1 = \begin{bmatrix} 5 \\ 6 \end{bmatrix} - \begin{bmatrix} 4.5 \\ 5.5 \end{bmatrix} = \begin{bmatrix} 0.5 \\ 0.5 \end{bmatrix} x2μ1=[56][4.55.5]=[0.50.5]

外积分别为:
( x 1 − μ 1 ) ( x 1 − μ 1 ) T = [ 0.25 0.25 0.25 0.25 ] (x_1 - \mu_1)(x_1 - \mu_1)^T = \begin{bmatrix} 0.25 & 0.25 \\ 0.25 & 0.25 \end{bmatrix} (x1μ1)(x1μ1)T=[0.250.250.250.25]
( x 2 − μ 1 ) ( x 2 − μ 1 ) T = [ 0.25 0.25 0.25 0.25 ] (x_2 - \mu_1)(x_2 - \mu_1)^T = \begin{bmatrix} 0.25 & 0.25 \\ 0.25 & 0.25 \end{bmatrix} (x2μ1)(x2μ1)T=[0.250.250.250.25]

协方差矩阵为:
Σ 1 = 1 2 − 1 ( [ 0.25 0.25 0.25 0.25 ] + [ 0.25 0.25 0.25 0.25 ] ) = [ 0.5 0.5 0.5 0.5 ] \Sigma_1 = \frac{1}{2-1} \left( \begin{bmatrix} 0.25 & 0.25 \\ 0.25 & 0.25 \end{bmatrix} + \begin{bmatrix} 0.25 & 0.25 \\ 0.25 & 0.25 \end{bmatrix} \right) = \begin{bmatrix} 0.5 & 0.5 \\ 0.5 & 0.5 \end{bmatrix} Σ1=211([0.250.250.250.25]+[0.250.250.250.25])=[0.50.50.50.5]

结果:

对于类 0 和类 1,它们的协方差矩阵分别为:
Σ 0 = [ 0.5 0.5 0.5 0.5 ] \Sigma_0 = \begin{bmatrix} 0.5 & 0.5 \\ 0.5 & 0.5 \end{bmatrix} Σ0=[0.50.50.50.5]
Σ 1 = [ 0.5 0.5 0.5 0.5 ] \Sigma_1 = \begin{bmatrix} 0.5 & 0.5 \\ 0.5 & 0.5 \end{bmatrix} Σ1=[0.50.50.50.5]

这是一个简单的二维数据集协方差矩阵的计算例子。

http://www.lryc.cn/news/445808.html

相关文章:

  • Maven的详细解读和配置
  • 在vue2项目中使用dart-sass
  • 【机器学习】过拟合与欠拟合——如何优化模型性能
  • 二进制日志gtid模式
  • 华硕主板开启TPM 2.0
  • Linux 一键部署Mysql 8.0.37
  • Elasticsearch可视化工具ElasticHD
  • Chrome截取网页全屏
  • Why Is Prompt Tuning for Vision-Language Models Robust to Noisy Labels?
  • C++ 折叠表达式
  • 双控开关接入NVBoard
  • 聊一聊软件系统性能测试的重要性
  • 双十一有哪些好物值得入手?五款超值数码好物分享!
  • uniapp监听滚动实现顶部透明度变化
  • Humanoid 3D Charactor_P08_Federica
  • TikTok直播推流不精准该怎么办?跟IP有关系吗?
  • Docker Registry API best practice 【Docker Registry API 最佳实践】
  • 便捷点餐:Spring Boot 点餐系统
  • 研一上课计划2024/9/23有感
  • 【H2O2|全栈】关于CSS(6)CSS基础(五)
  • 网页护眼宝——全方位解析 Chrome Dark Reader 插件
  • C++ 构造函数和析构函数抛出异常的详细说明
  • Unity开发绘画板——01.前言
  • Spring定时任务 - @Scheduled注解详解
  • 超详细超实用!!!AI编程之cursor编写设计模式接口隔离原则实例(七)
  • 解决在Nignx下Thinkphp路由不生效问题
  • 『功能项目』QFrameWork框架重构OnGUI【63】
  • 4款AI生成PPT工具推荐,提升工作效率
  • 3.postman脚本语言、接口关联(json引用(变量)、脚本用正则表达式)、断言封装、自动化构造接口请求(Postman工具)
  • 基于SpringBoot框架的订餐系统设计与实现