一文读懂卷积神经网络

简介: 一文读懂卷积神经网络

2022年有专家曾经预测:在视觉领域,卷积神经网络(CNN)会和Transformer平分秋色。随着Vision Transformers (ViT)成像基准SOTA模型的发布, ConvNets的黎明业已到来,这还不算:Meta和加州大学伯克利分校的研究认为, ConvNets模型的性能优越于ViTs。

在视觉建模中,虽然Transformer很快取代了递归神经网络,但是对于那些小规模的ML用例, ConvNet的使用量会出现陡降。而小型Transformer+ CNN(卷积神经网络)的混合模型,即谷歌的MaxViT模型,具备475 M参数,几乎与ConvNet-7完全匹配(89.5 3%),在ImageNet上的性能为90.88%,位居第一。

卷积神经网络的灵感来自神经科学家D.H.Hubel和T.N.Wiesel,他们在研究哺乳动物的视觉皮层时发现视觉皮层由多层神经元组成,这些层以分层结构排列,从而组成复杂的神经元。神经认知机将一个视觉模式分解成许多子模式(特征),然后进入分层递阶式相连的特征平面进行处理,它试图将视觉系统模型化,使其能够在即使物体有位移或轻微变形的时候,也能完成识别。

卷积神经网络是一种多层的监督学习神经网络,基础的CNN由 卷积(Convolution)、激活(Activation)和池化(Pooling)三种结构组成。隐含层的卷积层和池采样层是实现卷积神经网络特征提取功能的核心模块。该网络模型通过采用梯度下降法求最小化损失函数,对网络中的权重参数逐层反向调节,通过频繁的迭代训练提高网络的精度。卷积神经网络的低层由卷积层和最大池采样层交替组成,高层是全连接层对应传统多层感知器的隐含层和逻辑回归分类器。第一个全连接层的输入是由卷积层和子采样层进行特征提取得到的特征值,最后一层输出层是一个分类器,可以采用逻辑回归Softmax回归甚至是支持向量机对输入进行分类。

CNN输出的结果是每幅图像的特定特征空间。当处理图像分类任务时,通常会把CNN输出的特征空间作为全连接层或全连接神经网络(Fully Connected Neural Network, FCN)的输入,用全连接层来完成从输入图像到标签集的映射,即分类。当然,整个过程最重要的工作就是如何通过训练数据迭代调整网络权重,也就是后向传播算法。目前主流的卷积神经网络(CNN)都是由简单的CNN调整、组合而来。

图1 卷积神经网络的基础架构(来源:网络)


1. 卷积

卷积神经网络中最基础的操作是卷积(Convolution)运算,卷积运算是卷积神经网络与其它神经网络相区别的一种运算,再精确一点,基础CNN所用的卷积是一种2-D卷积。

卷积操作通过一个称为“卷积核“的窗口函数对输入进行过滤和特征提取,卷积核是一个维度更小的窗口函数,通过卷积核在二维空间的上下平移,计算出卷积核覆盖区域的点乘积,卷积的结果称为特征图或激活图。

卷积操作通常用星号表示,写作:

在实际使用中,经常在多个轴上使用卷积,因此上式也需要根据实际情况进行修改。例如,如果使用二维图像作为输入,会用到二维内核K:

2. ReLU 激活函数

卷积之后,通常会加入偏置(Bias), 并引入非线性激活函数(Activation Function),这里定义偏置为b,激活函数是 h() ,经过激活函数后,得到如下结果:

类似于其它深度学习算法,卷积神经网络通常使用修正线性单元(Rectified Linear Unit, ReLU),其它类似ReLU的变体包括有斜率的ReLU(Leaky ReLU, LReLU)、参数化的ReLU(Parametric ReLU, PReLU)、随机化的ReLU(Randomized ReLU, RReLU)、指数线性单元(Exponential Linear Unit, ELU)等  。在ReLU出现以前,通常利用Sigmoid函数和双曲正切函数(Hyperbolic Tangent)作为激活函数。

