卷积神经网络(CNN)算法详解

news2025/1/15 13:47:19

注意:本文引用自专业人工智能社区Venus AI

更多AI知识请参考原站 ([www.aideeplearning.cn])

引言

卷积神经网络(Convolutional Neural Networks, CNN)是一类包含卷积计算且具有深度结构的前馈神经网络(Feedforward Neural Networks, FNN),是深度学习的代表算法之一 。

对卷积神经网络的研究始于二十世纪80至90年代,时间延迟网络和LeNet-5是最早出现的卷积神经网络;在二十一世纪后,随着深度学习理论的提出和数值计算设备的改进,卷积神经网络得到了快速发展,并被应用于计算机视觉、自然语言处理等领域。

卷积神经网络仿造生物的视觉(visual perception)机制构建,可以进行监督学习和非监督学习,其隐含层内的卷积核参数共享和层间连接的稀疏性使得卷积神经网络能够以较小的计算量对格点化(grid-like topology)特征,例如像素和音频进行学习、有稳定的效果且对数据没有额外的特征工程(feature engineering)。

卷积神经网络的计算

首先,要讲基于深度学习的图像识别,卷积神经网络是读者必须掌握的前置知识。在讲卷积之前,先来了解一下什么是核。

核概念与卷积操作

图片[1]-卷积神经网络(CNN)算法详解-VenusAI
图1 CNN

如图1所示:g(x,y) 即为核(Kernel),每个小方格上都有一个标量代表权重 w。f(x,y) 为输入图像的像素矩阵,每个小方格上都有一个标量代表该图片在该点上的像素值。图1中卷积操作定义为核中的元素 w 与输入数据 f(x,y) 的对应元素进行相乘求和。

(1)在图1的示例中,与核中的权重 w 对应的一共有9个元素,相乘求和的结果即为卷积操作的输出。

(2)核中的权重 w 就是卷积神经网络训练需要求得的参数。

此外,通过图1可以发现,由于卷积核的尺寸一般都远远小于图像的像素矩阵尺寸,因此,只对图像进行一次卷积操作只能处理图像中的一小部分信息,这肯定是不合理的。所以,使用卷积处理图像还应存在多个滑动遍历的过程。具体来说,卷积核会从图像的起始位置(左上角)开始,以一定的顺序(从左到右,从上到下)遍历整张图像,每滑动一次就与对应的位置做一次卷积操作直到遍历到最终位置(右下角),这个过程叫做卷积对图像的一次处理。

通道

将一个图片数据集抽象为四维[数量、长、宽、色彩],每个维度都是一个通道的概念,一个通道中往往存储着相同概念的数据。例如对于一张 32×32 分辨率的彩色照片来讲,一般将其抽象为向量[1, 32, 32, 3],其中3指的是颜色特征通道,具体来说,当前的特征是RGB三种颜色。颜色通道的原理可以回忆一下小学美术课中的三原色:即世界上任何一种色彩都可以使用红色、绿色和蓝色三种颜色调配得到。因此计算机在存储彩色图像时,也借鉴了这一原理,其存储模式是三个相同大小的像素矩阵一同表征一张彩色图像,如图2所示。卷积核的维度与输入图像的维度相同,也是四维信息,其维度是[3,kernel_H, kernel_W, 3]。第一个维度的3代表卷积核的数量通道,对应图中的三个卷积核。第二维度和第三维度是高宽通道对应着卷积核的尺寸。第四维度的3代表卷积核的特征通道数量。需要注意的是,卷积核的特征通道数与输入信息的特征通道数必须是相等的,这是因为在一次卷积操作中,一个卷积核的特征通道会与一个输入信息的特征通道做卷积操作,每个通道一一对应,如图2的箭头所示。在示例中,一个卷积核的三个特征通道会分别计算得到三张特征图,但是,这三个特征图最后对应位置求和会得到一个计算结果,即不管一个卷积核的特征通道数量是多少,一个卷积核只能计算得到一张特征图,当然,如果是n个卷积核,即可计算得到n张特征图。

图片[2]-卷积神经网络(CNN)算法详解-VenusAI
图2 彩色图片的卷积过程

