DeepSORT(目标跟踪算法)中的数值表格与调参的关系

DeepSORT(目标跟踪算法)中的数值表格与调参的关系

flyfish

DeepSORT(目标跟踪算法)中的马氏距离详解(很详细)

DeepSORT(目标跟踪算法)中 可以设置阈值进行异常检测或目标跟踪的原因(写了重要步骤)

代码地址

https://github.com/shaoshengsong/DeepSORT

文字要是懒得看,直接拖到后面看图。

原始代码

Python版

chi2inv95 = {1: 3.8415,2: 5.9915,3: 7.8147,4: 9.4877,5: 11.070,6: 12.592,7: 14.067,8: 15.507,9: 16.919}

C++版

const double KalmanFilter::chi2inv95[10] = {0,3.8415,5.9915,7.8147,9.4877,11.070,12.592,14.067,15.507,16.919};

原始的这些数值表格
表示卡方分布在自由度为N时的0.95分位数。这些数值是通过统计软件(如MATLAB或Octave)的chi2inv函数计算出来的。chi2inv函数计算的是卡方分布的逆累积分布函数(inverse cumulative distribution function),即给定一个概率(这里是0.95),求对应的卡方分布的值。这些数值用于马氏距离的阈值。卡方分布(chi-square distribution)是用于统计学中的一种概率分布,通常用于假设检验和方差分析。对于给定的自由度N,卡方分布的0.95分位数表示在该自由度下,随机变量的值有95%的概率落在此分位数之下。

自己实现一个

数值计算方法:

假设我们使用Python和SciPy库来计算这些值,可以通过以下代码实现:

import scipy.stats as stats# 定义自由度列表
degrees_of_freedom = range(1, 10)# 计算每个自由度下的0.95分位数
chi2inv95 = {df: stats.chi2.ppf(0.95, df) for df in degrees_of_freedom}print(chi2inv95)

解释计算结果:

  • 自由度1: 对应的0.95分位数是3.8415,这意味着在自由度为1的情况下,随机变量有95%的概率其值在3.8415以下。
  • 自由度2: 对应的0.95分位数是5.9915,这意味着在自由度为2的情况下,随机变量有95%的概率其值在5.9915以下。
    依此类推,直至自由度为9。

使用场景:

在DeepSort算法中,马氏距离用于衡量目标检测之间的相似性。卡方分布的0.95分位数作为阈值,是为了确保在给定的置信水平下,可以有效地过滤掉不相似的目标检测,从而提高跟踪的准确性。换句话说,如果两个检测的马氏距离大于对应自由度的0.95分位数,那么它们被认为是不同的目标。

输出

{1: 3.841458820694124,2: 5.991464547107979, 3: 7.814727903251179,4: 9.487729036781154, 5: 11.070497693516351,6: 12.591587243743977, 7: 14.067140449340167,8: 15.507313055865453,9: 16.918977604620448}

马氏距离

马氏距离(Mahalanobis Distance)是一种度量点与点之间距离的方法,考虑了数据的相关性和尺度。具体来说,马氏距离计算两个点之间的距离时,使用了数据的协方差矩阵,使得它在数据的不同维度上有不同的缩放,能够更准确地反映点与点之间的关系。

马氏距离的公式如下:

D M ( x , y ) = ( x − y ) T S − 1 ( x − y ) D_M(\mathbf{x}, \mathbf{y}) = \sqrt{(\mathbf{x} - \mathbf{y})^T \mathbf{S}^{-1} (\mathbf{x} - \mathbf{y})} DM(x,y)=(xy)TS1(xy)

其中:

  • x \mathbf{x} x y \mathbf{y} y 是两个数据点的向量。
  • S \mathbf{S} S 是协方差矩阵。
  • S − 1 \mathbf{S}^{-1} S1 是协方差矩阵的逆矩阵。

马氏距离用于测量两个点之间的多维空间距离,其考虑了数据的协方差结构。阈值是在特定的置信水平下,用于判断两个点是否属于同一类别的界限。在DeepSort算法中,马氏距离的阈值对应于卡方分布的0.95分位数。如果两个检测的马氏距离超过了这个阈值,则认为它们不属于同一个目标。

动画展示

展示了马氏距离随给定点变化的情况,不同位置的给定点与数据集中其他点的马氏距离

