Fully Convolutional Adaptation Networks for Semantic Segmentation

news2025/1/11 7:14:54

参考  论文解析之《Fully Convolutional Adaptation Networks for Semantic Segmentation》 - 云+社区 - 腾讯云

论文网址:Fully Convolutional Adaptation Networks for Semantic Segmentation

摘要

深度神经网络的最新进展令人信服地证明了在大数据集上学习视觉模型的高能力。然而,收集专家标记的数据集,特别是带有像素级注释的数据集是一个非常昂贵的过程。一个吸引人的替代方案是渲染合成数据(例如,电脑游戏)并自动生成基本事实。但是,简单地将学到的模型应用于合成图像可能会由于域漂移而导致在真实图像上产生较大的泛化误差。在本文中,我们从视觉外观层和表示层的领域适应两个角度来促进这一问题。前者调整源域图像,使其看起来像是从目标域的“样式”中提取的,而后者试图学习域不变表示。具体来说,我们提出了完全卷积适应网络(FCAN),这是一种结合了外观适应网络(AAN)和表示适应网络(RAN)的新型语义分割深度架构。AAN在像素空间中学习从一个域到另一个域的转换,而RAN则以对抗学习的方式优化,以最大限度地利用所学的源和目标表示愚弄域鉴别器。我们进行了大量的实验,将GTA5(游戏视频)转换为城市场景(城市街道场景)进行语义分割,与目前最先进的无监督适应技术相比,我们的建议取得了更好的结果。更值得注意的是,我们获得了一个新的记录:在无监督设置下,BDDS (drivecam视频)的mIoU为47.5%。

1、介绍

深度神经网络已经成功地证明了在大规模数据集上学习视觉模型的有效性。到目前为止,在文献中有各种数据集(例如,ImageNet和COCO),其中包括注释良好的图像,可用于开发各种视觉任务的深度模型,例如,识别,检测,字幕和语义分割。尽管如此,给定一个新的数据集,典型的解决方案仍然是执行密集的手动标记,尽管付出了昂贵的努力和耗时的过程。另一种选择是利用合成数据,这主要是可从电脑游戏和ground truth可以自由自动生成。然而,许多以前的经验也表明,由于一种被称为“域移位”的现象,在合成数据上重新应用学到的模型可能会损害实际数据中的性能。以图1 (a)中真实街景视频一帧的分割结果为例,利用视频游戏的合成数据训练的模型不能正确地将场景分割为道路、人、汽车等语义类别。因此,无监督域适应将是解决这一挑战的理想方法,其目的是利用来自源域的带标签的例子和目标域的大量未带标签的例子,以减少对目标数据的预测误差。

                       

 无监督域自适应的一般做法是通过最小化域移位度量(如相关距离[28]或最大平均偏差[32])来建立跨域不变性。我们新奇地从表象层和表象层不变性的角度来考虑这个问题。外观级不变性的目的是将一个域中的图像内容与来自另一个域的“样式”重新组合。因此,两个域中的图像看起来就好像它们来自同一个域。换句话说,视觉外观往往是领域不变的。表征层不变性的灵感来自对抗学习在领域适应中的进展,即通过对抗目标对领域鉴别器建模领域分布。其背后的精神来自生成对抗学习,它通过让生成模型和区别模型相互竞争来训练两个模型,即生成模型和区别模型。在领域适应的背景下,这个对抗性原则相当于指导两个领域中的表示学习,使源和目标表示分布之间的差异无法通过领域鉴别器区分。我们遵循这个优雅的方法,并利用对抗机制来学习跨领域不变的图像表示。在这项工作中,我们特别研究了语义分割任务的领域适应问题,该问题可能依赖于最精确的像素级注释。

