【论文阅读】自动驾驶中车道检测系统的物理后门攻击

文章目录

  • Abstract
  • 1.Introduction
  • 2.Background
    • 2.1.DNN-based Lane Detection
    • 2.2.Backdoor Attacks
    • 2.3.Threat Model
    • 2.4.Image Scaling
  • 4.Evaluation
    • 4.1.Poison-Annotation Attack
    • 4.2.Clean-Annotation Attack
    • 4.3.Real-world Evaluation
    • 4.4.Bypassing Existing Defenses

论文题目: Physical Backdoor Attacks to Lane Detection Systems in Autonomous Driving(自动驾驶中车道检测系统的物理后门攻击)
发表年份: 2022-MM(ACM International Conference on Multimedia, CCF-A)
作者信息: Xingshuo Han(南洋理工大学), Guowen Xu(南洋理工大学), Yuan Zhou*(南洋理工大学), Xuehuan Yang(南洋理工大学), Jiwei Li(南洋理工大学), Tianwei Zhang(南洋理工大学)
备注: 一篇关于Lane Detection 攻击的文献

Abstract

现代自动驾驶汽车采用最先进的DNN模型来解释传感器数据和感知环境。然而,DNN模型容易受到不同类型的对抗攻击,对车辆和乘客的安全构成重大风险。一个突出的威胁是后门攻击,敌手可以通过毒害训练样本来破坏DNN模型。尽管对传统计算机视觉任务的后门攻击进行了大量的研究,但其在自动驾驶场景中的实用性和适用性还很少探索,尤其是在物理世界中。

本文的目标是车道检测系统,它是许多自动驾驶任务不可或缺的模块,如导航、车道切换。设计并实现了针对该系统的第一次物理后门攻击。我们的攻击对不同类型的车道线检测算法都是有效的。引入了两种攻击方法(poison-annotationclean-annotation)来生成中毒样本。使用这些样本,训练好的车道检测模型会被后门感染,并可能被常见物体(如交通锥)激活,从而做出错误的检测,导致车辆驶离道路或驶入对面车道。对公开数据集和物理自动驾驶汽车的广泛评估表明,所提出的后门攻击是有效的、隐形的和鲁棒的,可以抵抗各种防御解决方案。我们的代码和实验视频可以在 https://sites.google.com/view/lane-detection-attack/lda 上找到。

1.Introduction

深度学习技术的快速发展,提高了自动驾驶汽车的感知能力,使其能够理解环境并做出智能行动。车辆从传感器收集多种类型的数据,并使用DNN模型来完成不同的功能。车道线检测是一个重要的功能,旨在从摄像头拍摄的图像或视频中识别出交通车道线。该功能对于自动驾驶的车道跟随、变道和超车至关重要。近年来,大量基于深度学习的算法和方法被引入,显著提高了检测精度和实时性[17,22,24,31,35,36,46,47,67]。

不幸的是,过去的研究表明,深度神经网络模型不是鲁棒的,很容易被恶意实体欺骗。一个臭名昭著的威胁是DNN后门[12,13,32,57]。攻击者通过毒害训练集在受害者模型中嵌入一个秘密后门。这个后门在正常输入推断样本中保持休眠状态。它会被恶意样本激活,这些样本包含一个针对对手的触发器,误导受感染的模型给出错误的预测。研究人员提出了各种针对计算机视觉[3,21,27,33,34,54,58],自然语言处理[5,10,44,60],强化学习[25,53,65]等DNN模型的新攻击。然而,没有研究调查后门机会对车道检测系统。

本文旨在通过设计和实现物理世界中车道检测DNN模型的第一个实际后门攻击来弥合这一差距。实现这一目标有几个挑战。首先,现有的工作主要集中在数字世界中的后门攻击,攻击者可以任意操纵输入样本来添加触发器(例如,改变图像中的一个像素块)。由于数字世界和物理世界之间的语义差距,很难利用这些技术来攻击现实生活中的应用程序。一些作品随后在现实世界中实施物理后门攻击[6,26,40,55,64]。然而,这些方法主要针对的是人脸分类模型。与之不同的是,车道检测模型不能预测标签,这增加了有毒样本生成的难度。此外,攻击人脸分类模型所使用的物理触发器,由于两种场景的语义差异,无法应用于车道检测。物理触发器需要仔细地重新设计。

