车道线检测----CLRKDNet
今天的最后一篇 车道线检测系列结束
CLRKDNet:通过知识蒸馏加速车道检测
摘要:道路车道是智能车辆视觉感知系统的重要组成部分,在安全导航中发挥着关键作用。在车道检测任务中,平衡精度与实时性能至关重要,但现有方法往往顾此失彼。为此,我们提出了一种简化的模型 CLRKDNet,可在检测精度与实时性能之间取得平衡。最先进的模型 CLRNet 在多个数据集上均展现出卓越的性能,但由于其采用了特征金字塔网络(FPN)和多层检测头架构,计算开销较大。我们的方法简化了 FPN 结构与检测头,并重新设计了这两种架构,同时引入了一种新颖的师生蒸馏过程以及一系列新的蒸馏损失函数。这一组合方法可将推理时间最多缩短 60%,同时保持与 CLRNet 相当的检测精度。这种在精度与速度之间的战略性平衡,使 CLRKDNet 成为自动驾驶应用中实时车道检测任务的可行解决方案。代码和模型可在以下网址获取:
https://github.com/weiqingq/CLRKDNet。
一、引言
车道检测是智能交通(包括自动驾驶和高级驾驶辅助系统(ADAS))的关键组成部分。车道是道路交通的基本要素,划分了车辆行驶路径,有助于实现更安全、更顺畅的驾驶条件。检测方法主要分为基于模型和基于特征两类。基于模型的方法利用预定义的车道模型,将车道识别视为参数估计问题,这有助于降低对噪声的敏感性,并减少对大面积局部图像区域的依赖。相比之下,基于特征的方法将图像中的单个点分类为车道点或非车道点,依赖于边缘梯度、宽度、强度和颜色等特定特征。然而,这种方法需要清晰的车道边缘和强烈的颜色对比才能准确检测。这两种方法都遵循类似的步骤序列:感兴趣区域(ROI)提取、图像预处理、特征提取和车道拟合。随着深度学习技术的出现,传统车道检测方法大多被更先进的端到端深度学习方法所取代。这些现代方法消除了手动特征工程的需求,增强了检测系统的鲁棒性和有效性。当代车道检测技术可分为四类:基于分割的方法、基于参数曲线的方法、基于关键点的方法和基于锚点的方法。基于分割的方法将车道检测视为语义分割任务;基于参数曲线的方法使用曲线参数建模车道,通过参数回归进行检测;基于关键点的方法将车道检测视为关键点估计问题,随后进行整合;最后,基于锚点的方法使用线形锚点,回归这些预定义锚点的采样点偏移量。尽管深度学习技术在车道检测方面取得了相当大的进展,但仍有进一步提升的空间。车道线通常在图像中延伸很长的像素段,并且在局部尺度上具有与路面明显不同的特征,这凸显了提取全局和局部特征以实现准确检测的必要性。在 Zheng 等人的论文中,介绍了交叉层 refinement 网络(CLRNet),利用高级语义特征和低级细节特征。它首先使用高级特征进行粗略定位,然后通过细节特征进行 refinement,以实现精确的车道定位。ROIGather 模块通过将 ROI 车道特征与整个特征图链接起来,进一步捕获广泛的全局上下文信息,与以往方法相比显著提升了检测性能。然而,CLRNet 的复杂性,包括其特征金字塔网络(FPN)和多个检测头,增加了推理时间,阻碍了自动驾驶车辆所需的实时性能。为此,我们开发了 CLRKDNet,旨在减少推理时间的同时保持精度。CLRKDNet 简化了 FPN 架构,采用简化的特征聚合网络,并减少了检测头的数量,从而消除了迭代 refinement 过程。该模型以 CLRNet 为教师模型,引入了一种新颖的知识蒸馏程序,以提升简化的学生模型的性能,并抵消失败检测精度的潜在下降。这种多层蒸馏包括中间特征层、先验嵌入和检测头 logits,确保 CLRKDNet 在显著更快的速度下实现与 CLRNet 相当的检测精度。更多详细信息,请参见第三部分的方法部分。我们通过对 CULane 和 TuSimple 数据集进行广泛实验来验证所提方法的改进,并报告了这两个数据集上的最新结果。此外,全面的消融研究证实了框架中每个组件的有效性。我们的主要贡献总结如下:
-
我们通过简化 CLRNet 中的特征增强模块并减少检测头的数量,显著提高了计算效率,使推理速度最多提高了 60%。
-
我们提出了一种新颖的知识蒸馏技术,其中简化的学生模型 CLRKDNet 利用教师模型 CLRNet 的中间特征层、先验嵌入和最终检测头 logits 来提升其车道检测能力。
-
我们在多个车道检测数据集上进行了广泛的实验,以验证所提方法 CLRKDNet 的有效性,并进行了全面的消融研究,以验证每个模块对模型性能的贡献。
二、相关工作
(一)车道检测
-
基于分割的方法 :基于分割的方法将车道检测视为像素级分类任务,将车道线区域与背景分开。例如,SCNN 利用语义分割框架和消息传递机制来改善车道检测中的空间关系,但其实时应用受到速度限制。同样,RESA 通过实时特征聚合模块提升性能,但由于像素级处理,计算需求仍然较高。
-
基于锚点的方法 :基于锚点的方法依赖预定义的线或行锚点来引导车道检测。Line-CNN 和 LaneATT 使用带注意力机制的线锚点来提高准确性和效率。相反,行锚点方法如 UFLD 和 CondLaneNet 具有简单和快速的优点,但在复杂场景中由于难以准确识别初始车道点而可能表现不佳。CLRNet 及其扩展工作提出了一种跨层优化的车道检测网络,使用高级特征检测车道线,并利用低级特征调整车道线位置。
(二)知识蒸馏
知识蒸馏涉及将复杂且通常笨重的模型的见解转移到更紧凑、计算效率更高的模型,从而提升小型模型的性能和泛化能力。该技术最初由 Hinton 等人在 2015 年提出。多年来,它发展出许多方法,包括采用软标签和定制损失函数来优化学习过程。在计算机视觉中,知识蒸馏显著提升了小型模型在目标检测、图像分类和分割等各种任务中的能力。在车道检测领域,Hou 等人引入了自注意力蒸馏(SAD),采用自上而下和层次化的注意力蒸馏来增强表示学习和模型效能。值得注意的是,我们的蒸馏方法优于 SAD,在 CULane 数据集上的 F1 分数比其高出近 10 个百分点。
三、方法
(一)CLRKDNet
-
教师模型 :我们的方法采用复杂的 CLRNet 架构作为教师模型,它集成了 ResNet 或 DLA 等稳健的主干网络。这种集成使主干网络能够提取深度特征,然后由特征金字塔网络(FPN)处理,生成不同分辨率(包括输入图像尺寸的 1/8、1/16 和 1/32)的多尺度特征图,从而全面表示全局内容和局部细节。CLRNet 通过配置具有可学习参数(xi,yi,θi)的先验来启动车道检测,其中(xi,yi)定义起始坐标,θi 是相对于 x 轴的方向。符号 i 表示 M 个先验中的一个,M 表示先验的总数。这些先验对于识别潜在车道路径至关重要,通过在不同尺度的各种卷积层和全连接层中进行处理。如图 2 所示,这种多层处理生成分类和回归输出以调整先验。模型经过三次 refinement 循环,这些调整利用更高分辨率的特征图重新校准先验。交叉注意力机制在整个过程中整合上下文信息,最终精确计算多个水平行的 x 坐标以描绘车道路径。为应对车道检测的复杂性,CLRNet 采用全面的损失函数 L,结合 smooth L1 进行先验 refinement,focal loss 进行分类,以及交叉熵损失进行分割。此外,专门设计的 LineIoU 损失函数专门增强车道预测的交并比(IoU)度量,提升模型精度。
-
学生模型 :CLRKDNet 是 CLRNet 的简化版本,旨在满足自动驾驶应用对实时性的高要求,同时管理车道检测性能。它利用 CLRNet 的先进网络设计,包括其主干网络和检测头机制,但在架构上进行了显著优化以提高效率。在特征增强部分,CLRNet 通过 FPN 整合多尺度语义丰富的特征,而我们的 CLRKDNet 部署了一个轻量级特征聚合网络以减轻计算负担。如图 2 所示,该网络专门设计用于压缩从主干网络提取的特征的通道大小,增强特征的表示质量而不增加计算负担。这一创新不仅大幅减少了权重参数数量,还缩小了计算占用空间,使特征集成过程更快速。CLRKDNet 的检测头也经过了效率优化。与 CLRNet 的多个检测头和可学习先验(需要大量计算资源进行迭代 refinement)不同,我们的 CLRKDNet 采用单个检测头与固定先验集。该单检测头利用一组静态先验,不进行昂贵的迭代 refinement 过程。图 3 展示了单检测头的结构。实验分析表明,这种简化使 CLRKDNet 的推理速度最多提高了 60%,而评估分数仅略有下降。通过知识蒸馏进一步补偿了由于简化架构导致的检测性能下降。我们提出的知识转移方法利用从教师模型 CLRNet 的中间层蒸馏出的见解,以及先验和检测头的最终输出。通过这种多阶段蒸馏过程,我们的 CLRKDNet 模型以较低的计算成本接近 CLRNet 设定的基准。
-
二)注意力图蒸馏
-
激活注意力转移 :在车道检测模型中,知识蒸馏通过基于激活的注意力机制实现。对于卷积神经网络的第 n 层,我们提取激活输出,表示为 An ∈ RCn×Hn×Wn,其中 Cn、Hn 和 Wn 分别对应激活张量的通道数、高度和宽度。为了将教师模型的知识蒸馏到学生模型,我们从这些激活张量中生成空间注意力图。这些图作为浓缩表示,突出显示模型认为输入图像中最关键的区域。通过应用映射函数 Gsump(An)= ΣCn j=1 |An,j|p,其中 An,j 表示 An 在通道维度上的第 j 个切片,p > 1,来蒸馏这些注意力图。参考其他文献,我们选择 p = 2 以加强关注最显著的特征,从而引导学生模型的注意力方向,类似于教师模型的方向。图 2 展示了这一注意力图蒸馏过程。在整个训练阶段,学生模型的注意力图逐渐调整以匹配教师模型的注意力图,并通过损失函数最小化差异。
-
注意力转移损失 :在车道检测模型中,注意力图的蒸馏通过注意力转移损失函数量化,该函数专门测量学生模型和教师模型注意力图之间的差异。对于集合 N(表示每个教师 - 学生激活层对的索引)中索引为 n 的每一层,首先将学生模型的注意力图 ASn 和教师模型的注意力图 ATn 转换为向量形式,分别表示为 QS n 和 QT n。这些向量形式是通过将激活张量应用映射函数 G 并将得到的注意力图重塑为向量产生的。 Latt = Σn∈N ||QS n / ||QS n||2 − QT n / ||QTn||2||p 其中 QS n = vec(G(ASn))和 QT n = vec(G(ATn))分别是学生模型和教师模型第 n 对注意力图的向量化形式。||・||2 表示 ℓ2 范数,用于标准化每个向量化的注意力图,确保损失计算不受注意力图尺度的影响,仅关注其模式。参数 p 设置为 2,与注意力图计算中使用的二次映射函数 G 一致,这已被证明可以有效促进知识转移。
(三)检测头上的知识转移
在注意力图蒸馏过程之后,我们旨在进一步提高检测精度并缩小模型之间的差距。为此,我们提出了一种用于检测头的双重蒸馏程序,包括先验嵌入蒸馏和 logits 蒸馏。这些机制确保 CLRKDNet 尽管架构简化,仍能有效保留教师模型 CLRNet 的复杂检测能力。先验嵌入蒸馏使学生模型的先验与教师模型的精炼输出对齐,而 logits 蒸馏则测量并最小化输出 logits 的差异,引导 CLRKDNet 的预测尽可能接近 CLRNet 的预测。先验嵌入蒸馏:CLRNet 和 CLRKDNet 都使用嵌入先验初始化其检测头,这些先验定义了车道线的几何参数,包括初始坐标(xi,yi)和相对于 x 轴的方向 θi。这些先验和由主干网络和特征融合网络生成的特征图引导 ROI 模块为每个车道像素准确收集附近的特征。这一收集过程结合全局内容和丰富的语义信息,确保全面的检测能力。虽然 CLRNet 在其检测头的各个层中迭代地精炼这些先验,但 CLRKDNet 直接使用一组这些先验进行检测输出。通过比较学生模型的初始先验和教师模型的精炼先验之间的嵌入来完成这些先验的蒸馏。具体而言,嵌入被格式化为 [M,3] 维度的张量,其中 M 表示初始先验的数量,使用 L2 范数损失函数进行比较: Lprior = ΣM i=1 ||Pi S − Pi T ||2 其中,Pi S 和 Pi T 分别表示学生模型和教师模型的第 i 个先验向量,每个向量都包含初始坐标和方向(xi,yi,θi)。这种 L2 范数比较测量每对对应先验之间的欧几里得距离,有效使 CLRKDNet 的静态先验与 CLRNet 的动态精炼先验对齐。这种对齐确保学生模型从与教师模型迭代过程输出相当的精炼水平开始,有效弥合了两种模型在动态精炼能力上的差距。Logit 蒸馏:Logit 蒸馏关注检测头的最终输出,在将模型输出转换为预测线之前。如图 3 所示,这些 logits 包括分类分数和几何特征,例如起始坐标(xi,yi)、方向 θi、车道长度 li 以及预测车道与车道先验之间的水平偏移差 ∆xi。Logit 蒸馏过程包括将学生模型检测头的逻辑输出与教师模型的逻辑输出进行比较,并计算均方误差(MSE)以测量和最小化它们之间的差异。这种损失确保 CLRKDNet 的简化检测头(缺乏 CLRNet 的多个精炼阶段)仍能产生高精度的输出。MSE 对大差异敏感,特别有效微调学生模型的输出以尽可能接近教师模型的输出,从而补偿了迭代精炼层的缺失。这种特定损失表示为: Llogit = 1/M ΣM i=1 [(xi S − xi T )² + (yi S − yi T )² + (θi S − θi T )² + (li S − li T )² + (∆xi S − ∆xi T )²] 其中 M 是先验的数量。xi S,yi S,θi S,li S,∆xi S 是学生模型检测头的几何输出,包括起始坐标、方向、长度和水平差异。xi T,yi T,θi T,li T,∆xi T 是教师模型的相应输出。
损失函数
相关文章:
车道线检测----CLRKDNet
今天的最后一篇 车道线检测系列结束 CLRKDNet:通过知识蒸馏加速车道检测 摘要:道路车道是智能车辆视觉感知系统的重要组成部分,在安全导航中发挥着关键作用。在车道检测任务中,平衡精度与实时性能至关重要,但现有方法…...
【AI模型部署】
解决python引入huggingface_hub模块下载超时问题 背景问题解决 背景 AMD Ryzen™ AI处理器通过独特的NPUGPU异构架构,为AI工作负载提供强大的并行计算能力。本方案展示了如何将YOLOv8目标检测、RCAN超分辨率重建和Stable Diffusion文生图三类模型分别部署到NPU和GP…...
排序01:多目标模型
用户-笔记的交互 对于每篇笔记,系统记录曝光次数、点击次数、点赞次数、收藏次数、转发次数。 点击率点击次数/曝光次数 点赞率点赞次数/点击次数 收藏率收藏次数/点击次数 转发率转发次数/点击次数 转发是相对较少的,但是非常重要,例如转发…...
电子电器架构 --- Zonal架构正在开创汽车电子设计新时代
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 钝感力的“钝”,不是木讷、迟钝,而是直面困境的韧劲和耐力,是面对外界噪音的通透淡然。 生活中有两种人,一种人格外在意别人的眼光;另一种人无论…...
如何阅读、学习 Tcc (Tiny C Compiler) 源代码?如何解析 Tcc 源代码?
阅读和解析 TCC(Tiny C Compiler) 的源代码需要对编译器的基本工作原理和代码结构有一定的了解。以下是分步骤的指南,帮助你更高效地学习和理解 TCC 的源代码: 1. 前置知识准备 C 语言基础:TCC 是用 C 语言编写的&…...
Java 泛型与类型擦除:为什么解析对象时能保留泛型信息?
引言:泛型的“魔术”与类型擦除的困境 在 Java 中,泛型为开发者提供了类型安全的集合操作,但其背后的**类型擦除(Type Erasure)**机制却常常让人困惑。你是否遇到过这样的场景? List<String> list …...
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(22):复习
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(22):复习 1、前言(1)情况说明(2)工程师的信仰2、知识点(1)复习(2)復習3、单词(1)日语(2)日语片假名单词4、对话练习5、单词辨析记录6、总结1、前言 (1)情况说明 自己在今年,在日本留学中,目前在语言学校,…...
Java基础学习
Java 基础大纲 1. Java 概述 Java 语言特点(跨平台、面向对象、自动内存管理) JVM、JRE、JDK 的作用与区别 开发环境搭建(安装 JDK、配置环境变量、IDE 使用) 2. 基础语法(已经学习) 变量与数据类型&a…...
MGX:多智能体管理开发流程
MGX的多智能体团队如何通过专家混合系统采用全新方法,彻底改变开发流程,与当前的单一智能体工具截然不同。 Lovable和Cursor在自动化我们的特定开发流程方面取得了巨大飞跃,但问题是它们仅解决软件开发的单一领域。 这就是MGX(MetaGPT X)的用武之地,它是一种正在重新定…...
2025第三届盘古石杯初赛(计算机部分)
前言 比赛的时候时间不对,打一会干一会,导致比赛时候思路都跟不上,赛后简单复现一下,希望大家批批一下 计算机取证 1、分析贾韦码计算机检材,计算机系统Build版本为?【标准格式:19000】 183…...
XML介绍及常用c及c++库
一.xml概述 1.什么是XML? XML(eXtensible Markup Language)是一种标记语言,1998 年 2 月:XML 1.0 发布,用于存储和传输结构化数据。与HTML专注于数据显示不同,XML专注于数据本身及其结构。 它…...
动态规划-63.不同路径II-力扣(LeetCode)
一、题目解析 与62.不同路径不同的一点是现在网格中有了障碍物,其他的并没有什么不同 二、算法解析 1.状态表示 dp[i][j]表示:到[i,j]位置时,不同的路径数 2.状态转移方程 由于多了障碍物,所以我们要判断是否遇到障碍物 3.初…...
海盗王3.0的数据库3合1并库处理方案
原版的海盗王数据库有3个accountserver,gamedb,tradedb,对应到是账号数据库,游戏数据库,商城数据库。 一直都有个想法,如何把这3个库合并到一起,这样可以实现一些功能。 涉及到sqlserver的数据库…...
Vue百日学习计划Day16-18天详细计划-Gemini版
重要提示: 番茄时钟: 每个番茄钟为25分钟学习,之后休息5分钟。每完成4个番茄钟,进行一次15-30分钟的长休息。动手实践: DOM 操作和事件处理的理解高度依赖于实际编码。请务必在浏览器中创建 HTML 页面,并配…...
【C++】15.并发支持库
本篇内容参考自cplusplus 1. thread 1.1 thread thread库底层是对各个系统的线程库(Linux下的pthread库和Windows下Thread库)进行封装。C11thread库的第一个特点是可以跨平台,第二个特点是Linux和Windows下提供的线程库都是面向过程的&…...
Linux系统编程——exec族函数
我们来完整、系统、通俗地讲解 Linux 系统编程中非常重要的一类函数:exec 族函数(也叫 exec family)。 一、什么是 exec? exec 系列函数的作用是: 用一个新的程序,替换当前进程的内容。 也就是说…...
职教实训室中的写实数字人:技术与应用方案
在当今快速发展的数字化时代,职业教育的重要性日益凸显。面对传统教学模式中个性化不足、互动性差等挑战,深声科技基于2D写实交互数字人的解决方案为职教实训室带来了全新的变革。本文将详细介绍该技术方案的核心原理、产品特色及其在职业培训中的实际应…...
Nginx模块配置与请求处理详解
Nginx 作为模块化设计的 Web 服务器,其核心功能通过不同模块协同完成。以下是各模块的详细配置案例及数据流转解析: 一、核心模块配置案例 1. Handler 模块(内容生成) 功能:直接生成响应内容(如静态文件、重定向等) # 示例1:静态文件处理(ngx_http_static_module)…...
54. 螺旋矩阵
题目链接: a54. 螺旋矩阵 题目描述: 给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。 题目分析: 改题目需要判断是否溢出边界,与59不同,59可以判断是否为0…...
virtualbox虚拟机中的ubuntu 20.04.6安装新的linux内核5.4.293 | 并增加一个系统调用 | 证书问题如何解决
参考文章:linux添加系统调用【简单易懂】【含32位系统】【含64位系统】_64位 32位 系统调用-CSDN博客 安装新内核 1. 在火狐下载你需要的版本的linux内核压缩包 这里我因为在windows上面下载过,配置过共享文件夹,所以直接复制粘贴通过共享文…...
代码随想录算法训练营第三十八天打卡
今天是动态规划的第三天,昨天的不同路径与整数分解的几道题目大家理解得如何?如果有疑问大家还是多去想想dp数组究竟是什么含义,还有我的状态转移是否正确,初始化是否正确,这一点很重要,今天的题目依旧是跑…...
【论信息系统项目的整合管理】
论信息系统项目的整合管理 某省机场管理集团航空货运站原有物流生产信息系统无法满足机场货运站生产信息与航空公司、对方航站、进出口航空货物按海关监管要求电子报关等行业信息实时共享发展需要,生产信息需多次重复录入问题已成为业务发展最大瓶颈,急需…...
小学数学题批量生成及检查工具
软件介绍 今天给大家介绍一款近期发现的小工具,它非常实用。 软件特点与出题功能 这款软件体积小巧,不足两兆,具备强大的功能,能够轻松实现批量出题。使用时,只需打开软件,输入最大数和最小数,…...
Python线性回归:从理论到实践的完整指南
Python线性回归:从理论到实践的完整指南 线性回归是数据科学和机器学习中最基础且最重要的算法之一。本文将深入探讨如何使用Python实现线性回归,从理论基础到实际应用,帮助读者全面理解这一重要的统计学和机器学习方法。 什么是线性回归&a…...
python 爬虫框架介绍
文章目录 前言一、Requests BeautifulSoup(基础组合)二、Scrapy(高级框架)三、PySpider(可视化爬虫)四、Selenium(浏览器自动化)五、Playwright(新一代浏览器自动化&…...
强化学习算法实战:一个例子搞懂sarsa、dqn、ddqn、qac、a2c及其区别
简介 在学习强化学习算法:sarsa、dqn、ddqn、qac、a2c、trpo、ppo时,由于有大量数学公式的推导,觉得十分晦涩,且听过就忘记了。 但是当把算法应用于实战时,代码的实现要比数学推导直观很多。 接下来通过不同的算法实现…...
文章记单词 | 第86篇(六级)
一,单词释义 pretty /ˈprɪti/- adj. 漂亮的;相当的 /adv. 相当地labour /ˈleɪbə(r)/- n. 劳动;劳工;分娩 /v. 劳动;努力(英式英语, labor)imaginary /ɪˈmdʒɪnəri/- adj. …...
firewall防火墙
一.Firewalld 防火墙概述 1.firewalld 简介 firewalld 的作用是为包过滤机制提供匹配规则(或称为策略),通过各种不同的规则告诉netfilter 对来自指定源、前往指定目的或具有某些协议特征的数据包采取何种处理方式为了更加方便地组织和管理防火墙,firewa11d 提供了…...
TII-2024《AGP-Net: Adaptive Graph Prior Network for Image Denoising》
推荐深蓝学院的《深度神经网络加速:cuDNN 与 TensorRT》,课程面向就业,细致讲解CUDA运算的理论支撑与实践,学完可以系统化掌握CUDA基础编程知识以及TensorRT实战,并且能够利用GPU开发高性能、高并发的软件系统…...
Pageassist安装(ollama+deepseek-r1)
page-assist网站:https://github.com/n4ze3m/page-assist 首先电脑配置node.js,管理员打开命令窗口输入下面命令下载bun npm install -g buncd 到你想要安装page-assist的地方(推荐桌面) 输入下列命令 git clone https://gith…...
Java—— 方法引用 : :
方法引用是什么 把已经存在的方法拿过来用,当做函数式接口中抽象方法的方法体 方法引用符 :: 方法引用的条件 1.需要有函数式接口 2.被引用方法必须已经存在 3.被引用方法的形参和返回值需要跟抽象方法保持一致 4.被引用方法的功能要满足当前…...
Linux基础开发工具大全
目录 软件包管理器 1>软件包 2>软件生态 3>yum操作 a.查看软件包 b.安装软件 c.卸载软件 4>知识点 vim编辑器 1>基本概念 2>基本操作 3>正常模式命令集 a.模式切换 b.移动光标 c.删除 d.复制 e.替换 f.撤销 g.更改 4>底行模式命令…...
C语言实现INI配置文件读取和写入
一.INI文件介绍 INI配置文件是一种简单的文本文件,用于存储配置信息,通常由一个或多个节(section)组成,每个节包含多个键值对(Key-Value)格式。INI文件易于阅读和编辑,广泛应用于多…...
volatile关键字详解
volatile关键字详解 1. 定义与核心作用 volatile 是Java中的关键字,用于修饰变量,主要解决多线程环境下的内存可见性和指令重排序问题。其核心作用: 保证可见性:确保所有线程读取到变量的最新值。禁止指令重排序:防止…...
二叉树子树判断:从递归到迭代的全方位解析
一、题目解析 题目描述 给定两棵二叉树root和subRoot,判断root中是否存在一棵子树,其结构和节点值与subRoot完全相同。 示例说明 示例1: root [3,4,5,1,2],subRoot [4,1,2] 返回true,因为root的左子树与subRoot完…...
【PhysUnits】4.1 类型级比特位实现解释(boolean.rs)
一、源码 该代码实现了一个类型级(type-level)的布尔系统,允许在编译时进行布尔运算。 //! 类型级比特位实现 //! //! 这些是基础的比特位类型,作为本库中其他数值类型的构建基础 //! //! 已实现的**类型运算符**: //! //! - 来自 core::op…...
(7)python开发经验
文章目录 1 找不到资源文件2 使用subprocess执行时有黑色弹窗3 找不到exec4 pyside6-project lupdate的bug5 找不到pyd模块6 pyd模块编码错误7 运行显示Qt platform plugin "windows" in "8 tr()包含的字符串无法被翻译 更多精彩内容👉内容导航 &…...
【Manim】使用manim画一个高斯分布的动画
1 Manim例子一 最近接触到manim,觉得挺有趣的,来玩一玩把。如下是一个使用manim画的高斯分布的动画。 from manim import * import numpy as npclass GaussianDistribution(Scene):def construct(self):# 创建坐标系axes Axes(x_range[-4, 4, 1],y_ra…...
Day11-苍穹外卖(数据统计篇)
前言: 今天写day11的内容,主要讲了四个统计接口的制作。看起来内容较多,其实代码逻辑都是相似的,这里我们过一遍。 今日所学: Apache ECharts营业额统计用户统计订单统计销量排行统计 1. Apache ECharts 1.1 介绍 A…...
论文阅读:Self-Collaboration Code Generation via ChatGPT
地址:Self-Collaboration Code Generation via ChatGPT 摘要 尽管大型语言模型(LLMs)在代码生成能力方面表现出色,但在处理复杂任务时仍存在挑战。在现实软件开发中,人类通常通过团队协作来应对复杂任务,…...
LocaleContextResolver实现多语言切换-笔记
1. LocaleContextResolver功能简介 org.springframework.web.servlet.LocaleContextResolver是 Spring MVC 中用于解析和管理用户 Locale(语言环境) 的核心接口。 //LocaleContextResolver 接口定义 public interface LocaleContextResolver extends L…...
Vue3中setup运行时机介绍
在 Vue3 中,直接写在 <script setup>...</script> 中的代码运行时机可以分为以下几个关键阶段: 一、执行顺序层级 #mermaid-svg-bF3p98MiNdLfcoSG {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#33…...
计算机视觉----感兴趣区域(ROI)、非极大值抑制
感兴趣区域(Region of Interest,ROI)是指在一幅图像或者数据集中,用户关注并希望进行重点分析、处理或者研究的特定区域。以下为你详细介绍它在不同领域的应用: 医学影像领域 在医学影像中,医生可以通过确…...
YOLO11解决方案之对象裁剪探索
概述 Ultralytics提供了一系列的解决方案,利用YOLO11解决现实世界的问题,包括物体计数、模糊处理、热力图、安防系统、速度估计、物体追踪等多个方面的应用。 对象裁剪是指从图像或视频中分离并提取特定的检测对象,YOLO11 模型功能可用于准…...
将单链表反转【数据结构练习题】
- 第 98 篇 - Date: 2025 - 05 - 16 Author: 郑龙浩/仟墨 反转单链表(出现频率非常的高) 文章目录 反转单链表(出现频率非常的高)题目:反转一个链表思路:代码实现(第3种思路): 题目:反转一个链表 将 1->2->3->4->5->NULL反转…...
多网卡管理实战指南:原理、问题分析与实用工具推荐
多网卡管理实战指南:原理、问题分析与实用工具推荐 在现代网络环境中,越来越多的用户面临一个实际问题:一台电脑连接了多个网络接口,如有线 无线、双有线、或实体网卡 虚拟VPN网卡。这种“多网卡”环境虽然提供了更多可能性&am…...
qt5.14.2 opencv调用摄像头显示在label
ui界面添加一个Qlabel名字是默认的label 还有一个button名字是pushButton mainwindow.h #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <opencv2/opencv.hpp> // 添加OpenCV头文件 #include <QTimer> // 添加定…...
使用Python实现简单的人工智能聊天机器人
最近研学过程中发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击链接跳转到网站人工智能及编程语言学习教程。读者们可以通过里面的文章详细了解一下人工智能及其编程等教程和学习方法。下面开始对正文内容的…...
Python爬虫(28)Python爬虫高阶:Selenium+Splash双引擎渲染实战与性能优化
目录 一、背景:动态渲染技术的演进与挑战二、核心技术对比与选型三、环境搭建与工具链配置1. Docker部署Splash集群2. Selenium环境配置 四、双引擎渲染核心实现1. 智能路由中间件2. Splash高级Lua脚本控制 五、性能优化实战方案1. 浏览器资源池化2. 异步渲染加速 六…...
uv python 卸载
又是查了半天 官网wiki没有 网上一堆傻子胡说 uv提示也不对 AI还在这尼玛胡编乱造 开始 我原来装了这几个环境 uv python list 现在python3.7.7不需要了,卸载,直接 uv python uninstall 3.7.7 去找你自己要卸载的版本号,不需要整个包名复制…...