第九章:RefineNet——多路径细化网络用于高分辨率语义分割

news2025/1/11 2:34:09

0.摘要

        最近,非常深的卷积神经网络(CNN)在目标识别方面表现出色,并且也是密集分类问题(如语义分割)的首选。然而,在深度CNN中,重复的子采样操作(如池化或卷积跳跃)会导致初始图像分辨率的显著降低。因此,我们提出了RefineNet,这是一个通用的多路径细化网络,明确利用沿着降采样过程可用的所有信息,通过长程残差连接实现高分辨率预测。通过这种方式,能够直接利用较早卷积层的细粒度特征来精确调整捕获高级语义特征的深层。RefineNet的各个组件都采用了残差连接,遵循身份映射的思想,从而实现了有效的端到端训练。此外,我们引入了链式残差池化,以高效地捕捉丰富的背景上下文。我们进行了全面的实验,并在七个公共数据集上取得了最新的最优结果。特别是,在具有挑战性的PASCAL VOC 2012数据集上,我们取得了83.4的交并比分数,这是迄今为止报道的最好结果。

1.引言

        语义分割是图像理解中的一个关键组成部分。任务是为图像中的每个像素分配一个唯一的标签(或类别),可以被视为一种密集分类问题。所谓的对象解析问题通常可以被视为语义分割。最近,深度学习方法,特别是卷积神经网络(CNN),例如VGG [42]、残差网络 [24],在识别任务中显示出了显著的结果。然而,当涉及到密集预测任务,如密集深度或法线估计 [13,33,34]和语义分割 [36,5]时,这些方法显示出明显的局限性。多个阶段的空间池化和卷积步幅通常会使最终图像预测在每个维度上减少32倍,从而丧失了许多更精细的图像结构。

        解决这个限制的一种方法是学习反卷积滤波器作为上采样操作[38,36],以生成高分辨率的特征图。反卷积操作无法恢复在卷积前向阶段的降采样操作后丢失的低级视觉特征。因此,它们无法输出准确的高分辨率预测。低级视觉信息对于边界或细节的准确预测至关重要。最近由Chen等人提出的DeepLab方法[6]采用了扩张(或膨胀)卷积来考虑更大的感受野,而不对图像进行降采样。DeepLab被广泛应用,并代表了语义分割的最新性能。然而,这种策略至少有两个限制。首先,它需要在通常具有高维特征的大量详细(高分辨率)特征图上进行卷积,这在计算上是昂贵的。而且,大量的高维和高分辨率特征图也需要巨大的GPU内存资源,特别是在训练阶段。这阻碍了高分辨率预测的计算,并且通常将输出大小限制为原始输入的1/8。其次,扩张卷积引入了特征的粗糙子采样,可能导致重要细节的丢失。

        另一种方法利用中间层的特征来生成高分辨率的预测,例如[36]中的FCN方法和[22]中的超级像素方法。这些方法的直觉是,中间层的特征被期望描述对象部分的中级表示,同时保留空间信息。这些信息被认为是早期卷积层的特征的补充,早期卷积层的特征编码低级的空间视觉信息,如边缘、角点、圆等,以及深层的高级特征,编码高级语义信息,包括对象或类别级别的证据,但缺乏强的空间信息。

        我们认为所有层次的特征对于语义分割都是有帮助的。高级语义特征有助于图像区域的类别识别,而低级视觉特征有助于生成高分辨率预测的清晰、详细的边界。如何有效地利用中间层特征仍然是一个开放的问题,值得更多的关注。为此,我们提出了一种新颖的网络架构,有效地利用多层次特征生成高分辨率的预测。我们的主要贡献如下:

        1.我们提出了一个多路径细化网络(RefineNet),它利用多个抽象级别的特征进行高分辨率的语义分割。RefineNet以递归的方式将低分辨率(粗糙的)语义特征与细粒度的低级特征相结合,生成高分辨率的语义特征图。我们的模型具有灵活性,可以轻松地级联和修改。

        2.我们的级联RefineNet可以有效地进行端到端的训练,这对于最佳预测性能至关重要。具体而言,RefineNet中的所有组件都使用残差连接[24]和恒等映射[25],使得梯度可以通过短程和长程残差连接直接传播,从而实现有效和高效的端到端训练。

         3.我们提出了一个新的网络组件,称为串联残差池化,它能够从大范围的图像区域中捕获背景上下文。它通过使用多个窗口大小高效地池化特征,并通过残差连接和可学习权重将它们融合在一起。

        4.我们提出的RefineNet在包括PASCAL VOC 2012、PASCAL-Context、NYUDv2、SUN-RGBD、Cityscapes、ADE20K和对象解析人体部位数据集在内的7个公共数据集上取得了最新的最佳性能。特别是在PASCAL VOC 2012数据集上,我们的IoU得分达到了83.4,远远超过当前最好的方法DeepLab。

        为了促进未来的研究,我们发布了RefineNet的源代码和训练模型。

