第十七章:Dual Attention Network for Scene Segmentation ——双重注意力网络用于场景分割

news2025/1/7 6:47:17

0.摘要

        在本文中,我们通过基于自注意机制捕捉丰富的上下文依赖来解决场景分割任务。与以往通过多尺度特征融合来捕捉上下文的方法不同,我们提出了一种双重注意力网络(DANet),以自适应地将局部特征与全局依赖性相结合。具体而言,我们在扩张的FCN之上附加了两种类型的注意力模块,分别对空间和通道维度中的语义依赖关系进行建模。位置注意力模块通过对所有位置的特征进行加权求和,选择性地聚合每个位置的特征。无论距离如何,相似的特征都会相互关联。同时,通道注意力模块通过整合所有通道图像中的相关特征,选择性地强调相互依赖的通道图像。我们将两个注意力模块的输出相加,进一步改善特征表示,从而为更精确的分割结果做出贡献。我们在三个具有挑战性的场景分割数据集上取得了最新的分割性能,即Cityscapes,PASCAL Context和COCO Stuff数据集。特别是,在不使用粗数据的情况下,我们在Cityscapes测试集上实现了81.5%的Mean IoU分数。

图1:场景分割的目标是识别包括物体和区域在内的每个像素。物体/区域的各种尺度、遮挡和光照变化使得解析每个像素变得具有挑战性。

1.引言

        场景分割是一个基础且具有挑战性的问题,其目标是将场景图像分割和解析为与语义类别相关的不同图像区域,包括场景元素(如天空、道路、草地)和离散对象(如人、汽车、自行车)。对这个任务的研究可以应用于潜在的应用场景,如自动驾驶、机器人感知和图像编辑。为了有效地完成场景分割任务,我们需要区分一些容易混淆的类别,并考虑具有不同外观的对象。例如,“田地”和“草地”的区域通常难以区分,“汽车”的对象可能经常受到尺度、遮挡和光照的影响。因此,有必要增强像素级别识别的特征表示的区分能力。

        最近,基于全卷积网络(FCN)[13]的最先进方法被提出来解决上述问题。一种方法是利用多尺度上下文融合。例如,一些方法[3,4,30]通过结合不同的扩张卷积和池化操作生成的特征图来聚合多尺度上下文。另一些方法[15,28]通过扩大卷积核大小、引入有效的编码层等方式来捕捉更丰富的全局上下文信息。此外,编码器-解码器结构[6,10,16]被提出来融合中层和高层语义特征。尽管上下文融合有助于捕捉不同尺度的物体,但它不能从全局视角利用物体或场景元素之间的关系,而这对于场景分割也是必不可少的。

        另一类方法利用循环神经网络来利用长距离依赖关系,从而提高场景分割的准确性。基于2D LSTM网络的方法[1]被提出来捕捉标签之间的复杂空间依赖关系。工作[18]构建了一个带有有向无环图的循环神经网络,以捕捉局部特征之间丰富的上下文依赖关系。然而,这些方法通过循环神经网络隐式地捕捉全局关系,其有效性高度依赖于长期记忆的学习结果。

        为了解决上述问题,我们提出了一种新的框架,称为双重注意力网络(DANet),用于自然场景图像分割,如图2所示。它引入了自注意力机制,分别捕捉空间和通道维度上的特征依赖关系。具体而言,我们在扩张FCN的顶部附加了两个并行的注意力模块。一个是位置注意力模块,另一个是通道注意力模块。对于位置注意力模块,我们引入自注意力机制来捕捉特征图中任意两个位置之间的空间依赖关系。对于某个位置的特征,通过加权求和聚合所有位置的特征来更新,其中权重由对应两个位置之间的特征相似性决定。也就是说,具有相似特征的任意两个位置可以相互改进,无论它们在空间维度上的距离如何。对于通道注意力模块,我们使用类似的自注意力机制来捕捉任意两个通道图之间的通道依赖关系,并使用所有通道图的加权和来更新每个通道图。最后,这两个注意力模块的输出被融合在一起,进一步增强特征表示。

        需要注意的是,与之前的方法[4,30]相比,我们的方法在处理复杂多样的场景时更加有效和灵活。以图1中的街景为例,

        首先,由于光照和视角的原因,第一行中的一些“人”和“红绿灯”是不显眼或不完整的对象。如果仅仅探索简单的上下文嵌入,来自主导显著对象(如汽车、建筑物)的上下文会影响这些不显眼的对象的标注。相比之下,我们的注意力模型选择性地聚合不显眼对象的相似特征,突出它们的特征表示,并避免了显著对象的影响。

        其次,“汽车”和“人”的尺度是多样的,识别这样多样化的对象需要不同尺度上的上下文信息。也就是说,不同尺度上的特征应该被平等对待,以表示相同的语义。我们的带有注意力机制的模型旨在从全局视角自适应地整合任何尺度上的相似特征,这在一定程度上可以解决上述问题。

        第三,我们明确考虑了空间和通道关系,使场景理解可以从长距离依赖中受益。