通过将外观级和表示级不变性的思想整合到无监督域自适应中以增强语义分割,我们提出了一种全新的全卷积自适应网络(FCAN)架构,如图2所示。整个框架由外观适应网络(Appearance Adaptation network, AAN)和表示适应网络(Representation Adaptation network, RAN)组成。理想情况下,AAN是构建一个图像,该图像捕获源图像中的高级内容和目标域的低级像素信息。AAN从白噪声图像开始,通过梯度下降调整输出图像,使输出图像的特征映射与源图像或目标域图像的均值特征映射之间的欧氏距离最小。在RAN中,首先使用共享的全卷积网络(FCN)生成每个域的图像表示,然后通过双线性插值对输出进行上采样,用于像素级分类,同时使用域鉴别器区分源和目标域。为了扩大特征图中滤波器的视场,赋予域鉴别器更大的能力,设计了一种空间金字塔池(ASPP)策略。RAN通过优化两个损失来训练,即分类损失来度量像素级语义,对抗损失来最大限度地愚弄域鉴别器,利用学到的源和目标表示。通过外观层和表示层的适应性,我们的FCAN可以更好地构建跨域不变性,从而获得图1 (b)中令人鼓舞的分割结果。

这项工作的主要贡献是提出了全卷积适应网络,用于解决领域适应背景下的语义分割问题。该解决方案还引出了一个优美的观点,即应该在跨领域构建什么样的不变性来适应,以及如何在深度学习框架中建模领域不变性,特别是在语义分割任务中,这些问题在文献中尚未得到充分理解。

2、相关工作

我们将相关研究分为两类:语义分割和深度域适应。

语义分割:

语义分割是计算机视觉中最具挑战性的任务之一,它试图预测给定图像或视频帧的像素级语义标签。受全卷积网络(FCN)最新进展的启发,已经提出了几种技术,从多尺度特征集成(例如,扩张卷积,RefineNet, DeepLab和HAZNet)到上下文信息保存(例如,ParseNet, PSPNet和DST-FCN)。原始的FCN公式也可以通过利用一些后处理技术(如条件随机场)加以改进。此外,由于大多数语义分割方法依赖于像素级标注,这需要非常昂贵的标注工作,研究人员也在努力利用弱监督代替(例如实例级边界框,图像级标签)来完成语义分割任务。为了实现这一目标,文献中利用了多实例学习、EM算法和约束CNN等技术。[10]中的替代方案利用来自辅助类别的像素级注释,将语义分割推广到只有图像级别标签可用的类别。本工作的目标是探索自由获取的带注释的合成数据和大量未标记的真实数据,用于像素级真实图像注释,这是一个新兴的研究领域。

深度域适配:

深度域自适应的目的是在深度学习框架中,将从标记源域学到的模型转移到目标域。本课题的研究从三个不同的维度展开:无监督适应、监督适应和半监督适应。无监督域自适应是指标记的目标数据不可用时的设置。深度相关比对(CORAL)利用最大平均差异(MMD)来匹配源和目标分布的均值和协方差。对抗性判别域适应(ADDA)[31]通过对抗性训练优化了适应模型。相反,当标记的目标数据可用时,我们将此问题称为监督域适应。Tzeng等人利用二值域分类器并设计域混淆损失来鼓励预测的域标签均匀分布。深度域混淆(DDC)应用MMD以及在源上的常规分类损失来学习既具有鉴别性又具有域不变的表示。此外,还提出了利用标记和未标记目标数据的半监督域自适应方法。深度适应网络(DAN)将所有任务特定的层嵌入到一个复制内核希尔伯特空间中。同时考虑半监督和非监督设置。

总之,本文的工作主要集中在语义分割任务的无监督自适应方面,这方面的研究很少。最密切相关的工作是FCNWild,它通过仅利用完全卷积对抗训练来解决跨域分割问题。我们的方法与[9]的不同之处是,我们从视觉外观级和表示级域适应的角度来解决域转移,以更有原则的方式弥合了域的差距。

3、全卷积域适配网路来进行语义分割

在本节中,我们提出了用于语义分割的完全卷积自适应网络(FCAN)。 图2说明了我们的框架的概述。 它由两个主要部分组成:外观适应网络(AAN)和表示适应网络(RAN)。 给定两个域的输入图像,首先利用AAN从视觉外观的角度将图像从一个域转移到另一个域。 通过将一个域中的图像内容与来自另一个域的“样式”重新组合,视觉外观趋向于域不变。 在本节中,我们以从源到目标的转换为例,其他选项将在我们的实验中详细说明。 另一方面,RAN以对抗的方式学习域不变表示,并设计一个域判别器来分类特征图中每个空间单元的接受域对应的图像区域来自哪个域。 RAN的目标是指导两个域的表示学习,通过域鉴别器使源和目标表示不可区分。 因此,我们的FCAN从视觉外观级和表示级域不变性的角度解决了域适应问题,并且在消除域移位的影响方面可能更有效。