图1.我们方法在对象解析任务(左)和语义分割(右)上的示例结果。

1.1.相关工作

        在近年来,卷积神经网络(CNN)已成为语义分割最成功的方法。早期的方法[18,23]是基于区域提议的方法,通过对区域提议进行分类来生成分割结果。最近,完全卷积网络(FCNN)[36,5,10]展示了有效的特征生成和端到端训练,并因此成为语义分割最受欢迎的选择。FCNN还被广泛应用于其他密集预测任务,例如深度估计[15,13,33]、图像恢复[14]和图像超分辨率[12]。这里提出的方法也基于完全卷积风格的网络。

        基于FCNN的方法通常存在低分辨率预测的限制。有许多提出的技术来解决这个限制,并旨在生成高分辨率的预测结果。在[5]中,采用了基于空洞卷积的方法DeepLab-CRF,直接输出中等分辨率的分数图,然后利用颜色对比信息应用密集CRF方法[27]来优化边界。CRF-RNN [47]通过实现循环层来扩展这种方法,以端到端学习密集CRF和FCNN。解卷积方法[38,2]学习解卷积层来上采样低分辨率的预测结果。在[34]中的深度估计方法采用超像素池化来输出高分辨率的预测结果。

        存在一些利用中间层特征进行分割的方法。Long等人的FCN方法[36]在中间层添加预测层,以生成多分辨率的预测分数。他们对多分辨率的分数进行平均,生成最终的预测掩码。他们的系统采用阶段性训练而非端到端训练。Hypercolumn方法[22]合并了来自中间层的特征,并学习密集分类层。该方法也采用阶段性训练策略而非端到端训练。SegNet [2]和U-Net [40]都在解卷积架构中应用跳过连接,以利用中间层的特征。

        尽管存在一些相关工作,如何有效地利用中间层特征仍然是一个开放的问题。我们提出了一种新颖的网络架构RefineNet来解决这个问题。RefineNet的网络架构与现有方法有所不同。它由一些特别设计的组件组成,能够通过利用低级视觉特征来改进粗糙的高级语义特征。特别是,RefineNet采用了短程和长程的残差连接,并使用恒等映射,实现了整个系统的有效端到端训练,从而帮助实现卓越的性能。全面的实证结果清楚地验证了我们的新颖网络架构在利用中间层特征方面的有效性。

2.背景

        在介绍我们的方法之前,我们首先详细回顾完全卷积网络(FCN)用于语义分割[36]的结构,并讨论最近的空洞卷积技术[6],该技术专门设计用于生成高分辨率的预测结果。非常深的卷积神经网络(CNN)在目标识别问题上显示出出色的性能。具体而言,最近提出的残差网络(ResNet)[24]在早期架构上显示出了巨大的改进,而且已经公开提供了在ImageNet识别任务上预训练的ResNet模型。因此,在接下来的内容中,我们将采用ResNet作为我们进行语义分割的基本构建模块。然而,请注意,将其替换为任何其他深度网络也是简单直接的。由于语义分割可以视为密集分类问题,因此可以很容易地修改ResNet模型以适应这个任务。这是通过将单标签预测层替换为密集预测层来实现的,该层在每个像素点上输出每个类别的分类置信度。这个方法在图2(a)中有所说明。正如可以看到的,在ResNet的前向传播过程中,特征图(层的输出)的分辨率会降低,而特征深度,即每层的特征图数目(或通道),会增加。前者是由于卷积和池化操作中的步幅造成的。

        根据输出特征图的分辨率,ResNet层可以自然地分为4个块,如图2(a)所示。通常情况下,步幅被设置为2,因此当从一个块传递到下一个块时,特征图的分辨率减少到一半。这种顺序的子采样有两个效果:首先,它增加了深层卷积的感受野,使得滤波器能够捕获更多的全局和上下文信息,这对于高质量的分类是至关重要的;其次,为了保持训练的高效性和可行性,这是必要的,因为每个层都包含大量的滤波器,因此产生的输出具有相应数量的通道。因此,特征图的通道数和分辨率之间存在权衡。通常情况下,最终的特征图输出在每个空间维度上比原始图像小32倍(但具有数千个通道)。这个低分辨率的特征图会丢失早期低级滤波器捕捉到的重要视觉细节,导致分割地图较粗糙。这个问题是基于深度CNN的分割方法的一个众所周知的局限性。

        为了避免降低分辨率同时保持较大的感受野,一种替代方法是使用扩张(atrous)卷积。这种方法在[6]中介绍,并在语义分割中显示出最先进的性能。子采样操作被移除(步幅从2更改为1),并且第一个块之后的所有卷积层都使用扩张卷积。这种扩张卷积实际上是一个子采样卷积核,它可以增加滤波器的感受野大小,而不增加必须学习的权重的数量(参见图2(b)中的示例)。即使如此,这种方法在内存方面有很大的成本,因为与图像子采样方法不同,我们必须在更高的分辨率下保留大量的特征图。例如,如果我们保留所有通道的所有层的分辨率至少为原始图像分辨率的1/4,并且考虑到典型的滤波器通道数为1024,那么我们可以看到即使是高端GPU的内存容量也很快被非常深的网络所耗尽。因此,在实践中,扩张卷积方法通常使用深度网络时的分辨率预测不超过原始图像的1/8而不是1/4。与扩张卷积方法相比,本文提出了一种方法,既能享受降低分辨率的内存和计算优势,又能产生高效且高分辨率的分割预测,如下一节所述。