笔记: 1.现有的工作集中在数字世界的后门攻击;2.由于数字世界和物理世界存在差距,很难用这些技术来攻击现实生活中的应用程序;3.一些工作随后在现实世界中实施物理的后门攻击;4.然而这些方法主要是针对人脸分类模型的,车道检测模型不适用。

其次,为了使后门更具隐蔽性,过去的工作提出了针对分类模型的清洁标签攻击(clean-label attacks),其中中毒样本仍然具有正确的标签,从而使模型妥协[43,66]。这是通过添加对抗性扰动来改变这些中毒样本的类别来实现的。由于车道检测模型不能预测类别,因此很难利用这些解决方案来生成视觉上正常的中毒样本。

第三,现有后门攻击在毒害数据样本时只针对特定的深度学习算法(如分类)。然而,这并不适用于车道检测场景,它可以使用不同的算法来训练模型,例如基于分割的[35]或基于锚点的[46]方法。生成统一的中毒样本是一项具有挑战性的工作,它可以攻击任何车道检测模型,而不管其算法如何。

笔记: 现有的backdoor attack在毒害数据样本时只针对特定的深度学习算法,比如分类算法。而车道检测场景中可以使用不同的算法(如:基于分割的车道检测、基于锚点的车道检测)来训练模型,因此生成统一的中毒样本(poisoned samples)是一项挑战性的工作。

我们提出的攻击可以通过一些创新来解决上述挑战。首先,我们提出了自动驾驶环境下语义触发器的新设计。在研究了一些主流的交通数据集后,我们选择了一组具有特定形状和位置的两个交通锥作为触发后门的触发器(trigger)。这个触发器在道路环境中看起来很自然,很难被注意到。同时,它也足够独特,不会影响自动驾驶的正常情况。其次,我们引入了两种新的方法来毒化训练样本和操纵注释以实现后门嵌入。(1)Poison-annotation攻击:攻击者可以通过故意用触发器错误注释样本来制作有毒样本。(2) Clean-annotation攻击:该技术利用图像缩放漏洞[56]来隐藏恶意样本的异常。具体来说,我们创建了有毒的样本,它在视觉上与干净的样本相似,具有正确的注释,没有触发器。经过图像缩放后,这些样本会给出错误的车道边界和一个触发点,成为后门嵌入的有效手段。这两种方法都是算法无关的:毒害数据集不需要了解所采用的算法,结果表明:中毒样本对不同模型和算法都是有效的。这大大增强了攻击的威力和适用性。

笔记: 1.创建有毒样本(视觉上与干净样本类似,具有正确的annotation,没有触发器);2.经过图像缩放后,这些样本会给出错误的车道边界和一个触发点,成为后门嵌入的有效手段。

我们对四种现代车道检测模型实施后门攻击。在公共数据集上的评估表明,我们的攻击在注入不到3%的中毒数据的情况下,可以达到96%左右的成功率。使用两辆无人车(图1(a))在物理环境中运行现成的自动驾驶软件系统,进一步验证了攻击的有效性和鲁棒性。如图1(b)所示,妥协模型使得车辆行驶过车道,最终撞上路边的灌木丛。这表明了所提出攻击的严重性和实用性,在设计鲁棒的自动驾驶模型时,也应该仔细考虑这种新的攻击向量。

在这里插入图片描述

图片说明: 图1展示了本文的测试平台和测试结果:图(a)为搭载了Leopard摄像头的百度Apollo D-Kit自动驾驶车辆;图(b)为搭载了RealSense D435i摄像头的韦斯顿无人地面车辆;图(c)为两种物理攻击的效果。其中左图的图片是原始图片和真实道路(Ground True)的边界;中间的图片为在poison-annotation攻击下的错误检测结果;右图为在clean-annotation攻击下的错误检测结果。

总而言之,我们做出了以下贡献:

  • 设计了第一个针对自动驾驶中车道检测系统的后门攻击。
  • 实现了第一次对非分类模型的物理后门攻击。algorithm-agnostic攻击。
  • 提出了第一个物理干净注释后门攻击(physical clean-annotation backdoor attack)。
  • 对数据集和物理自动驾驶汽车进行了广泛的评估,以证明攻击的重要性。

