DEYO: DETR with YOLO for End-to-End Object Detection论文翻译

news2024/11/18 1:26:57

 DEYO:DETR与YOLO用于端到端目标检测

摘要

        DETR的训练范式在很大程度上取决于在ImageNet数据集上预训练其骨干。然而,由图像分类任务和一对一匹配策略提供的有限监督信号导致DETR的预训练不充分的颈部。此外,在训练的早期阶段匹配的不稳定性会导致DETR的优化目标不一致。为了解决这些问题,我们设计了一种创新的培训方法,称为逐步培训。具体来说,在训练的第一阶段,我们采用一个经典的检测器,用一对多的匹配策略进行预训练,以初始化端到端检测器的主干和颈部。在训练的第二阶段,我们冻结了端到端检测器的主干和颈部,需要从头开始训练解码器。通过逐步训练的应用,我们引入了第一个利用纯卷积结构编码器的实时端到端对象检测模型,DETR with YOLO(DEYO)。在不依赖任何补充训练数据的情况下,DEYO在速度和准确性方面都超过了所有现有的实时对象检测器。此外,全面的DEYO系列可以使用单个8GB RTX 4060 GPU在COCO数据集上完成其第二阶段训练,大大降低了训练支出。源代码和预训练模型可在https://github.com/ouyanghaodong/DEYO上获得。

1.介绍

        目标检测是计算机视觉领域的一项基本任务,其任务是精确定位和识别图像或视频中的各种目标类别。这项技术是许多计算机视觉应用的基石,包括自动驾驶、视频监控、面部识别和对象跟踪。近年来,深度学习的进步,特别是基于卷积神经网络(CNN)的方法[12],已经在对象检测任务中取得了突破性的进展,成为该领域的主导技术。 

        DETR(Detection Transformer)[3]介绍了一种用于对象检测的端到端方法,包括CNN骨干,Transformer编码器和Transformer解码器。DETR采用匈牙利损失来预测一对一的对象集,从而消除了对非最大抑制(NMS)的手动调整组件的依赖,这通过端到端优化显着简化了对象检测管道。

        尽管基于Transformers(DETR)的端到端对象检测器在性能方面取得了显著的成功,但这些检测器通常依赖于在ImageNet数据集上预训练其骨干网络。如果选择新的主干,则需要在训练DETR或使用现有的预训练主干之前在ImageNet上进行预训练。这种依赖性限制了设计主干的灵活性,并增加了开发成本,当任务数据集与ImageNet显著偏离时,这种预训练策略可能会导致特定数据集上DETR的次优微调结果。

        此外,由于DETRs采用匈牙利匹配算法直接一对一的对象集预测,其解码器的复杂性是二次的输入序列的长度,在训练过程中接收直接监督信号的查询的数量基本上小于在经典的对象检测器使用一对多匹配策略。再加上图像分类任务的固有局限性,这导致DETR的颈部没有得到充分的预训练。此外,在DETR [3]训练的早期阶段,同一个查询经常在同一个图像中的不同时间与不同的对象匹配,导致优化过程既模糊又不稳定,从而破坏了预先训练的骨干。

        为了应对上述挑战,我们引入了一种创新的培训模式,称为“分步培训”。这种方法从自定义数据集的预训练阶段开始,利用经典检测器进行对象检测任务,从而避免了对额外数据集的需求。随后,在训练的第二阶段中,采用在初始阶段期间通过一对多匹配细化的经典训练检测器的主干和颈部来初始化端到端检测器。在此阶段,端到端检测器的主干和颈部组件被冻结,允许从头开始对解码器进行专门的重新训练。与传统的DETR训练方法相比,逐步训练方法在性能上有显着的提高。同时,这种逐步训练大大降低了检测器的训练成本:第一阶段的训练只需16GB的VRAM即可完成,而第二阶段只需8GB的VRAM。

        利用逐步训练方法,我们引入了第一个采用纯卷积架构作为编码器的实时端到端对象检测器,名为DETR [3]与YOLO [23-25](DEYO)。具体来说,我们首先在自定义数据集上训练一个强大的YOLO对象检测模型,以初始化DEYO的主干和颈部。随后,我们将预训练的颈部与简单的特征投影相结合,以构建DEYO的轻量级解码器。由于在初始阶段为DEYO的脊柱和颈部提供了高质量的预训练,DEYO在速度和准确性方面超过了当代最先进的实时目标探测器。

        DEYO-tiny在COCO [16] val 2017上实现了37.6%的AP,并在NVIDIA Tesla T4 GPU上以497 FPS运行,而DEYO-X则达到了53.7%的AP和65 FPS。此外,通过放弃对NMS的依赖,DEYO在CrowdHuman [27]数据集上展示了比YOLOv 8 [9]显着的性能增强。在没有额外训练数据的情况下,DEYO在速度和精度方面优于所有可比较的实时检测器,为实时目标检测建立了新的最先进技术。

        本文的主要工作如下:

        1.我们提出了第一种不需要额外数据集来训练DETR的训练方法:逐步训练。与传统的DETR训练方法相比,分步训练可以为探测器的颈部提供高质量的预训练,并从根本上解决训练初期由于二进制匹配不稳定而对骨干造成的损伤,从而显著提高探测器的性能。

        2.使用逐步训练,我们开发了第一个使用纯卷积结构作为编码器的实时端到端对象检测器DEYO,它在速度和准确性方面都超过了当前最先进的实时检测器,并且不需要后处理,因此其推理速度无滞后且稳定。

        3.我们进行了一系列的消融研究,以分析我们提出的方法和模型的不同组成部分的有效性。