3.1、表观级适配网络

AAN的目标是使来自不同领域的图像在视觉上相似。 换句话说,AAN试图使源图像看起来像是从目标域绘制的。 为了实现这一目标,需要将目标域中所有图像的底层特征进行分离,并将其视为目标域的“风格”,因为这些特征编码了图像的底层形式,如纹理、灯光和阴影。 而源图像中对象及其关系方面的高级内容则需要提取出来,并结合目标域的“风格”进行重组,从而生成自适应图像。

 图3说明了AAN的架构。 给定一组图像在目标域和来自源域的一张图像,我们从一张白噪声图像开始,并用中的语义内容加上Xt的“风格”反复渲染这张图像,以产生自适应图像。 具体来说,利用预先训练好的CNN提取每一幅图像的特征图。 假设CNN中每个卷积层l都有N_l响应映射,其中N_l为通道数,每个响应映射的大小为,其中H_lW_l分别为映射的高度和宽度。 因此,层l中的特征映射可以表示为。 基本上,不同卷积层的响应在不同的语义层次上表征了图像内容,其中更深的层响应更高的语义。 为了更好地管理源图像中的语义内容,对不同的层赋予不同的权重,以反映每一层的贡献。 然后将目标函数表述为  

                               

其中L是要考虑测量的层的集合。 w^l_s是第l层的权值,M^l_oM^l_s分别是第l层在x_ox_s上的特征映射。 通过最小化式(1)中的欧氏距离,期望在自适应图像x_o中保留x_s中的图像内容。  

其次,一个图像的“风格”通常被视为一种统计测量或模式,这与空间信息[4]是不可知的。 在CNN,这样的统计测量之一是不同反应图之间的相关性。 因此,可以通过计算图层l上的图像G^l的“样式”  

               

的第i个和第j个向量化响应映射之间的内积。在我们的例子中,我们通过平均在目标域的所有图像上,将一个图像的“风格”扩展到一个域(目标域的)的“风格”。 为了将目标域的“风格”综合到中,我们将每一层的目标表述为  

                            

其中为第l的权值。最后,需要最小化的总损失函数LAAN为:

                    

其中\alpha是平衡源图像语义内容和目标域风格的权重。 在训练中,与[5]类似,AAN通过将Eq.(4)导出的梯度反向传播到x_o来调整输出图像,从而产生域不变外观。  

 使用外观适应网络,来自不同域的图像似乎来自同一域。 为了进一步减少域移位的影响,我们尝试学习域不变表示。 因此,表示自适应网络(RAN)被设计来适应跨领域的表示,这是源自对抗性学习[7]的想法。 在我们的RAN中,对抗性原则相当于通过愚弄域识别器D来指导两个域的特征表示的学习,即使用所学的源和目标表示。 具体来说,RAN首先利用共享的全卷积网络(FCN),通过AAN从两个域提取图像或自适应图像的表示。 这里的FCN模型F旨在学习跨两个域的不可区分图像表示。 此外,鉴别器D尝试区分源和目标表示,其输出是最终特征图中空间单元对应的每个图像区域的域预测。 正式地,给定训练集在源域和在目标域,对抗性损失是所有空间单元的平均分类损失,表示为:

                  

其中Z是D输出的空间单元数。与标准GAN类似,我们的RAN的对抗性训练是优化以下的极小极大函数:

                               