最后,回到特征通道的概念。刚刚解释过计算机要表示整张彩色图片,需要特征通道为三维来存储RGB三个颜色。实际上,在深度学习,尤其是卷积神经网络(CNN)中,特征通道的概念被扩展。一开始,网络接受的输入可能仅仅是原始的RGB图像,即3个特征通道。但是,当数据通过网络的不同层时,网络会自动提取和学习更复杂的特征。每一层可能会产生数十甚至数百个新的特征通道,每个通道代表了输入数据的不同特征。例如,在初级层,这些特征可能是边缘、角点或颜色斑块。在更深的层,这些通道可能代表更复杂的特征,如对象的部分或特定的纹理。重要的是,这些特征不是手动设计的,而是通过模型从数据中自动学习得到的。使用多个特征通道可以使网络捕捉到更多维度的信息,从而在执行任务(如图像分类、物体检测等)时更加精确。每个通道都携带着不同的信息,网络结合这些信息来做出判断。

填充

经过对卷积处理图像的方式和核概念的认识后,可以将卷积神经网络理解为一个卷积核在输入图片上遍历的过程,遍历过程中卷积核与输入信息之间对应点的乘积求和即为卷积输出。输出结果的尺寸一般是要小于输入信息的,除非卷积核的大小为1×1的,如图3所示。

图片[3]-卷积神经网络(CNN)算法详解-VenusAI
图3 1×1卷积

很多情况下,我们希望在不使用 1×1 大小卷积核的前提下,可以调整卷积输出结果的尺寸。此时可以在输入信息的四周填充一圈新像素(一般填充0值像素),使卷积核遍历图片后得到的卷积输出大小不变。填充的像素多少与卷积核的尺寸大小成正相关,填充过程如图4所示。当卷积核尺寸为3,步长大小为1时,需要填充一行一列像素使得输出大小与输入信息一致。

图片[4]-卷积神经网络(CNN)算法详解-VenusAI
图4 带填充的卷积操作

此外,可以观察图4中1号和2号的两个像素。根据卷积的遍历规则,1号像素在整个遍历过程中只会被计算一次,而2号像素在整个遍历过程中会被计算多次。这体现了卷积算法的一个性质:更关注图片中心区域的信息。因此,如果想让卷积操作对整张图片的关注度差不多,那么可以通过填充的方式将原本在边缘的像素信息变换到靠近中心的位置。

最后,卷积计算结果的尺寸与卷积核、步长、填充和输入信息尺寸这四个因素相关。先定义几个参数:输入图片大小[W, W]、卷积核大小[F, F]、步长S、填充的像素数P。于是可以得出卷积结果的尺寸计算公式为:

                                                         N=\frac{W-F+2P}S+1

即卷积核的输出尺寸为NxN

步长

此外,通过图1可以发现,由于卷积核的尺寸一般都远远小于图像的像素矩阵尺寸,因此,只对图像进行一次卷积操作只能处理图像中的一小部分信息,这肯定是不合理的。所以,使用卷积处理图像还应存在多个滑动遍历的过程,如图5gif动图所示(请点击观看)。卷积核会从图像的起始位置(左上角)开始,以一定的顺序(从左到右,从上到下)遍历整张图像,每滑动一次就与对应的位置做一次卷积操作直到遍历到最终位置(右下角),这个过程叫做卷积对图像的一次处理。其中,卷积核每次滑动的像素大小被定义为步长(stride),图5中的stride=2.

图5 卷积操作

 在图5gif的动图中,卷积核的数量为8个,每个卷积核的形状为8x3x3,其中8为卷积核特征通道的数量,这与输入数据的特征通道数量是相等的。卷积核在计算过程中的填充为1,步长为2,每个卷积核都可计算得到一张特征图,8个卷积核可计算得到8张,因此最后输出结果的通道数量也为8.

卷积的设计思想

1.平移不变性

需要注意的一点是:卷积核从图像的初始位置(左上角)滑动到最后位置(右下角)这个过程中,卷积核中的参数是不会发生改变的,这叫做参数共享,是卷积操作的重要性质之一。相反,参数独立的情况为卷积核每滑动一次,其中的参数就要重新计算。

