Towards a Rigorous Evaluation of Time-series Anomaly Detection(论文翻译)

news2025/1/11 0:14:28

1 Introduction

  随着工业4.0加速系统自动化,系统故障的后果可能会产生重大的社会影响(Baheti和Gill 2011; Lee 2008; Lee,Bagheri和Kao 2015)。为了防止这种故障,检测系统的异常状态比以往任何时候都更加重要,并且正在以异常检测(AD)的名义进行研究。与此同时,深度学习在对从大型系统的众多传感器和执行器收集的多变量时间序列数据进行建模方面表现出了有效性(Chalapathy and Chawla 2019)。因此,各种时间序列AD(TAD)方法已经广泛采用深度学习,并且它们中的每一种都通过报告比之前的方法更高的F1分数来证明其自身的优越性(Choi et al. 2021年)。对于一些数据集,报告的F1得分超过0.9,这给今天的TAD能力留下了令人鼓舞的印象。
  然而,大多数目前的TAD方法测量F1评分后,应用一个特殊的评价协议命名为点调整(PA),由Xu等人提出。(Audibert et al. 2020;沈,李,和郭2020; Su等人,2019)。PA的工作原理如下:如果连续异常段中的至少一个时刻被检测为异常,则认为整个段被正确地预测为异常。典型地,F1分数是用调整的预测(在下文中由F1PA表示)来计算的。如果在没有PA的情况下计算F1分数,则将其表示为F1。PA协议的提出是基于在异常期间内的单个警报足以采取系统恢复的措施。它已经成为TAD评估中的基本步骤,并且以下一些研究仅报道了F1PA而没有F1(Chen et al. 2021年)。较高的F1PA已指示较好的检测能力。
  然而,PA有一个高估模型性能的可能性很大。典型的TAD模型产生通知输入异常程度的异常分数,并且如果该分数高于阈值则预测异常。使用PA,来自随机生成的异常评分的预测和良好训练的模型的预测变得相同,如图1-(a)所示。
在这里插入图片描述

图1:(a)PA使不同的异常评分难以区分。黑线、灰色区域和虚线分别指示异常分数、GT异常段和TAD阈值。在应用PA之后,针对信息性和随机异常分数的预测退化为相同的调整后的预测(红色)。

  黑色实线表示两种不同的异常分数;上面的线示出了来自良好训练的模型的信息分数,而下面的线是随机生成的。阴影区域和虚线分别指示地面实况(GT)异常段和TAD阈值。信息分数(上图)是理想的,因为它们仅在GT段期间较高。相比之下,随机生成的异常评分(下图)在GT段内仅超过阈值一次。尽管存在差异,但PA之后的预测变得不可区分,如红线所示。如果随机异常分数可以产生与熟练检测模型一样高的F1PA,则难以得出具有较高F1PA的模型比其他模型表现更好的结论。我们在第5节中的实验结果表明,随机异常分数可以推翻大多数最先进的方法(图1-(B))。
在这里插入图片描述
图1:(b)现有的方法未能超过随机生成的异常分数的F1PA(左),并且即使当PA被禁止用于WADI数据集时,也没有显示出对新提出的基线(右)的改进。
  出现的另一个问题是PA是否是TAD方法评估中的唯一问题。到目前为止,只报道了绝对F1,没有试图建立基线和相对比较。如果二元分类器的准确率为50%,则尽管是明显较大的数字,但它与随机猜测没有太大区别。同样,应讨论TAD的适当基线,并应根据与基线相比的改进来评估未来的方法。根据我们的观察,现有的TAD方法似乎没有得到显着的改善,本文提出的基线。此外,一些方法未能超过它。我们对一个基准数据集的观察总结在图1-(b)的右侧。
  在本文中,我们提出了一个问题,是否目前的TAD方法,声称带来显着的改进进行了适当的评估,并提出了第一次严格的评估TAD的方向。我们的贡献总结如下:

  • 我们发现,PA,一个奇特的评估协议,大大高估了现有方法的检测性能。
  • 我们表明,在没有PA的情况下,现有方法在基线上没有(或大多数是微不足道的)改进。
  • 基于我们的发现,我们提出了一个新的基线和评估协议,用于严格评估TAD。

