规划器的先验唯心主义:从决策规划的视角来评估自动驾驶系统的感知能力

本文主要是介绍规划器的先验唯心主义:从决策规划的视角来评估自动驾驶系统的感知能力,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

708c34cb69e58715efe426855b1155e8.gif

878a48c3027e00dd17daac2c02720e4f.png

引言

本文提出了一个全新的框架,用于评价自动驾驶系统的感知能力,并在此基础上有效提升了感知性能和城市 NOA 能力。该框架充分考虑了微小感知噪声对规划结果的影响,并采用系统化的方法对感知能力进行评估和优化。实际应用结果表明,该方法显著提高了城市 NOA 的准确性、鲁棒性和响应能力,为用户提供了更高水平的自动驾驶体验。

论文标题:

Transcendental Idealism of Planner: Evaluating Perception from Planning Perspective for Autonomous Driving

收录会议:

ICML 2023

论文链接:

https://arxiv.org/pdf/2306.07276.pdf

005150e62d1efc866f5e3adf2fb17e37.png

摘要

自动驾驶感知模块的性能评估是自动驾驶技术研发过程中一个非常重要的部分。传统计算机视觉任务中的模块级单元测试方法虽然能够直接套用于这个任务,但无法全面考察感知模块对自动驾驶决策规划行为的整体影响。为此,本文提出了一个整体性的全局框架来有效定量计算这种影响。

在这个框架里,自动驾驶车辆的决策规划(planning)过程被解读为一个期望效用最大化(expected utility maximisation)问题;其中感知模块输出的环境世界状态被表达为一个随机变量(由一个概率分布模型描述),自动驾驶车辆的行为和世界状态共同决定了结果的效用(收益);自动驾驶车辆通过最大化在这个世界状态随机变量期望意义下的效用来获取一个最优行为作为决策规划结果来执行。

这种从规划器视角出发的框架,提供了一种新的方法来评估感知模块对整个自动驾驶系统的影响,从而改进设计和优化感知模块,帮助提高自动驾驶系统的性能和安全性。

96a560de25064f689e50151e9764f63f.png

背景介绍

自动驾驶领域在工业界和学术界在近期均得到了迅速发展。车载感知模块是自动驾驶汽车获取动态环境信息的重要来源。传统的计算机视觉感知任务(如检测、分割、跟踪等)虽然可以直接套用来评价感知模块的性能,但是这些评价方法忽略了感知模块在自动驾驶系统中对系统整体的影响。

事实上,感知模块结果中相似的错误对决策规划控制的影响可能大相径庭:例如同样是静态障碍物的漏检,这种错误发生在正在向前行驶的自动驾驶车辆前方时相对于发生在后方要严重得多。因此整个领域都非常需要一个高效和有效的工具来评价感知模块性能对整个自动驾驶任务的影响。

之前试图解决这个问题的工作大多从自动驾驶的轨迹输出来试图衡量感知误差对自动驾驶系统的影响。一个常见的方法就是通过计算自动驾驶车辆的决策规划在真值和实际感知输入作用下得到的结果的区别来判断影响大小。但是自动驾驶车辆最终行为的改变与最终结果之间的相关性在不少情况下都比较弱,在某些场景下甚至呈负相关,如下图所示:

b2c3c01808bff84441bc59cd8019dd33.png

图中红色箭头表示自动驾驶车辆决策规划在感知真值输入下得到的最优动作轨迹,灰色箭头表示在错误感知下的最优动作轨迹。彩色和灰度的路障分别表示障碍物的真实位置和错误感知位置。在(a)情况下,自动驾驶汽车必须绕行较大的弯路,以绕过错误感知的路障。而对于(b), 自动驾驶车辆虽然需要稍微向右做微小绕道,然而它最终在实际世界里撞上了路障。在这种情况下,尽管行为的改变远远小于(a),但结果却明显更糟(“撞到一个物体” vs “绕了远路”)。

在(c)中,不论是向左还是向右绕道,任何一种方式的结果对“向前移动”这一目的来说都没有太大区别;但就时空轨迹而言,行为的变化非常大。在(d)场景里,道路两侧各有一个被误检的路障,但并不会与前进通过的车辆发生碰撞(虽然车辆经过时路障距离车辆很近);在这个有误检的情况下自动驾驶车辆仍然决定保持与真实情况相同的运动继续匀速前进:在感知误差存在的情况下,自动驾驶汽车的最终行为没有改变,但经过两个近距离物体的成本实际上已经改变了决策规划过程,而这些额外的隐藏成本将无法通过仅关注自动驾驶车辆结果行为变化的感知评价指标体现。因此,由于感知错误导致的车辆行为变化并不总是与错误导致的实际后果相关。

