【论文精读】ID-like Prompt Learning for Few-Shot Out-of-Distribution Detection
🌈 个人主页:十二月的猫-CSDN博客
🔥 系列专栏: 🏀论文精读_十二月的猫的博客-CSDN博客💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光
注:下文块引用部分均为猫猫的笔记
目录
1. 摘要
2. 介绍
3. 相关工作
3.1 预训练语言模型
3.2 视觉语言模型
3.3 提示词调优工程
3.4 方法
3.4.1 Preliminaries
3.4.2 ID-like Prompt Learning
3.4.3 Loss函数的设计
4. 总结
1. 摘要
分布外(out -distribution, OOD)检测方法通常利用辅助离群值来训练识别OOD样本的模型,特别是从辅助离群值数据集中发现具有挑战性的离群值来提高OOD检测。然而,在有效区分最具挑战性的OOD样本方面,它们可能仍然面临限制,这些样本与分布中(ID)数据非常相似,即类ID样本。为此,我们提出了一种新的OOD检测框架,该框架使用CLIP[28]从ID样本的附近空间发现类ID异常值,从而有助于识别这些最具挑战性的OOD样本。然后提出了一个快速学习框架,该框架利用识别出的类id异常值进一步利用CLIP进行OOD检测的能力。得益于强大的CLIP,我们只需要少量的ID样本来学习模型的提示,而不需要暴露其他辅助的离群数据集。通过专注于最具挑战性的id -类OOD样本并优雅地利用CLIP的功能,我们的方法在各种真实世界的图像数据集上实现了卓越的少镜头学习性能(例如,在ImageNet-1k数据集上的4镜头OOD检测中,与最先进的方法相比,我们的方法将平均FPR95降低了12.16%,将平均AUROC提高了2.76%)。
2. 介绍
当在实际环境中部署机器学习模型时,可能会遇到在训练过程中没有遇到的分布外(OOD)样本。当涉及到这些OOD输入时,错误决策的风险会增加,这可能会带来严重的安全问题,特别是在自动驾驶和医疗诊断等应用中。除了在ID样本上表现良好外,系统还需要识别OOD样本,以产生可信的预测。因此,OOD检测对于同等贡献是非常关键的为了在现实中安全地部署机器学习模型。
现有方法[8,16,19]通常侧重于仅使用训练中的ID数据检测OOD样本,以预测OOD样本的较低置信度[7,23]或较高能量[20]。然而,由于缺乏OOD信息,这些模型难以有效地检测OOD。因此,一些研究[9,20]建议使用辅助离群值来正则化模型并识别OOD样本。Chen等[1]和Ming等[25]认为,选择更具挑战性的离群样本可以帮助模型更好地学习ID和OOD之间的决策边界。然而,这些有限的辅助异常值包含更少挑战性的异常值。此外,这些方法大多需要额外的离群数据,这使得它们在无法获得离群数据集时无效。最近,Du等[4]提出在训练过程中,在不需要额外数据的情况下,从ID数据特征空间的低似然区域合成虚拟离群数据来构建离群数据。该方法对鉴别ID和OOD有较强的疗效。然而,有两个主要的限制:i)它假设特征空间中的ID数据符合一类条件高斯分布,这在复杂的现实应用中并不总是成立[30];ii)需要大量的ID样本来构建更准确的ID数据分布,而获得大量的ID样本往往成本高昂。
OOD检测:开放式离群值检测,离群值就是和原本训练数据分布差距很大的数据。检测离群值作用就是不对这些数据做出判断,而是辅助识别出这些数据。
因此,在这项工作中,我们专注于灵活地构建信息异常值,以提高对具有挑战性的OOD样本的识别。
在本文中,我们首先构建了与ID数据高度相关的离群值,并引入了一种新的类ID提示用于OOD检测,从而有效地识别具有挑战性的OOD样本。我们发现具有挑战性的OOD样本通常与ID数据高度相关,表现出高度的视觉或语义相似性,例如,OOD的局部特征与ID相关(如图1所示)。由于OOD样本的这些类ID特征导致错误的预测,因此自然产生了一个想法:从ID样本中提取相关特征来构建具有挑战性的OOD样本。为此,我们对ID样本的邻近空间进行多次采样。在这些样本中,那些与ID提示相似度较低的样本不被归类为ID类,即使它们包含与ID类相关的特征。因此,这些样本自然被选为具有挑战性的OOD样本。与VOS[4]和NPOS[30]在特征空间的低似然区域合成虚拟离群点不同,我们的方法直接从原始图像中构建离群点,增强了灵活性和可解释性。
思考流程:
具有挑战性的OOD样本难以寻找———自己制造具有挑战性的OOD样本———具有挑战性=邻近空间(和ID特征空间上相似)———OOD样本(与ID提示相似度低)
虽然我们可以构建具有挑战性的OOD样本,但有效识别这些OOD样本仍然具有挑战性。如图2左侧所示,“狼”代表了“狗”类的一个具有挑战性的OOD示例。这些图像与ID提示类似,导致分类概率高,并且在区分ID和OOD方面存在重大挑战。我们认为,仅仅依靠ID提示不足以解决这个问题。因此,我们引入了额外的提示来增强OOD识别。如图2右半部分所示。
前面工作:构建具有挑战性OOD样本,并通过这些OOD样本增强模型对于离散数据的学习。
通过前面学习,能够让模型(包括ID提示词工程)进一步学习出 特征相似但是提示词不相似 的数据。
从某种角度来说,进一步在ID提示词层面做到了不相似类分离。
但是对于狼、狗这类数据,仍然在图片特征值以及提示词上都是类似的。这种数据,我们难以处理。
我们开发了一个额外的提示,称为“dog-like”,它类似于“dog”的提示。如果我们可以增加“狗样”提示和与“狗”高度相关的OOD样本之间的相似度,模型将通过“狗”提示识别狗,并通过“狗样”提示识别具有挑战性的OOD样本(包括“狼”)。
具体来说,我们将额外的提示与这些构建的具有挑战性的OOD对齐,创建类似于ID提示的OOD提示,以有效地识别具有挑战性的OOD样本。大量的实验表明,我们的方法在各种现实世界的任务中实现了优越的少量OOD检测性能。与在训练过程中需要大量数据的方法[4,30]相比,我们的方法在每个类只使用一张图像的情况下,将平均FPR95分数从38.24%显著降低到24.08%,将平均AUROC从91.60%提高到94.70%。我们将我们的主要贡献总结如下:
•我们提出了一个新的框架,无需额外的训练,通过利用CLIP自动探索ID样本附近空间中的类ID OOD样本,这有助于模型有效识别与ID相关的具有挑战性的OOD样本。
•通过利用预训练的视觉语言模型的能力,提出了一种类似id的提示学习方法来识别最具挑战性的OOD样本,这些样本的行为类似id,但却不同。
•我们在几个大规模数据集上验证了我们的方法,结果表明我们的方法取得了令人印象深刻的性能,在ImageNet-1K上4次OOD检测的平均AUROC达到96.66%。另外还进行了烧蚀实验来验证所设计方法的有效性
增加一个新的Prompt提示词,在训练时同时训练旧提示词和新的提示词。
从而针对性提高特征值相似的类的识别度
3. 相关工作
3.1 预训练语言模型
Hendrycks和Gimpel[8]使用最大软最大概率(maximum softmax probability, MSP)建立了OOD检测的基线。随后的研究探索了通过ODIN评分[11,19]和Mahalanobis评分[16]来检测OOD。
1、利用MSP方法来建立OOD检测是一种相当直观、简单的OOD检测方法。
2、ODIN评分在OOD检测中的优势在于,它利用了温度缩放和扰动的结合,使得模型在处理未见过的分布时更加敏感。(手工调整缩放参数)
3、Mahalanobis评分的优势在于,它能够利用样本的分布信息,从而为OOD检测提供了一种更为可靠的方式。
Fort等[6]首先将OOD检测任务扩展到预训练的视觉语言模型。esmailpour等[5]通过生成额外的负面标签来构建负面提示,增强了预训练的视觉语言模型的OOD检测性能。最近,Ming等[24]将MSP扩展到预训练的视觉语言模型,并探讨了softmax和温度缩放对OOD检测的影响。CLIPN[34]对CLIP进行了微调,使其能够输出负面提示,以评估图像中不存在概念的概率。
3.2 视觉语言模型
对比视觉语言模型。与传统的机器学习模型相比,近年来大规模预训练的视觉语言模型在各种下游任务上取得了很大的进展。例如,CLIP[28]、FILIP[36]和ALIGN[13]利用对比损失(如InfoNCE损失[31])来学习图像和文本的对齐表示。匹配的图像-文本对的表示距离越来越近,不匹配的图像-文本对的表示距离越来越远。具体来说,这些方法采用了一种简单的双流架构,包括一个图像编码器和一个文本编码器,它将图像和文本特征映射到一个共享空间中进行相似性计算。CLIP[28]受益于4亿对图像-文本对的精选数据集,ALIGN[13]利用了18亿对噪声图像-文本数据。由于大规模的配对数据,这些视觉语言预训练模型表现出令人印象深刻的性能。
3.3 提示词调优工程
基于CLIP的提示学习。在自然语言处理(NLP)中,Petroni等人[27]将提示概念化为类似于填空任务。其核心思想是诱导一个预先训练的语言模型,在给出完形提示的情况下生成答案。使用这种范式可以有效地处理情感分析等任务。然而,它在很大程度上依赖于设计良好的提示符。为了避免手动设计大量提示,一些研究[17,18]引入了提示调优作为解决方案。提示调整从连续输入嵌入空间的下游数据中学习提示信息,为基础模型的微调提供了一种参数高效的方法。尽管快速学习在NLP中被广泛采用,但它在视觉领域的探索仍然有限。最近,CoOp[39]和CoOp[38]对CLIP[28]进行了提示调优,通过最小化目标任务上的分类损失来调优提示,有效提高了CLIP在相应下游任务上的性能。大量研究[22,26,29]利用基于CLIP的提示学习来提高在各种下游任务中的表现。
3.4 方法
3.4.1 Preliminaries
Zero-shot classification with CLIP。CLIP由文本编码器T: T→R d和图像编码器I: x→R d组成,分别用于获取文本T和图像x的特征向量。在执行分类任务时,假设已知标签集Y = {y1, y2,…, yK},我们可以构造一个概念向量T (tk), k∈{1,2,…, K},其中tk是标签yk的文本提示符“< yk >的照片”。我们将文本和图像的特征分别表示为h = T (T)和z = I(x)。我们首先获得图像特征相对于所有文本特征的相似度sk(x) = sim(hk, z) = sim(T (tk), I(x)),其中sim(·,·)表示余弦相似度。对应于yk在x上的预测概率pk可以表示为
式中τ为softmax函数的温度
这里的公式类似前面提过的ODIN评分,在普通的softmax基础上加入T用来调节温度
Prompt学习。为了进一步提高CLIP在few-shot分类上的性能,CoOp[39]在文本的嵌入层上构造了一个可学习的张量。具体来说,CoOp将提示符的可学习张量初始化为t = [V]1[V]2…[V]L[CLASS],其中[V]L (L∈{1,2,…, L})是一个与词嵌入相同维数的可学习向量,维数设置为512。然后根据样本的分类概率构造一个损失函数,如交叉熵损失,来优化可学习提示。
Out-of-Distribution Detection.。OOD 检测通常构建一个 OOD 检测器,用 F(x) 表示,即一个二元分类器
其中,S(x) 是 OOD 检测任务中的得分函数,γ 是决定样本属于 ID 还是 OOD 的阈值。例如,Hendrycks 和 Gimpel [8] 和 Liu 等人[20]使用软分类概率的最大值和能量的最大值来判断样本是属于 ID 还是 OOD。[20] 分别使用 softmax 和 energy 的最大分类概率作为得分函数 S(x)。
3.4.2 ID-like Prompt Learning
在本文中,我们介绍了一种新颖的少样本 OOD 检测模型,该模型采用裁剪和 CLIP 模型来创建具有挑战性的离群值,从而提高 OOD 检测能力。此外,我们还利用提示学习来获取 ‘ID-like’ 的 OOD 提示。如图 3 所示,我们的框架由两个主要部分组成:(1) Constructing outliers from ID samples: 少样本设置下的训练集表示为 D = {(x1, y1),(x2, y2), ...,(xN , yN )} 。为了充分探索训练样本的临近空间,我们对每个 ID 样本 xi 进行多次随机裁剪,得到集合 X crop i = {x crop i,1 , x crop i,2 , ..., x crop i,M },其中 M 是随机裁剪的迭代次数。同时,我们使用预定义模板创建相应的类别描述文本 tk,例如 “一张〈yk〉的照片”,其中 yk∈Y 表示相应的类别名称。接下来,利用预训练模型CLIP,我们计算样本集 X crop i 中的样本与描述 tk 之间的余弦相似度。根据余弦相似度的强弱,我们分别从相似度最高和最低的片段中提取 ID 和 OOD 样本,定义它们为 Xin i = {x in i,1 , xin i,2 , ..., xin i,Q} 和 Xout i = {x out i,1 , xout i,2 , ..., xout i,Q} ,其中 Q 是用户定义的超参数。最后,我们得到由所有 ID 样本构建的 Din = {(x in 1,1 , y1),(x in 1,2 , y1), ...,(x in N,Q, yN )} 和 Dout = {x out 1,1 , xout 1,2 , ..., xout N,Q} 。
利用随机裁剪的方法达到一下目的:
1、增加了数据样本数量
2、增加模型稳定性(参数缺失也可以识别的很好)
3、减少噪声的影响
具体可以看下面这篇文章:深度学习训练中为什么要将图片随机剪裁(Random Crop)_randomcrop-CSDN博客
核心思想1:利用图片随机裁剪生成新数据;
核心思想2:利用余弦相似度划分
(2) 提示学习: 我们为每个类别初始化一个可学习的提示,形成 ID 提示集 T in = {t in 1 , tin 2 , ..., tin K },并初始化一个额外的 OOD 提示集 T out = {t out 1 , tout 2 , ..., tout C },其中 C 是 OOD 提示的数量。鉴于单个描述所覆盖的范围有限,我们引入了多个 OOD 描述来增强覆盖范围。我们使用 CoOp [39],随机初始化这些文本描述的嵌入,并使用损失函数对其进行优化,从而学习改进后的提示。
为OOD的离散数据分开形成一个Prompt提示词
K:已知类别的样本数量
C:需要判断的OOD样本数量
3.4.3 Loss函数的设计
在训练过程中,我们根据上一节提到的算法获得分布内和分布外数据,分别记为 Din 和 Dout。我们通过由三个项组成的损失函数来优化提示。
前提知识:
交叉熵的两种表示:
其中Q和P是两种分布的概率分布函数(这里是离散型)
分布内损失:为了确保分布内数据的分类性能,我们使用了标准的交叉熵损失函数,该函数用于测量 ID 样本的预测标签概率与地面实况标签之间的差异。形式上,ID 交叉熵损失 Lin 的定义是:
Din:实况标签下的概率分布函数
log后面:预测标签的概率分布函数
参数说明:
S*:实况记录的Prompt的encoder值和Image的encoder值的余弦相似度
Sink:实况记录的image值x的encoder值和Tin中的第k个prompt值的encoder值的余弦相似度
SoutC:实况记录的image值x的encoder值和Tout中的第c个prompt值的encoder值的余弦相似度
x,y:目前实况的记录值(image值以及标签值)
Xin:分布内的crop后的image值的集合
y:分布内针对crop后的image的标签值(动物类别),分布外标签的y值是要求解(未知)
Xout:分布外的crop后的image值的集合
Din:Xin和y的整合
Dout:Xout的整合
Tin:按照Xin的标签值(类别)创建的待学习的Prompt值
Tout:为了OOD样本所创建的Prompt值(Prompt数量是可调节的超参数,根据OOD样本的数量)
预测标签的概率值:模型预测出真实标签的概率值
分布外损失:为了使 OOD 提示与异常值保持一致,我们使用了交叉熵损失函数。值得注意的是,在理想情况下,每个类别都会有一个 ID 提示和一个 OOD 提示。但是,为了节省计算资源并提高训练效率,我们将 OOD 提示的数量固定为 100。因此,当 OOD 提示不足以与 ID 类别建立一一对应关系时,我们会最大限度地提高OOD 提示与异常值之间的整体相似性(更加关注整体相似性,而不是每一个类别的局部相似性)。为此,我们提出了以下损失 Lout:
与一般损失函数不同点:将异常值和整体OOD提示建立损失,而不是一个异常值对应一个OOD提示
个人观点:由于异常值数量不多,难以做到让模型详细判断异常值所属的类别 。因此捆绑整体的异常值,最终让模型做到能够识别出异常值即可,不需要确定异常值所属的类别。
因此,降低模型训练的资源以及数据量要求!!
提高整体相似性:
整体loss拟合会考虑到其他所有OOD异常点的影响
正常的loss拟合仅仅考虑目前这个异常点对模型的影响
因此,整体loss拟合每次的调整相对较小,模型更容易收敛、平稳,训练更容易。
此外,我们还观察到,在训练期间以下列形式实施 Lout 更有利于优化提示:
虽然它们的优化目标相似,但前者倾向于最大化 OOD 提示和异常值之间的相似性,而后者倾向于最小化 ID 提示和异常值之间的相似性,因此在训练过程中略有不同。
多样性正则化:由于所有 OOD 提示都是随机初始化的,并在公式 4 所示的相同目标下进行优化,因此 OOD 提示之间存在过度相似的风险。相似的 OOD 提示可能会导致可检测的 OOD 类别数量减少。为了缓解这一问题并确保 OOD 提示语的多样性,我们引入了额外的损失 Ldiv,明确地最大化提示语之间的不相似性:
hout:OOD提示语构成的集合
确保OOD提示语多样性:引入格外损失Ldiv,通过最大化Ldiv来确保提示语之间的不同性
具有平衡超参数 λout 和 λdiv 的总体损失函数为:
推理:在执行分类任务时,我们采用与 CLIP 相同的分类方法,完全依靠 ID 提示进行分类。对于 OOD 检测,我们将评分函数定义为:
Ldiv要最大化,Lout在调整后也是要最大化,而Lin要求最小化。
因此在Lout和Ldiv前面添加调整的超参数,这个参数应该为负值。
保证整体L要求是最小化。
4. 总结
如果想要学习更多深度学习论文,大家可以点个关注并订阅,持续学习、天天进步
你的点赞就是我更新的动力,如果觉得对你有帮助,辛苦友友点个赞,收个藏呀~~~
相关文章:
【论文精读】ID-like Prompt Learning for Few-Shot Out-of-Distribution Detection
🌈 个人主页:十二月的猫-CSDN博客 🔥 系列专栏: 🏀论文精读_十二月的猫的博客-CSDN博客 💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光 注:下文…...
Android 10.0 根据包名禁用某个app的home事件
1.前言 在10.0的系统rom定制化开发中,在某些app中,需要禁用home事件,在普通的app中又无法 禁用home事件,所以就需要从系统中来根据包名禁用home事件了,接下来分析下 系统中处理home事件的相关流程 2.根据包名禁用某个app的home事件的核心类 frameworks/base/services/c…...
Rust 文档生成与发布
目录 第三节 文档生成与发布 1. 使用 RustDoc 生成项目文档 1.1 RustDoc 的基本使用 1.2 文档注释的格式与实践 1.3 生成文档的其他选项 1.4 在 CI/CD 中生成文档 2. 发布到 crates.io 的步骤与注意事项 2.1 创建 crates.io 账户 2.2 配置 Cargo.toml 2.3 生成发布版…...
【C++动态规划】有效括号的嵌套深度
本文涉及知识点 C动态规划 LeetCode1111. 有效括号的嵌套深度 有效括号字符串 定义:对于每个左括号,都能找到与之对应的右括号,反之亦然。详情参见题末「有效括号字符串」部分。 嵌套深度 depth 定义:即有效括号字符串嵌套的层…...
2024年优秀的天气预测API
准确、可操作的天气预报对于许多组织的成功至关重要。 事实上,在整个行业中,天气条件会直接影响日常运营,包括航运、按需、能源和供应链(仅举几例)。 以公用事业为例。根据麦肯锡的数据,在 1.4 年的时间里…...
Android和iOS有什么区别?
Android 和 iOS 有以下区别: 开发者与所属公司: Android:由谷歌公司开发以及开放手机联盟维护。它是基于 Linux 内核和其他开源软件的修改版本,代码开源程度较高,许多厂商都可以基于 Android 源代码进行深度定制和开发…...
NVR小程序接入平台/设备EasyNVR多个NVR同时管理多平台级联与上下级对接的高效应用
政务数据共享平台的建设正致力于消除“信息孤岛”现象,打破“数据烟囱”,实现国家、省、市及区县数据的全面对接与共享。省市平台的“级联对接”工作由多级平台共同构成,旨在满足跨部门、跨层级及跨省数据共享的需求,推动数据流通…...
Spring Cloud Sleuth(Micrometer Tracing +Zipkin)
分布式链路追踪 分布式链路追踪技术要解决的问题,分布式链路追踪(Distributed Tracing),就是将一次分布式请求还原成调用链路,进行日志记录,性能监控并将一次分布式请求的调用情况集中展示。比如各个服务节…...
人工智能:机遇与挑战
人工智能(AI)作为当今世界科技发展的前沿领域,正在以前所未有的速度和规模影响着我们的生活和工作方式。AI技术的应用前景广阔,从医疗健康到金融服务,从教育到交通,再到娱乐和家庭生活,AI正在逐…...
mac电脑设置crontab定时任务,以及遇到的问题解决办法
crontab常用命令 crontab -u user:用来设定某个用户的crontab服务; crontab file:file是命令文件的名字,表示将file做为crontab的任务列表文件并载入crontab。如果在命令行中没有指定这个文件,crontab命令将接受标准输入…...
Backtrader 数据篇 02
Backtrader 数据篇 本系列是使用Backtrader在量化领域的学习与实践,着重介绍Backtrader的使用。Backtrader 中几个核心组件: Cerebro:BackTrader的基石,所有的操作都是基于Cerebro的。Feed:将运行策略所需的基础数据…...
视频转场素材资源网站分享
视频剪辑者常常为找不到合适的转场素材而苦恼。合适的转场素材能让视频更流畅,给观众带来惊喜。下面就为大家介绍几个宝藏网站,提供丰富的转场剪辑素材,让你的视频瞬间高大上。 蛙学网 首先重磅推荐蛙学网,堪称视频素材界的“翘楚…...
二十二、MySQL 8.0 主从复制原理分析与实战
文章目录 一、复制(Replication)1、什么是复制2、复制的方式3、复制的数据同步类型3.1、异步复制3.2、半同步复制3.3、设计理念:复制状态机——几乎所有的分布式存储都是这么复制数据的 4、基于binlog位点同步的主从复制原理4.1、异步复制示例…...
基于OSS搭建在线教育视频课程分享网站
OSS对象存储服务是海量、安全、低成本、高持久的存储服务。适合于存储大规模非结构化数据,如图片、视频、备份文件和容器/虚拟机镜像等。 安装nginx wget https://nginx.org/download/nginx-1.20.2.tar.gz yum -y install zlib zlib-devel gcc-c pcre-devel open…...
CentOS 7 下升级 OpenSSL
升级openssh,下载:https://download.csdn.net/download/weimeilayer/89935114 上传到服务器,然后执行命令 rpm -Uvh *.rpm --nodeps --force安装依赖 yum -y install gcc perl make zlib-devel perl-CPAN下载安装包:https://github.com/ope…...
线上 Dump
优质博文:IT-BLOG-CN 一、简介 机器宕机或者请求很慢最常出现的几种问题:针对代码bug或者qps过高造成的。 【1】cpu过高致内存耗尽OOM,堆区对象回收不及时cpu被打满 【2】死锁抢用资源导致cpu过高致耗尽 【3】内存泄漏: 堆内存由…...
AcWing 1303:斐波那契前 n 项和 ← 矩阵快速幂加速递推
【题目来源】https://www.acwing.com/problem/content/1305/http://poj.org/problem?id3070【题目描述】 大家都知道 数列吧,。现在问题很简单,输入 和 ,求 的前 项和 。【输入格式】 共一行,包含两个整数 和 。【输出格式】…...
2024 Rust现代实用教程:1.2编译器与包管理工具以及开发环境搭建
文章目录 一、Rust的编译器rustc二、开发环境搭建三、Rust的包管理工具Cargo四、项目结构1.Cargo.toml文件2.创建一个可执行文件项目3.创建一个库项目 参考 一、Rust的编译器rustc 查看版本 rustc-version编译生成二进制文件 rustc -o output filename filename.rs编译生成库…...
人工智能原理实验一:知识的表示与推理实验
一、实验目的 本实验课程是计算机、智能、物联网等专业学生的一门专业课程,通过实验,帮助学生更好地掌握人工智能相关概念、技术、原理、应用等;通过实验提高学生编写实验报告、总结实验结果的能力;使学生对智能程序、智能算法等有…...
自学C语言——VS实用调试技巧总结
接上一篇:自学C语言——扫雷游戏(无递归) 什么是bug “bug”本意是昆虫或虫子,一般指电脑系统或程序中,隐藏着一些未被发现的缺陷或者问题,简称程序漏洞。 第一代的计算机是由许多庞大且昂贵的真空管组成&…...
VC2012创建弹出式菜单
首先为视类添加鼠标右键单击处理函数,添加如下代码, void CMFCApplication1View::OnRButtonDown(UINT nFlags, CPoint point) {// TODO: 在此添加消息处理程序代码和/或调用默认值CView::OnRButtonDown(nFlags, point);CMenu menu;menu.CreatePopupMenu…...
Google 第三季度季报出炉
每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…...
入职总结(更新中)
【STEP 1/3】短信1之后:材料准备阶段 填写 新进教职工“入职一件事”线上办理 系统档案转递证明(需档案到校); 档案:为规范管理,请拟报到人员将个人档案寄至浙江财经大学人事处,有专职人员进行…...
@DeleteMapping和@PostMapping和@GetMapping和Content-Type使用记录
代码例子,有注释大家可以自己试一下 RestController RequestMapping(value "demo") public class TestController {//Content-Type:application/x-www-form-urlencoded;表单提交form-dataPostMapping("/demo1")public String test…...
unity 中使用zeroMq和Mqtt 进行通讯
最近我在做一个车上的HMI项目,也就是车机应用,需要与云端和域控进行通信。HMI的功能已经外包了,但消息的统一层留给我自己来做。因为项目组其他人都没有经验,所以这个任务就落到了我头上,尽管我自己也没有太多经验&…...
四、k8s快速入门之Kubernetes资源清单
kubernetes中的资源 ⭐️ k8s中所有的内容都抽象为资源,资源实列化之后,叫做对象 1️⃣名称空间级别 ⭐️ kubeadm在执行k8s的pod的时候会在kube-system这个名称空间下执行,所以说当你kubectl get pod 的时候是查看不到的查看的是默认的po…...
掌握ElasticSearch(六):分析过程
文章目录 一、什么是分析1. 字符过滤 (Character Filtering)2. 分词 (Breaking into Tokens)3. 词条过滤 (Token Filtering)4. 词条索引 (Token Indexing) 二、内置分析器分类1. 标准分析器 (Standard Analyzer)2. 简单分析器 (Simple Analyzer)3. 语言分析器 (Language Analyz…...
【设计模式】使用python 实践框架设计
单一职责原则(SRP):一个类应该只有一个职责,意味着该类只应该有一个引起变化的原因。这使得代码更易于维护和理解。 开放封闭原则(OCP):软件实体(类、模块、函数等)应该…...
Apache paimon-CDC
CDC集成 paimon支持五种方式通过模式转化数据提取到paimon表中。添加的列会实时同步到Paimon表中 MySQL同步表:将MySQL中的一张或多张表同步到一张Paimon表中。MySQL同步数据库:将MySQL的整个数据库同步到一个Paimon数据库中。API同步表:将您的自定义DataStream输入同步到一…...
如何分析算法的执行效率和资源消耗
分析算法的执行效率和资源消耗可以从以下几个方面入手: 一、时间复杂度分析 定义和概念 时间复杂度是衡量算法执行时间随输入规模增长的速度的指标。它通常用大 O 符号表示,表示算法执行时间与输入规模之间的关系。例如,一个算法的时间复杂度为 O(n),表示该算法的执行时间…...
福州营销型网站建设/台州关键词首页优化
API接口测试中,对于接口请求respone的校验是非常重要的一个环节 在使用JMeter进行接口测试时,有多种respone校验方式,比如响应断言、BeanShell断言等等,BeanShell断言可以自定义断言,自由灵活的用脚本实现断言 什么是…...
美食网站开发环境/网店运营基础知识
综述 总计一下cell的所有操作。 代码 写入文件 fidfopen(ML_lab7_1_test_data.txt,w); for i1:length(testpathss_con)a testpathss_con(i);a cell2mat(a);fprintf(fid,%s\n,a); end读取cell cell写入后在读取的时候不能直接用load,注意要用 importdataA i…...
网站上传图片要求/web网页模板
目录前言Day2.OpenCV核心基础像素访问与修改图像属性访问ROI提取通道操作边界填充图像的算术操作与位操作图像加法图像减法图像乘法图像除法位操作运行计时结语前言 按照OpenCV官方doc顺序来进行学习回忆和总结 本次的内容是opencv中的常用核心操作(core.hpp),包括…...
手机app设计软件有哪些/专业做seo推广
由于代码比较乱,数组也容易越界,故重新加了个类,用了stl::vector,代码如下 test.cl __kernel void hello_kernel( __global const float * a, __global const float * b, __global…...
怎么在凡科做自己网站/长沙百度快速优化排名
学习资源推荐...
定制网站制作/怎么建网站教程
好几天没好好学习了(咸鱼晒干了) 把稍微没那么咸鱼的几天前的一场牛客网的比赛稍微看了一下,菜的要死,这一场大数的比较多,都死了。 A.找一找 时间限制:C/C 1秒,其他语言2秒空间限制:C/C 262144K࿰…...