考虑到真实数据中存在许多不同大小的对象,我们进一步考虑利用多尺度表示来增强对抗学习。一种传统的多尺度策略是用多种分辨率调整图像的大小,这确实提高了性能,但代价是大量的计算。在这项工作中,我们扩展了Atrous空间金字塔池(ASPP)来实现这一点,如图2所示。具体来说,我们并行利用k个不同采样率的扩张卷积层,在FCN输出上独立产生k个特征表示,每个特征表示具有c个特征通道。然后,所有的特征通道被堆叠起来,形成一个新的特征地图与ck通道,接着是一个1 × 1卷积层加上一个sigmoid层,以产生最终的得分地图。分数图中的每个空间单元表示对应图像区域属于目标域的概率。此外,我们同时对标准像素级分类损失进行优化,用于对来自源域的图像进行监督分割,其中标签是可用的。因此,RAN的总体目标是将整合为:

                          

λ是折衷参数。通过用源和目标表示愚弄域鉴别器,我们的RAN能够产生域不变表示。在测试阶段,将目标域的图像送入学习的FCN生成像素级分类的表示。

4、实现

4.1、表观级适配

 我们采用预训练的ResNet-50[8]架构作为基本的CNN。特别地,我们在集合中只包含了5个卷积层,即,因为这些层的表示在每个尺度上通常具有最高的能力。图像在源域和目标域的层权值通常取决于自适应图像的视觉外观。此外,在优化Eq.(4)时,一个常见的问题是需要设置权衡参数\alpha来平衡内容和“风格”。由于最终的目标是从语义上分割图像中的每个像素,因此需要精确地保留语义内容。因此,我们将“风格”的影响仅仅看作是调整外观的“delta”函数,并基于经验设定较小的权重。l的最大迭代次数固定为1k。在每次迭代i中,图像x_o更新,其中

4.2、表征级适配

在我们的实现中,我们使用来自ResNet-101的扩展的全卷积网络作为我们的FCN,它已经被证明在生成强大的语义分割表示方面是有效的。最后一个卷积层(即res5c)的特征地图被输入分割和对抗分支。在监督分割分支中,我们还使用金字塔池[37]来增加FCN的输出,将上下文先验整合到表示中。在对抗性分支中,我们使用k = 4个扩展卷积层并行生成多个特征映射,每个特征映射具有c = 128个通道。不同扩张卷积核的采样率分别为1、2、3和4。最后利用ASPP旁边的sigmoid层输出预测,其范围为[0,1]。

4.3、训练策略

我们的建议在Caffe框架上实现,并利用小批量随机梯度下降算法对模型进行优化。我们在源域上对RAN进行预训练,只会造成分割损失。初始学习率为0.0025。与[1]类似,我们使用“poly”学习率策略,其功率固定为0.9。动量衰减和重量衰减分别设置为0.9和0.0005。批号是6最大迭代数为30k。然后,结合分割损失和对抗损失对RAN进行微调。折衷参数λ设置为5。初始学习率为0.0001。批大小为8,最大迭代次数为10k。其余超参数与预训练相同

5、实验

5.1、数据集

我们对从GTA5(游戏视频)数据集到城市景观(城市街道场景)数据集[2]的域适配进行了彻底的FCAN评估。

GTA5数据集包含24966张来自《侠盗猎车手5》(GTA5)的图像(视频帧),并且每个图像的像素级地面真相也会被创建。在游戏中,图像是在虚拟城市洛斯桑托斯拍摄的,这个城市起源于洛杉矶。每张图像的分辨率为1914 × 1052。有19个类与其他户外场景(如城市景观)分割数据集兼容并用于评价。城市景观数据集是城市街景语义理解的一个流行基准,它包含了从50个不同城市的街景收集的5000张图像(帧)的高质量像素级注释。图像分辨率为2048 × 1024。按照分割任务中的标准协议,使用19个语义标签(汽车、道路、人、建筑物等)进行评价。其中,训练集、验证集和测试集分别包含2,975帧、500帧和1525帧。按照[9,21]中的设置,在我们的实验中,只有验证集(500帧)用于验证无监督语义分割。

图4显示了源域和目标域图像的四个外观级传输示例。如图所示,原始图像中的语义内容在自适应图像中都得到了很好的保存。当呈现《GTA5》中带有城市景观“风格”的图像时,图像的整体颜色变得暗淡,色彩饱和度趋于低。相反,当转换方向相反时,城市景观中图像的颜色变得更亮,饱和度也更高。结果表明,两者之间具有良好的外观级迁移。

 5.3、FCAN的消融实验