2.相关工作

2.1检测变换器(DETR)

        Carion等人提出了一种基于变换器的端到端对象检测器,称为DETR(检测变换器)[3],由于其在对象检测中的端到端特性,引起了研究人员的极大关注。具体而言,DETR消除了传统检测管道中的锚和NMS组件,采用二分图匹配标签分配方法直接预测一对一的对象集合。该策略极大地简化了目标检测过程,消除了网络管理系统带来的性能瓶颈。然而,DETR遭受缓慢的收敛速度和查询歧义问题。为了解决这些问题,已经提出了DETR的几种变体,例如Deformable-DETR [34],Conditional-DETR [22],Anchor-DETR [30],DABDETR [18],DN-DETR [14]和DINO [31]。DeformableDETR提高了注意力机制的效率,并通过利用多尺度特征加速训练收敛。Conditional-DETR和Anchor-DETR降低了查询的优化难度。DAB-DETR引入了4D参考点,并逐层优化预测框。DN-DETR通过引入查询去噪来加速训练收敛。DINO改进了以前的工作,并取得了最先进的成果。然而,上述改进没有解决DETR中的高计算成本的问题。RT-DETR [20]设计了一种高效的混合编码器来取代原始的Transformer编码器,减少了DETR编码器中不必要的计算冗余,并提出了第一个端到端对象检测器。

2.2.You Only Look Once(YOLO)

        多年来,YOLO [23-25]系列一直是最好的单级实时物体探测器类别之一。YOLO将目标检测任务转化为回归问题,在单次向前传递中预测多个目标的位置和类别,实现高速目标检测。经过多年的发展,YOLO已经发展成为一系列性能良好的快速机型。基于锚点的YOLO方法包括YOLOv 4 [1]、YOLOv 5 [8]和YOLOv 7 [28],而无锚点的方法是YOLOX [7]、YOLOv 6 [13]和YOLOv 8 [9]。考虑到这些检测器的性能,无锚方法的性能与基于锚的方法一样好,锚盒不再是限制YOLO发展的主要因素。然而,所有YOLO变体都会生成许多冗余的边界框,NMS必须在预测阶段过滤掉这些边界框,这会显著影响检测器的准确性和速度,并与实时对象检测器的设计理论相冲突。

3.DEYO