3. 池化

池化(Pooling),是一种降采样操作(Subsampling),主要目标是降低特征映射空间的维度,即高维空间到低维空间的降维,或者可以认为是降低特征映射的分辨率。由于特征映射参数太多,不利于高层特征的抽取,池化操作可以降低卷积层的空间复杂性,降低学习的权重,从而加快训练的时间。

历史上,曾经使用过不同的池化技术,主要的池化操作有:

  • 最大值池化( Max pooling):2 * 2的最大值池化就是取4个像素点中最大值保留
  • 平均值池化( Average pooling): 2 * 2的平均值池化就是取4个像素点中平均值值保留
  • L2池化( L2 pooling): 即取均方值保留


通常,最大值池化是首选的池化技术,池化操作会减少参数,降低特征图的分辨率,在计算力足够的情况下,这种强制降维的技术是非必须的,只有一些大型的CNN 网络会用到池化技术。

4. 全连接层

如果卷积网络输入是224×224×3的图像,经过一系列的卷积层和池化层(卷积层增加深度维度,池化层减小空间尺寸),尺寸变为7×7×512,之后需要输出类别分值向量,计算损失函数。假设类别数量是1000(ImageNet是1000类),则分值向量可表示为特征图1×1×1000。如何将7×7×512的特征图转化为1×1×1000的特征图呢?最常用的技巧是全连接方式,即输出1×1×1000特征图的每个神经元(共1000个神经元)与输入的所有神经元连接,而不是局部连接。每个神经元需要权重的数量为7×7×512=25088,共有1000个神经元,所以全连接层的权重总数为:25088×1000=25088000,参数如此之多,很容易造成过拟合,这是全连接方式的主要缺点。

全连接层的实现方式有两种:一种方式是把输入3D特征图拉伸为1D向量,然后采用常规神经网络的方法进行矩阵乘法;另一种方式是把全连接层转化成卷积层,这种方法更常用,尤其是在物体检测中。

卷积神经网络(CNN)是前馈神经网络,层间无反馈,CNN 可以有效解决图像分类等模式识别问题。通常,CNN 的前面是较深的多层卷积层,后接较浅的全连接层,各种实验表明,增加卷积神经网络的深度比增加卷积神经网络的宽度能更加有效地提高准确率,使得CNN的深度越来越深,随着网络深度的增加,如何有效传递误差梯度,避免梯度消失或梯度爆炸已成为CNN 需要面对的首要问题。