接下来,我们研究FCAN中每个设计如何影响整体性能。自适应批处理归一化(ABN)简单地将源域学习的FCN中BN层的均值和方差替换为目标域图像的均值和方差。对抗域适应(ADA)利用对抗训练的思想学习域不变表示,域判别器在图像层面上判断域。当将域鉴别器扩展到对每个图像区域进行分类时,该设计被命名为Conv, ASPP进一步扩大了滤波器的视野以增强对抗学习。AAN是我们外表层面的适应。

表2详细说明了在FCAN的每个阶段多考虑一个域适配因素对mIoU的改进。ABN是一种缓解域转移的通用方法,与任何域适配框架无关。在我们的例子中,ABN成功地将mIoU性能从29.15%提升到35.51%。这说明ABN是一种非常有效和实用的选择。在我们的RAN中,ADA、Conv和ASPP是三个具体的设计,它们的性能增益分别为5.78%、1.88%和1.64%。换句话说,我们的RAN总共带来了9.3%的性能提升。结果验证了表征层1自适应的思想。AAN进一步提高了mIoU的1.79%,FCAN的mIoU性能最终达到46.6%。图5展示了我们的FCAN在不同阶段的四个语义分割结果示例。如图所示,分割结果正变得越来越准确,因为更多的适应性设计包括在内。例如,在早期阶段,道路和天空等大多数类别都不能很好的分割。相反,即使是像自行车和卡车这样的少数类也会在后面的步骤中被很好地分割。

5.4、和最先进方法的比较

我们比较了几种最先进的技术。域混淆(DC)通过域混淆损失来对齐域,它被优化以学习跨不同域的均匀分布。ADDA(对抗性判别域适应)将联合权值共享和对抗性学习结合起来进行判别特征学习。FCNWild采用全卷积对抗训练进行语义分割领域自适应。为了便于比较,所有方法中使用的基本FCN都来源于ResNet-101。表3总结了性能比较。FCNWild和FCAN在区域水平上进行域对抗学习,相比于在图像水平上设计域鉴别器的DC和ADDA, FCNWild和FCAN在区域水平上表现得更好。此外,FCAN通过添加ASPP策略和AAN加强,使其比FCNWild有了明显的改善。多尺度(MS)方案使mIoU性能提高到47.75%。图6详细描述了跨不同类别的性能。我们的FCAN在19个类别中的17个类别中取得了最好的表现,这从经验上验证了我们模型在类别层面的有效性。

为了检验在FCAN中学习到的域鉴别器,图7展示了四个图像示例,包括原始图像、它们的ground truth、FCAN分割结果和域鉴别器预测地图。亮度表明该区域具有很高的概率属于目标域。让我们回想一下,对抗性学习就是最大限度地愚弄领域识别器。这意味着理想情况下,目标域中图像的预测映射应该是暗的。例如,区域鉴别器对前两幅图像中红色边框区域的预测是错误的,这表明这些区域的表示往往是不可区分的。因此,这些区域(天空)被FCAN精确分割。相比之下,区域鉴别器对最后两幅图像中的区域进行了正确的预测,表明区域表示仍然是依赖于区域的。因此,在这些区域(自行车)的分割结果不是很好。

5.5、半监督适配

在实践中另一种常见的情况是,在目标域中有少量带标记的训练示例。因此,我们将FCAN扩展为半监督版本,它将城市景观的训练集作为标记数据。技术上,进一步考虑目标域图像像素级分类损失,将式(7)中的总体目标变为。表4显示了随着目标域带标签训练数据的增加,mIoU性能的变化。同样值得注意的是,这里的FCN是直接在目标域的标记数据上学习的,FCAN指的是我们的半监督版本。不出所料,如果在训练中只包含目标域的几百张图像,FCAN的性能增益往往会很大。当增加来自城市景观的图像数量时,增益会逐渐降低。即使当数量达到1k时,我们的半监督FCAN仍然比监督FCN略好。

5.6、BDDS上的结果