我们的主要贡献可以总结如下:

  • 我们提出了一种新颖的双重注意力网络(DANet),利用自注意力机制增强场景分割的特征表示的辨别能力。
  • 我们提出了位置注意力模块,用于学习特征的空间相互依赖关系,设计了通道注意力模块来建模通道之间的依赖关系。通过对局部特征建模丰富的上下文依赖关系,显著提高了分割结果的准确性。
  • 我们在包括Cityscapes数据集[5]、PASCAL Context数据集[14]和COCO Stuff数据集[2]在内的三个流行基准上取得了新的最先进结果。

2.相关工作

语义分割。基于完全卷积网络(FCN)的方法在语义分割方面取得了重大进展。已经提出了几种模型变体来增强上下文聚合。

        首先,Deeplabv2 [3]和Deeplabv3 [4]采用扩张空间金字塔池化来嵌入上下文信息,其中包括具有不同扩张率的并行扩张卷积。PSPNet [30]设计了一个金字塔池化模块,收集有效的上下文先验,包含不同尺度的信息。编码器-解码器结构[?,6,8,9]融合中级和高级语义特征,以获得不同尺度的上下文。

        第二,学习局部特征的上下文依赖性也有助于特征表示。DAG-RNN [18]使用循环神经网络模型有向无环图,捕捉丰富的上下文依赖关系。PSANet [31]通过卷积层和空间维度中的相对位置信息捕捉像素级关系。同时进行的工作OCNet [27]采用自注意力机制与ASPP结合,利用上下文依赖关系。此外,EncNet [28]引入了通道注意力机制来捕捉全局上下文。

自注意力模块。注意力模块可以建模长距离依赖关系,并广泛应用于许多任务[11,12,17,19-21]。特别是,[21]首次提出了自注意力机制,以获取输入的全局依赖关系,并将其应用于机器翻译。同时,注意力模块在图像视觉领域的应用也越来越多。[29]引入了自注意力机制来学习更好的图像生成器。与之相关的工作[23]主要探索了在视频和图像的时空维度中非局部操作的有效性。与以往的工作不同,我们将自注意力机制扩展到场景分割任务中,并精心设计了两种类型的注意力模块,以捕捉丰富的上下文关系,以实现更好的特征表示和类内紧凑性。全面的实证结果验证了我们提出的方法的有效性。图2:双重注意力网络的概述。(最佳浏览效果为彩色)

3.双重注意力网络

        在本节中,我们首先介绍了我们网络的总体框架,然后分别介绍了两个注意力模块,它们在空间和通道维度上捕捉长距离的上下文信息。最后,我们描述了如何将它们聚合在一起进行进一步的优化。