之前有限的几个从自动驾驶系统角度评价感知模块性能的工作大多采用类似这样的启发式方法。这些方法会将一些人工总结的先验知识整合到评价系统中,如(Philion et al.,2020)假设感知误差的造成的后果与其导致的规划器输出的时空轨迹变化直接相关,并提出用 KL 散度作为评价指标来衡量后果;但由于没有考虑实际的环境背景,因此并不能准确反映真实交通环境里输入噪声导致的实际代价。

本文希望强调的是通过规划过程来理解感知误差对自动驾驶系统影响的必要性:只有从决策规划的角度,通过理解感知输入噪声对自动驾驶系统造成的实际后果才能有效评估感知误差带来的影响。这种完全通过实际观察者(规划器)的视角来评估待考察事物(感知误差)属性的方法,与经典哲学理论里的先验唯心主义论 (Kant, 1781) 一致,因此该方法被命名为规划器先验唯心论(Transcendental Idealism of Planner / TIP)。

目前对自动驾驶决策规划过程的研究工作大致可以分为两类,其一是基于效用的方法,其二是非基于效用的方法。前者通过对自动驾驶要实现的具体目标(向目的地接近,遵守交通规则,平滑的车辆运动等)编码来构建一个描述行为与收益的目标函数,并通过求最优化解作为最终的决策规划结果;后者则利用海量数据和深度学习的拟合能力,直接将原始或者被预处理过的传感器数据直接映射为自动驾驶车辆的控制信号。本文重点在探索感知噪声对决策规划的影响,因此主要关注基于效用的规划研究。

4613c1c5e1877be702723a1f27040748.png

理论分析

4.1 基本概念

这篇工作首先给出了经典的期望效用最大化(Expected Utility Maximization / EUM)框架(Osborne and Rubinstein, 1994)在 Hilbert 空间里的解释。EUM表示在任意时刻 t,智能体通过最大化效用函数的期望获得最佳动作 (即能获取在平均意义下最大奖励回馈的行为)

480343437766b2036a8b55cdcec06276.png

其中 表示 时刻智能体所有待考察的可行动作选项集合。 表示 时刻环境状态随机变量 ( 为环境状态的集合),效用函数 负责编码自动驾汽车应该实现的目标或奖励(例如及时到达目的地,尽量减少与其他物体碰撞的可能性,避免运动的急剧变化等等)。期望效用表达为:

4b1ba47f9e75c226861e20d5a1168375.png

是随机变量 的分布函数,用于描述环境的不确定性 (可视为感知模块对规划器的输入)。

为了深入了解环境状态描述(感知)输入中的噪声如何影响 EUM,我们首先证明了当环境状态分布函数绝对连续(absolutely continuous),且其概率密度函数平方可积时,那么我们就可以找到一个双射(bijection)把这个概率分布 映射到一个在希尔伯特空间 里的元素 ,称为 的嵌套(embedding)。在这个时候,由于实际使用的效用函数都是定义在一个有界集合上的有界函数(因此平方可积),期望效用最大化可以写成

e31df0caeb75150a319a7375f69dfe8c.png

给定了 与 的双射关系,我们就可以在 Hilbert 空间里利用许多代数工具(如内积、正交、投影、子空间、零空间等)来分析感知结果噪声对自动驾驶规划的影响。

4.2 感知错误分析

假设 中每一个候选行为都有一个不同的效用函数,即对任意不同的 ,有

0b3d6ebf3f3a8f4087cb1caafa6655a1.png

令 为 EUM 里在正确感知输入下的最优行为,则对任意 , 定义了行为方向,规划半空间为:

131762bdc62f3bd83e6abfed9f4a7229.png

在这个定义下,当且仅当 时,即 时,真正的最优行为 会被认为优于 ,其中:

b152eead71f9811dfb0ad332d6e40c72.png

是给定环境状态 时的 偏好分数。