3.提出的方法

        我们提出了一个新的框架,通过使用通用的构建块RefineNet,提供了多条路径,从不同分辨率和可能的长程连接中吸收信息。图2(c)展示了一种可能的构建块排列方式,以实现我们对高分辨率语义分割的目标。

3.1.多路精细化

        如前所述,我们旨在利用多级特征进行高分辨率预测,并通过长程残差连接进行信息融合。RefineNet提供了一种通用的方法,将粗粒度的高级语义特征与细粒度的低级特征融合,生成高分辨率的语义特征图。设计的一个关键方面是确保梯度能够轻松地通过网络向后传播,一直到早期的低级层,通过长程残差连接,确保整个网络可以端到端地进行训练。对于我们的标准多路径架构,我们根据特征图的分辨率将预训练的ResNet(在ImageNet上训练)分成4个块,并使用4个级联的RefineNet单元的架构,每个单元直接连接到一个ResNet块的输出以及级联中的前一个RefineNet块。然而,请注意,这样的设计并不唯一。实际上,我们灵活的架构可以简单地探索不同的变体。例如,一个RefineNet块可以接受来自多个ResNet块的输入。在第4.3节中,我们将分析一个2级联版本、一个单块方法以及一个2尺度7路径架构。

        我们将连接到ResNet中的第m个块的RefineNet块表示为RefineNet-m。在实践中,每个ResNet输出都通过一个卷积层进行维度适应。尽管所有的RefineNet都共享相同的内部结构,但它们的参数是独立的,这样可以更灵活地适应不同级别的细节。根据图2(c)中的示意图自底向上,我们从ResNet中的最后一个块开始,将ResNet块4的输出连接到RefineNet-4。在这里,RefineNet-4只有一个输入,并且RefineNet-4作为一组额外的卷积层,将预训练的ResNet权重适应到我们的任务上,即语义分割。在下一个阶段,RefineNet-4的输出和ResNet块3的输出被作为2个路径的输入传递给RefineNet-3。RefineNet-3的目标是利用来自ResNet块3的高分辨率特征来优化RefineNet-4在前一个阶段输出的低分辨率特征图。类似地,RefineNet-2和RefineNet-1通过融合后面层的高级信息和前面层的高分辨率但低级别的特征来重复这个逐阶段的优化过程。作为最后一步,最终的高分辨率特征图被送入一个密集的softmax层,以生成密集的分数图形式的最终预测。然后,使用双线性插值将该分数图上采样以匹配原始图像的大小。请注意,整个网络可以高效地进行端到端的训练。

        重要的是要注意,我们在ResNet块和RefineNet模块之间引入了长程残差连接。在前向传播过程中,这些长程残差连接传递了编码视觉细节的低级特征,用于优化粗糙的高级特征图。在训练步骤中,长程残差连接允许直接的梯度传播到早期的卷积层,这有助于有效的端到端训练。

 图2.全卷积方法进行密集分类的比较。标准的多层CNN,如ResNet (a),在特征图的缩小过程中会丢失细节结构。扩张卷积 (b)通过引入空洞滤波器来弥补这个缺点,但是其训练计算量大,在现代GPU上很快达到内存极限。我们提出的被称为RefineNet (c)的架构利用不同阶段的卷积中的各个细节级别,并将它们融合起来,以获得高分辨率的预测,而无需维护大型的中间特征图。详见正文和图3。

 