3.1.概述

        在场景分割中,由于场景中的物体或区域在尺度、光照和视角上具有多样性。由于卷积操作会导致局部感受野,与相同标签的像素对应的特征可能会有一些差异。这些差异引入了类内不一致性,影响了识别准确性。为了解决这个问题,我们通过注意力机制建立特征之间的关联,探索全局上下文信息。我们的方法能够自适应地聚合长距离的上下文信息,从而改善场景分割的特征表示。

        如图2所示,我们设计了两种类型的注意力模块,以在通过扩张残差网络生成的局部特征上绘制全局上下文,从而获得更好的像素级预测的特征表示。我们使用带有扩张策略的预训练残差网络作为骨干网络。请注意,我们移除了下采样操作,并在最后两个ResNet块中使用扩张卷积,从而将最终特征图的大小扩大到输入图像的1/8。这样可以保留更多细节而不增加额外的参数。然后,扩张残差网络的特征将被输入到两个并行的注意力模块中。以图2上半部分的空间注意力模块为例,我们首先应用卷积层来获得降维后的特征。然后将特征输入到位置注意力模块中,并通过以下三个步骤生成具有空间长距离上下文信息的新特征。第一步是生成一个空间注意力矩阵,用于建模特征之间的空间关系。接下来,我们在注意力矩阵和原始特征之间进行矩阵乘法。第三步,我们对上述乘积结果矩阵和原始特征进行逐元素求和操作,以获得反映长距离上下文的最终表示。与此同时,通道维度中的长距离上下文信息由通道注意力模块捕捉。捕捉通道关系的过程与位置注意力模块类似,只是在第一步中,通过计算通道维度上的通道注意力矩阵。最后,我们将两个注意力模块的输出聚合起来,以获得更好的特征表示,用于像素级预测。图3:(A)和(B)中详细说明了位置注意力模块和通道注意力模块的细节。(最佳浏览效果为彩色)

3.2.位置注意力模块

        判别特征表示对于场景理解至关重要,可以通过捕捉长距离的上下文信息来获得。然而,许多研究[15,30]表明,传统FCN生成的局部特征可能会导致物体和区域的错误分类。为了在局部特征上建模丰富的上下文关系,我们引入了位置注意力模块。位置注意力模块将更广泛的上下文信息编码到局部特征中,从而增强了它们的表示能力。接下来,我们详细说明自适应聚合空间上下文的过程。如图3(A)所示,给定一个局部特征A ∈ RC×H×W,我们首先将其输入到卷积层中生成两个新的特征图B和C,分别为fB;Cg ∈ RC×H×W。然后,我们将它们重新调整为RC×N的形状,其中N = H × W是像素的数量。然后,我们对C的转置和B进行矩阵乘法,并应用softmax层来计算空间注意力映射S ∈ RN×N:

 其中sji衡量了第i个位置对第j个位置的影响。两个位置的特征表示越相似,它们之间的相关性就越大。同时,我们将特征A输入到卷积层中生成一个新的特征图D ∈ RC×H×W,并将其重塑为RC×N的形状。然后,我们对D和S的转置进行矩阵乘法,并将结果重塑为RC×H×W的形状。最后,我们将其乘以一个尺度参数α,并与特征A进行逐元素求和操作,得到最终的输出E ∈ RC×H×W,如下所示:

 其中α的初始值为0,并逐渐学习分配更多的权重[29]。从公式2可以推断出,每个位置上的结果特征E是所有位置上特征和原始特征的加权和。因此,它具有全局的上下文视图,并根据空间注意力映射选择性地聚合上下文。相似的语义特征实现了相互增益,从而提高了类内的紧凑性和语义一致性。