pip install matplotlib seaborn numpy scipy
pip install imageio
import numpy as np
import matplotlib.pyplot as plt
import seaborn as sns
from scipy.spatial.distance import mahalanobis
from scipy.stats import chi2
import imageio# 生成示例数据
np.random.seed(42)
mean = [0, 0]
cov = [[1, 0.5], [0.5, 1]]
data = np.random.multivariate_normal(mean, cov, 500)# 计算马氏距离的函数
def calculate_mahalanobis_distance(data, point):cov_matrix = np.cov(data, rowvar=False)inv_cov_matrix = np.linalg.inv(cov_matrix)mean_data = np.mean(data, axis=0)distances = [mahalanobis(d, point, inv_cov_matrix) for d in data]return distances# 绘制散点图并添加马氏距离
def plot_mahalanobis(data, point, frame_number):plt.figure(figsize=(10, 8))sns.scatterplot(x=data[:, 0], y=data[:, 1], hue=calculate_mahalanobis_distance(data, point), palette='viridis')plt.scatter(point[0], point[1], color='red')plt.colorbar(label='Mahalanobis Distance')plt.title(f'Mahalanobis Distance at Frame {frame_number}')plt.xlabel('X')plt.ylabel('Y')plt.savefig(f'frame_{frame_number}.png')plt.close()# 定义动画点
points = np.linspace(-3, 3, 30)
frames = []# 生成每一帧图像
for i, p in enumerate(points):plot_mahalanobis(data, [p, p], i)frames.append(imageio.imread(f'frame_{i}.png'))# 保存为GIF
imageio.mimsave('mahalanobis_distance.gif', frames, fps=2,loop=0)

在这里插入图片描述

生成示例数据:使用 np.random.multivariate_normal 生成500个二维数据点,服从均值为 [0, 0] 和协方差矩阵为 [[1, 0.5], [0.5, 1]] 的多元正态分布。
计算马氏距离的函数:calculate_mahalanobis_distance 函数计算数据集中每个点与给定点的马氏距离。
绘制散点图并添加马氏距离:plot_mahalanobis 函数绘制散点图,并根据马氏距离着色。给定点用红色标出。
定义动画点:在 [-3, 3] 区间内生成30个点,作为动画中的给定点。

协方差

协方差(Covariance)是衡量两个变量共同变化程度的统计量。如果两个变量的协方差为正,意味着这两个变量一起增加或减少;如果协方差为负,意味着一个变量增加时另一个变量减少。

协方差的公式如下:

Cov ( X , Y ) = ∑ i = 1 n ( X i − X ˉ ) ( Y i − Y ˉ ) n − 1 \text{Cov}(X, Y) = \frac{\sum_{i=1}^{n} (X_i - \bar{X})(Y_i - \bar{Y})}{n-1} Cov(X,Y)=n1i=1n(XiXˉ)(YiYˉ)

其中:

  • X X X Y Y Y 是两个随机变量。
  • X i X_i Xi Y i Y_i Yi 是对应的观测值。
  • X ˉ \bar{X} Xˉ Y ˉ \bar{Y} Yˉ X X X Y Y Y 的均值。
  • n n n 是样本数量。
    协方差矩阵是包含所有变量对之间协方差的矩阵,用于多维数据的分析。

自由度(Degrees of Freedom)

自由度(Degrees of Freedom, df)在统计学中,表示用于估算一个统计量的独立信息数量。对于样本方差,自由度等于样本数量减去一个,这是因为我们在计算样本方差时使用了样本均值(这个均值本身也来自样本数据)。因此,我们失去了一个自由度来计算均值,剩下的自由度用于估算方差。

在计算样本方差时,我们首先计算样本均值:

X ˉ = 1 n ∑ i = 1 n X i \bar{X} = \frac{1}{n} \sum_{i=1}^{n} X_i Xˉ=n1i=1nXi

样本均值 X ˉ \bar{X} Xˉ 是基于 n n n 个数据点计算出来的,但其实际上只提供了 n − 1 n-1 n1 个独立信息,因为最后一个数据点的值可以从前 n − 1 n-1 n1 个数据点的值及均值推断出来。因此,自由度减去1,用以反映我们在估算过程中消耗的一个独立信息。