图3.我们的多路径细化网络架构RefineNet的各个组件。RefineNet中的组件使用具有恒等映射的残差连接,使得梯度可以直接在网络中局部传播,并通过长程残差连接直接传递到输入路径,从而实现整个系统的有效端到端训练。

3.2.细化网络

        图3(a)展示了一个RefineNet块的结构。在图2(c)中显示的多路径概述中,RefineNet-1只有一个输入路径,而所有其他的RefineNet块都有两个输入。然而,请注意,我们的架构是通用的,每个Refine块可以很容易地修改为接受任意数量的具有任意分辨率和深度的特征图。

残差卷积单元。每个RefineNet块的第一部分由一个自适应卷积集组成,主要对我们的任务微调预训练的ResNet权重。为此,每个输入路径依次通过两个残差卷积单元(RCU),这是原始ResNet [24]中卷积单元的简化版本,在其中批量归一化层被移除(参见图3(b))。在我们的实验中,RefineNet-4的每个输入路径的滤波器数量设置为512,其余的为256。

多分辨率融合。所有路径的输入通过多分辨率融合块融合成一个高分辨率特征图,如图3(c)所示。这个块首先应用卷积进行输入适应,生成具有相同特征维度(在输入中最小的维度)的特征图,然后将所有(较小的)特征图上采样到输入的最大分辨率上。最后,所有特征图通过求和进行融合。该块中的输入适应也有助于在不同路径上适当地重新缩放特征值,这对于后续的求和融合非常重要。如果只有一个输入路径(例如,图2(c)中RefineNet-4的情况),输入路径将直接通过此块而不进行任何更改。

链式残差池化。输出特征图然后通过链式残差池化块,如图3(d)所示。提出的链式残差池化旨在从大范围的图像区域中捕获背景上下文。它能够高效地汇聚具有多个窗口大小的特征,并使用可学习的权重将它们融合在一起。具体而言,该组件是由多个池化块组成的链,每个池化块包括一个最大池化层和一个卷积层。一个池化块将前一个池化块的输出作为输入。因此,当前的池化块能够重复使用前一个池化操作的结果,从而在不使用大型池化窗口的情况下访问大范围的特征。在我们的实验中,如果没有进一步指定,我们使用两个步长为1的池化块。所有池化块的输出特征图通过残差连接与输入特征图进行融合,通过求和运算。请注意,我们选择使用残差连接也在这个构建块中持续存在,这再次在训练过程中促进了梯度传播。在一个池化块中,每个池化操作后面都是卷积层,用于加权求和融合。预期这个卷积层将在训练过程中学习适应池化块的重要性。

输出卷积。每个RefineNet块的最后一步是另一个残差卷积单元(RCU)。这导致每个块之间有三个RCU的序列。为了反映这种行为,在最后的RefineNet-1块中,我们在最后的softmax预测步骤之前放置了两个额外的RCU。这里的目标是对多路径融合的特征图进行非线性操作,以生成用于进一步处理或最终预测的特征。通过这个块后,特征维度保持不变。