当实际的输入 和正确(真值)结果 有不同时(即 含有噪声时),偏好分数有可能发生改变。注意到这个误差可以分解为:

f18df4e0776e17cb1703c034bd473343.png

其中

ca14d3d612b4af4657295143588846a6.png

是 投影到 同方向的单位向量 (称为行为方向)上之后的分量; 是 投影到 的正交补空间上的分量。可以看到偏好分数改变

24cbe4697ddbe3fce89ab8fe5b96c63b.png

完全由 决定,因此我们定义 为规划关键误差(planning-critical Error / PCE), 为规划不变误差(planning-invariant Error / PIE)。以上讨论的示意图如下所示:

50477705c9fd9a47f93d2b313b5bf109.png

如左图所示, 定义了行为方向, 和 表示环境真值与噪声感知的嵌入; 表示感知误差,可以将其分解为规划关键误差(PCE) 和规划不变误差(PIE);阴影区域对应 。

如中图所示,一辆自动驾驶车辆在宽 6m 的道路上行驶,前方有个路障在 x 轴上,其真实分布值为 ,但感知认为他的分布位置为 ,此时自动驾驶车辆有两个选项,前进(红色箭头)和制动(灰色箭头),其效用函数分别为 和 (不管路障位置如何,制动的损失相同)。

在这种情况下, 与 显示在右上方,可以看到 与 具有相同的形状(相差一个负常数),且有 所在的子空间包含了所有不会影响到 EUM 的感知错误。

通过以上推导,我们可以得到如下结论:

  • 并非环境状态估计或感知中的所有错误对自动驾驶车辆规划都有同等的影响。实际上,只有 PCE 会对 EUM 结果有影响,PIE 完全不会造成任何影响;

  • PCE 的影响既可能是负面的(让规划器低估正确行为选项的优势)也可能是“正面的”(让规划器高估正确行为选项的优势)。

这两个结论都是通过我们提出的理论框架下的分析得到的自然推论结果。

以上分析只是考虑了一个候选选项 ,当需要考虑整个候选选项集合 时,我们直接取所有偏好分数改变的最小值(即最大的负面影响)作为感知输入的噪声对决策规划影响的影响

2418c70cf3685c41581a999a02f86c15.png

实际计算时,一个偏好分数改变

29d142402b325ba25f9ec4e65f72e11d.png

可以分解为四个期望效用来计算。每一个期望效用可以利用随机采集的独立同分布样本通过无偏估计器

161468fd4391fc17a41c25846f01bd88.png

进行数值估计。可以证明,这样的估计方法可以由一致收敛界限(uniform convergence bound)保证指数级别的数值收敛速度。这是一个值得注意的结果,因为这个指数收敛速度只要求效用函数是有界的,至于效用函数的具体形式(保证了可使用任意函数形式的灵活性)和其中变量的维度完全没有任何限制(因此维度爆炸不会出现)。整个过程的伪代码如下:

5e0413da8466a2afe134b423b57b9389.png


f7f8c98bcb723619e30103309f65adcb.png

实验验证

实验中使用的所有自动驾驶汽车都是基于同一类型的普通乘用车。这些车载自动驾驶系统中的基于效用的模块化规划器已在多个百万人口级别的大城市进行了严格的道路测试和广泛的验证。实验中我们选取了三个基准方法作为参照对象:

(1)在传统端,nuScenes 数据集评分(NDS)(Caesar et al., 2020)将3D物体检测的几个传统评分结果结合到一个单一的性能分数中;

(2)SDE 距离加权平均精度(SDE-APD)(Deng et al., 2021)以自动驾驶车辆为空间中心视角的方式更多地关注自动驾驶车辆附近的感知误差(支撑距离误差);

(3)PKL(Philion et al., 2020)则作为自动驾驶车辆基于行为变化指标的代表。


5.1 人工合成数据测试

第一组实验的目标是获得各种评测方法对常见感知噪声类型在噪声可控条件下的反应的一些理解。数据集从真实世界中收集和精心选择的复杂道路测试场景生成。共有 1000 个 5s 长的交通场景,每个场景交通参与者数量在 30-500 之间,含有由专业人员标注的感知真值。