3.3.通道注意力模块

        高级特征的每个通道图可以被视为类别特定的响应,不同的语义响应彼此相关。通过利用通道图之间的相互依赖关系,我们可以强调相互依赖的特征图并改善特定语义的特征表示。因此,我们构建了一个通道注意力模块来明确建模通道之间的相互依赖关系。通道注意力模块的结构如图3(B)所示。与位置注意力模块不同,我们直接从原始特征A ∈ RC×H×W 计算通道注意力映射X ∈ RC×C。具体来说,我们将A重塑为RC×N,然后在A和A的转置之间进行矩阵乘法。最后,我们应用一个softmax层来获得通道注意力映射X ∈ RC×C:

其中xji衡量了第i个通道对第j个通道的影响。此外,我们对X的转置和A进行矩阵乘法,并将它们的结果重塑为RC×H×W的形状。然后,我们将结果乘以一个尺度参数β,并与A进行逐元素求和操作,得到最终的输出E ∈ RC×H×W:

 其中β逐渐学习一个从0开始的权重。公式4显示,每个通道的最终特征是所有通道特征和原始特征的加权和,这模拟了特征图之间的长距离语义依赖关系。它有助于提高特征的可区分性。需要注意的是,在计算两个通道之间的关系之前,我们没有使用卷积层来嵌入特征,因为这样可以保持不同通道图之间的关系。此外,与最近的研究[28]通过全局池化或编码层来探索通道关系不同,我们利用所有相应位置的空间信息来建模通道之间的相关性。

3.4.注意力模块与网络的嵌入

        为了充分利用长程上下文信息,我们从这两个注意力模块中聚合特征。具体而言,我们通过卷积层对两个注意力模块的输出进行转换,并进行逐元素求和以完成特征融合。最后,跟随一个卷积层来生成最终的预测图。我们没有采用级联操作,因为它需要更多的GPU内存。需要注意的是,我们的注意力模块简单且可以直接插入现有的FCN流程中。它们没有增加太多参数,却能有效加强特征表示。

4.实验

        为了评估所提出的方法,我们在Cityscapes数据集 [5]、PASCAL VOC2012 [7]、PASCAL Context数据集 [14]和COCO Stuff数据集 [2]上进行了全面的实验。实验结果表明,DANet在这三个数据集上达到了最先进的性能。在接下来的小节中,我们首先介绍数据集和实现细节,然后在Cityscapes数据集上进行了一系列消融实验。最后,我们报告了在PASCAL VOC 2012、PASCAL Context和COCO Stuff上的实验结果。

4.1.数据集和实现细节

Cityscapes数据集包含了来自50个不同城市的5,000张图像。每个图像具有2048×1024像素,具有19个语义类别的高质量像素级标签。训练集中有2,979张图像,验证集中有500张图像,测试集中有1,525张图像。我们在实验中没有使用粗糙数据。

PASCAL VOC 2012数据集包含10,582张用于训练的图像,1,449张用于验证,以及1,456张用于测试。该数据集涉及20个前景对象类别和一个背景类别。

PASCAL Context数据集为整个场景提供了详细的语义标签,其中包含4,998张用于训练的图像和5,105张用于测试的图像。我们按照[10,28]的方法,对最常见的59个类别以及一个背景类别(总共60个类别)进行了评估。

COCO Stuff数据集包含9,000张用于训练的图像和1,000张用于测试的图像。我们按照[6,10]的方法,对包括80个对象和91个物品的171个类别进行了每个像素的注释,并报告了我们的实验结果。图4:Cityscapes验证集上位置注意力模块的可视化结果。

图5:Cityscapes验证集上通道注意力模块的可视化结果。

4.1.1.实现细节

        我们基于Pytorch实现了我们的方法。按照[4,28]的方法,在每次迭代之后,我们采用多项学习率策略,初始学习率乘以(1−total iter/iter)^0.9。对于Cityscapes数据集,基础学习率设置为0.01。动量和权重衰减系数分别设置为0.9和0.0001。我们使用了Synchronized BN [28]来训练我们的模型。Cityscapes数据集的批大小设置为8,其他数据集的批大小设置为16。在采用多尺度数据增强时,我们将COCO Stuff的训练时间设置为180个epochs,其他数据集设置为240个epochs。按照[3]的方法,在使用两个注意力模块时,我们在网络末端采用多损失函数。在Cityscapes数据集的消融实验中,我们使用随机裁剪(裁剪尺寸为768)和随机左右翻转进行数据增强。