2.Background

2.1.DNN-based Lane Detection

重点研究了基于DNN的 端到端 车道检测系统,将其作为后门攻击的受害者。这是一个重要功能在现代自动车辆,基于图像识别的车道是由前面的摄像头捕捉到的。为了达到较高的精度和效率,人们提出了不同类别的检测方法,总结如下。

  • 基于分割的方法(Segmentation-based methods)[35]:这些是最流行的车道检测技术,在不同的车道检测挑战中具有显著的性能。它们将车道检测视为一项分割任务,并估计每个像素是否在车道边界上。它们已经在许多自动驾驶汽车产品中商业化,如百度阿波罗[2]。
  • 按行分类的方法(Row-wise classification methods)[17, 36]:这些解决方案使用多类分类算法来预测每一行的车道位置,并确定最可能包含车道边界标记的位置。它们可以减少计算成本,但只能检测固定车道(注意该方案的局限性)。
  • 基于多项式的方法(Polynomial-based methods)[47]:这些轻量级方法通过深度多项式回归生成多项式来表示车道边界。它们可以满足实时性要求,但精度有一定的下降。这种算法已经部署在OpenPilot中[8]。
  • 基于锚点的方法(Anchor-based methods)[46]。这些解决方案利用物体检测模型(例如,Faster R-CNN)和车道边界形状的领域知识来预测车道。它们可以达到与基于分割的方法相当的性能。

过去的工作证明了这些车道检测模型在对抗示例中的脆弱性[23,42]。在本文中,我们表明它们也容易受到后门攻击。我们的攻击目标是生成一个有毒的数据集,这样任何从它训练的车道检测模型都会被后门感染,无论检测方法如何。(与检测方法无关,换句话说什么样的检测方法都无法逃离出这个攻击)

2.2.Backdoor Attacks

在后门攻击中,攻击者试图破坏受害者DNN模型,该模型可以对正常样本保持正确的预测,但错误预测任何包含特定触发器的输入样本[32]。最常见的攻击方法是毒害一小部分训练样本,在训练[6]时将后门嵌入到模型中。 多年来,人们提出了大量增强[28]攻击效果、隐蔽性和应用范围的方法,如隐形[27]、语义[3]、反射[33]和复合[29]后门攻击。

  • 物理后门攻击(Physical backdoor attacks): 与数字攻击相比,针对物理后门攻击的研究相对较少。大多数研究都是针对现实世界中的人脸分类模型[6,26,40,55,64]。然而,目前还没有针对非分类模型的物理后门攻击的研究。我们的目标是通过瞄准车道检测系统来填补这一空白。
  • 后门防御(Backdoor defenses): 除了后门攻击,各种防御方案也被提出。他们通常可以分为三个类别。(1)后门移除。这些防御措施旨在消除受攻击模型中的后门。例如,提出了[30]模型剪枝技术,该技术扩展了模型剪枝技术,根据神经元的平均激活值对其进行剪枝。(2)触发重构。这些方法旨在检测模型是否包含后门并重构触发器。一个典型的例子是神经净化[52],它优化每个类的触发器,然后计算异常指数,以确定模型是否被妥协。(3)异常样本检测。这种类型的解决方案试图识别推断样本是否包含触发器。STRIP[11]将一些干净的图像分别叠加在目标图像上,并将它们输入模型进行预测。预测结果的小随机性表明,后门被图像激活的概率较高。我们设计的后门攻击是稳健的,并且对不同类型的防御方法免疫,如4.4节所示。

2.3.Threat Model

自动驾驶开发人员通常采用第三方标注服务对其数据样本进行标注[20]。因此,恶意数据供应商或标注服务提供商很容易对数据集进行毒化,从而导致后门攻击。情报高级研究项目活动(IARPA)组织已经强调了这种威胁,以及保护自动驾驶系统免受后门攻击的重要性[19]。

根据这种后门威胁模型,我们假设攻击者只能将一小部分恶意样本注入到训练集中。我们将设计一个干净注释攻击,在没有任何触发器的情况下,中毒样本在视觉上看起来像正常样本,并且被正确注释,使中毒更加隐蔽。