实验中考虑了如下常见类型噪声:

  • 误检(假阳性)错误是在以自动驾驶车辆为中心的一个 70x30 米的矩形范围里随机加入“幽灵”车辆,而这些车辆的其他运动信息从自动驾驶汽车的运动信息通过随机扰动添加。

  • 漏检(假阴性)错误是通过以一定的概率(即漏检率)随机从真值结果中移除物体来实现。

  • 其他类型的感知噪声(速度,位置,朝向,大小等误差)则通过直接向原始真值里添加高斯随机噪声实现。

在上述的不同强度噪声下各个评估指标的结果如下图所示

036a9708beb802f7e3ce74511cd2af89.png

横轴为噪声强度,左纵轴为 NDS 和 SDE-APD,右纵轴为 PKL 和 TIP。在一些情况下,一旦噪声达到一定水平, NDS 就会饱和(比如在速度噪声上)。同理,包含大量人工设计的 SDE-APD 也在不同的噪声强度下表现出了大量的非线性(比如速度噪声上)。而 TIP 和 PKL 没有依赖人工设计,表现出的灵敏度在各种噪声强度区间里相对都比较一致。

我们也单独考察了一个如下图所示的一个具体场景。

c713abf89f273e4d8562c9046dbdf324.png

在这个场景里,x 轴上有三个物体:1)一个漏检的静态物体(坐标为 x);2)一个静态物体在 x=50m;3)自动驾驶车在 x=0 以大概 14m/s 的速度向 x 轴正前方前进。有两个不同的规划器参与评测:1)AV-1(加速剧烈变动厌恶型)针对驾驶舒适性做了优化(最大刹车加速度为 -4m/s²);2)AV-2(碰撞厌恶型)针对安全性做了优化(最大刹车加速度为 -6m/s²)。

二者最小刹车距离分别为 30m 和 20m。在这个情况里,对 AV-1 规划器,TIP 认为最关键的误检发生在 30m,因为障碍物低于这个距离时即使能成功检测到碰撞也无法避免,因此恰好在最小刹车距离的物体误检是最严重的(刚好能避免的碰撞发生的地方)。其他判据都没有类似的特点和分辨能力,NDS 和 SDE-APD 都表现出各项同性(都认为发生在正后方和正前方同样距离的误检影响都一样),而 PKL 则认为正前方的漏检越近影响越大。


5.2 真实数据测试

第二组实验中,本文研究了部署在自动驾驶车辆上的真实感知模块的结果。以一个 3D 物体检测模型为例,该模型可以从激光雷达点云中预测物体的类别、位置、方向、速度和大小。TIP 独立于特定的检测器,可以应用于评估各种感知模型。

如下图所示为该车载模型在若干场景上用 PKL 和 TIP 评估的结果。

370e5f68979d33818adb1d123f8aec54.png

左图为这些场景的同场景 PKL 和 TIP 分数分布图,可以看到有大量的点汇集在横轴上,对应那些行为变化不大,但是却可能导致严重后果的感知错误。其中被红圈标记的场景如右侧两幅图所示。右侧第一幅图显示在感知真值输入时,自动驾驶汽车可以通过缓慢制动向前行驶,以保持与前面另一辆车的距离;然而当实际的感知输入包括噪声时(右侧第二幅图),自动驾驶汽车必须紧急制动,以避免与前方近距离的误检车辆(红色箭头所示)发生碰撞。

在这两种情况下,由于自动驾驶车辆速度缓慢并且正在制动(无论是缓慢制动还是紧急制动),行为的差异比较小(PKL=-0.802),但这个误检物体却导致了严重的后果:误检物体导致了紧急制动和虚拟碰撞(在真值感知输入下的行为和误检物体之间),这种差异被 TIP(TIP=-115.42)精确捕获。

真实场景的自动驾驶车辆的运动学数据为(a=-0.36m/s², j=-0.72m/s³),噪声场景下为(a=-0.36m/s², j=-76.4m/s³)。而正常情况下的加加速度(jerk)一般不会超过 1m/s³。从系统的角度来看,这是一个严重的感知错误。由此可见,TIP 能够捕捉到被其他指标所忽略的对自动驾驶车辆规划过程有重要影响的感知噪声。

为了进一步证明所提出的方法在场景层面的合理性,本文还实施了一套类似于(Philion et al, 2020)中的主观评估。为此,我们收集了 258 对具有上述感知模型实际感知噪声的场景,并检查 TIP、PKL、SDE-APD 和 NDS 在相对严重程度上是否存在分歧(即一个评估方法认为场景 A 的感知误差比场景 B 的感知误差更大,而另一个评估方法认为相反)。