3.3.在RefineNet中的身份映射

        需要注意的是,RefineNet中的所有卷积组件都是受到残差连接背后的思想的启发,并遵循恒等映射的规则。这使得梯度能够有效地通过RefineNet进行反向传播,并促进级联多路径细化网络的端到端学习。使用具有恒等映射的残差连接使得梯度能够直接从一个块传播到任何其他块,正如He等人最近展示的那样。这个概念鼓励保持捷径连接的清晰信息路径,以确保这些连接不会被任何非线性层或组件“阻塞”。相反,非线性操作被放置在主要信息路径的分支上。我们遵循这个指导方针来开发RefineNet中的各个组件,包括所有的卷积单元。正是这个特定的策略使得多级联的RefineNet能够有效地进行训练。需要注意的是,我们在链式残差池化块中包含了一个非线性激活层(ReLU)。我们观察到这个ReLU对于后续的池化操作的有效性很重要,它还使得模型对学习率的变化不太敏感。我们观察到,在每个RefineNet块中只有一个ReLU并不会显著降低梯度流的有效性。

        在RefineNet中,我们同时使用了短程和长程的残差连接。短程残差连接指的是在一个RCU或残差池化组件中的局部快捷连接,而长程残差连接指的是RefineNet模块和ResNet块之间的连接。通过长程残差连接,梯度可以直接传播到ResNet的早期卷积层,从而实现了所有网络组件的端到端训练。

        融合模块将多个快捷路径的信息进行融合,可以将其视为对多个残差连接进行求和融合,并进行必要的维度或分辨率适应。在这个方面,多分辨率融合模块的作用类似于传统ResNet中的“求和”融合。在RefineNet中有一些层,特别是在融合模块中,执行线性特征转换操作,如线性特征降维或双线性上采样。这些层被放置在快捷路径上,与ResNet中的情况类似。在ResNet中,当一个快捷连接穿过两个块时,它会在快捷路径中包含一个卷积层进行线性特征维度的适应,确保特征维度与下一个块中的求和匹配。由于这些层只使用线性变换,梯度仍然可以有效地通过这些层传播。

表1.在Person-Part数据集上的对象解析结果。我们的方法取得了最佳性能(加粗显示)。

 

表2.在NYUDv2和Person-Part上的消融实验。初始化、链式池化和多尺度评估的结果如下:

 

表3.在NYUDv2(40类)上的分割结果。 请注意,由于缺乏具体的结果数据,此处无法提供具体的数值。

 

4.实验

4.1.对象解析

4.2.语义分割

5.结论

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

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

相关文章

Matplotlib figure图形对象