相关文章
|
4月前
|
机器学习/深度学习 PyTorch TensorFlow
卷积神经网络深度解析:从基础原理到实战应用的完整指南
蒋星熠Jaxonic,深度学习探索者。深耕TensorFlow与PyTorch,分享框架对比、性能优化与实战经验,助力技术进阶。
|
5月前
|
机器学习/深度学习 人工智能 算法
卷积神经网络深度解析:从基础原理到实战应用的完整指南
蒋星熠Jaxonic带你深入卷积神经网络(CNN)核心技术,从生物启发到数学原理,详解ResNet、注意力机制与模型优化,探索视觉智能的演进之路。
533 11
|
8月前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于PSO粒子群优化TCN-LSTM时间卷积神经网络时间序列预测算法matlab仿真
本内容展示了一种基于粒子群优化(PSO)与时间卷积神经网络(TCN)的时间序列预测方法。通过 MATLAB2022a 实现,完整程序运行无水印,核心代码附详细中文注释及操作视频。算法利用 PSO 优化 TCN 的超参数(如卷积核大小、层数等),提升非线性时间序列预测性能。TCN 结构包含因果卷积层与残差连接,结合 LSTM 构建混合模型,经多次迭代选择最优超参数,最终实现更准确可靠的预测效果,适用于金融、气象等领域。
|
5月前
|
机器学习/深度学习 传感器 数据采集
【故障识别】基于CNN-SVM卷积神经网络结合支持向量机的数据分类预测研究(Matlab代码实现)
【故障识别】基于CNN-SVM卷积神经网络结合支持向量机的数据分类预测研究(Matlab代码实现)
391 0
|
7月前
|
机器学习/深度学习 人工智能 PyTorch
零基础入门CNN:聚AI卷积神经网络核心原理与工业级实战指南
卷积神经网络(CNN)通过局部感知和权值共享两大特性,成为计算机视觉的核心技术。本文详解CNN的卷积操作、架构设计、超参数调优及感受野计算,结合代码示例展示其在图像分类、目标检测等领域的应用价值。
417 7
|
9月前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于PSO粒子群优化TCN时间卷积神经网络时间序列预测算法matlab仿真
本内容介绍了一种基于PSO(粒子群优化)改进TCN(时间卷积神经网络)的时间序列预测方法。使用Matlab2022a运行,完整程序无水印,附带核心代码中文注释及操作视频。TCN通过因果卷积层与残差连接处理序列数据,PSO优化其卷积核权重等参数以降低预测误差。算法中,粒子根据个体与全局最优位置更新速度和位置,逐步逼近最佳参数组合,提升预测性能。
|
8月前
|
机器学习/深度学习 数据采集 监控
基于CNN卷积神经网络和GEI步态能量提取的步态识别算法matlab仿真,对比不同角度下的步态识别性能
本项目基于CNN卷积神经网络与GEI步态能量提取技术,实现高效步态识别。算法使用不同角度(0°、45°、90°)的步态数据库进行训练与测试,评估模型在多角度下的识别性能。核心流程包括步态图像采集、GEI特征提取、数据预处理及CNN模型训练与评估。通过ReLU等激活函数引入非线性,提升模型表达能力。项目代码兼容Matlab2022a/2024b,提供完整中文注释与操作视频,助力研究与应用开发。
|
8月前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于WOA鲸鱼优化的TCN-GRU时间卷积神经网络时间序列预测算法matlab仿真
本内容包含时间序列预测算法的相关资料,涵盖以下几个方面:1. 算法运行效果预览(无水印);2. 运行环境为Matlab 2022a/2024b;3. 提供部分核心程序,完整版含中文注释及操作视频;4. 理论概述:结合时间卷积神经网络(TCN)与鲸鱼优化算法(WOA),优化TCN超参数以提升非线性时间序列预测性能。通过因果卷积层与残差连接构建TCN模型,并用WOA调整卷积核大小、层数等参数,实现精准预测。适用于金融、气象等领域决策支持。
|
8月前
|
机器学习/深度学习 数据采集 并行计算
基于WOA鲸鱼优化的TCN时间卷积神经网络时间序列预测算法matlab仿真
本内容介绍了一种基于TCN(Temporal Convolutional Network)与WOA(Whale Optimization Algorithm)的时间序列预测算法。TCN通过扩张卷积捕捉时间序列长距离依赖关系,结合批归一化和激活函数提取特征;WOA用于优化TCN网络参数,提高预测精度。算法流程包括数据归一化、种群初始化、适应度计算及参数更新等步骤。程序基于Matlab2022a/2024b开发,完整版含详细中文注释与操作视频,运行效果无水印展示。适用于函数优化、机器学习调参及工程设计等领域复杂任务。
|
8月前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于PSO粒子群优化TCN-GRU时间卷积神经网络时间序列预测算法matlab仿真
本内容涵盖基于粒子群优化(PSO)与时间卷积神经网络(TCN)的时间序列预测算法。完整程序运行效果无水印,适用于Matlab2022a版本。核心代码配有详细中文注释及操作视频。理论部分阐述了传统方法(如ARIMA)在非线性预测中的局限性,以及TCN结合PSO优化超参数的优势。模型由因果卷积层和残差连接组成,通过迭代训练与评估选择最优超参数,最终实现高精度预测,广泛应用于金融、气象等领域。