网站推广策划案关键词上海软件系统开发公司
2026/6/20 3:58:23 网站建设 项目流程
网站推广策划案关键词,上海软件系统开发公司,没营业执照怎么做网站,网站关键词如何做优化汇聚层 学习目标 通过本课程#xff0c;学习汇聚层的双重特性#xff08;降低卷积层对位置的敏感性#xff0c;同时降低对空间降采样表示的敏感性#xff09;、指定汇聚层的填充和步幅、汇聚层的输出通道数与输入通道数相同的特性。 相关知识点 汇聚层的特性及应用 学习内容…汇聚层学习目标通过本课程学习汇聚层的双重特性降低卷积层对位置的敏感性同时降低对空间降采样表示的敏感性、指定汇聚层的填充和步幅、汇聚层的输出通道数与输入通道数相同的特性。相关知识点汇聚层的特性及应用学习内容1 汇聚层的特性及应用通常当我们处理图像时我们希望逐渐降低隐藏表示的空间分辨率、聚集信息这样随着我们在神经网络中层叠的上升每个神经元对其敏感的感受野输入就越大。而我们的机器学习任务通常会跟全局图像的问题有关例如“图像是否包含一只猫呢”所以我们最后一层的神经元应该对整个输入的全局敏感。通过逐渐聚合信息生成越来越粗糙的映射最终实现学习全局表示的目标同时将卷积图层的所有优势保留在中间层。此外当检测较底层的特征时我们通常希望这些特征保持某种程度上的平移不变性。例如如果我们拍摄黑白之间轮廓清晰的图像X并将整个图像向右移动一个像素即Z[i, j] X[i, j 1]则新图像Z的输出可能大不相同。而在现实中随着拍摄角度的移动任何物体几乎不可能发生在同一像素上。即使用三脚架拍摄一个静止的物体由于快门的移动而引起的相机振动可能会使所有物体左右移动一个像素除了高端相机配备了特殊功能来解决这个问题。本课程将介绍汇聚pooling层它具有双重目的降低卷积层对位置的敏感性同时降低对空间降采样表示的敏感性。1.1 最大汇聚层和平均汇聚层与卷积层类似汇聚层运算符由一个固定形状的窗口组成该窗口根据其步幅大小在输入的所有区域上滑动为固定形状窗口有时称为汇聚窗口遍历的每个位置计算一个输出。然而不同于卷积层中的输入与卷积核之间的互相关计算汇聚层不包含参数。相反池运算是确定性的我们通常计算汇聚窗口中所有元素的最大值或平均值。这些操作分别称为最大汇聚层maximum pooling和平均汇聚层average pooling。在这两种情况下与互相关运算符一样汇聚窗口从输入张量的左上角开始从左往右、从上往下的在输入张量内滑动。在汇聚窗口到达的每个位置它计算该窗口中输入子张量的最大值或平均值。计算最大值或平均值是取决于使用了最大汇聚层还是平均汇聚层。图1汇聚窗口形状为2×2的最大汇聚层图1中的输出张量的高度为222宽度为222。这四个元素为每个汇聚窗口中的最大值max⁡(0,1,3,4)4,max⁡(1,2,4,5)5,max⁡(3,4,6,7)7,max⁡(4,5,7,8)8. \max(0, 1, 3, 4)4,\\ \max(1, 2, 4, 5)5,\\ \max(3, 4, 6, 7)7,\\ \max(4, 5, 7, 8)8.\\max(0,1,3,4)4,max(1,2,4,5)5,max(3,4,6,7)7,max(4,5,7,8)8.汇聚窗口形状为p×qp \times qp×q的汇聚层称为p×qp \times qp×q汇聚层汇聚操作称为p×qp \times qp×q汇聚。回到本课程开头提到的对象边缘检测示例现在我们将使用卷积层的输出作为2×22\times 22×2最大汇聚的输入。设置卷积层输入为X汇聚层输出为Y。无论X[i, j]和X[i, j 1]的值相同与否或X[i, j 1]和X[i, j 2]的值相同与否汇聚层始终输出Y[i, j] 1。也就是说使用2×22\times 22×2最大汇聚层即使在高度或宽度上移动一个元素卷积层仍然可以识别到模式。在下面的代码中的pool2d函数我们实现汇聚层的前向传播。这类似于corr2d函数。然而这里我们没有卷积核输出为输入中每个区域的最大值或平均值。#安装依赖%pip install torch2.1.0%pip install torchvision0.16.0%pip install d2limporttorchfromtorchimportnnfromd2limporttorchasd2ldefpool2d(X,pool_size,modemax):p_h,p_wpool_size Ytorch.zeros((X.shape[0]-p_h1,X.shape[1]-p_w1))foriinrange(Y.shape[0]):forjinrange(Y.shape[1]):ifmodemax:Y[i,j]X[i:ip_h,j:jp_w].max()elifmodeavg:Y[i,j]X[i:ip_h,j:jp_w].mean()returnY我们可以构建输入张量X验证二维最大汇聚层的输出。Xtorch.tensor([[0.0,1.0,2.0],[3.0,4.0,5.0],[6.0,7.0,8.0]])pool2d(X,(2,2))tensor([[4., 5.], [7., 8.]])此外我们还可以验证平均汇聚层。pool2d(X,(2,2),avg)tensor([[2., 3.], [5., 6.]])1.2 填充和步幅与卷积层一样汇聚层也可以改变输出形状。和以前一样我们可以通过填充和步幅以获得所需的输出形状。下面我们用深度学习框架中内置的二维最大汇聚层来演示汇聚层中填充和步幅的使用。我们首先构造了一个输入张量X它有四个维度其中样本数和通道数都是1。Xtorch.arange(16,dtypetorch.float32).reshape((1,1,4,4))Xtensor([[[[ 0., 1., 2., 3.], [ 4., 5., 6., 7.], [ 8., 9., 10., 11.], [12., 13., 14., 15.]]]])默认情况下深度学习框架中的步幅与汇聚窗口的大小相同。因此如果我们使用形状为(3, 3)的汇聚窗口那么默认情况下我们得到的步幅形状为(3, 3)。pool2dnn.MaxPool2d(3)pool2d(X)out:tensor([[[[10.]]]])填充和步幅可以手动设定。pool2dnn.MaxPool2d(3,padding1,stride2)pool2d(X)out:tensor([[[[ 5., 7.], [13., 15.]]]])当然我们可以设定一个任意大小的矩形汇聚窗口并分别设定填充和步幅的高度和宽度。pool2dnn.MaxPool2d((2,3),stride(2,3),padding(0,1))pool2d(X)tensor([[[[ 5., 7.], [13., 15.]]]])1.3 多个通道在处理多通道输入数据时汇聚层在每个输入通道上单独运算而不是像卷积层一样在通道上对输入进行汇总。这意味着汇聚层的输出通道数与输入通道数相同。下面我们将在通道维度上连结张量X和X 1以构建具有2个通道的输入。Xtorch.cat((X,X1),1)Xtensor([[[[ 0., 1., 2., 3.], [ 4., 5., 6., 7.], [ 8., 9., 10., 11.], [12., 13., 14., 15.]], [[ 1., 2., 3., 4.], [ 5., 6., 7., 8.], [ 9., 10., 11., 12.], [13., 14., 15., 16.]]]])如下所示汇聚后输出通道的数量仍然是2。pool2dnn.MaxPool2d(3,padding1,stride2)pool2d(X)tensor([[[[ 5., 7.], [13., 15.]], [[ 6., 8.], [14., 16.]]]])

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询