参数共享的目的从某种角度来说是在模仿人类的一种视觉习惯:平移不变性。换句话说,就是在图像中,只要是同一种特征,那么不管这个特征被平移到图像中的什么位置,人类都能做很好的识别。实际上,卷积的设计是天然符合这个特性的:首先,卷积核在输入信息上做卷积的目的就是为了识别某一种特征(本章后续会详细解释);其次,由于滑动遍历的原因,不管要识别的特征出现在图片中的什么位置,卷积都可以通过滑动的方式,滑动到该特征的上面进行识别。但是,这有一个前提,就是该卷积核从图像的起始位置滑动到结尾位置这个过程中,寻找的都是同一种特征。这个前提可以通过参数共享的方式实现,即卷积核在对图像做一次完整的遍历过程中不发生改变,一个不变的卷积核寻找的肯定是同一种特征了。

2.局部相关性

从图像的性质来说,卷积的设计天然符合图像的局部相关性。首先关于图像的局部相关性的理解可以列举一个场景:从某人物图片中,人物的眼睛附近随机选取一个像素值a,如果单独地把a从图像的像素矩阵中拿出来,那么a仅仅只是一个数值,它代表不了任何东西,这是没有意义的;但是,如果把a再放回原本的像素矩阵中,那么它就可以跟周边的像素值一起表示眼睛这一特征,这叫作相关性。此外,考虑离a相距较远的其他像素值,由于两个像素在原图中的距离较远,它们之间的联系也是比较小的,这就体现了局部。因此,图像是一种局部相关的数据,在此性质的背景下,类似全连接神经网络这种计算全局信息的方式反而是冗余的,不符合图像性质的;而卷积处理局部的方式则显得更加合理。

实际上,对图片进行卷积操作就是把卷积核与原图片做点积操作。点积的数学解释可以解释为:两个向量之间的相似度。在当前的例子里,可以说成卷积核与原图的相似度,卷积的结果越大,说明图片中某位置和卷积核的相似度越大,反之亦然。如果把卷积核作为特征算子或者特征向量,那么卷积的过程就是通过移动卷积核在原图中的对应位置,不断去寻找原始数据中是否存在跟卷积核表征相似的特征,这在图片识别中意义重大。例如,判断一张图片是否为车子,假设卷积模型设置了4个核,它们的特征可能代表[“轱辘”,“车窗”,“方向盘”,“车门”],通过卷积核在原图上进行匹配进而综合判断图像中是否存在这四种特征,如果存在则该图片大概率是车子。

实际上,深度卷积神经网络就是去求解这些卷积核的一种网络。它们不是凭借经验随便定义的,而是通过网络不断地学习更新参数得来的。而卷积神经网络的不易解释性就在于此,随着模型的复杂,抽象出很多不同的卷积核,我们难以去解释每个核的具体含义,也难以介绍每个中间层和中间节点的含义。

3.人类的视觉习惯

最后可以从人类的视觉习惯来理解卷积的设计思想。相较于全连接神经网络,卷积神经网络的计算方法更符合人类的视觉习惯。可以想象一个场景:当突然置身于一个复杂且陌生的环境时,是怎么快速地获得周边信息的?

如果以神经网络的方式,由于神经网络的计算是全局性的,为了模仿这一性质,在观察场景时需要同时观察全局,思考全局。这其实并不是人类视觉的观察习惯。我们往往会选择先观察一个感兴趣的局部区域,观察时,只需要思考这个局部区域有什么即可。之后,再选择查看其他地方,看到哪里思考到哪里,通过有规律地扫视对全局做完整的观察。这其实与卷积神经网络先观察局部,再通过滑动的方式遍历全局,滑动到哪里就计算到哪里是一样的。所以说,卷积的设计是更符合人类的视觉习惯的。

卷积进行特征提取的过程

让我们来看一个识别字母X的图像识别示例,如图6所示。在图像的像素矩阵中,白色的像素块值为1,黑色的像素块值为负1。在图像上方的三个小矩阵分别是三个不同的卷积核。现在使用第一个卷积核去图像中进行滑动遍历:当这个卷积核滑动到图6所示的位置时(即图像左上角的方框),其卷积计算结果等于9,此时9为这个 3×3 卷积核能够计算得到的最大值。

图片[6]-卷积神经网络(CNN)算法详解-VenusAI
图6 卷积核的特征提取1