3.1.模型概述

        图2展示了我们的3.DEYO 3.1.模型概述图2展示了我们提出的DEYO的全面架构。DEYO采用YOLOv8 [9]作为其一对多分支,其中YOLOv8包括一个主干,一个特征金字塔网络(FPN)[17]和一个路径聚合网络(PAN)[19],它们共同形成了颈部结构,此外还有一个能够在三个不同尺度上产生预测的头部。相反,DEYO的一对一分支使用了一个轻量级的纯卷积编码器和一个基于变换器的解码器。此外,我们还引入了与DINO [31]中使用的CDN组件相同的CDN组件,以提高模型的精度。

图2.我们消除了编码器的使用,而是采用颈部提供的多尺度特征{P3,P4,P5}。在特征投影之后,这些特征被用作编码器的输入,同时生成候选边界框并通过查询选择器对其进行过滤。随后,该信息被传递到具有辅助预测头的解码器中,从而实现用于生成边界框和分数的迭代优化。

3.2.一对多分支

        YOLO [23-25]模型的泛化能力和实用性在计算机视觉领域得到了广泛验证和广泛认可。即使没有额外的数据集的帮助,YOLO在处理复杂场景,执行多目标检测和适应实时应用方面也表现出卓越的性能。利用这些优势,我们选择YOLO作为我们DEYO模型的一对多分支,为DEYO提供高质量的、经过预先训练的骨干和颈部结构。该分支具有三个多尺度输出层,能够生成多达8,400个候选区域。与DETR模型所采用的一对一标签分配策略不同,YOLO在训练过程中受益于一对多标签分配策略,由于阳性样本的数量更高,因此在初始训练阶段可以对网络进行更全面的监督。这些候选区域的任务不仅仅是分类;它们面临着更复杂的目标检测挑战。这进一步培养了一个强大的颈部结构,为解码器提供丰富的多尺度信息,从而显着提高模型的整体性能。

3.3.高效的编码器

        与使用Transformer作为编码器的DETR [3]相反,DEYO利用了YOLO's Neck的纯卷积架构,该架构在初始阶段进行了预训练,以编码多尺度特征。然后,这些编码的特征被馈送到特征投影模块中,以将它们与隐藏的维度对齐。由于颈部的强大的多尺度特征提取能力,在一开始就通过有效的预训练获得,编码器可以为解码器提供高质量的键,值和建议的边界框。与DETR的随机初始化多尺度层和Transformer编码器相比,DEYO的纯卷积结构实现了显着的速度。这一进程可概述如下:

3.4.查询生成

        如图3所示,DEYO的查询生成方法与DETR的传统两阶段策略不同。具体来说,DEYO采用了一种解耦的边界框和嵌入生成方法,允许通过特征投影更有效地压缩颈部的多尺度信息。同时,DEYO继承了一个一对多的分支预先训练的边界框头部,将学习策略从密集过渡到稀疏,而不是从头开始训练。

图3.我们将边界框的生成与嵌入分离,通过增强的特征投影,可以更有效地压缩颈部发出的多尺度信息。

3.5.一对一分支

        如图所示,DEYO的一对一分支采用类似于DINO的架构,利用Transformer的自我注意机制来捕获查询间的关系,从而建立抑制冗余边界框的分数差异。在Transformer解码器的每一层中,查询被逐步细化,最终得到与对象一一对应的预测。这种设计大大简化了DEYO中的对象检测过程,消除了对非最大抑制(NMS)的依赖,确保了一致的推理速度。在DEYO训练的第二阶段,我们冻结了DEYO的骨干和颈部,以从根本上规避训练初始阶段的二分匹配不稳定性,否则可能会对预训练的骨干造成不良影响。受益于第一阶段提供的高质量初始化,DEYO实现了快速收敛和卓越的性能,即使在一对一分支中只监督几百个查询并从头开始训练。

4.实验