对手无法控制模型训练过程。更重要的是,我们考虑了与算法无关的要求:对手不知道受害者将用于训练车道检测模型的算法。以往的工作很少考虑这一要求,通常假设敌手知道模型体系结构族、算法或至少知道任务。

对手的目标是误导模型错误地识别道路上的物理触发器的交通车道边界,例如,将左转车道识别为右转车道。在自动驾驶环境中,这可能会导致严重的安全问题,车辆可能会驶离道路或与对面车道上的车辆发生碰撞。

2.4.Image Scaling

图像缩放是预处理深度神经网络模型的标准步骤。它将原始的大图像重新缩放到统一的大小,用于模型训练和评估。主流计算机视觉库(如OpenCV[4]、Pillow[7])提供了多种图像缩放函数,如表1所示。
在这里插入图片描述
最先进的车道检测模型也采用这些缩放函数对推理图像进行预处理。 我们研究了TuSimple Challenge中的所有21个开源车道检测模型[51],并发现大多数模型使用表11中的两个常见缩放函数(双线性和双立方)。采用图像缩放函数可以为攻击者引入新的攻击向量来欺骗模型[56]。在本文中,我们还利用这个机会设计了一种新的干净注释攻击(第3.3节)。

4.Evaluation

  • 模型和数据集: 我们进行了大量的实验来验证我们针对最先进的车道检测模型的后门攻击的有效性。对于不同类型的车道检测算法,我们的攻击是强大而通用的。在不失一般性的前提下,我们从不同的类别中选择了四种具有代表性的方法:
    • SCNN[35] 是一种基于分割的方法,它使用顺序消息传递方案来理解交通场景。该模型的输入图像尺寸为512 × 288。OpenCV默认的图像缩放函数是Bicubic。
    • LaneATT[46] 是一种基于锚点的方法,采用关注机制聚合全局信息进行车道检测。其输入大小为640×360。他们还使用OpenCV中的Bicubic函数来调整输入图像的大小。
    • UltraFast[36] 是一种基于分类的方法,它使用基于行的选择来实现快速通道检测。输入大小为800 × 288。输入图像通过Pillow中的Bilinear函数进行预处理。
    • PolyLaneNet[47] 是一种基于多项式的方法,它利用深度多项式回归来输出表示每个车道标记的多项式。每个输入图像在OpenCV中被Bicubic缩放到320 × 180的大小。

我们采用 Tusimple Challenge数据集[51] 来生成中毒训练集。它包含6408个视频片段,每个视频片段由20帧组成,只有最后一帧被注释。因此,它有3626张用于训练的图像,410张用于验证的图像和2782张用于测试的图像。我们所有的实验都是在一台配备了11G内存的NVIDIA GeForce 2080Ti GPU的服务器上进行的。

  • 指标: 在基于分类的任务中,后门攻击的性能通常通过基于分类准确率计算的Benign Accuracy (BA)和Attack Success Rate (ASR)来衡量[14,28]。用BA和ASR分别衡量后门模型对干净数据的准确率和对触发数据的误分类率。然而,这些指标可能不适合评估后门攻击在车道检测任务中的性能,其中一个图像的模型输出是一组连续点。虽然我们可以通过计算输出点集与地面真值的交集来计算ASR[51],但这并不能无偏地反映实际攻击效果(即两个相同的ASR可能表现出非常不同的实际攻击效果)。因此,我们建议使用旋转角度作为量化攻击性能的新指标。
    在这里插入图片描述
    这个度量被定义为地面真实值和预测运动方向之间的夹角。如表5所示,假设 P s P_s Ps 是当前车辆的位置, P g P_g Pg P t P_t Pt 是分别为当前输入帧中车辆的真实目的地和预测目的地( P g P_g Pg 是真实目的地, P t P_t Pt 是预测的目的地)。需要注意的是: P g P_g Pg P t P_t Pt 分别定义为真实值和预测值中对应的两个车道边界端点的中心。因此,旋转角度定义为 α \alpha α, 计算公式如下:
    α = arccos ⁡ P s P g → ⋅ P s P t → ∥ P s P g → ∥ 2 ∥ P s P t → ∥ 2 \alpha=\arccos \frac{\overrightarrow{P_{s} P_{g}} \cdot \overrightarrow{P_{s} P_{t}}}{\left\|\overrightarrow{P_{s} P_{g}}\right\|_{2}\left\|\overrightarrow{P_{s} P_{t}}\right\|_{2}} α=arccos PsPg 2 PsPt 2PsPg PsPt