在统计学中,自由度是指用于计算统计量的独立数值的数量。对于卡方分布,自由度通常对应于所涉及的随机变量的数量。举个简单的例子,如果我们有一个数据集,进行样本方差计算时,自由度等于样本数量减去一个(因为我们要用一个样本均值来估计总体均值)。

0.95分位数

0.95分位数是指在给定分布中,有95%的数据点位于该值以下。对于卡方分布来说,这个值用于判断在95%的置信水平下,观察值是否显著。使用stats.chi2.ppf(0.95, df)可以计算出对应自由度下的0.95分位数。

计算马氏距离并使用卡方分布的0.95分位数作为阈值

import numpy as np
from scipy.stats import chi2def mahalanobis_distance(x, y, cov):diff = x - yinv_cov = np.linalg.inv(cov)md = np.sqrt(np.dot(np.dot(diff.T, inv_cov), diff))return md# 示例数据
x = np.array([1, 2])
y = np.array([1.5, 1.8])
cov = np.array([[1, 0.5], [0.5, 1]])# 计算马氏距离
md = mahalanobis_distance(x, y, cov)
print(f"Mahalanobis Distance: {md}")# 设定自由度
degrees_of_freedom = 2# 计算0.95分位数的卡方门限值
threshold = chi2.ppf(0.95, degrees_of_freedom)
print(f"Chi-square 0.95 quantile for df={degrees_of_freedom}: {threshold}")# 判断是否匹配
if md < threshold:print("Match: The points are considered similar.")
else:print("No Match: The points are considered different.")

计算马氏距离的函数:mahalanobis_distance 计算两个点之间的马氏距离。它接受两个点 x 和 y 以及协方差矩阵 cov 作为输入。
示例数据:定义两个点 x 和 y 及其协方差矩阵 cov。
计算马氏距离:调用 mahalanobis_distance 函数计算两个点之间的马氏距离。
设定自由度:设定自由度为2,因为数据点是二维的。
计算卡方分布的0.95分位数:使用 chi2.ppf 函数计算卡方分布的0.95分位数,作为马氏距离的门限值。
判断是否匹配:通过比较马氏距离与门限值,判断两个点是否匹配。

Mahalanobis Distance: 0.7211102550927978
Chi-square 0.95 quantile for df=2: 5.991464547107979
Match: The points are considered similar.

使用SciPy和Matplotlib来绘制卡方分布的图形,同时标注0.95分位数

import numpy as np
import matplotlib.pyplot as plt
import scipy.stats as stats# 定义自由度
degrees_of_freedom = [1, 2, 3, 4, 5, 6, 7, 8, 9]# 设置x轴范围
x = np.linspace(0, 30, 1000)plt.figure(figsize=(12, 8))# 绘制不同自由度的卡方分布
for df in degrees_of_freedom:plt.plot(x, stats.chi2.pdf(x, df), label=f'df={df}')# 标注0.95分位数
for df in degrees_of_freedom:chi2_95 = stats.chi2.ppf(0.95, df)plt.axvline(chi2_95, color='r', linestyle='--')plt.text(chi2_95, 0.02, f'{chi2_95:.2f}', rotation=90, verticalalignment='bottom')plt.title('Chi-Square Distribution for Different Degrees of Freedom')
plt.xlabel('Value')
plt.ylabel('Probability Density')
plt.legend()
plt.grid(True)
plt.show()

在这里插入图片描述

调参

阈值用于过滤噪声和不相关的目标检测,以提高跟踪算法的准确性和可靠性。在目标跟踪过程中,存在许多不确定性,例如检测误差和环境干扰。通过设置一个合适的阈值,可以在一定的置信水平下排除不可靠的检测结果,从而增强算法的稳健性。具体来说,在DeepSORT算法中,使用卡方分布的0.95分位数作为阈值,可以确保在95%的置信水平下,正确匹配目标检测,从而提高跟踪的准确性。

阈值可以根据应用的需求进行调整。例如,在某些应用中,可以选择更高的置信水平(比如0.99),以获得更严格的匹配标准。只需修改 chi2.ppf 函数中的置信水平即可:

# 计算0.99分位数的卡方门限值
threshold = chi2.ppf(0.99, degrees_of_freedom)
print(f"Chi-square 0.99 quantile for df={degrees_of_freedom}: {threshold}")

这样得到数值再应用到代码中,通过调整置信水平,可以灵活地控制目标匹配的严格程度,从而适应不同的应用场景和需求。

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

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

相关文章

问题:在信息点统计表中,对于没有信息点的工作区或者房间填写,表明已经分析过该区域 #微信#职场发展#职场发展

问题&#xff1a;在信息点统计表中,对于没有信息点的工作区或者房间填写,表明已经分析过该区域 参考答案如图所示

学历还算能力的一部分吗(机器人方向)

前篇 在人工智能时代&#xff0c;学历还算是能力的一部分吗&#xff1f; 之前写过一篇&#xff0c;现在感觉应该是不严谨&#xff0c;不准确的。 AI如何看待能力&#xff0c;学历&#xff0c;文凭-CSDN博客 那一篇讨论了&#xff1a;{文凭}⊂{学历}⊂{能力} 本篇 不合格且…

【Echarts系列】带图片的饼图

【Echarts系列】带图片的饼图 序前提说明示例数据格式代码动态旋转图片 序 为了节省后续开发学习成本&#xff0c;这个系列将记录我工作所用到的一些echarts图表。 前提说明 因为饼图中间需要添加图片&#xff0c;所以比较特殊&#xff0c;对于饼图中间数据的对齐很容易出现…

正大国际期货:原油投资出现亏损的五种心理弱点

在原油投资当中&#xff0c;有五种心理弱点最容易导致投资者失败&#xff0c;必须注意加以克服! 盲目胆大心理。 有些投资者从未认真系统地学习过投资理论技巧&#xff0c;也没有经过任何模拟训练&#xff0c;甚至连最起码的投资基础知识都不明白&#xff0c;就贸然的进入原油…

企业管理/市场经营/自我管理,500+个经典职场工具 . rar

​500N个实用管理工具包&#xff0c;精选人力资源从业者必备之132项工具、40个管理者实效管理工具、成功自我管理的29个工具、常见的9种营销分析工具等&#xff0c;成功自我管理必备工具。 与班主任联系&#xff0c;即可获得完整资料包&#xff01; 1.PEST分析 2.五力分析 3.…

哈尔滨等保如何做?

哈尔滨等保测评是确保信息系统安全稳定运行的重要一环&#xff0c;它涉及到对业务、资产、安全技术和安全管理的全面调研和评估。本文将详细阐述哈尔滨等保测评的实施步骤和注意事项&#xff0c;帮助读者更好地理解和执行等保测评工作。 首先&#xff0c;我们需要明确等保测评的…

Hexo+Github搭建个人博客教程

hexo官网&#xff1a;https://hexo.io/zh-cn/ butterfly 主题设置&#xff1a;https://butterfly.js.org/ GitHub地址&#xff1a;https://github.com/jerryc127/hexo-theme-butterfly 基础命令 初始化博客命令&#xff1a;hexo init “文件名” 开启本地服务&#xff08;本…

Docker:Docker容器使用

文章目录 容器与宿主机复制容器环境变量设置镜像的导出和导入 由于篇幅原因&#xff0c;把后续的使用搬到这篇来 容器与宿主机复制 启动一个nginx服务 rootVM-24-7-ubuntu:~# docker run --name nginx -p 80:80 -d nginx 7a1578bedd97ffc48e9516d03a148c69e216a30f2d18f2624…

【MySQL】复合查询+表的内外连接

复合查询表的内外连接 1.基本查询回顾2.多表查询3.自连接4.子查询4.1单列子查询4.2多列子查询 5.在from子句中使用子查询6.合并查询7.表的内连和外连7.1内连接7.2外连接7.2.1左外连接 7.2.2右外连接 点赞&#x1f44d;&#x1f44d;收藏&#x1f31f;&#x1f31f;关注&#x1…

Java程序设计————从控制台输入

向控制台输入信息可以借助Scanner扫描器类来实现 语法&#xff1a; Scanner input new Scanner(System.in); 提示 &#xff08;1&#xff09;在使用Scanner类型之前&#xff0c;需要首先指明Scanner类所在的位置&#xff0c;既通过代码 import java.util.Scanner; &…