4.1.设置

       COCO为了评估我们的方法在对象检测任务中的性能,我们在广泛使用的Microsoft COCO上进行了实验[16]。我们使用train 2017训练DEYO,并使用val 2017评估性能。

        CrowdHuman为了评估与经典检测器相比DEYO在密集检测中的端到端有效性,我们在CrowdHuman上进行了实验[27]。我们利用了数据集中可用的全面全身注释,并对验证集进行了评估。在优化器相关参数方面,我们采用了与COCO相同的设置。所有实验后处理参考Iter-DeformableDETR [33]的论文,未作任何修改。

        Implementation Details在训练的第一阶段,我们从头开始遵循[9]训练的策略和超参数。在训练的第二阶段,我们使用了6层Transformer解码器作为DEYO的解码器。我们按照[9]超参数训练了检测器,但我们使用了AdamW [11]优化器。学习率设置为0.0001,权重衰减设置为0.0001。第二阶段的数据增强策略与第一阶段的训练相同,包括随机颜色失真、逆平移、翻转、拼接、马赛克等操作。在COCO [16]数据集上,除了DEYO-tiny使用100个查询,其他尺度的DEYO使用300个查询。所有评估均使用Tesla T4 GPU进行,并辅以8 vCPU Intel Xeon处理器(Skylake,IBRS)。实验使用PyTorch版本1.9.0,与TensorRT 8.6.1集成。

4.2.主要结果

        我们在表1中比较了缩放的DEYO与YOLOv 5 [8]、YOLOv 8 [9]和RT-DETR [21]。与YOLOv 8相比,DEYO在N、S和M尺度下的准确度显著提高了2.4 AP / 0.9 AP/ 0.5 AP,同时FPS提高了143% / 110% / 32%。在尺度L和X,DEYO继续表现出更好的准确性和速度之间的权衡。如表3所示,DEYO在密集场景中表现出色,具有实时速度。具体来说,DEYO-X已经达到了令人印象深刻的92.3 AP和43.3 mMR,在CrowdHuman中的召回率为97.3。

表1.主要结果。实时检测器和我们的DEYO使用一致的输入大小640,而端到端检测器使用输入大小(800,1333)。根据RT-DETR中提出的方法,在T4 GPU上使用TensorRT FP 16报告了端到端速度结果。我们不测试DETR的速度,因为它们不是真实的时间探测器。

表3.比较YOLOv8和DEYO在CrowdHuman(全身)上的性能。由于DEYO放弃了对NMS的依赖,性能得到了显著提高。

4.3.消融研究

        表5列出了在CrowdHuman [27]数据集上使用三种不同训练方法的YOLO [23-25]和DEYO模型的训练结果:YOLO方法、DETR方法和分步训练策略。研究结果表明,YOLOv 8 N [9]模型可以实现82.6的平均精度(AP),即使在不依赖补充数据集的情况下从头开始训练,也可以利用一对多训练策略提供的丰富监督信息。相比之下,DEYO-N模型受到一对一匹配训练策略的约束,提供有限的监督信号,尽管经历了与YOLO对应模型相同的迭代次数,但其性能上限为72.1AP。此外,当DEYO-N模型的主干使用YOLOv 8-N-CLS初始化,从ImageNet [5]预训练,并结合DETR训练策略时,DEYO-N的性能达到78.3AP。值得注意的是,实施分步培训显著提高了DEYO-N的绩效,提高了4.7AP。

表5.比较在CrowdHuman数据集上训练的不同方法,应该注意的是,在这个实验中,我们使用YOLOv8提供的工具计算了AP50指标。

        在表7中,我们检查了Neck组件提供的高质量多尺度特征的重要性,这些特征在DEYO模型的第一阶段进行了预训练。该模型的性能显着下降了18.8平均精度点,仅达到68.3平均精度,当单独使用预先训练的骨干,而没有预先训练的颈部逐步训练。这些发现清楚地表明,DEYO模型上级性能的关键不在于使用ImageNet之外的更复杂的预训练骨干,而在于第一阶段预训练的Neck,它用高质量的多尺度特征来描述模型。