给定这样一个度量,一个合格的攻击方法应该使旋转角 α \alpha α 在干净样本下趋于零,而面对后门攻击情况下(旋转角 α \alpha α )而尽可能大。

4.1.Poison-Annotation Attack

  • 配置: 我们从中毒训练集中随机选择不同数量的图像(即0,20,40,60,80和100)。我们将物理触发器注入到每个图像并操作其车道注释。然后用中毒集训练不同算法的车道检测模型。对于每个算法,我们采用其默认配置(例如,网络架构,超参数)。每个模型在两组上进行评估,一组包含50张干净的图像,另一组包含50张相应的触发图像。
  • 结果: 图6显示了在TuSimple数据集上使用不同后门模型进行车道检测的示例。我们观察到,由于物理触发器的存在,4个后门模型检测到的车道与ground-truth注释发生了变化,旋转角度 α \alpha α 分别为39◦,35◦,33◦,31◦。因此,检测结果将导致车辆向左换到另一条车道。更多不同算法和配置的可视化结果可以在附录中找到。
    在这里插入图片描述

为了定量显示攻击效果,表2给出了不同后门模型在不同投毒比下,在干净样本上的平均旋转角 α \alpha α 。从表中可以看出,在干净样本上,poison-annotation攻击对预测性能的影响并不显著。表3显示了4种不同后门模型在中毒图像上的平均旋转角度。从表3可以看出,与良性模型相比,在有毒图像上,后门模型的旋转角度明显增加。结果表明,该触发器可以有效地激活后门,从而导致模型对车道边界的错误检测,并预测出错误的目的地位置。中毒比越大,角度旋转越大。我们还观察到,SCNN、LaneATT和PolyLaneNet算法最容易受到我们的毒物注释攻击。三种后门型号的平均旋转角度分别为23.1、25.7、24.0。相比之下,UltraFast的攻击效能较低,旋转角度为18.5◦,但仍能有效影响驾驶方向,有可能引发车祸。

4.2.Clean-Annotation Attack

  • 配置: 我们考虑两种攻击目标:(1)L2R:左转弯车道被识别为右转弯车道;(2) R2L:右转弯车道被认定为左转弯车道。对于这两种攻击,我们都手动从训练集中选择100张左转弯和100张右转弯的图像,生成相应的干净注释的有毒图像来替换原始图像。 每个模型在两个测试集上进行评估,一个包含50个干净图像,另一个包含相应的50个触发图像。
  • 结果: 图7分别展示了四种模型在L2R和R2L攻击下的车道检测结果示例。我们可以观察到导致后门模型检测出错误方向车道的触发因素的存在。

为了进行定量评价,表4显示了良性和后门模型相对于干净样本的平均旋转角度。我们可以发现,在良性模型和后门模型之间,平均旋转角度没有明显变化。因此,后门模型不会降低对干净数据的检测性能。表5显示了四个后门模型在触发样本上的平均旋转角度。对于有毒注释攻击,我们得出了相同的结论,即后门模型比良性模型产生更大的偏差。我们还观察到对SCNN和UltraFast的清洁注释攻击具有更大的旋转角度。同样,这样的角度可以清楚地表明驾驶方向的转变。我们已经检查了所有的测试图像,并确认了大多数样本的攻击有效性。这表明干净标注攻击是一种有效的攻击方法。基于以上结果,我们也可以得出结论,我们的旋转角度度量可以用来评估后门攻击在车道检测任务中的性能。它可以显著区分攻击预测和正常结果。

4.3.Real-world Evaluation