超强的文本转语音模型ChatTTS,一键打包,免费使用

超强的文本转语音模型ChatTTS&#xff0c;一键打包&#xff0c;免费使用 项目简介项目亮点安装使用python 代码直接引入一键启动包安装部署 ChatTTS webUI 小结一下 文本转语音&#xff08;TTS&#xff09;在生活中的应用非常的广泛&#xff0c;比如有声小说、语音导航&#xf…

电脑安全模式怎么进?详细步骤一学就会!

电脑安全模式是一种特殊的启动模式&#xff0c;加载最少的驱动程序和服务&#xff0c;帮助用户解决系统问题&#xff0c;如驱动程序冲突、病毒感染或系统文件损坏。进入安全模式可以帮助您诊断和修复问题&#xff0c;恢复系统的正常运行。本文将介绍电脑安全模式怎么进的三种方…

长期套餐是不是永久套餐?注意:并不是!

当我们在网上选择流量卡时&#xff0c;除了有短期套餐外&#xff0c;还有不少标注着长期套餐的流量卡&#xff0c;那么&#xff0c;长期套餐是不是永久套餐呢&#xff1f;能一直使用吗&#xff1f; ​ 在这里小编要说一下&#xff0c;长期套餐≠永久套餐 长期套餐就是字面意思…

上海斯歌荣获“2023年度杰出数字化转型方案提供商”奖项

为表彰上海斯歌在各行业的数字化转型事业中所做出的突出贡献&#xff0c;经CIO时代、新基建创新研究院专家组评审认定&#xff0c;授予上海斯歌“2023年度杰出数字化转型方案提供商”奖项。荣获该殊荣&#xff0c;不仅是业界对上海斯歌解决方案专业能力及落地实施能力的又一次认…

字符编码字符集那些事

此篇文章仅为网上资料的汇总&#xff0c;方便自己查询使用&#xff0c;原文如下&#xff1a; 参考文章1:一文读懂字符编码 参考文章2:菜鸟教程字符集 参考文章3:百度字符集 参考文章4:一个线上BUG彻底搞懂MySQL字符集&#xff0c;工作也快搞丢了 参考文章5:深入理解MySQL字符集…

Kaggle -- Titanic - Machine Learning from Disaster

新手kaggle之旅&#xff1a;1 . 泰坦尼克号 使用一个简单的决策树进行模型构建&#xff0c;达到75.8%的准确率&#xff08;有点低&#xff0c;但是刚开始&#xff09; 完整代码如下&#xff1a; import pandas as pd import numpy as npdf pd.read_csv("train.csv&quo…

我用香橙派做了一个Klipper 3D打印控制器

一个好用的Klipper 3D打印机&#xff0c;一定离不开一个可以稳定进行无线通信&#xff0c;而且性能足够&#xff0c;最重要是价格亲民的上位机。 所谓Klipper&#xff0c;简单来说就是一套可以通过联动上、下位机来有效提升3D打印精度的固件。它拥有高精度的步进电机控制&#…

【图书推荐】《Spark 3.0大数据分析与挖掘:基于机器学习》

本书重点 学习Spark 3.0 ML模块的机器学习算法&#xff0c;用于大数据分析与挖掘。 内容简介 Spark作为新兴的、应用范围广泛的大数据处理开源框架&#xff0c;吸引了大量的大数据分析与挖掘从业人员进行相关内容的学习与开发&#xff0c;其中ML是Spark 3.0机器学习框架使用…

STM32智能家居项目esp8266上云OneNet【附源码+详细教程】

目录 一、硬件选材 二、OneNet使用教程 三、代码修改教程 四、添加数据流方法 五、项目工程&#xff08;源码元件清单教程&#xff09; 小白也能做&#xff0c;项目工程在后文可下载。 一、硬件选材 二、OneNet使用教程 拿到代码后肯定是连不上网的&#xff0c;因为源码…

java复习知识点

1.get&#xff0c;set: java 中当定义了一个私有的成员变量的时候&#xff0c;如果需要访问或者获取这个变量的时候&#xff0c;就可以编写set或者get方法去调用&#xff0c;set是给属性赋值的&#xff0c;get是取得属性值的&#xff0c;被设置和存取的属性一般是私有&#xf…