除了Cityscapes数据集外,我们还将BDDS作为目标域来评估我们的FCAN的无监督设置。表5总结了性能比较。其中,FCAN的mIoU性能达到43.35%,比FCNWild提高了3.98%。多尺度设置,即FCAN(MS),将性能提高到45.47%。最后,融合ResNet-101、ResNet-152和SENet[11]模型的集成版本FCAN(MS+EN)可以将mIoU提高到47.53%。图8显示了BDDS中的三个语义分割示例,分别由FCN和FCAN输出。显然,FCAN可以得到更有前景的分割结果。即使在反射(第二行)或天空中的云块(第三行)的情况下,我们的FCAN也可以很好地分割天空。

6、结论

我们提出了完全卷积适应网络(FCAN)架构,该架构探索了用于语义分割的领域适应。特别地,我们从视觉表象层面和表征层面的适应两个角度来研究这一问题。为了验证我们的声明,我们在我们的FCAN中针对每种目的分别设计了外观适应网络(AAN)和表示适应网络(RAN)。AAN是用来自另一个域的域“样式”在一个域中渲染图像,从而在两个域之间产生不变的外观。RAN旨在以领域对抗的方式指导表示学习,理想地输出领域不变表示。从游戏视频(GTA5)到城市街景场景(Cityscape)的转换实验验证了我们的提议和分析。更值得注意的是,当将游戏视频传输到车载摄像机视频(BDDS)时,我们实现了新的最先进的性能。我们未来可能的工作包括两个方向。首先,在AAN中将研究使用另一种统计模式渲染图像语义内容的更先进的技术。其次,我们将进一步将我们的FCAN扩展到其他特定的分割场景,如室内场景分割或肖像分割,这些场景很容易生成合成数据。

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

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

相关文章

基于MediatR管道的公共业务校验

基于MediatR的管道模式,我们可以在处理业务之前,进行统一验证,记录日志等。 所有命令(Command)再被处理(Handle)之前,都要经过IRequestPreProcessor处理,我们注入自己的拦截器,执行…

chrome拓展插件开发中使用chrome.storage本地存储