通过前面的学习,我们知道matplotlib.pyplot模块能够快速地生成图像,但如果使用面向对象的编程思想,我们就可以更好地控制和自定义图像。 在 Matplotlib 中,面向对象编程的核心思想是创建图形对象(figure object&#…

第十三章——类继承

面向对象编程的主要目的之一是提供可重用的代码。(重用经过测试的代码比重新编写代码要好的多) C类提供了更高层次的重用性。很多厂商提供了类库,类组合了数据表示和类方法,因此提供了比函数库更加完整的程序包。通常类库是以源代…

文件IO_文件读写(附Linux-5.15.10内核源码分析)

目录 1.什么是文件偏移量? 1.1 文件偏移量介绍 1.2 文件偏移量重点 1.3 文件偏移量工作原理 2.文件偏移量设置 2.1 lseek函数 2.2 lseek内核源码分析 3.写文件 3.1 write函数 3.2 write内核源码分析 4.读文件 4.1 read函数 4.2 read内核源码分析 5.文…

物流难统计、难管理?学会这招,问题迎刃而解

在当今数字化的时代,商家面临着诸多物流挑战。物流数据人工统计成本高、管理难、决策难是很常见的问题。本文将探讨如何通过智能数据分析解决这些问题,帮助商家提升物流效率和管理能力。 物流数据人工统计,难决策 物流数据沉淀全靠人工线下…

Vue3_简介、CompositionVPI、新的组件

文章目录 Vue3快速上手1.Vue3简介2.Vue3带来了什么1.性能的提升2.源码的升级3.拥抱TypeScript4.新的特性 一、创建Vue3.0工程1.使用 vue-cli 创建2.使用 vite 创建 二、常用 Composition API1.拉开序幕的setup2.ref函数3.reactive函数4.Vue3.0中的响应式原理vue2.x的响应式Vue3…

labview实现呼吸灯颜色渐变效果

呼吸灯效果具有美好的视觉观感,前一段时期感受了一位大佬在MCU中实现呼吸灯颜色渐变效果,很是震撼。这引起了我的兴趣,本文则是实现一种呼吸灯效果(主要在于颜色的渐变体现)。 程序整体视图 程序框图 公式节点程序 int red_is_0 red 0 ?…

探索MR与AIGC技术的发展机遇:教育、医疗领域的前景展望

在当今科技迅猛发展的时代,混合现实(MR)和增强智能生成创作(AIGC)技术正逐渐成为教育、医疗领域中的关键驱动力。这两项前沿技术的结合为我们带来了无限的可能性和创新的机遇。 MR技术在教育领域中的发展与机遇是广泛而…

非洲秃鹫优化算法(AVOA)(含MATLAB代码)

先做一个声明:文章是由我的个人公众号中的推送直接复制粘贴而来,因此对智能优化算法感兴趣的朋友,可关注我的个人公众号:启发式算法讨论。我会不定期在公众号里分享不同的智能优化算法,经典的,或者是近几年…

LayUI框架实现OA会议系统——增删改查

目录 前言 1. 配置准备 1.1 Layui框架 1.2 mysql数据库表 1.3 用户管理JSP页面 1.4 新增、修改用户共用界面 2. 后台编写 2.1 编写UserDao类增删改查方法 2.2 R工具类 2.3 BaseDao数据库查询方法 2.4 UserAction控制器类 3. 前台JS编写 3.1 userManage页面JS 3.2…

测试报告?Python自动化测试-Allure测试报告使用大全,一篇全通透

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 安装并配置环境变…

工业相机的基础参数释义

景深: 可以清晰拍摄被测物的距离范围。 工作距离: 相机镜头至被测物的距离。 物像距离: 被测物至芯片靶面的距离。 像元尺寸: 一个像素在长和宽方向上所代表的实际大小,单位通常为微米。像元尺寸越大,分辨率…

记录stm32c8t6使用TIM4_CH1、TIM4_CH2输出PWM波控制编码电机出现的问题

由于之前是使用PB9、PB7引脚即TIM4_ch3\TIM4_ch4,由于项目更改为c8t6的PB、PB7引脚(TIM4_ch3\TIM4_ch4) 改为配置后发现只有一边的轮子可以转到,明明配置没什么问题,编译也没有报错,最后将pwm的调制模式更改…

Android 进程与进程之间的通信--AIDL详细教程,以传递对象为例,两个app实现

我这里案例是 通过 IPC 传递对象 (以DemoBean类为例) 如下: AIDL 使用一种简单语法,允许您通过一个或多个方法(可接收参数和返回值)来声明接口。参数和返回值可为任意类型,甚至是 AIDL 生成的其…

TypeScript 学习笔记 环境安装-类型注解-语法细节-类-接口-泛型

文章目录 TypeScript 学习笔记概述TypeScript 开发环境搭建 类型注解类型推断 数据类型JS的7个原始类型Array数组object、Object 和 {}可选属性 ? 和 可选链运算符?. function函数TS类型: any类型 | unknow类型TS类型: void类型TS类型:never类型 (几乎…

数据库应用:CentOS 7离线安装MySQL与Nginx

目录 一、理论 1.安装依赖 二、实验 1.离线安装MySQL与Nginx 2.离线安装Nginx 三、问题 1.执行nginx -v命令报错 四、总结 一、理论 1.安装依赖 (1)概念 安装依赖是指在软件开发中,为了运行或者编译一个程序或者库,在计…

JVM——类加载和垃圾回收

目录 前言 JVM简介 JVM内存区域划分 JVM的类加载机制 1.加载 双亲委派模型 2.验证 验证选项 3.准备 4.解析 5.初始化 触发类加载 JVM的垃圾回收策略 GC 一:找 谁是垃圾 1.引用计数 2.可达性分析 (这个方案是Java采取的方案&#x…

k210学习篇(一)环境搭建

一、为什么选择Canmv开发板? 便宜!便宜!便宜!淘宝200即可买到一个能带摄像头和LCD屏等等的开发板 二、利用Maix Hub在线训练 Maix Hub官网https://maixhub.com/home Maix Hub使用教程:K210学习笔记——MaixHub在线训练模型(新版) 注意: 三、配置开发环境 1.MaixPy IDE…

某网站提交登陆信息加密JS逆向实战分析

1. 写在前面 对于爬虫开发者来说,职业生涯中可能或多或少会遇到各种各样的网站,其中有些必要要求登陆才能浏览。那么模拟登陆的时候发现提交的登陆信息(用户名、密码)都是经过加密后的,如何处理?这里找到了…

我只改五行代码,接口性能提升了 10 倍!

背景 某公司的一个 ToB 系统,因为客户使用的也不多,没啥并发要求,就一直没有经过压测。这两天来了一个“大客户”,对并发量提出了要求:核心接口与几个重点使用场景单节点吞吐量要满足最低500/s的要求。 当时一想&am…

C++ IO流

文章目录 C语言的输入与输出流是什么?CIO流C标准IO流C文件流 stringstream的简单介绍 C语言的输入与输出 在C语言中,我们使用最频繁的输入输出方式为: scanf 和 printf. scanf : 从输入设备(键盘)读取数据,并将值存放在变量中.printf: 将指定的文字/字符串输出到标准输出设备…