表7.逐步训练的消融研究结果。(CrowdHuman)

        在表8中,我们分析了通过在训练的第二阶段期间冻结DEYO的主干和颈部从根本上解决早期二分图匹配的不稳定性而产生的增强,这积极地改善了早期二分图匹配的稳定性。这积极地影响了网络性能。与在整个第二阶段微调骨干和颈部相比,冻结的行为使DEYO的性能提高了1.1 AP。此外,由于DEYO的第一阶段涉及对COCO [16]数据集进行对象检测任务的预训练,因此它允许在训练的第二阶段实施更强大的数据增强策略。因此,与DETR不同,采用Mosaic数据增强不会导致性能下降;相反,它有助于0.2 AP的改进。

表8.探索冻结操作和镶嵌数据增强的影响。 

4.4.分析

        表6中给出的实验结果阐明了当不采用逐步训练策略时,DINO[31],H-DETR[10]和Group-DETR[4]的性能明显下降,与我们的方法形成鲜明对比。与我们的方法相比,参考文献[4,10,31]中提出的方法未能有效地应对由于缺乏监督信号而引发的培训挑战,同时最终导致培训支出膨胀。相反,如表9所示,我们的训练方案不仅避免了额外的训练开销,而且还大大减少了检测器的训练费用(Group-DETR所需的3300个查询可能会使训练持续时间增加六倍)。DEYO模型训练的初始阶段只需要16 GB的VRAM,而随后的阶段需要更少,8 GB的VRAM。对于培训资源受限的场景,DEYO可以停用CDN功能,以进一步降低VRAM要求。如表6所示,渐进式培训策略在第一阶段为DEYO提供了高质量的预培训基础,确保即使CDN停用,性能改进仍然是可管理的。

表6.DEYO-N 12-Epoch训练设置下不同方法的比较。与我们的方法相比,以前的方法不能有效地解决监督信号不足所带来的培训挑战,这也导致了额外的培训成本。

表9.YOLO和DEYO的详细配置以及GPU内存使用情况。

        如图6所示,在X尺度上,与RT-DETR-X相比,DEYO表现出一些差异,RT-DETR-X利用ImageNet [5]进行预训练。然而,这种差距可以归因于RT-DETR [21]并入了更有效的骨架。此外,我们认为COCO [16]数据集上的性能并不能完全概括检测器的优点和缺点。考虑到DEYO不需要额外的训练数据,它可以利用更强大的数据增强策略,并降低训练成本。因此,DEYO在应用于自定义数据集时具有独特的优势。在不改变YOLO原有骨架和颈部的情况下[23-25],DEYO毫不费力地实现了最先进的(SOTA)性能,展示了DEYO模型设计理念的即插即用特性。然而,我们观察到YOLOv 8 [9]的颈部和模型缩放策略与DEYO不完全一致。随着模型大小的增加,DEYO的性能增益逐渐减少。我们假设其中一个原因是YOLOv 8颈部的输出尺寸和DEYO解码器的隐藏尺寸之间的不匹配。这种差异凸显了DEYO模型尚未开发的潜力。我们相信,专为DEYO量身定制的骨干、颈部和模型扩展策略以及逐步训练可以将DEYO的性能提升到前所未有的水平。

图6.对DEYO和RT-DETR的综合比较表明,尽管在更大范围内存在特定差距,但DEYO不依赖额外的训练数据,并且大幅降低了训练成本。我们相信,DEYO在定制数据集方面具有独特的优势。

5.结论

        在本文中,我们创新性地开发了一种训练策略,不仅避免了对额外数据集的需求,而且成功地解决了以前的方法无法克服的问题:由于多尺度特征层训练不足而导致的性能下降。这种方法不仅提高了模型性能,还显著降低了训练成本。通过将我们精心设计的轻量级编码器与这一革命性策略相结合,我们推出了DEYO,它超越了所有现有的实时对象检测器,而无需依赖补充数据集。我们认为DEYO是经典检测器和基于查询的检测器之间融合的一个具体实例。我们相信,还有其他方法可以满足更高的精度要求。然而,DEYO的创新探测器设计带来了新的挑战,例如需要重新设计主干和颈部,以充分发挥DEYO的潜力。我们预计,未来的研究将为这些挑战提供有效的解决方案。

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

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