继续思考,当在图6所示的位置附近做卷积操作时,卷积计算结果应该是比9要小的数值,如图7所示,向右滑动一个像素位置的卷积计算结果为-1。

图片[7]-卷积神经网络(CNN)算法详解-VenusAI
图7 卷积核的特征提取2

现在,继续滑动卷积核,如图8所示,直到滑动到图8中所示的右下角的位置时,其卷积计算结果又等于9。思考图8所示的左上角的卷积核与图中的绿色框和黄色框两个卷积位置是否有什么联系?答案很简单,它们特征相同。

图片[8]-卷积神经网络(CNN)算法详解-VenusAI
图8 卷积核的特征提取3

因此,答案就出来了:第一个卷积核就是去图像里滑动遍历,然后寻找一个是否有跟它长的一模一样的这种对角特征;如果找到了,那么卷积计算结果就是最大值;如果没有找到,那么卷积计算结果就是一个非极大值;通过极大值与非极大值的区分,就可以完成这种对角特征与其他特征的区分。卷积就是通过这种方法对输入信息进行特征提取的。简而言之,可以把卷积核看作识别某种特征的模式,卷积核的目的就是尝试去图像中提取这种特征。

需要注意的是,在一个卷积操作中,我们往往会选择使用不同的卷积核对图像做卷积操作,如图9所示。

图片[9]-卷积神经网络(CNN)算法详解-VenusAI
图9 卷积核的特征提取4

其目的是:希望不同的卷积核可以从图像中提取不同的特征。因为当提取的特征太少,是没有办法完成图像识别这个任务的。一个简单的例子:我们不能凭借眼睛这一种特征来识别猫和狗这两个类别,往往需要根据眼睛、嘴巴、外形、毛发、耳朵等等多种特征才能对猫和狗做正确的识别。

池化与采样

从某种程度上,池化可以看作特殊的卷积,因为池化操作包含卷积中常见的概念(核、填充、步长);区别在于,池化的核与输入信息的对应位置元素进行的操作不同,在卷积中,该操作是相乘求和;而池化中,这个操作是求平均或最大,分别对应平均池化(Average Pooling)和最大池化(Max Pooling)。池化最主要的作用就是对输入信息做降维,如图10所示。池化的核是左上角绿色方框所示部分,大小为2×2;原始输入数据的填充为0,因为在原始数据的四周并没有像素填充;池化的初始位置为左上角的2×2矩阵,滑动一次后到了右上角的2×2矩阵,滑动了两个像素位置,即池化操作的步长为2。

图片[10]-卷积神经网络(CNN)算法详解-VenusAI
图10:池化操作

至于左下角的2×2矩阵为平均池化的结果,例如第一个元素2的计算过程为:(1+3+1+3)/4,即池化的核与输入信息的对应位置做平均的结果;而右下角的2×2矩阵为最大池化的结果,例如第一个元素3的计算过程为:Max(1, 3, 1, 3),即池化的核与输入信息的对应位置比较取最大的结果。

最大池化的主要作用是特征提取。这种技术通过在每个窗口中保留最大值来实现,有效地识别图像中的显著特征,如边缘和纹理。同时,最大池化也起到了降维的作用,通过减少数据的空间尺寸(例如,从2×2像素块中选择最大值),帮助减少计算复杂性和防止过拟合。

继续刚才的例子,从图像的起始位置开始做卷积操作,每次滑动的步长为2,直到末尾的位置。当第一个卷积核滑动依次到图中四个位置时,卷积结果分别是9、3、-1、-3,如图11所示。

图片[11]-卷积神经网络(CNN)算法详解-VenusAI
图11 最大池化计算过程

这四个值在本次卷积的计算结果中大致如图12所示,注意,滑动到其他位置的卷积计算结果也应该是有输出值的,这里以“…”代替。池化操作一般接在卷积操作之后,即卷积的计算结果是池化操作的输入信息,在当前案例中,图12即为卷积的计算结果。使用一个2×2大小的池化核对上述卷积结果做操作时,我们发现被保留下来的数值是9。对此解释是:9正是卷积操作在原图中找到的对角特征,通过最大池化的方式被保留下来了;同时把卷积操作认为不是很重要的特征(例如3、-1、-3)删掉,这就完成了特征汇聚的过程。

图片[12]-卷积神经网络(CNN)算法详解-VenusAI
图12 池化计算结果