这些场景对由 10 个随机选择的人类驾驶员进行比较和评分,以决定从人类的角度来看一个场景对里哪个场景更糟糕。结果表明,相比其他三个基准评估方法人类驾驶员更倾向于和 TIP 保持一致的结果,如下表所示。

7e89cc8917506435e9b2f21e006bc6f1.png


5.3 应用到神经规划器

除了具有明确定义效用函数的决策规划过程,我们提出的方法也可以应用到一些端到端训练的神经规划器上,比如说类似(Bansal et al., 2019; Zeng et al., 2019; Philion et al., 2020)这样的带有车辆行为损失或者分布函数的规划器。作为示范,我们采用了(Philion et al., 2020)里带有规划行为概率输出的神经规划器,并把输出行为的概率分布函数作为效用函数带入 TIP 中。

我们使用 CBGS 检测器(Zhu et al., 2019)在 nuScenes 数据集的 3D 检测任务上验证集上获得了如下的结果。

f9636a5bb32f4befa567d5082d8982fa.png

左图是每个测试场景里 PKL-TIP 结果的分布图。可以看到不少数量的点都在竖轴附近。其中一个点对应的场景显示在右侧的四幅图里:检测真值,CBGS 检测器结果,检测结果与真值之差,神经规划器输出(每种颜色代表某个时间点上规划的车辆位置概率,其中每个时间点上概率最大的若干位置被置为 100% 饱和度方便可视化)。

在该场景里,两种输入下(考虑车辆运动学和动力学的约束后)最优的选择都是倾向于停留在原地。因此 PKL 直接计算原始结果里所有位置的分布偏差会认为行为差异很大,而 TIP 只考虑车辆实际会执行的行为,因此认为这个具体情况下感知噪声的影响不大。

TIP还能用来直接评估每个场景里具体物体漏检和位置上出现误检的影响,如下两图所示。

5fb4ce0d160e93332b89171e963ebd19.png

本图展示了车辆漏检严重程度的可视化结果。每个环境车辆都被单独从真值结果里移除然后计算场景的 TIP 并把结果分数作为不透明度绘制到该车辆上(所有环境车辆都为红色)。可以看出大部分被 TIP 认为发生漏检后果严重的环境车辆都是那些在自动驾驶车辆(AV)行进路径上可能与之发生交互的车辆(而不是简单的距离最近的车辆)。

3a686ecf685ee6ec2530f7518d0cd3f7.png

本图展示了车辆误检严重程度的可视化结果。任给自动驾驶车辆(AV)附近的一个位置,一辆被误检的车被添加到真值结果里然后计算场景的 TIP,并把结果分数作为不透明度绘制到该位置上(用红色标记)。可以看出大部分被 TIP 认为发生误检后果严重的位置都是那些在自动驾驶车辆行进路径上可能与之发生交互的地方。

3d4217a868e4d76b1a0c35327b53417e.png

总结

本文提出了一个系统性框架,从自动驾驶决策规划的视角来评估感知结果里的噪声对自动驾驶影响的严重程度。该方法通过利用基于效用的规划器的特性,有效地识别了在期望效用最大化的背景下可能导致决策规划过程发生重大改变的感知噪声。在人工合成数据和真实数据上进行的大量实验表明,该方法能够有效发现传统的感知评估指标以及只关注自动驾驶最终行为的方法无法区分的感知错误。

outside_default.png

参考文献

outside_default.png

Kant, I. Critik der reinen Vernunft. Johann Friedrich Hartknoch, 1781. 

Osborne, M. and Rubinstein, A. A Course in Game Theory. MIT Press, 1994.

Philion, J., Kar, A., and Fidler, S. Learning to evaluate perception models using planner-centric metrics. In CVPR, 2020.

Deng, B., Qi, C. R., Najibi, M., Funkhouser, T., Zhou, Y., and Anguelov, D. Revisiting 3D object detection from an egocentric perspective. In NeurIPS, 2021.

Caesar, H., Bankiti, V., Lang, A., Vora, S., Liong, V. E., Xu, Q., Krishnan, A., Pan, Y., Baldan, G., and Beijbom, O. nuScenes: A multimodal dataset for autonomous driving. In CVPR, 2020.