2 背景

2.1 Types of anomaly in time-series signals(时间序列信号中的异常类型)

  各种类型的异常存在于数据集中(Choi et al. 2021年)。上下文异常表示具有与正常信号不同形状的信号。集体异常指示在一段时间内累积的少量噪声。点异常指示由于信号值的快速增加或减少而与预期范围的暂时和显著偏差。点异常是目前TAD数据集中最主要的类型。

2.2 Unsupervised TAD(无监督的网络)

  典型的AD设置假定在训练时间期间仅可访问正常数据。因此,无监督方法是TAD最合适的方法之一,TAD训练模型以仅在正常信号中学习共享模式。最终目标是根据输入的异常程度将不同的异常分数分配给输入,即,分别用于正常和异常输入的低异常分数和高异常分数。基于重构的AD方法训练模型,以最小化正常输入与其重构之间的距离。在测试时间的异常输入导致大距离,因为它是难以重建的。距离或重建误差用作异常分数。基于预测的方法训练模型以预测将在正常输入之后到来的信号,并采取地面实况和预测信号之间的距离作为异常分数。每个类别的详细示例请参阅附录。

2.3 Assessment of TAD evaluation(评估可持续发展评价)

  已经有几种方法指出了当前TAD评估中的缺陷。(Wu和Keogh 2021)提出了基准TAD数据集的局限性,并表明简单的检测器,所谓的单线性,对于一些数据集是足够的。他们还提供了几个合成数据集。(Lai等人,2021)为异常类型(例如,点与模式),并引入了根据新标准合成的新数据集。相比之下,我们提出了TAD评估中的陷阱:PA高估的风险和基线的缺失以及解决方案。如果陷阱没有解决,它是不可能的,以评估是否改进的TAD方法是显着的,即使与上述论文提出的更好的数据集。

3 Pitfalls of the TAD evaluation(评估的陷阱)

3.1 Problem formulation(问题公式化)

  首先,我们将在时间T期间从N个传感器观察到的时间序列信号表示为X = {x1,…xT},xt ∈ RN。作为常规方法,其被归一化并分成一系列窗口W = {w1,…wT-τ+1},其中wt = {xt,…,xt+τ−1},τ是窗口大小。仅针对测试数据集给出地面真值二进制标签yt ∈ {0,1},指示信号是否为异常(1)或不是(0)。TAD的目标是预测测试数据集中所有窗口的异常标签。通过将异常分数A(wt)与如下给出的阈值δ进行比较来获得标签:
在这里插入图片描述
  A(wt)的示例是原始输入与其重构版本之间的均方误差(MSE),其定义如下:
在这里插入图片描述
  其中,w = fθ(wt)表示来自用θ参数化的重建模型fθ的输出。标记后,精确度(P)、召回率(R)和F1得分计算如下:
在这里插入图片描述  其中TP、FP和FN分别表示真阳性、假阳性和假阴性的数量。
  所述异常测试数据集可以包含持续几个时间步长的多个异常段。我们将S表示为M个异常段的集合;即,S = {S1,…,SM},其中Sm = {Sm,.,tm_s和tm_e分别表示Sm的开始和结束时间。如果Sm中至少有一次异常评分高于δ,则PA将所有t ∈ Sm的Δ yt调整为1。使用PA,Eq.1变更如下:
在这里插入图片描述
  F1PA表示使用调整后的标签计算的F1分数。

3.2 Random anomaly score with high F1PA(F1PA高的随机异常评分)

  在本节中,我们证明了PA协议高估了检测能力。我们从抽象分析的P和R的方程。3,并且我们在数学上表明,随机生成的A(wt)可以实现接近1的高F1PA值。根据等式3,因为F1评分是P和R的调和平均值,所以它还取决于TP、FN和FP。如等式1所示。4、PA增加TP,降低FN,而维持FP。因此,在PA之后,P、R以及因此F1分数只能增加。
  接下来,我们证明F1PA可以很容易地接近1。首先,R被重述为条件概率,如下所示:
在这里插入图片描述
  让我们假设A(wt)是从均匀分布U(0,1)中提取的。我们使用0 ≤ δ θ ≤ 1来表示该假设的一个阈值。如果只存在一个异常段,即,S = {{ts,…,te}},PA之后的R可以表示如下,参考Eq.4:
在这里插入图片描述
  其中,γ = Pr(t ∈ S)是测试数据集异常率,Pr(A(wt)< δ ε)= δ ε ε 0 1 = δ ε。
在这里插入图片描述
  关于更一般化的证明,请参阅附录。数据集的异常率γ通常在0到0.2之间; te-ts也由数据集决定,在基准数据集中通常在100到5,000之间。图2描绘了当γ固定为0.05时,在不同的te−ts下,F1 PA随δ ε的变化。如图所示,除了异常段长度较短的情况外,我们总是可以通过改变δ ε来获得接近1的F1 PA。
在这里插入图片描述
图2:均匀随机异常分数随不同te − ts的δ变化的情况下的F1PA。如果异常段相当长,也就是说,如果te −ts足够大,则随着δ的增加,F1PA接近1。

3.3 Untrained model with comparably high F1(具有较高F1的未训练模型)

  本节显示从未经训练的模型获得的异常分数在一定程度上是信息性的。深度神经网络通常用从高斯分布N 0,σ2中提取的随机权重初始化,其中σ是通常小于1。在没有训练的情况下,模型的输出接近于零,因为它们也遵循零均值高斯分布。基于重建或基于预测的方法的异常分数通常被定义为输入和输出之间的欧几里得距离,在上述情况下,该距离与输入窗口的值成比例:
在这里插入图片描述
  在点异常的情况下,特定传感器值突然增加。这导致比正常窗口更大的Δ Wt Δ 2的幅度,这直接与GT异常的高A(wt)相关。第5节中的实验结果表明,由Eq.8与目前的方法相当。它还表明,当窗口大小变得更长时,F1增加得更多。

4 Towards a rigorous evaluation of TAD(严格评估可持续发展)

4.1 New baseline for TAD(新的基线)

  对于分类任务,基线准确度通常被定义为随机猜测的准确度。可以说,只有当分类精度超过该基线时才有改善。类似地,TAD不仅需要与现有方法进行比较,还需要与基线检测性能进行比较。因此,基于第3.3节的发现,我们建议建立一个新的基线,其中F1是从具有简单架构的随机初始化重建模型的预测中测量的,例如包含单层LSTM的未经训练的自动编码器。可替代地,异常分数可以被定义为输入本身,这是等式1的极端情况。8,此时模型始终输出零,而不管输入。如果新TAD模型的性能未超过该基线,则应重新检查模型的有效性。

4.2 New evaluation protocol PA%K(新评估方案PA%K)

  在上一节中,我们证明了PA有很大的可能性高估检测性能。没有PA的F1可以立即解决高估。在这种情况下,建议按照第4.1节中的介绍设定基线。然而,根据测试数据分布,F1可能会意外地低估检测能力。事实上,由于不完全的测试集标记,一些标记为异常的信号与正常信号共享更多的统计信息。即使在一段时间内间歇地插入异常,对于该时段中的所有t,yt = 1。
  我们使用t分布随机邻居嵌入(t-SNE)(货车der Maaten和欣顿2008)进一步研究了这个问题,如图3所示。t-SNE由安全水处理(SWaT)的测试数据集生成(Goh等人,2016)。蓝色和橙子分别表示正常和异常样品。大多数异常形成了一个远离正态数据分布的独特的聚类。然而,一些异常窗口比异常更接近正常数据。对应于绿色和红色点的信号的可视化分别在(B)和(c)中描述。虽然两个样本都被注释为GT异常,但(b)与(a)的正常数据相比(c)共享更多模式。仅仅因为模型不能检测到诸如(b)的信号而得出模型性能有缺陷的结论可能会导致低估检测能力。

  因此,我们提出了一种替代的评估协议PA%K,它可以减轻F1PA的高估效果和低估F1的可能性。请注意,它不是建议取代现有的TAD指标,而是与它们沿着使用。PA%K的思想是仅当Sm中正确检测到的异常的数量与其长度的比率超过PA%K阈值K时才将PA应用于Sm。PA%K修改Eq.4如下:
在这里插入图片描述
  其中表示Sm的大小(即,tm-tm)和K可以基于现有的知识在0和100之间手动选择。例如,如果测试集标签是可靠的,则允许更大的K。如果用户想要去除对K的依赖性,建议测量通过将K从0增加到100获得的FlPA *k的曲线下面积。

5 Experimental results(实验结果)

5.1 Benchmark TAD datasets(基准测试数据集)

  在本节中,我们介绍了五个最广泛使用的水处理基准数据集的列表,如下所示:

安全水处理(SWaT)(Goh et al. 2016):

  SWaT数据集是在11天内从一个由51个传感器组成的缩小规模的水处理测试平台上收集的(Mathur和Tippenhauer 2016)。在过去的4天里,使用不同的攻击方法注入了41个异常,而在前7天只生成了正常数据。

配水试验台(WADI)(Ahmed,Palleti和Mathur 2017):

  WADI数据集是从一个简化的城市配水系统中获取的,该系统具有123个传感器和执行器,运行了16天。在前14天中只收集正常数据,其余两天包含异常数据。测试数据集共有15个异常段。

服务器机器数据集(SMD)(Su et al. 2019):

  SMD数据集是从28台服务器机器和38个传感器收集的,持续10天;前5天仅出现正常数据,最后5天间歇性注入异常。SMD数据集的结果是每台机器28个不同型号的平均值。

火星科学实验室(MSL)和土壤水分主动被动(SMAP)(Hundman et al. 2018):

  MSL和SMAP数据集是从NASA航天器收集的真实世界数据集。这些是来自航天器监测系统的意外异常(伊萨)报告的异常数据。与其他数据集不同,训练数据中包含未标记的异常,这使得训练变得困难。统计数据总结见表1
在这里插入图片描述

5.2 Evaluated methods(评价方法)

  下面,我们介绍了最近提出的7种代表性的方法和第3节中研究的3种情况。

USAD(Audibert et al. 2020)

  代表无监督异常检测,它在两个阶段的训练方案下训练两个自动编码器,包括一个共享编码器和两个单独的解码器:自动编码器训练阶段和对抗训练阶段。

DAGMM(Zong et al. 2018)

  代表深度自动编码高斯混合模型,该模型采用自动编码器来产生表示向量并将其馈送到高斯混合模型。它使用估计的样本能量作为重建误差;高能量表示高异常。

LSTM-VAE

  代表了一种基于LSTM的变分自动编码器,该编码器采用变分推理进行重构。

OmniAnomaly(Su et al. 2019)

  应用VAE将时间序列信号建模为随机表示,如果给定输入的重建可能性低于阈值,则会预测异常。它还定义了重建概率的个别功能的归因得分和量化的解释。

MSCRED(Zhang et al. 2019)

  代表了一种多尺度卷积递归编码器-解码器,包括卷积LSTM,用于重建表征多个系统级别的输入矩阵,而不是输入本身。THOC(Shen,Li,and Kwok 2020)表示一个时间层次单类网络,它是一个多层扩张递归神经网络和一个层次深度支持向量数据描述。

GDN(Deng and Hooi 2021)

  表示学习传感器关系图以检测异常与学习模式的偏差的图偏差网络。
  例一。随机异常评分对应于第3.2节中描述的情况。F1分数用从均匀分布U中抽取的随机生成的异常分数来测量,即,A(wt)= 0,1。
  案例2.作为异常分数的输入本身表示假设fθ(wt)= 0而不考虑wt的情况。这等于Eq.8.因此,A(wt)= 10wt 102。
  案例3.来自随机化模型的异常评分对应于等式其中η表示来自随机化模型的小输出。参数在从高斯分布N(0,0.02)初始化之后被固定。

5.3 Correlation between F1PA and F1(F1PA与F1的相关性)

  F1是检测性能的最保守指标。因此,如果F1PA可靠地表示检测能力,则它应该与F1至少具有一些相关性。图4绘制了SWaT和WADI的F1 PA和F1,如对USAD、DAGMM、LSTMVAE、OmniAnomaly和GDN的原始研究所报告的。该图还包括情况1-3的结果。值得注意的是,考虑到只有一部分数据集和方法一起报告了F1PA和F1,我们只绘制了它们。对于SWaT,Pearson相关系数(PCC)和Kendall秩相关系数(KRC)分别为-0.59和0.07。对于WADI,PCC和KRC分别为0.41和0.43。然而,这些数字不足以确保相关性的存在,并证实比较仅使用F1PA的方法的优效性可能存在检测性能评估不当的风险。
在这里插入图片描述
图4:SWaT和WADI数据集上现有方法的F1PA和F1之间的相关性。图中显示了肯德尔等级相关(KRC)和皮尔逊相关系数(PCC)

5.4 Comparison results(比较结果)

  在这里,我们将AD方法的结果与情况1-3进行比较。应当注意,对于情况1和2,异常分数是直接生成的,而不需要模型推断。对于案例3,我们采用了最简单的具有LSTM层的编码器-解码器架构。情况2和3的窗口大小τ被设置为120。对于包括随机性的实验,例如案例1和案例3,我们用五种不同的种子重复它们并报告平均值。对于现有的方法,我们使用原始论文中报告的最佳数字和官方复制的结果(Choi et al. 2021);如果没有可用的分数,我们参考官方提供的代码复制它们。请注意,我们没有应用任何预处理,例如早期时间步长删除或下采样。在以前的论文中没有提供MSL、SMAP和SMD的F1,因此它们都是复制的。值得注意的是,我们在论文中建议的范围内搜索最佳超参数,并且我们没有应用下采样。所有阈值均从产生最佳分数的阈值获得。有关实施的进一步详情载于附录。结果示于表2中。再现的结果标记为t。粗体和下划线数字分别表示最佳和次佳结果。向上箭头(↑)显示以下情况的结果:(1)F1 PA高于情况1,(2)F1高于情况2或3,以较大者为准。
在这里插入图片描述
表2:各种方法的F1评分。†表示再现结果。下面三行表示以下情况:情况1。随机异常评分,病例2。输入自身作为异常评分,案例3。来自随机化模型的异常评分。详细解释请参阅手稿。粗体和下划线的情况分别表示最佳和次佳。在下列情况下标记↑:(1)F1 PA高于情况1,(2)F1高于情况2或3。
  显然,随机生成的异常分数(情况1)不能检测异常,因为它不反映关于输入中的异常的任何内容。相应地,F1相当低,这清楚地表明检测能力不足。然而,当应用PA协议时,情况1似乎产生远远超出现有方法的最先进的F1 PA,除了SMD。如果结果仅被提供有PA,如在MSL、SMAP和SMD的情况下,则区分该方法是否成功地检测到异常或者其是否仅输出与输入无关的随机异常分数是不可能的。特别是,MSL和SMAP的F1非常低;这意味着很难对它们进行建模,因为它们都是真实世界的数据集,并且训练数据包含异常。然而,F1 PA似乎相当高,造成了一种错觉,即这些数据集的异常被很好地检测到。
  SMD的Case 1的F1值低于其他数据集,并且有以前的方法超过它,这可能是由于SMD测试数据集的组成。根据等式如图6和图7所示,F1 PA随三个参数而变化:测试数据集中的异常率(γ)、异常段的长度(te-ts)和阈值(δ)。与其他数据集不同,SMD的异常率非常低,如表1所示。此外,异常段的长度相对较短; 28台机器的平均长度为90,不像其他数据集从数百到数千不等。这类似于图2中的最低情况,图2示出了在这种情况下可实现的最大F1 PA仅约为0.8。因此,我们可以得出结论,PA的高估效果取决于测试数据集的分布,其效果变得不太明显,异常段越短。
  在所有数据集中,现有方法的F1大多低于案例2和案例3,这意味着目前提出的方法可能相对于基线取得了微小的进步,甚至没有进步。只有GDN始终超过所有数据集的基线。情况2和情况3的F1取决于输入窗口的长度。如果窗口较长,F1基线会变得更大。我们在案例2中使用从1到250的各种窗口长度进行了实验,并在图5中描绘了结果。对于SWaT、WADI和SMAP,随着τ的增加,F1在短暂下降后开始增加。出现这种增加是因为较长的窗口更可能包含更多的点异常,从而导致窗口的高异常分数。如果τ变得太大,F1饱和或退化,可能是因为过去只包含正常信号的窗口意外地包含异常信号。
在这里插入图片描述
图5:不同窗口大小(τ)的F1。随着τ的增加,F1在短暂下降后大部分增加。

5.5 Effect of PA%K protocol

  为了研究PA%K如何缓解PA的高估效应和F1的低估趋势,我们观察了F1PA%K随不同PA%K阈值K的变化。图6示出了当K从0到100以10的增量改变时,来自情况1的SWaT和完全训练的编码器-解码器的F1PA%K。K = 0和K = 100的F1PA%K值分别等于原始F1PA和F1。无论K的值如何,经过良好训练的模型的F1PA%K都将显示恒定的结果。相应地,经训练的编码器-解码器(橙子)的F1PA%K显示出一贯高的F1PA%K。相反,病例1(蓝色)的F1PA%K在K增加时迅速降低。我们还建议测量曲线下面积(AUC)以减少对K的依赖性。在这种情况下,对于训练的编码器-解码器和情况1,AUC分别为0.88和0.41;这表明PA%K清楚地将前者与后者区分开来,而不管K如何。
在这里插入图片描述
图6:具有PA%K和不同K的F1评分。如果K = 0,它等于F1PA,如果K = 100,它等于F1。

6 Discussion

  在本文中,我们已经证明,目前的评估有两个方面的陷阱:(1)由于PA高估了检测性能,我们不能确保具有较高的F1 PA的方法确实具有更好的检测能力;(2)结果只与现有的方法进行了比较,而不是对基线。在适当评估目前的成就时,可以开发出更好的异常检测器。在本节中,我们为未来的可持续发展评估提出了几个方向。
  PA的动机,即,第一个陷阱的来源,源于测试数据集标记过程的不完整性,如4.2节所述。一个彻底的解决方案是开发一个新的基准数据集,以更细粒度的方式进行注释,以便时间步长标签变得可靠。由于细粒度注释需要大量资源,因此通常不可行,F1PA%K可以是一个很好的替代方案,可以在不修改任何额外数据集的情况下减轻高估。请注意,PA%K是一种评估协议,可应用于F1分数以外的各种指标。对于第二个问题,重要的是设置一个基线作为案例2和案例3中未训练模型的性能,并测量相对于它的相对改进。窗口大小应该通过考虑其对基线的影响来仔细确定,如第5.4节所述。
  此外,在不访问测试数据集的情况下预定义阈值在真实的世界中通常是不切实际的。相应地,视野中的许多AD方法使用受试者工作特征(AUROC)曲线下面积进行自我评估(Yi和Yoon 2020)。相比之下,现有的F1方法在调查测试数据集之后设置阈值,或者简单地使用产生最佳F1的最佳阈值。因此,检测结果很大程度上取决于阈值的选择。具有降低依赖性的其他指标,如AUROC或精确召回率(AUPR)曲线下的面积将有助于严格的评估。即使在这种情况下,所提出的基线选择方法是有效的。由于PA%K是一个协议,它也可以用于上述指标。

7 Conclusion

  在本文中,我们首次表明,应用PA可以严重高估TAD模型的能力,这可能无法反映真实的建模性能。我们还提出了一个新的TAD基线,并表明只有少数方法在这方面取得了显着的进步。为了减轻高估的PA,我们提出了一个新的PA%K协议,可以应用于现有的指标。最后,我们提出了几个方向,严格评估TAD方法,包括基线选择。我们希望我们的研究有助于澄清目前的TAD方法的潜力,并导致TAD在未来的改进。

8 Acknowledgement

  这项工作得到了韩国政府(MSIT)资助的信息和通信技术规划与评估研究所(IITP)的资助[No.20210-02068,人工智能创新中心,No.20210-01343,人工智能研究生院计划(首尔国立大学)],韩国国家研究基金会(NRF)赠款,由韩国政府资助(科学和信息通信技术部)[2018 R1 A2 B3001628,2019 R1 G1 A1003253],2021年的Brain Korea 21 Plus项目,通过HMC-SNU AI联盟基金在现代汽车公司的AIR实验室(AI研究实验室),以及三星电子
  
  
  
  

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

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

相关文章

python+unittest+requests+HTMLRunner编写接口自动化测试集

问题描述&#xff1a; 搭建接口测试框架&#xff0c;执行用例请求多个不同请求方式的接口 实现步骤&#xff1a; ① 创建配置文件config.ini&#xff0c;写入部分公用参数&#xff0c;如接口的基本url、测试报告文件路径、测试数据文件路径等配置项 1 [DATABASE] 2 data_addre…

QT:编译opencv4.5.3

软件版本 QT&#xff1a;5.9.11 OpenCV 4.5.3 mingw 530&#xff08;32位&#xff09; cmake 3.15.3 下载地址&#xff1a; opencv下载&#xff1a;https://sourceforge.net/projects/opencvlibrary/files/opencv-unix/ cmake下载&#xff1a;https://cmake.org/files/ qt下…

多变量GARCH模型R代码实现

大家好&#xff0c;我是带我去滑雪&#xff01; 多变量GARCH&#xff08;Generalized Autoregressive Conditional Heteroskedasticity&#xff09;模型是一种用于建模多个时间序列变量之间的条件异方差性&#xff08;conditional heteroskedasticity&#xff09;的统计模型。它…

Unity开发之观察者模式(事件中心)

观察者模式是一种对象行为模式。它定义对象间的一种一对多的依赖关系&#xff0c;当一个对象的状态发生改变时&#xff0c;所有依赖于它的对象都得到通知并被自动更新。在观察者模式中&#xff0c;主体是通知的发布者&#xff0c;它发出通知时并不需要知道谁是它的观察者&#…

随机森林算法(Random Forest)的二分类问题

二分类问题 1. 数据导入2. RF模型构建2.1 调参&#xff1a;mtry和ntree2.2 运行模型 3. 模型测试4.绘制混淆矩阵5.绘制ROC曲线6. 参考 1. 数据导入 library(dplyr) #数据处理使用 library(data.table) #数据读取使用 library(randomForest) #RF模型使用 library(caret) # 调参…

软件测试之 测试用例 如何设计

在软件开发过程中&#xff0c;测试是一个至关重要的环节&#xff0c;它有助于确保软件的质量和稳定性。而测试用例设计则是测试过程中的一个关键步骤&#xff0c;它帮助测试团队确定如何测试软件以发现潜在的问题和缺陷。本文将介绍测试用例设计的基本概念和步骤&#xff0c;以…

产品研发团队协作神器!10款提效工具大盘点!

在如今科技驱动的时代&#xff0c;产品研发团队面临着前所未有的竞争压力和不断变化的市场需求。为了在这个激烈的环境中脱颖而出&#xff0c;团队需要高效协作并充分利用先进的工具来提高生产力和创新能力。 本文将为你盘点产品研发团队协作必备的10个提效工具&#xff0c;这…

TiDB、MySQL与Oracle的char字段

文章目录 MySQLTiDBOracle结论 我们组在团队内维护了一套TiDB&#xff0c;有时候会有其他同事来请教一些问题&#xff0c;当然遇到比较复杂的问题&#xff0c;我也会直接抛给DBA。今天有个同事来问了一下TiDB的char字段查询是否需要补空格。在我的印象中&#xff0c;TiDB是高度…

【Docker】Docker学习之一:离线安装Docker步骤

前言&#xff1a;基于Ubuntu Jammy 22.04 (LTS)版本安装和测试 1、Docker安装 1.1、离线安装 步骤一&#xff1a;官网下载 docker 安装包 wget https://download.docker.com/linux/static/stable/x86_64/docker-24.0.6.tgz步骤二&#xff1a;解压安装包; tar -zxvf docker…

安防监控视频汇聚平台EasyCVR增加AI算法列表接口的实现方法

安防监控视频汇聚平台EasyCVR基于云边端一体化架构&#xff0c;具有强大的数据接入、处理及分发能力&#xff0c;可提供视频监控直播、云端录像、云存储、录像检索与回看、智能告警、平台级联、云台控制、语音对讲、智能分析等功能。平台既具备传统安防监控的能力&#xff0c;也…

C++进阶语法之函数和指针【学习笔记(三)】

文章目录 1、C 函数1.1 函数的定义1.2 函数原型&#xff08;function prototypes&#xff09;1.3 参数&#xff08;parameter&#xff09;——值传递&#xff08;pass by value&#xff09;1.4 重载&#xff08;overloading&#xff09;1.5 函数传参——传递数组&#xff08;ar…

Linux下控制GPIO的三种方法

https://blog.csdn.net/qq_41076734/article/details/124669908 1. 应用空间控制gpio 1.1简介 在/sys/class/gpio/下有个export文件&#xff0c;向export文件写入要操作的GPIO号&#xff0c;使得该GPIO的操作接口从内核空间暴露到用户空间&#xff0c;GPIO的操作接口包括dir…

Flink学习笔记(四):Flink 四大基石之 Window 和 Time

文章目录 1、 概述2、 Flink 的 Window 和 Time2.1、Window API2.1.1、WindowAssigner2.1.2、Trigger2.1.3、Evictor 2.2、窗口类型2.2.1、Tumbling Windows2.2.2、Sliding Windows2.2.3、Session Windows2.2.4、Global Windows 2.3、Time 时间语义2.4、乱序和延迟数据处理2.5、…

linux系统安装Googletest单元测试框架

环境信息 系统&#xff1a;ubuntn cmake版本&#xff1a;3.5.1 gcc版本&#xff1a;5.4.0 1、下载googletest git clone https://github.com/google/googletest.git注意&#xff01;不选branch的话默认下载最新版本&#xff08;需要编译器能够支持C14&#xff09;&#xff0c;…

如何生成osg的动画路径文件

目录 1. 前言 2. 生成动画路径文件 2.1. 粗糙方式 2.2. 精确方式 1. 前言 在进行osg的开发中&#xff0c;有时需要对模型按某个路径或规则进行动画&#xff0c;如下&#xff1a; 奶牛在10秒时间段从起始的osg::Vec3d(0.0, 18, 1.0)位置 匀速直线运动到osg::Vec3d(0.0, -8, …

ubuntu 中使用Qt连接MMSQl,报错libqsqlodbc.so: undefined symbol: SQLAllocHandle

Qt4.8.7的源码编译出来的libqsqlodbc.so&#xff0c;在使用时报错libqsqlodbc.so: undefined symbol: SQLAllocHandle&#xff0c;需要在编译libqsqlodbc.so 的项目pro文件加上LIBS -L/usr/local/lib -lodbc。 这里的路径根据自己的实际情况填写。 编辑&#xff1a; 使用uni…

Python数据结构(队列)

Python数据结构&#xff08;队列&#xff09; 队列(queue)是只允许在一端进行插入操作&#xff0c;而在另一端进行删除操作的线性表。 队列是一种先进先出的 (First n First ut)的线性表&#xff0c;简称FIFO。允许插入的一端为队尾&#xff0c;允许删除的一端为队头&#xff…

深度学习——图像分类(CIFAR-10)

深度学习——图像分类&#xff08;CIFAR-10&#xff09; 文章目录 前言一、实现图像分类1.1. 获取并组织数据集1.2. 划分训练集、验证集1.3. 图像增广1.4. 引入数据集1.5. 定义模型1.6. 定义训练函数1.7. 训练模型并保存模型参数 二、生成一个桌面小程序2.1. 使用QT设计师设计界…

建筑工程模板分类以及特点?

建筑工程模板可以根据材料、结构和用途等方面进行分类。以下是一些常见的建筑工程模板分类及其特点&#xff1a; 1. 木质模板&#xff1a; - 特点&#xff1a;木质模板是最常见和传统的模板类型。它们由木材制成&#xff0c;具有良好的可塑性和可加工性。木质模板适用于各种形状…

京东数据分析:2023年9月京东白酒行业品牌销售排行榜

鲸参谋监测的京东平台9月份白酒市场销售数据已出炉&#xff01; 9月白酒市场的整体热度较高&#xff0c;贵州茅台先是与瑞幸联名推出酱香拿铁&#xff0c;后又宣布与德芙推出联名产品酒心巧克力&#xff0c;引起了诸多消费者的关注。在这一热度的加持下&#xff0c;从销售上看&…