一、描述 在扩展程序中本地存储数据可以通过 chrome.storage API 实现,和 web 中的 localstorage 在某些方面是有区别的,chrome.storage 已经做了优化。 与 localStorage 的区别: 用户数据可以与 chrome 自动同步(通过 storage…

【推荐】智能制造工业4.0与MES资料合集

智能制造,源于人工智能的研究,一般认为智能是知识和智力的总和,前者是智能的基础,后者是指获取和运用知识求解的能力。 智能制造应当包含智能制造技术和智能制造系统,智能制造系统不仅能够在实践中不断地充实知识库&a…

请上车MySQL面试必备点:从常见的存储引擎到混淆的锁分类

我们之前的文章InnoDB解决幻读的方案中提到了记录锁(行锁)、间隙锁和临键锁,后台有小伙伴催我更新一下其他的锁。拖延症又犯了,趁周末,今天我们来总结一下MyISAM和InnoDB引擎下锁的种类及使用方法。 MySQL的四大常见存…

面试题:Linux是如何避免内存碎片的

Linux是如何避免内存碎片的? 在网上看到这个面试题,参考答案是这样的: 伙伴算法,用于管理物理内存,避免内存碎片;高速缓存Slab层用于管理内核分配内存,避免碎片。 故继而去深入了解了一波,做了…

牛客之基础单片机知识_1

✅作者简介:大家好我是 xxx,是一名嵌入式工程师,希望一起努力,一起进步! 📃参照主页:嵌入式基地 🔥系列专栏:硬件基础知识——单片机 习题专栏 💬网上关于嵌入…

软件测试不常用但是一定要会的测试技术与用例设计

一、认识基本术语 术语一: ◆动态测试(dynamic testing) 通过运行软件的组件或系统来测试软件(实际运行被测软件/系统)【需要进行操作】 ◆静态测试(static testing) 对组件的规格说明书进行评审,对静态代码进行走…

【推荐】700套高端简历模板合集

简历(英语:resume),顾名思义,就是对个人学历、经历、特长、爱好及其它有关情况所作的简明扼要的书面介绍。简历是有针对性的自我介绍的一种规范化、逻辑化的书面表达。对应聘者来说,简历是求职的“敲门砖”…

JSP学生宿舍网站

开发工具(eclipse/idea/vscode等): 数据库(sqlite/mysql/sqlserver等): 功能模块(请用文字描述,至少200字): 模块划分:通知类型模块、通知信息模块、院系信息、班级信息、宿舍 楼信息、宿舍信息、宿管信息、学生信息、…

three.js之多线条组合

文章目录多线条组合例子专栏目录请点击 多线条组合 我们可以通过CurvePath把多个曲线、直线等合并成一个曲线 例子 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><style>body {margin: 0;overflow: hidde…

CSS习题解答

文章目录1.1 样式定义方式1.2 选择器1.3 颜色1.4 文本1.5 字体1.6 背景1.7 边框1.8 元素展示格式1.9 内边距与外边距1.10 盒子模型1.11 位置1.12 浮动实战&#xff1a;个人名片1.13 flex布局1.14 响应式布局作业01作业02作业03作业04作业05作业06作业07作业08作业09作业10其他1…

正则表达式学习

文章目录入门开始和结束字符组区间特殊字符转义取反快捷匹配数字和字母匹配空白任意字符重复次数和区间或者条件进阶分组非捕获分组分组的引用正向先行断言反向先行断言正向后行断言反向后行断言常用元字符整理相关网站在线测试网站题目练习网站其他笔记入门 开始和结束 正则…

计算机毕设Python+Vue学生量化考核系统(程序+LW+部署)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Python中groupby函数详解(非常容易懂)

目录&#xff1a;Python中的groupby函数一、groupby 能做什么&#xff1f;二、单类分组2.1 创建数据集三、多类分组一、groupby 能做什么&#xff1f; groupby函数主要的作用是进行数据的分组以及分组后地组内运算&#xff01; 于数据的分组和分组运算主要是指groupby函数的应…

网络安全等级保护十问十答

网络安全等级保护十问十答1.什么是等级保护&#xff1f;2.为什么需要等级保护&#xff1f;3.目标客户是&#xff1f;4.等保工作步骤包括什么&#xff1f;5.等保测评结论有几种结果&#xff1f;6.等保如何定级&#xff1f;7. 定级对象在哪备案&#xff1f;8. 等级保护都测评什么…

[附源码]计算机毕业设计Node.js宠物商店网站(程序+LW)

项目运行 环境配置&#xff1a; Node.js最新版 Vscode Mysql5.7 HBuilderXNavicat11Vue。 项目技术&#xff1a; Express框架 Node.js Vue 等等组成&#xff0c;B/S模式 Vscode管理前后端分离等等。 环境需要 1.运行环境&#xff1a;最好是Nodejs最新版&#xff0c;我…

Opencv(C++)笔记--Sobel算子

1--Sobel算子 1-1--原理 Sobel算子的构成如下图所示&#xff1a; 基于 Sobel 算子可以实现对图像的边缘检测&#xff0c;Gx常用于提取纵向边缘&#xff0c;Gy则常用于提取横向边缘&#xff1b; 1-2--Opencv API 在 ddeth 参数上&#xff0c;使用 cv::CV_16S 处理 8 位原图像&…

jsp+ssm计算机毕业设计高校班主任班级管理系统【附源码】

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; JSPSSM mybatis Maven等等组成&#xff0c;B/S模式 Mave…

跨模态检索的简单实现(pytorch)

目录说明说明往期文章和专栏代码及数据集下载什么是跨模态检索代码导入需要的库构建图像、文本子网络加载数据集计算mAP损失函数构建总损失函数训练部分主函数参数设置查看结果说明 说明 还是读研时候剩下的代码&#xff0c;是我从几篇论文里面摘出来的代码做了简单的拼装&am…

SCN时间序列预测模型详解(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f468;‍&#x1f4bb;4 Matlab代码 &#x1f4a5;1 概述 SCN&#xff08;System Change Number 简称 SCN&#xff09;是当Oracle数据库更新后&#xff0c;由DBMS自动维护去累积递增的一…