相关文章

利用Cocos游戏开发中的跑马灯祝女神们节日快乐

点击上方亿元程序员+关注和★星标 引言 Cocos游戏开发中的跑马灯广播效果 大家好,今天是国际劳动妇女节,也就是我们如今熟知的女神节。 今天打算通过游戏开发中的跑马灯广播这最直接的方式祝女神们节日快乐! 跑马灯作为游戏中常见的UI元素,通常被用来展示重要的信息或者…

Gafana Redis Overview dashboard

1. 简介 根据提供的 Redis 监控仪表盘 JSON 文件,包含的监控指标及其简要描述如下: redis_uptime_in_seconds: Redis 实例的运行时间(秒)。 redis_connected_clients: 当前连接到 Redis 实例的客户端数量。 redis_memory_used_bytes: Redis 实例使用的内存量(字节)。 redis_m…

Qt + mqtt对接阿里云平台(一)

一、阿里云平台 官网:点击跳转 二、创建产品与设备 1、“公共实例” 2、“设备管理”->“产品”->“创建产品” 3、“产品名称”->“自定义品类”->"确认" 4、“前往添加” 5、“添加设备” 6、摄入DeviceName和备注名称 7、"前往查…

css-vxe-form-item中输入框加自定义按钮(校验位置错误)

1.浮动错误效果 提示内容不对 2.不使用浮动&#xff0c;使用行内块元素 代码如下 <vxe-form-item title"yoyo:" field"assembleWorkNo" span"8"><template #default><vxe-input style"width:70%;display:inline-block;&quo…

Linux之cd、pwd、mkdir 命令

cd命令&#xff0c;切换目录 1&#xff09;当Linux终端&#xff08;命令行&#xff09;打开的时候&#xff0c;会默认以用户的HOME目录作为当前的工作目录。 2&#xff09;我们可以通过cd命令&#xff0c;更改当前所在的工作目录。 3&#xff09;cd命令来自英文&#xff1a;C…

基于FPGA的PSRAM接口设计与实现

一 PSRAM与HyperRAM 1、概述 2、异同 待完善 二 PSRAM分析 1、特性 1、关键点 待完善 三 PSRAM方案设计与验证 待完善 1、整体方案设计 2、验证 仿真工具采用VCSVerdi&#xff0c;PSRAM接口控制IPAPS6408L model进行验证。 四 结论 备注&#xff1a;以AP公司的APS6408L…

IP传输方式——组播

组播作为IP传输三种方式之一&#xff0c;指的是报文从一个源发出&#xff0c;被转发到一组特定的接收者&#xff0c;相同的报文在每条链路上最多有一份。相较于传统的单播和广播&#xff0c;组播可以有效地节约网络带宽、降低网络负载&#xff0c;所以被广泛应用于IPTV、实时数…

mysql如何开启远程访问?

MySQL是一种常见的关系型数据库管理系统&#xff0c;广泛应用于各行各业。默认情况下&#xff0c;MySQL仅允许本地访问&#xff0c;即只能在本地主机上进行数据库操作。有时候我们需要通过远程连接访问MySQL数据库&#xff0c;以便实现更灵活的管理和操作。本文将介绍如何在MyS…