相比之下,平均池化的作用是特征融合。这种技术通过计算每个窗口的平均值来实现,有助于平滑图像的局部特征,使得模型更加关注于图像的整体结构而非局部细节。与最大池化类似,平均池化也通过降低数据的空间尺寸来减少维度,有助于降低计算负担并减少过拟合的风险。

卷积神经网络的感受野

感受野(Receptive Field)是指卷积神经网络中某一神经元在输入图像上感受到的区域大小。换句话说,感受野描述了神经元对输入图像的哪些部分产生响应。在卷积神经网络中,随着网络层数的增加,每个神经元的感受野会逐渐变大,能够感受到更广阔的输入图像区域,从而提高网络对整个图像的理解能力。

举个例子来理解,假设现在有两层卷积神经网络,它们的卷积核大小都是3×3。在网络的第一层中,每个神经元计算的输入信息范围是由卷积核定义的,即3×3=9,也就是说第一层神经元的感受野是9。但在第二层中,因为层级结构的原因,感受野会明显增加,如图13所示。

图片[13]-卷积神经网络(CNN)算法详解-VenusAI
图13 卷积层级结构的感受野

卷积神经网络感受野的作用如下:

(1)提高特征表征能力:随着网络层数的增加,每个神经元的感受野增大,能够感受到更广阔的输入图像区域,从而提高网络对整个图像的理解能力,进一步提高特征表征能力。这也是卷积神经网络为什么要设计成层级结构的原因。

(2)提高模型的鲁棒性:感受野的增大能够提高模型的鲁棒性,使得网络在面对不同尺寸、姿态、光照等情况下都能够进行有效的特征提取和图像识别。此外,通过适当地调整卷积核的大小和填充等参数,可以实现对不同尺寸的输入图像进行有效的处理。

计算感受野大小的公式是基于递归计算每一层神经元在输入图像上感受野的大小,可以使用下述公式计算:

                                              R_i=R_{i+1}+(k_i-1)\times s_i

其中,R_i 表示第 i 层神经元在输入图像上感受野的大小,R_{i-1} 表示第 i−1 层神经元在输入图像上感受野的大小, k_i 表示第 i 层卷积核的大小, s_i 表示第 i 层卷积核的步长。

在计算感受野的时候,一般从输入层开始逐层计算,假设输入图像的大小为 H×W, 则输入层中的每个神经元的感受野大小为 1 , 即 R_1=1 。注意, 这里的输入层可以看作模型的第 0 层, 而不是图13中的 “Layer1”。对于之后的每一层, 都可以通过上述公式计算出感受野的大小。

需要注意的是,上述公式只考虑了卷积层的计算方式,而对于池化层等其他操作,其感受野的计算方式可能会有所不同。此外,还有一些基于卷积的变体操作也可以改变感受野,例如膨胀卷积等。到此,卷积模型的标准结构已经全部介绍完了。

卷积模型实现图像识别

卷积模型实现图像识别的标准网络结构如图14所示。卷积网络被分为两个阶段,分别用两个方框圈出。

在左侧的方框内,模型的第一阶段是通过不断堆叠卷积层和池化层组成的(虽然图中只显示了一层卷积和池化,实际的模型中会有多层),其中卷积的目的是做特征提取;池化的目的是做特征汇聚。

在右侧的方框内,模型的第二阶段是通过不断堆叠全连接神经网络层组成的,其目的是对上一阶段输出的特征进行学习,判断这些特征最有可能属于哪个类别。

图片[14]-卷积神经网络(CNN)算法详解-VenusAI
图14 卷积模型框架

送进全连接神经网络之前,有一步叫做展平(Flatten)的操作。对此的解释是:卷积的计算结果是一组特征图,这些数据是有空间维度的(即高度和宽度),但是全连接神经网络层能接受的数据是向量格式(即维度等于1的数据),因此,展平操作的目的是把多维的特征图压缩成长度为 “特征图高x特征图宽x特征图数量” 的一维数组,然后再与全连接层连接,通过全连接层处理卷积操作提取到的特征并输出结果。

此外,在做图像识别时,一般习惯在模型的输出结果后增加一个简单的分类器,例如Softmax分类器,其作用是把输入数据归一化到[0,1]区间,且所有归一化后的所有元素相加等于1,归一化后的数值即可表示图像属于某种类别的可能性了。