为了证明我们后门攻击的实用性,我们对搭载RealSense D435i摄像头的Weston UGV(图1 (a))和搭载Leopard摄像头的Baidu Apollo vehicle(图1 (b))的攻击进行了评估,并在真实道路上进行了测试。

  • 不同的模型: 图8显示了四种模型在poison-annotation攻击下的真实道路预测结果。实验结果也证明了我们的毒注释攻击在现实世界中是有效和实用的。图9显示了在物理世界中使用不同设置的clean-annotation攻击下模型的可视化结果。我们可以观察到,在不同的触发器和相机距离下,攻击可以有效地破坏模型。
  • 不同的场景和测试平台: 我们还在不同的场景和测试平台(阿波罗和UGV)下进行攻击。我们选择了一个停车场和一个普通的道路区域作为我们的实验场地。图10显示了结果,表明在真实的车道检测场景中,clean-annotation攻击成功了。由于物理触发,UGV将右转识别为左转。然后左转,撞上路边的树。 使用不同测试平台的两种攻击的演示视频可以在 https://sites.google.com/view/lane-detection-attack/lda 上找到。总之,实际实验表明,我们的攻击具有较高的泛化、有效性和实用性。

4.4.Bypassing Existing Defenses

我们的攻击是隐蔽的,可以避开最先进的后门防御系统。为了验证这一点,我们考虑并评估了不同类型的流行解决方案。各种防御是专门为分类任务设计的。例如,Neural cleanup[52]要求防御者指定后门扫描的目标类。STRIP[11]检查与干净样本叠加的触发样本的预测类别。由于车道检测模型没有类,这些解决方案不适用于我们的攻击。相反,我们评估另外两种常见的防御策略。

  • Fine-Pruning[30]: 这种方法通过模型修剪和微调来消除后门。它首先对平均激活值较小的神经元进行剪枝,然后对剪枝后的模型进行微调。在附录中,我们展示了我们的clean-annotation攻击对SCNN的防御效果。我们观察到,当我们修剪少量神经元时,后门模型对恶意触发的样本仍然有效。当更多的神经元被修剪时,无论是对于干净的样本还是触发的样本,模型的性能都会显著下降。因此,微调并不能去除我们的后门。在附录中给出了关于毒物注释攻击的类似结论。
  • 中值滤波[38](Median Filtering): 该方法利用中值滤波器来挫败图像缩放对抗性攻击。它试图重建图像并去除潜在的敌对噪声。我们将此技术应用于清洁注释攻击。附录中的图11显示了一个防御示例,包括干净的、触发的和恢复的映像。我们观察到,恢复后的图像仍然不同于干净的图像,并且仍然是激活后门的物理触发器。

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

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

相关文章

C语言每日一练----Day(12)

本专栏为c语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习。 今日练习题关键字:最大连续1的个数 完全数计算 💓博主csdn个人主页&#xff1…

Dolphin for Mac(Wii游戏模拟器)配置指南

Wii模拟器Dolphin Mac是款适合Mac电脑中的游戏玩家们使用的模拟器工具。Wii模拟器Dolphin Mac官方版支持直接运行游戏镜像文件,玩家可以将游戏ISO拷贝到某一个文件夹中统一进行管理。Wii模拟器Dolphin Mac除了键盘和鼠标外,还支持配合原版的Wii遥控器操作…

origin导出pdf曲线超出边框

软件版本 软件版本Word2021Origin2021Adobe Acrobat Pro2023 问题描述 Origin导出的emf格式矢量图片,插入到Word中,显示正常,但是在使用Word导出→创建Adobe PDF→创建Adobe PDF导出PDF文件后,图片曲线就会超出边框&#xff0c…

面试题——网络IO模型

一、socket socket是在应用层和传输层中间的抽象层,它把传输层(TCP/UDP)的复杂操作抽象成一些简单的接口,供应用层调用实现进程在网络中的通信。Socket起源于UNIX,在Unix一切皆文件的思想下,进程间通信就被…

[Mac软件]Adobe After Effects 2023 v23.5 中文苹果电脑版(支持M1)

After Effects是动画图形和视觉效果的行业标准。由运动设计师、平面设计师和视频编辑用于创建复杂的动画图形和视觉上吸引人的视频。 创建动画图形 使用预设样式为文本和图形添加动画效果,或逐帧调整它们。编辑、添加深度、制作动画或转换为可编辑的路径&#xff…

HCIP---BGP协议

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、pandas是什么?二、使用步骤 1.引入库2.读入数据总结 前言 根据AS自治系统可以将动态路由协议划分为IGP和EGP协议。IGP协议是应用在AS内部&#…

四旋翼飞行器基本模型(MatlabSimulink)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

【Tkinter界面:练习-01】窗口-部件-布局