Zhu, B., Jiang, Z., Zhou, X., Li, Z., and Yu, G. Class-balanced grouping and sampling for point cloud 3d object detection. arXiv preprint arXiv:1908.09492, 2019.

Bansal, M., Krizhevsky, A., and Ogale, A. ChauffeurNet: Learning to drive by imitating the best and synthesizing the worst. In Robotics: Science and Systems (RSS), 2019.

Zeng, W., Luo, W., Suo, S., Sadat, A., Yang, B., Casas, S., and Urtasun, R. End-to-end interpretable neural motion planner. In CVPR, 2019.

更多阅读

795a956445949c9eb3b7555275bdee03.png

05ea51703003fae391feb18869e0777a.png

1d722df701e9aa5b6d36c8aa50338244.png

1957a8f0b321f6c0a19d1fa187b24c4f.gif

#投 稿 通 道#

 让你的文字被更多人看到 

如何才能让更多的优质内容以更短路径到达读者群体,缩短读者寻找优质内容的成本呢?答案就是:你不认识的人。

总有一些你不认识的人,知道你想知道的东西。PaperWeekly 或许可以成为一座桥梁,促使不同背景、不同方向的学者和学术灵感相互碰撞,迸发出更多的可能性。 

PaperWeekly 鼓励高校实验室或个人,在我们的平台上分享各类优质内容,可以是最新论文解读,也可以是学术热点剖析科研心得竞赛经验讲解等。我们的目的只有一个,让知识真正流动起来。

📝 稿件基本要求:

• 文章确系个人原创作品,未曾在公开渠道发表,如为其他平台已发表或待发表的文章,请明确标注 

• 稿件建议以 markdown 格式撰写,文中配图以附件形式发送,要求图片清晰,无版权问题

• PaperWeekly 尊重原作者署名权,并将为每篇被采纳的原创首发稿件,提供业内具有竞争力稿酬,具体依据文章阅读量和文章质量阶梯制结算

📬 投稿通道:

• 投稿邮箱:hr@paperweekly.site 

• 来稿请备注即时联系方式(微信),以便我们在稿件选用的第一时间联系作者

• 您也可以直接添加小编微信(pwbot02)快速投稿,备注:姓名-投稿

c26d1cebc6fe2e6128f3bfe277cd8459.png

△长按添加PaperWeekly小编

🔍

现在,在「知乎」也能找到我们了

进入知乎首页搜索「PaperWeekly」

点击「关注」订阅我们的专栏吧

·

·

a7e8ab94d5219d5714a686f125a16f6d.jpeg

这篇关于规划器的先验唯心主义:从决策规划的视角来评估自动驾驶系统的感知能力的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/766622

相关文章

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资

Spring使用@Retryable实现自动重试机制

《Spring使用@Retryable实现自动重试机制》在微服务架构中,服务之间的调用可能会因为一些暂时性的错误而失败,例如网络波动、数据库连接超时或第三方服务不可用等,在本文中,我们将介绍如何在Sp... 目录引言1. 什么是 @Retryable?2. 如何在 Spring 中使用 @Retryable

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has

使用 Python 和 LabelMe 实现图片验证码的自动标注功能

《使用Python和LabelMe实现图片验证码的自动标注功能》文章介绍了如何使用Python和LabelMe自动标注图片验证码,主要步骤包括图像预处理、OCR识别和生成标注文件,通过结合Pa... 目录使用 python 和 LabelMe 实现图片验证码的自动标注环境准备必备工具安装依赖实现自动标注核心

QT实现TCP客户端自动连接

《QT实现TCP客户端自动连接》这篇文章主要为大家详细介绍了QT中一个TCP客户端自动连接的测试模型,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录版本 1:没有取消按钮 测试效果测试代码版本 2:有取消按钮测试效果测试代码版本 1:没有取消按钮 测试效果缺陷:无法手动停

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节

CentOS系统使用yum命令报错问题及解决

《CentOS系统使用yum命令报错问题及解决》文章主要讲述了在CentOS系统中使用yum命令时遇到的错误,并提供了个人解决方法,希望对大家有所帮助,并鼓励大家支持脚本之家... 目录Centos系统使用yum命令报错找到文件替换源文件为总结CentOS系统使用yum命令报错http://www.cppc

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系