Softmax 分类器的作用简单的说就是计算一组数值中每个值的占比, 公式一般性描述为: 设一共有 n 个用数值表示的分类 S_k,k\in(0,n], 其中 n 表示分类的个数。那么 Softmax 函数计算公式为:

                                                   P\left(S_i\right)=\frac{\mathrm{e}^{gi}}{\sum_k^n\mathrm{e}^{gk}}

其中, i 表示 k 中的某个分类, g_i 表示该分类的值。

第一个卷积神经网络模型:LeNet

LeNet-5模型诞生于1994年,是最早的卷积神经网络之一,由Yann LeCun完成,推动了深度学习领域的发展。彼时,没有GPU帮助训练模型,甚至CPU的速度也很慢,神经网络模型处理图像时的大量参数并不能通过计算机得到很好地计算,LeNet-5模型通过巧妙的设计,利用卷积、参数共享及池化等操作提取特征,避免了大量的计算成本,最后再使用全连接神经网络进行分类识别。从此卷积成为图像处理之中的可行方式。

LeNet作为最初的卷积神经网络,其模型结构组成较为简单:两个卷积层、两个下采样、和三个全连接层,如图15所示。

图片[15]-卷积神经网络(CNN)算法详解-VenusAI
图15 LeNet

其中,卷积层和池化层负责对原始图像进行特征提取,全连接层负责对卷积池化提取到的特征进行学习,进一步根据这些特征来判断该输入图片属于哪一个类别。

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

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

相关文章

Android Termux系统安装openssh实现公网使用SFTP远程访问

文章目录 1. 安装openSSH2. 安装cpolar3. 远程SFTP连接配置4. 远程SFTP访问4. 配置固定远程连接地址 SFTP(SSH File Transfer Protocol)是一种基于SSH(Secure Shell)安全协议的文件传输协议。与FTP协议相比,SFTP使用了…

外包干了5天,技术退步明显。。。。。

在湖南的一个安静角落,我,一个普通的大专生,开始了我的软件测试之旅。四年的外包生涯,让我在舒适区里逐渐失去了锐气,技术停滞不前,仿佛被时间遗忘。然而,生活的转机总是在不经意间降临。 与女…

【系统学习】2-Java进阶知识总结-3-集合-1-补充【泛型、树、数据结构】

文章目录 泛型什么是泛型?常见的泛型标识符泛型类泛型方法泛型接口通配符 树树的基本概念什么是二叉树?二叉树--普通二叉树二叉树--二叉查找树定义规则优缺点 二叉树--平衡二叉树定义规则旋转机制 二叉树--红黑树定义规则红黑规则 常见数据结构总体特点结…

node的安装与介绍