HTML静态网页成品作业(HTML+CSS)——原神介绍设计制作(4个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有4个页面。 二、作品演示 三、代…

如何恢复未保存的Word文档

Microsoft Word 是世界上最流行的软件之一。它不仅是各行业提高生产力的利器&#xff0c;而且广泛应用于我们的日常生活中。因此&#xff0c;当您发现自己工作了数小时和数天的word doc文档被意外未保存、删除或丢失时&#xff0c;大多数人可能都知道恐慌和绝望。 今天我们将向…

HelpLook VS GitBook:知识库优劣详解

在信息爆炸的时代&#xff0c;企业要保持竞争优势&#xff0c;就必须善于管理和利用内部的知识资产。企业知识库作为一种集中存储和共享知识的工具&#xff0c;正在成为现代企业不可或缺的一部分。 HelpLook和Gitbook是提供专业知识库的两个平台&#xff0c;也被大众熟知。它们…

Spring Boot 配置热部署

前言 对于 Spring Boot 项目之中, 在刚开始学习的时候, 每当代码进行变动的时候, 想要生效那就必须要手动重启. 为什么要重启呢 ? 原因在于写的代码是依靠运行之后的 class 文件运行的, 当我们的代码更新以后, 如果不去手动重启, 那么就无法生成新的 class 文件, 执行的就是旧…

Python与FPGA——图像锐化

文章目录 前言一、图像锐化二、Python robert锐化三、Python sobel锐化四、Python laplacian锐化五、FPGA sobel锐化总结 前言 在增强图像之前一般会先对图像进行平滑处理以减少或消除噪声&#xff0c;图像的能量主要集中在低频部分&#xff0c;而噪声和图像边缘信息的能量主要…

结构体:位段(C语言进阶)(二)

目录 前言 2、位段 2.1 什么是位段 2.2 位段的内存分配 2.3 位段的跨平台问题 2.4 位段的应用 总结 前言 C语言除了有其内置类型&#xff0c;还有自定义类型。因为在实际运用中&#xff0c;我们可能会遇到一类数据&#xff0c;它的内容是由多种数据组成的&#xff0c;例如&…

27.基于springboot + vue实现的前后端分离-网上租赁交易系统(项目 + 论文)

项目介绍 本课题是根据用户的需要以及网络的优势建立的一个基于Spring Boot的网上租贸系统&#xff0c;来满足用户网络商品租赁的需求。本网上租贸系统应用Java技术&#xff0c;MYSQL数据库存储数据&#xff0c;基于Spring Boot框架开发。在网站的整个开发过程中&#xff0c;首…

centos离线安装 k8s (实操可用)

全部安装包rpm下载&#xff08;已整理好k8s和docker&#xff09;&#xff1a;链接&#xff1a;https://pan.baidu.com/s/1ATv8BPijhvIKWz4hMnkx6Q?pwdt5db 提取码&#xff1a;t5db 将文件下载以后&#xff0c;解压到服务器 #执行所有docker-rpm包 yum -y localinstall *.rpm…

【你也能从零基础学会网站开发】Web建站之HTML+CSS入门篇 CSS层叠样式表语法基础

&#x1f680; 个人主页 极客小俊 ✍&#x1f3fb; 作者简介&#xff1a;web开发者、设计师、技术分享 &#x1f40b; 希望大家多多支持, 我们一起学习和进步&#xff01; &#x1f3c5; 欢迎评论 ❤️点赞&#x1f4ac;评论 &#x1f4c2;收藏 &#x1f4c2;加关注 什么是CSS?…

【机器学习】详解正则化思想

我们的生活当中真正有意义或者有价值的部分可以概括为两句话&#xff1a;一句话是&#xff1a;弄清楚某个东西是怎么一回事&#xff0c;另一句话是&#xff0c;弄清楚某个东西是怎么一回事。头一句话&#xff0c;我们弄清楚的那个东西对于我们而言是未知的&#xff0c;但是已经…

(学习总结)如何使用ChatGPT API训练自定义知识库

第一步&#xff1a; 安装OpenAI、GPT Index、PyPDF2和Gradio库 pip install openai pip install gpt_index pip install PyPDF2 pip install gradio 第二步&#xff1a;用VScode代码编辑器写app.py代码 记得替换api密钥 from llama_index import SimpleDirectoryReader, …

企智汇:引领企业项目管理的数字智能化管理系统工具!

随着数字化时代的来临&#xff0c;企业对项目管理的要求也日益增高。面对日益复杂的业务流程和海量数据&#xff0c;如何有效地管理项目、整合资源、优化流程、提高管理效率&#xff0c;成为了摆在企业面前的重要课题。在这样的背景下&#xff0c;专业做了10年项目管理系统的&a…