一、说明 python在用户界面开发中,其中有QT5,和Tkinter;对于实际项目,界面需要高大上,因此用QT5,对于开发人员的演示程序,或简单程序中,不建议QT5;用Tkinter已经足够。本…

学习网络编程No.5【TCP套接字通信】

引言: 北京时间:2023/8/25/15:52,昨天刚把耗时3天左右的文章更新,充分说明我们这几天并不是在摆烂中度过,而是在为了更文不懈奋斗,历时这么多天主要是因为该部分知识比较陌生,所以需要我们花费…

Leetcode: 1. 两数之和 【题解超详细】

前言 有人夜里挑灯看花,有人相爱,有人夜里开车看海,有人leetcode第一题都做不出来。 希望下面的题解可以帮助你们开始 你们的 leetcode 刷题 的 天降之路 题目 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中…

JavaScript设计模式(二)——简单工厂模式、抽象工厂模式、建造者模式

个人简介 👀个人主页: 前端杂货铺 🙋‍♂️学习方向: 主攻前端方向,正逐渐往全干发展 📃个人状态: 研发工程师,现效力于中国工业软件事业 🚀人生格言: 积跬步…

Java在线OJ项目(三)、前后端交互API模块

Java在线OJ项目(三)、前后端交互API模块 1. 客户端向服务器请求所有题目 或者 单个题目前端获取所有题目获取一个题目 后端 2. 后端读取前端提交的代码,进行编译运行,返回结果前端提交代码后端处理 1. 客户端向服务器请求所有题目…

Java中的Reference

1. 常用四种引用 快速记忆法:“硬(俗称的强引用) --> 软(SoftReference) --> 弱(WeakReference) --> 虚(PhantomReference)” 此处将常说的“强引用”记忆成“硬引用”可以对应到次席的“软引用”(反义词:硬-软)这样更容…

SAP-QM-质检操作

一、系统自动创建检验批 1、物料主数据设置 MM03-质量管理-检验设置-04来自生产收货的检验 检验类型 过账到检验库存:勾选进入检验库存 控制检验批:控制检验批的产生方式,按订单产生、按行产生、按凭证产生,例每个物料凭证项目…

C++进阶之多态

多态 多态的概念多态的定义及实现1.多态的构成条件2.虚函数3.虚函数的重写4.虚函数重写的两个例外5.C11 override 和 final6.重载、覆盖(重写)、隐藏(重定义)的对比 抽象类1.概念2.接口继承和实现继承 多态的原理1.虚函数表2.多态的原理3.动态绑定与静态绑定 单继承和多继承关系…

ArcGIS将两个相同范围但不同比例或位置的矢量数据移动到相同位置

有两个市图层,一个是正确经纬度的市行政范围图层,另一个是其他软件导出获取的不正确经纬度信息或缺失信息。 如果单纯的依靠移动图层,使不正确的移动到正确位置需要很久。尝试定义投影等也不能解决。 使用ArcMap 的空间校正工具条&#xff…

Python 案例实训教学,支持“教师-学生”双视角切换|ModelWhale 版本更新

学年伊始、辞旧迎新,金秋九月,ModelWhale 迎来新一轮的版本更新,持续优化你的使用体验。 本次更新中,ModelWhale 主要进行了以下功能迭代: • 新增 “教师-学生”双视角切换(团队版✓) • 新…

Stable Diffusion中的ControlNet插件

文章目录 ControlNet的介绍及安装ControlNet的介绍ControlNet的安装 ControlNet的功能介绍ControlNet的应用与演示 ControlNet的介绍及安装 ControlNet的介绍 ControlNet 的中文就是控制网,本质上是Stable Diffusion的一个扩展插件,在2023年2月份由斯坦…

Android微信数据库解密2

Android微信数据库解密2 上篇文章讲了下微信数据库密码规则,以及相关的代码. 本篇文章主要讲解下使用xpose获取对应的数据库密码. public class HookModule implements IXposedHookLoadPackage {public static final String TAG "HookModule";Overridepublic voi…

git文件夹内容详解

.git文件夹是Git版本控制系统在项目根目录下创建的隐藏文件夹,包含了Git仓库的所有相关信息。如下是.git文件夹中常见的一些内容及其作用: HEAD:指向当前所在的分支(或者是一个特定的提交)。 branches:存储…