💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
#### 2.1.4生成对抗网络 生成性对抗网络(GAN)是利用多层体系结构强大的代表性功能的相对较新的模型。 GAN最初是在2014年推出的[57]虽然它们本身没有提出不同的架构(_即_。例如,在新型网络构建模块方面),它们具有一些特殊性,这使得它们略有不同不同类型的多层架构。 GAN响应的一个关键挑战是采用无监督的学习方法,不需要标记数据。 典型的GAN由两个竞争块或子网组成,如图2.7所示;发生器网络![](https://img.kancloud.cn/d8/26/d8269b24182ee5a22641d376c5993358_60x20.gif)和鉴别器网络![](https://img.kancloud.cn/84/b5/84b5516c36ee52c8dfdbc6bb75460b8d_63x18.gif),其中![](https://img.kancloud.cn/7f/05/7f05ba32c44427a0a85b373fd193bb05_9x8.gif)是输入随机噪声,![](https://img.kancloud.cn/3c/1a/3c1a60edb621d9a7b223a34d87cdef02_11x10.gif)是实际输入数据(_,例如_。图像)和![](https://img.kancloud.cn/19/b5/19b5edfbfd190edb57cd97dc6e381191_15x18.gif)和![](https://img.kancloud.cn/2e/e2/2ee237c15e5041876276ffbf6a747ece_15x15.gif)分别是两个块的参数。每个块可以由任何先前定义的多层体系结构构成。在原始论文中,发生器和鉴别器都是多层全连接网络。鉴别器![](https://img.kancloud.cn/26/61/2661c2f73236ce62700299f2115fb4d9_15x12.gif)被训练为识别来自发生器的数据并且以概率![](https://img.kancloud.cn/ae/6d/ae6d7dcb015d3d9a4878611695b4d0c8_17x12.gif)分配标签“假”,同时以概率![](https://img.kancloud.cn/53/f4/53f4a2336db9f462081fd46690604bc5_46x16.gif)将标签“真实”分配给真实输入数据。作为补充,生成器网络被优化以生成能够欺骗鉴别器的伪表示。这两个块在几个步骤中交替训练,其中训练过程的理想结果是鉴别器,其将![](https://img.kancloud.cn/c3/b5/c3b5904fc03536dbc796c74b06060961_32x15.gif)的概率分配给真实和伪造数据。换句话说,在收敛之后,生成器应该能够从随机输入生成实际数据。 ![](https://img.kancloud.cn/de/9c/de9c8426d92e4f010cdb6a88af05cf15_333x246.png) 图2.7:通用生成性对抗网络(GAN)结构的图示。 自原始论文以来,许多贡献都参与了通过使用更强大的多层架构作为网络的主干来增强GAN的能力[114](_,例如_。用于鉴别器和反卷积网络的预训练卷积网络,学习发电机的上采样滤波器。 GAN的一些成功应用包括:文本到图像合成(其中网络的输入是要渲染的图像的文本描述[115]),图像超分辨率,其中GAN从较低的生成逼真的高分辨率图像分辨率输入[94],图像修复GAN的作用是从输入图像填充缺失信息的孔[149]和纹理合成,其中GAN用于从输入噪声合成真实纹理[10]。 #### 2.1.5多层网络培训 如前几节所述,各种多层架构的成功在很大程度上取决于其学习过程的成功与否。虽然神经网络通常首先依赖于无监督的预训练步骤,如2.1.1节所述,但它们通常遵循最广泛使用的多层架构训练策略,这是完全监督的。训练过程通常基于使用梯度下降的误差反向传播。梯度下降因其简单性而广泛用于训练多层架构。它依赖于最小化平滑误差函数![](https://img.kancloud.cn/97/8f/978fb38532842fa6b79cc8ee2e428939_43x18.gif),遵循定义为的迭代过程 ![](https://img.kancloud.cn/18/66/18660be3990b6d3ca1d0177cf847d387_127x24.gif)(2.11) 其中![](https://img.kancloud.cn/86/7a/867a12bcaa0b2c9327f095d6ccd1bfa7_15x9.gif)表示网络参数,![](https://img.kancloud.cn/38/9a/389a9983ea24ad0b3af0559c2aca381b_11x8.gif)是可以控制收敛速度的学习速率,![](https://img.kancloud.cn/a4/5d/a45d23410b59160d6955eb918252e2da_53x40.gif)是在训练集上计算的误差梯度。这种简单的梯度下降方法特别适用于训练多层网络,这要归功于使用链规则进行反向传播并计算相对于不同层的各种网络参数的误差导数。虽然反向传播可追溯到多年[16,146],但它在多层架构的背景下得到了普及[125]。在实践中,使用随机梯度下降[2],其包括从连续的相对小的子集中近似整个训练集上的误差梯度。 梯度下降算法的主要问题之一是学习率![](https://img.kancloud.cn/38/9a/389a9983ea24ad0b3af0559c2aca381b_11x8.gif)的选择。学习率太小会导致收敛缓慢,而较大的学习率会导致围绕最佳状态的过冲或波动。因此,提出了几种方法来进一步改进简单的随机梯度下降优化方法。最简单的方法,称为随机梯度下降与动量[137],跟踪从一次迭代到另一次迭代的更新量,并通过进一步推动更新,如果梯度从一个方向指向同一方向,进一步推动学习过程时间步骤到另一个定义, ![](https://img.kancloud.cn/18/66/18660be3990b6d3ca1d0177cf847d387_127x24.gif)(2.12) 用![](https://img.kancloud.cn/8c/8b/8c8b9dbbd1e6b0fac772d9589e2d0ca2_10x12.jpg)控制动量。另一种简单的方法涉及根据固定的时间表以递减的方式设置学习速率,但这远非理想,因为该时间表必须在训练过程之前预先设定并且完全独立于数据。其他更复杂的方法(_,例如_ .Adagrad [34],Adadelta [152],Adam [86])建议通过执行较小的更新,在训练期间调整学习率到每个参数![](https://img.kancloud.cn/49/4f/494f262c0ded99d8ddd368cee8ff26d6_17x11.jpg)。频繁变化的参数和不常见的更新。这些算法的不同版本之间的详细比较可以在其他地方找到[124]。 使用梯度下降及其变体进行训练的主要缺点是需要大量标记数据。解决这一困难的一种方法是采用无监督学习。用于训练一些浅层ConvNet架构的流行的无监督方法基于预测稀疏分解(PSD)方法[85]。 Predictive Sparse Decomposition学习一组过度完整的滤波器,其组合可用于重建图像。该方法特别适用于学习卷积体系结构的参数,因为该算法被设计用于学习以补丁方式重建图像的基函数。具体地,预测稀疏分解(PSD)建立在稀疏编码算法的基础上,该算法试图通过与基组B的线性组合来找到输入信号X的有效表示Y.形式上,稀疏编码的问题广泛地存在。制定为最小化问题,定义为, ![](https://img.kancloud.cn/71/d0/71d0144f09e6cd32a31f88f4179d13a6_209x21.gif)(2.13) PSD通过最小化定义为的重构误差,在卷积框架中调整稀疏编码的思想, ![](https://img.kancloud.cn/08/e9/08e9f16aeab818cd9ed56dc64a71c4d0_490x21.gif)(2.14) 其中![](https://img.kancloud.cn/af/68/af68991085075f1aa71a1c2e6cdbf021_281x18.gif)和![](https://img.kancloud.cn/98/2b/982ba703f70cd3d04aa174ca0d31e9ac_19x12.gif),![](https://img.kancloud.cn/26/61/2661c2f73236ce62700299f2115fb4d9_15x12.gif)和![](https://img.kancloud.cn/33/8e/338ec0451e1b4b7e7decd0b4443a8828_14x12.gif)分别是网络的权重,偏差和增益(或归一化因子)。通过最小化方程2.14中定义的损失函数,算法学习表示![](https://img.kancloud.cn/11/0b/110b4406a2b7b64282c80e0d43398d01_14x12.jpg),重建输入补丁![](https://img.kancloud.cn/89/38/8938f7479ea72465602bb25b05952684_16x12.gif),同时类似于预测表示![](https://img.kancloud.cn/01/aa/01aa158fc8bc3d7f7f3b2807df8b4a5e_14x12.gif)。由于等式的第二项,学习的表示也将是稀疏的。在实践中,误差在两个交替步骤中被最小化,其中参数![](https://img.kancloud.cn/49/d4/49d4bbe8be1a84d6d5956f57efd64751_97x18.gif)是固定的并且在![](https://img.kancloud.cn/11/0b/110b4406a2b7b64282c80e0d43398d01_14x12.jpg)上执行最小化。然后,表示![](https://img.kancloud.cn/11/0b/110b4406a2b7b64282c80e0d43398d01_14x12.jpg)被固定,同时最小化其他参数。值得注意的是,PSD以补片程序应用,其中每组参数![](https://img.kancloud.cn/39/b2/39b2ccbd064f8e3241bb0dfae4f2a4c4_74x18.gif)是从输入图像重建不同的补丁中学习的。换句话说,通过将重建聚焦在输入图像的不同部分上来学习不同的内核集。 #### 2.1.6关于转学的一个词 培训多层体系结构的一个意想不到的好处是学习特征在不同数据集甚至不同任务中的令人惊讶的适应性。例子包括使用ImageNet训练的网络识别:其他物体识别数据集,如Caltech-101 [38](_,例如_。[96,154]),其他识别任务,如纹理识别(_例如_。[25]),其他应用,如物体检测(_,例如_。[53])甚至基于视频的任务,如视频动作识别(_,例如_)。 [134,41,144])。 使用多层体系结构在不同数据集和任务中提取的特征的适应性可以归因于它们的层次性,其中表示从简单和局部到抽象和全局。因此,在层次结构的较低层提取的特征往往在不同的任务中是共同的,从而使多层架构更适合于转移学习。 对不同网络和任务中特征的有趣可转移性进行系统探索,揭示了考虑转移学习时需要考虑的几个良好实践[150]。首先,它表明仅微调更高层,与微调整个网络相比,系统性能更好。其次,这项研究表明,任务越多,转移学习效率就越低。第三,更令人惊讶的是,人们发现,即使经过微调,网络在初始任务下的表现也不会受到特别的阻碍。 最近,一些新兴的努力试图通过将学习问题作为连续的两步程序,_,例如_ [3,127]来强制执行网络“转移学习能力。首先,所谓的快速学习步骤如通常所做的那样,在网络针对特定任务进行优化的情况下执行。其次,在全局学习步骤中进一步更新网络参数,该步骤尝试最小化不同任务之间的错误。 ### 2.2空间卷积网络 理论上,卷积网络可以应用于任意维度的数据。它们的二维实例非常适合于单个图像的结构,因此在计算机视觉中受到了相当大的关注。随着大规模数据集和功能强大的计算机的可用性,视觉界最近看到ConvNets在各种应用中的使用激增。本节介绍最突出的2D ConvNet架构,它将相对新颖的组件引入2.1.3节中描述的原始LeNet。