4.2.在Cityscapes数据集上的结果

4.2.1.注意力模块的消融研究

        我们在膨胀网络的顶部采用了双重注意力模块,以捕捉更好的场景理解所需的长程依赖关系。为了验证注意力模块的性能,我们在表格1中进行了不同设置的实验。

        如表1所示,注意力模块显著提升了性能。与基线FCN(ResNet-50)相比,采用位置注意力模块的结果为75.74%的平均IoU,改进了5.71%。同时,单独采用通道上下文模块的性能比基线提高了4.25%。当我们将两个注意力模块整合在一起时,性能进一步提升至76.34%。此外,当我们采用更深的预训练网络(ResNet-101)时,具有两个注意力模块的网络在分割性能上显著优于基线模型,提高了5.03%。结果表明,注意力模块对场景分割带来了很大的好处。

        位置注意力模块的效果可以在图4中可视化。使用位置注意力模块,一些细节和物体边界更清晰,例如第一行的“电线杆”和第二行的“人行道”。选择性地融合局部特征增强了细节的区分能力。同时,图5展示了使用我们的通道注意力模块后,一些被错误分类的类别现在被正确分类,例如第一行和第三行的“公交车”。通道图之间的选择性集成有助于捕捉上下文信息。语义一致性明显提高了。

表1:Cityscapes验证集上的消融研究。PAM代表位置注意力模块,CAM代表通道注意力模块。

4.2.2.改进策略的消融研究

根据文献[4]的方法,我们采用相同的策略进一步提高性能。具体策略如下:

  1. 数据增强(DA):使用随机缩放进行数据增强。
  2. 多网格(Multi-Grid):在最后一个ResNet块中,我们采用不同尺寸(4、8、16)的网格层次结构。
  3. 多尺度输入(MS):在推理过程中,我们对8个图像尺度(0.5、0.75、1、1.25、1.5、1.75、2、2.2)的分割概率图进行平均。 实验结果如表2所示。使用随机缩放进行数据增强使性能提高了近1.26%,这表明网络受益于丰富的训练数据尺度多样性。采用多网格方法可以获得更好的预训练网络特征表示,进一步提高了1.11%的性能。最后,分割图融合将性能进一步提升到81.50%,超过了著名方法Deeplabv3 [4](Cityscapes验证集上的79.30%)2.20%。

表2:Cityscape验证集上不同策略的性能比较。DANet-101代表使用ResNet-101作为基础网络的DANet,DA代表使用随机缩放进行数据增强。Multi-Grid表示采用多网格方法,MS表示在推理过程中使用多尺度输入。