安装 下载地址 node官网首页就会有两个安装选择,会根据当前电脑的系统自动显示对应的安装包,一个长期维护版(LTS),一个是尝鲜版,记住选择LTS版本 安装指定版本下载截图 安装过程截图(非常简单&#xff…

STM32CubeMX学习笔记14 ---SPI总线

1. 简介 1.1 SPI总线介绍 SPI 是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。是Motorola(摩托罗拉)首先在其MC68HCXX系列处理器上定义的。 SPI,是一种高速的,全双工,同步的通信总线,并且在…

掌握Linux之巅:RHCE认证快速攻略

在数字化时代,Linux系统已经成为企业级应用的重要支柱。RHCE(Red Hat Certified Engineer)认证,作为Linux领域的权威认证,不仅代表了专业技术的认可,更是职业发展的有力武器。本文将为你揭秘如何快速掌握Li…

@Autoweird和@Resourse的区别 java定义Bean的方式

Autoweird private Apple apple; Autoweird首先是根据类型来找 就是这个Apple 如果找到多个 会在根据名称就是这个apple来找,如果再找不到,就报错 Resourse相反 举例说明: 我们使用Autoweird ZhouyuService zhouyuService Resourse特别之…

C语言题目练习

目录 前言 1、转置矩阵 1.1 题目 描述 输入描述: 输出描述: 1.2解题 分析: 程序: 2、KiKi判断上三角矩阵 2.1 题目 描述 输入描述: 输出描述: 2.2 解题 分析: 程序: 3、…

什么是工业交换机?

如今,工业交换机在能源、环保、交通、智慧城市监控等各个行业都发挥着至关重要的作用,其需求也日益增长。本文将全面介绍工业交换机,帮助你进一步加深了解。 什么是工业交换机? 工业交换机,又称工业以太网交换机&…

基于微信小程序的电影院订票选座系统的设计与实现(程序+数据库+)

** 🍅点赞收藏关注 → 私信领取本源代码、数据库🍅 本人在Java毕业设计领域有多年的经验,陆续会更新更多优质的Java实战项目,希望你能有所收获,少走一些弯路。🍅关注我不迷路🍅** 一、研究背景…

轻薄蓝牙工牌室内人员定位应用

在现代化企业管理的背景下,轻薄蓝牙工牌人员定位应用逐渐崭露头角,成为提升企业效率和安全性的重要工具。本文将从轻薄蓝牙工牌的定义、特点、应用场景以及未来发展趋势等方面,对其进行全面深入的探讨。 一、轻薄蓝牙工牌的定义与特点 轻薄…

Vue:纯前端实现文件拖拽上传

先看一下拖拽相关的事件:dragover、dragenter drop和dragleave 。 dragover事件:当被拖动的元素在一个可放置目标上方时,该事件会被触发。 通常,我们会使用event.preventDefault()方法来取消浏览器默认的拖放行为,以便…

赛事通知丨2024年(第12届)“泰迪杯”挑战赛即将开始

2024年(第12届)“泰迪杯”数据挖掘挑战赛将于3月8日开放报名。“泰迪杯”数据挖掘挑战赛始创于2013年,迄今已经连续举办了12年。累计参赛高校千余所,累计参赛人数逾10万人,全国各省份均有参加。大赛的开展始终秉持推动…

局域网管理工具

每个组织的业务运营方法都是独一无二的,其网络基础设施也是如此,由于随着超融合基础设施等新计算技术的发展,局域网变得越来越复杂,因此局域网管理也应该如此,组织需要量身定制的局域网管理解决方案,这些解…

QT6.6 android开发环境搭建

一.目标 本文目的为实现在QT6.6下搭建android开发环境,可以实现QT6.6开发的QT程序(widget及qml工程)部署到android设备中。 二.环境安装 1.QT6.6环境安装 (1)在线安装器下载: https://download.qt.io/a…

手动更新服务器node新版本

1.安装nodejs下载到本地 2.下载后放到服务器上的指定目录中。例如/usr/local/src/node 3.执行tar -xvf node-v20.10.0-linux-x64.tar.xz解压 4.执行一下命令配置软连接 -f是如果文件存在就覆盖 # 将node源文件映射到usr/bin下的node文件 ln -fs /usr/local/src/node/node-…

10G Ethernet Subsystem 基于K7芯片的UDP通讯

此文章只用于教程开发笔记,不做过多的废话介绍。 IP核的建立 此选项不进行共享时钟逻辑。优点接口少好操作,缺点只可以建立一个IP核。(我有一篇文章介绍了如何进行多个核互联)传送门:FPGA光纤Aurora_8B_10B_fpga auro…

实现vue elmentUI图片本地上传

实现思路 后端代码 //上传头像PostMapping("/uplaod")public String upload(MultipartFile file) { // System.out.println(file"图片上次");//图片校验if (file.isEmpty()) {return "图片上传失败";}//可以自己加一点校验 例如上传的是不…

HBase 的安装与部署

目录 1 启动 zookeeper2 启动 Hadoop3 HBase 的安装与部署4 HBase 高可用 1 启动 zookeeper [huweihadoop101 ~]$ bin/zk_cluster.sh start2 启动 Hadoop [huweihadoop101 ~]$ bin/hdp_cluster.sh start3 HBase 的安装与部署 (1)将 hbase-2.0.5-bin.tar.…

加速大模型落地:火山引擎向量数据库的实践应用

近两年随着大模型技术的快速发展,图片、视频、自然语言等多模态、非结构化数据的查找需求变大,非结构化数据的量级也远大于结构化数据,传统数据库已经无法满足如此多样化数据的处理需求。向量数据库以其海量的数据存储规模、高效的计算查询能…