4.2.3.注意力模块的可视化

        对于位置注意力,整体的自注意力图的大小为(H × W) × (H × W),这意味着对于图像中的每个特定点,都有一个相应的子注意力图,其大小为(H × W)。在图6中,对于每个输入图像,我们选择两个点(标记为#1和#2),并分别在第2列和第3列显示它们对应的子注意力图。我们观察到位置注意力模块可以捕捉清晰的语义相似性和长距离关系。例如,在第一行中,红色点#1标记在一个建筑物上,其注意力图(在第2列)最突出的是建筑物所在的区域。此外,在子注意力图中,即使其中一些边界离点#1很远,边界也非常清晰。至于点#2,它的注意力图主要集中在标记为“车辆”的位置上。在第二行中,对于“交通标志”和“人类”在全局区域中也是如此,尽管相应像素的数量较少。第三行是关于“植被”类和“人类”类。特别是,点#2对附近的“骑手”类没有反应,但却对远处的“人类”类有反应。

        对于通道注意力,直接给出注意力图的可理解可视化是困难的。相反,我们展示一些被关注的通道,以查看它们是否突出显示了清晰的语义区域。在图6中,我们在第4列和第5列显示了第11个和第4个被关注的通道。我们发现,在通道注意力模块增强后,特定语义的响应明显可见。例如,第11个通道映射在所有三个示例中对“车辆”类有响应,而第4个通道映射是针对“植被”类的,这有助于对两个场景类别进行分割。

        简而言之,这些可视化进一步证明了在场景分割中捕捉长距离依赖关系以改善特征表示的必要性。

图6:在Cityscapes验证集上对注意力模块的可视化结果。对于每一行,我们展示一个输入图像,两个与输入图像中标记的点相对应的子注意力图(大小为H×W)。同时,我们给出了来自通道注意力模块输出的两个通道图,这些图分别来自第4个和第11个通道。最后,提供相应的结果和真值。

表3:Cityscapes测试集上的各类别结果。DANet优于现有方法,平均IoU达到了81.5%。

4.2.4.与最先进的方法进行比较

        我们进一步在Cityscapes测试集上将我们的方法与现有方法进行比较。具体而言,我们仅使用精细标注的数据训练了我们的DANet-101,并将我们的测试结果提交到官方评估服务器。结果如表3所示。DANet在多数方面都表现出优势,优于现有方法。特别是,我们的模型在使用相同的ResNet-101骨干网络的情况下,明显优于PSANet [31]。此外,它还超过了使用比我们更强大的预训练模型的DenseASPP [25]。

4.3.在PASCAL VOC 2012数据集上的结果

        我们在PASCAL VOC 2012数据集上进行了实验,以进一步评估我们方法的有效性。在PASCAL VOC 2012验证集上的定量结果如表4所示。我们的注意力模块显著提高了性能,其中DANet-50的改进率超过了基准线3.3%。当我们采用更深的网络ResNet-101时,模型进一步达到了80.4%的平均IoU。在进一步微调我们的最佳模型时,我们采用了PASCAL VOC 2012 trainval集。在PASCAL VOC 2012测试集上的结果如表5所示。

表4:在PASCAL VOC 2012验证集上的消融研究。PAM代表位置注意力模块,CAM代表通道注意力模块。

表5:在PASCAL VOC 2012测试集上的分割结果。

表6:在PASCAL Context测试集上的分割结果。

4.4.在PASCAL Context数据集上的结果

        在本小节中,我们在PASCAL Context数据集上进行了实验,以进一步评估我们方法的有效性。我们采用了与PASCAL VOC 2012数据集相同的训练和测试设置。PASCAL Context的定量结果如表6所示。基准模型(Dilated FCN-50)的平均IoU为44.3%。DANet-50将性能提升到了50.1%。此外,使用预训练的深层网络ResNet101,我们的模型达到了52.6%的平均IoU,大幅优于之前的方法。在之前的工作中,Deeplab-v2和RefineNet通过不同的空洞卷积或编码器不同阶段的多尺度特征融合。此外,它们还使用额外的COCO数据训练模型或采用更深的模型(ResNet152)来提高分割结果。与之前的方法不同的是,我们引入了注意力模块来明确捕捉全局依赖关系,提出的方法可以获得更好的性能。

4.5.在COCO Stuff数据集上的结果

         我们还在COCO Stuff数据集上进行了实验证实我们提出的网络的泛化性能。与之前最先进的方法进行对比的结果如表7所示。结果表明,我们的模型在平均IoU方面达到了39.7%,大幅优于这些方法。在比较的方法中,DAG-RNN [18]利用链式RNN来对2D图像进行建模以捕捉丰富的空间依赖关系,Ding等人[6]在解码器阶段采用门控机制来改进不明显的物体和背景材料分割。我们的方法能够更有效地捕捉长距离的上下文信息,并在场景分割中学习更好的特征表示。

5.总结

        在本文中,我们提出了一种用于场景分割的双重注意力网络(DANet),它利用自注意机制自适应地融合局部语义特征。具体而言,我们引入了位置注意力模块和通道注意力模块,分别在空间和通道维度上捕捉全局依赖关系。消融实验表明,双重注意力模块能够有效地捕捉长距离的上下文信息,并给出更精确的分割结果。我们的注意力网络在四个场景分割数据集(Cityscapes、Pascal VOC 2012、Pascal Context和COCO Stuff)上始终取得了出色的性能。此外,降低计算复杂度和增强模型的鲁棒性也是重要的,这将在未来的工作中进行研究。

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

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

相关文章

.net6中WPF的串口通信和USB通信

之前写过串口通信,不过是winform的。 c#使用串口进行通信_c# 串口通信_故里2130的博客-CSDN博客 今天说一下,.net6中wpf的串口通信和USB通信,在工控行业中,这2种的方式非常多,还有网口通信,它们都是用来和…

TypeScript基础教程

ts与js区别 TypeScript is a syntactic sugar for JavaScript. TypeScript syntax is a superset of ECMAScript 2015 (ES2015) syntax. Every JavaScript program is also a TypeScript program. 语言层面:JavaScript和TypeScript都是ECMAScript(ECMA-2…

【布局优化】基于遗传算法的车间布局优化 车间设施布局优化【Matlab代码#50】

文章目录 【获取资源请见文章第5节:资源获取】1. 车间布局优化2. 基于GA的布局优化模型3. 部分代码展示4. 仿真结果展示5. 资源获取 【获取资源请见文章第5节:资源获取】 1. 车间布局优化 车间设施布置的规划一直是工业工程领域不断研究和探索的内容&am…

【2023江西省研究生数学建模竞赛】第二题 国际“合作-冲突”的演化规律研究 80页论文及Python代码

【2023江西省研究生数学建模竞赛】第二题 国际“合作-冲突”的演化规律研究 80页论文及Python代码 相关链接 【江西省研究生数学建模竞赛】第一题 蒸汽发生器倒U型管内液体流动 70页论文及MATLAB代码 【江西省研究生数学建模竞赛】第一题 蒸汽发生器倒U型管内液体流动 70页论…

<数据结构>并查集

目录 并查集概念 合并 查找集合的数量 并查集类代码实现 并查集概念 并查集和堆一样,都是通过数组来实现树的节点映射,不过并查集作用是,把一堆数据分为不同的几个小集合 不过并查集是森林的概念,并查集的学习可以帮助我们去更…

(QGIS)在QGIS中加载星图地球数据云的数据

本文以“瓦片数据”为例进行操作示例说明,类似矢量数据、地形数据等,方法步骤一样,将URL换成对应数据的示例网址与本人的token即可。 1、星图地球数据云上注册用户 注册登录星图地球数据云网站:https://datacloud.geovisearth.c…

Python 函数(二)

Python 函数(二) 一、可变参数、不可变参数 ​ 什么是可变类型,什么又是不可变类型? 这里我们首先要了解一个东西,在计算机程序中我们定义一个变量,并对其存储一个数值。这里有两个关键概念:内…

数码管显示(静态与动态)

文章目录 一、数码管简介二、数码管连接方式2.1 共阴极2.2 共阳极2.3 数码管真值表 三、数码管驱动方式3.1 静态显示3.2 动态显示四、Cyclone IV数码管原理图 五、模块代码六、引脚分配七、动态显示八、引脚分配 一、数码管简介 数码管分七段数码管和八段数码管。七段和八段的…

为什么不推荐在头文件中直接定义函数?

1. 函数的分文件编写 在C中,函数的分文件编写是一种让代码结构更加清晰的方法,通常可以分为以下几个步骤: 创建后缀名为 .h 的头文件,在头文件中写函数的声明,以及可能用到的其他头文件或命名空间创建后缀名为 .cpp …

ES6迭代器、Set、Map集合和async异步函数

目录 迭代器 Iterator 的作用 Iterator 的遍历过程 Set Map集合 map和对象区别? async异步函数 迭代器 迭代器(Iterator)就是这样一种机制。它是一种接口,为各种不同的数据结构提供统一的访问机制。任何数据结构只要部署Iterator接口&…

自动化运维工具——Ansible学习(二)

目录 一、handlers和notify结合使用触发条件 1.新建httpd.yml文件 2.复制配置文件到ansible的files目录中 3.卸载被控机已安装的httpd 4.执行httpd.yml脚本 5.更改httpd.conf配置文件 6.使用handlers 7.重新执行httpd.yml脚本 8.检查被控机的端口号是否改变 9.handle…

矩阵乘法的硬件加速

矩阵乘法的硬件加速 这里的硬件加速是指,如果依靠算法,可以通过减少访存次数来加速。可以将数据预取到cache来减少访存次数。 矩阵相乘最简单的实现 寄存器平铺矩阵乘法 将矩阵划分成多个小的矩阵块,小的矩阵块可以存放在寄存器中&#xff0…

QT开发技巧之嵌入式linux QT的QCombobox显示空白的问题

1.问题 开发平台:imx6ull qt版本:5.12.9 在嵌入式linux上运行的qt,QCombobox显示空白,不能显示其中的文本内容 2.解决办法 选中QCombobox,在属性栏中将foucsPolicy由WheelFocus改成NoFocus就好了

用户、角色、权限、菜单--数据库设计

用户角色关联表--user_role id-------------------主键 user_id------------用户ID role_id-------------角色ID create_time------创建时间 is_deleted--------状态(0:未删除 1:删除) 角色权限关联表--role_permission id------…

【PHP面试题50】Redis的主从复制实现原理是怎么样的?如何保证数据一致性?数据延迟又该如何处理?

文章目录 一、前言二、主从复制的基本原理三、数据一致性的保证四、数据延迟的处理四、总结 一、前言 本文已收录于PHP全栈系列专栏:PHP面试专区。 计划将全覆盖PHP开发领域所有的面试题,对标资深工程师/架构师序列,欢迎大家提前关注锁定。 R…

OpenCv算子

目录 一、索贝尔(sobel)算子 二、沙尔(Scharr)算子 三、拉普拉斯算子 一、索贝尔(sobel)算子 边缘的定义: 边缘是像素值发生跃迁的位置,是图像的显著特征之一,在图像特征提取、对象检测、模式识别等方面都有重要的作用。 sobel算子对图像求一阶导数。…

【V8】【1. 内存布局、隐藏类Hidden Class】

JavaScript 中的对象是由一组组属性和值的集合。JavaScript 对象像一个字典,字符串作为键名,任意对象可以作为键值,可以通过键名读写键值。 在 ECMAScript 规范中定义了数字属性应该按照索引值大小升序排列,字符串属性根据创建时…

python将dataframe数据导入MongoDB非关系型数据库

文章目录 pymongo连接新建数据库和集合pandas导入数据插入数据数据查看 pymongo连接 import pymongo client pymongo.MongoClient("mongodb://localhost:27017/") dblist client.list_database_names() for db in dblist:print(db) #查看已有数据库admin bilibil…

apply()函数--Pandas

1. DataFrame.apply()函数 1.1 函数功能 对DataFrame沿着指定轴运用函数。 函数接收到的对象是Series对象,它们的索引可以是DataFrame的行索引(axis0)或列索引(axis1)。结果为Series或DataFrame。 1.2 函数语法 Da…

java基础浮点类型

目录 1:float类型和double类型的定义 2:二者的范围和精度 3:float类型详解 3.1:整数位10进制转换为2进制 3.2:小数位10进制转换为2进制 3.3:把二进制放到浮点类型中 3.4:精度损失 4&…