当前位置: 首页 > news >正文

做网站会提供源代码吗浙江耀华建设集团网站

做网站会提供源代码吗,浙江耀华建设集团网站,计算机 网站开发 文章,深圳代理记账多少钱一月注#xff1a;书中对代码的讲解并不详细#xff0c;本文对很多细节做了详细注释。另外#xff0c;书上的源代码是在Jupyter Notebook上运行的#xff0c;较为分散#xff0c;本文将代码集中起来#xff0c;并加以完善#xff0c;全部用vscode在python 3.9.18下测试通过书中对代码的讲解并不详细本文对很多细节做了详细注释。另外书上的源代码是在Jupyter Notebook上运行的较为分散本文将代码集中起来并加以完善全部用vscode在python 3.9.18下测试通过同时对于书上部分章节也做了整合。 Chapter7 Modern Convolutional Neural Networks 7.6 Residual Networks(ResNet) 随着我们设计越来越深的网络深刻理解“新添加的层如何提升神经网络的性能”变得至关重要。 7.6.1 Function Class 首先假设有一类特定的神经网络架构 F \mathcal{F} F它包括学习速率和其他超参数设置。对于所有 f ∈ F f \in \mathcal{F} f∈F存在一些参数集例如权重和偏置这些参数可以通过在合适的数据集上进行训练而获得。现在假设 f ∗ f^* f∗是我们真正想要找到的函数如果是 f ∗ ∈ F f^* \in \mathcal{F} f∗∈F那我们可以轻而易举的训练得到它但通常我们不会那么幸运。我们将尝试找到一个函数 f F ∗ f^*_\mathcal{F} fF∗​这是我们在 F \mathcal{F} F中的最佳选择。例如给定一个具有 X \mathbf{X} X特性和 y \mathbf{y} y标签的数据集我们可以尝试通过解决以下优化问题来找到它 f F ∗ : a r g m i n f L ( X , y , f ) ,  f ∈ F . f^*_\mathcal{F} : \mathop{\mathrm{argmin}}_f L(\mathbf{X}, \mathbf{y}, f) \text{ , } f \in \mathcal{F}. fF∗​:argminf​L(X,y,f) , f∈F. 为了得到更近似真正 f ∗ f^* f∗的函数唯一合理的可能性是设计一个更强大的架构 F ′ \mathcal{F} F′。换句话说我们预计 f F ′ ∗ f^*_{\mathcal{F}} fF′∗​比 f F ∗ f^*_{\mathcal{F}} fF∗​“更近似”。然而如果 F ⊈ F ′ \mathcal{F} \not\subseteq \mathcal{F} F⊆F′则无法保证新的体系“更近似”。事实上 f F ′ ∗ f^*_{\mathcal{F}} fF′∗​可能更糟如下图所示对于非嵌套函数non-nested function类较复杂的函数类并不总是向“真”函数 f ∗ f^* f∗靠拢复杂度由 F 1 \mathcal{F}_1 F1​向 F 6 \mathcal{F}_6 F6​递增。在下图的左边虽然 F 3 \mathcal{F}_3 F3​比 F 1 \mathcal{F}_1 F1​更接近 f ∗ f^* f∗但 F 6 \mathcal{F}_6 F6​却离的更远了。相反对于下图右边的嵌套函数nested function类 F 1 ⊆ … ⊆ F 6 \mathcal{F}_1 \subseteq \ldots \subseteq \mathcal{F}_6 F1​⊆…⊆F6​我们可以避免上述问题。 因此只有当较复杂的函数类包含较小的函数类时我们才能确保提高它们的性能。对于深度神经网络如果我们能将新添加的层训练成恒等映射identity function f ( x ) x f(\mathbf{x}) \mathbf{x} f(x)x新模型和原模型将同样有效。同时由于新模型可能得出更优的解来拟合训练数据集因此添加层似乎更容易降低训练误差。针对这一问题何恺明等人提出了残差网络ResNet。其核心思想是每个附加层都应该更容易地包含原始函数作为其元素之一。于是残差块residual blocks便诞生了这个设计对如何建立深层神经网络产生了深远的影响。 7.6.2 Residual Blocks 如上图所示假设我们的原始输入为 x x x而希望学出的理想映射为 f ( x ) f(\mathbf{x}) f(x)。上图左边是一个正常块虚线框中的部分需要直接拟合出该映射 f ( x ) f(\mathbf{x}) f(x)而右边是ResNet的基础架构–残差块residual block虚线框中的部分则需要拟合出残差映射 f ( x ) − x f(\mathbf{x}) - \mathbf{x} f(x)−x。残差映射在现实中往往更容易优化。以恒等映射作为理想映射 f ( x ) f(\mathbf{x}) f(x)只需将上图右边虚线框内上方的加权运算如仿射的权重和偏置参数设成0那么 f ( x ) f(\mathbf{x}) f(x)即为恒等映射。实际上当理想映射 f ( x ) f(\mathbf{x}) f(x)极接近于恒等映射时残差映射也易于捕捉恒等映射的细微波动。在残差块中输入可通过跨层数据线路更快地向前传播且可以避免某些梯度消失或梯度爆炸的问题。 ResNet沿用了VGG完整的 3 × 3 3\times 3 3×3卷积层设计。残差块里首先有2个有相同输出通道数的 3 × 3 3\times 3 3×3卷积层每个卷积层后接一个批量规范化层和ReLU激活函数然后我们通过跨层数据通路跳过这2个卷积运算将输入直接加在最后的ReLU激活函数前。这样的设计要求2个卷积层的输出与输入形状一样从而使它们可以相加。如果想改变通道数就需要引入一个额外的 1 × 1 1\times 1 1×1卷积层来将输入变换成需要的形状后再做相加运算。 import torch from torch import nn from torch.nn import functional as F from d2l import torch as d2l import matplotlib.pyplot as pltclass Residual(nn.Module): #savedef __init__(self, input_channels,num_channels,use_1x1convFalse, strides1):super().__init__()self.conv1 nn.Conv2d(input_channels, num_channels,kernel_size3, padding1, stridestrides)self.conv2 nn.Conv2d(num_channels, num_channels,kernel_size3, padding1)if use_1x1conv:self.conv3 nn.Conv2d(input_channels, num_channels,kernel_size1, stridestrides)else:self.conv3 Noneself.bn1 nn.BatchNorm2d(num_channels)self.bn2 nn.BatchNorm2d(num_channels)def forward(self, X):Y F.relu(self.bn1(self.conv1(X)))Y self.bn2(self.conv2(Y))if self.conv3:X self.conv3(X)Y Xreturn F.relu(Y)如下图所示此代码生成两种类型的网络当use_1x1convFalse时应用ReLU非线性函数之前将输入添加到输出当use_1x1convTrue时使用 1 × 1 1 \times 1 1×1卷积调整通道和分辨率。 blk Residual(3,3)#输入和输出形状一致 X torch.rand(4, 3, 6, 6) Y blk(X) print(Y.shape)blk Residual(3,6, use_1x1convTrue, strides2)#增加输出通道数的同时减半输出的高和宽 print(blk(X).shape)#定义ResNet的模块 #b2-b5各有4个卷积层不包括恒等映射的1x1卷积层加上第一个7x7卷积层和最后一个全连接层共有18层因此这种模型通常被称为ResNet-18 b1 nn.Sequential(nn.Conv2d(1, 64, kernel_size7, stride2, padding3),nn.BatchNorm2d(64), nn.ReLU(),nn.MaxPool2d(kernel_size3, stride2, padding1))def resnet_block(input_channels, num_channels, num_residuals,first_blockFalse):blk []for i in range(num_residuals):if i 0 and not first_block:blk.append(Residual(input_channels, num_channels,use_1x1convTrue, strides2))else:blk.append(Residual(num_channels, num_channels))return blkb2 nn.Sequential(*resnet_block(64, 64, 2, first_blockTrue)) b3 nn.Sequential(*resnet_block(64, 128, 2)) b4 nn.Sequential(*resnet_block(128, 256, 2)) b5 nn.Sequential(*resnet_block(256, 512, 2))net nn.Sequential(b1, b2, b3, b4, b5,nn.AdaptiveAvgPool2d((1,1)),nn.Flatten(), nn.Linear(512, 10))X torch.rand(size(1, 1, 224, 224)) for layer in net:X layer(X)print(layer.__class__.__name__,output shape:\t, X.shape)lr, num_epochs, batch_size 0.05, 10, 256 train_iter, test_iter d2l.load_data_fashion_mnist(batch_size, resize96) d2l.train_ch6(net, train_iter, test_iter, num_epochs, lr, d2l.try_gpu()) plt.show()训练结果
http://www.w-s-a.com/news/378613/

相关文章:

  • 南昌建站如何上wordpress
  • 洛阳网站建设优惠公司建筑企业上市公司有哪些
  • 营销型网站建设营销型网站建设手机网站设计需要学什么
  • 在线视频网站 一级做爰片南通网站建设找哪家
  • 网站优化文章东莞专业网站建设价钱
  • 哈尔滨网页设计网站模板泰兴建设局网站
  • 响应式网站设计公司报纸做垂直门户网站
  • 陕西旭泽建设有限公司网站企业网站建设软件需求分析
  • 上海公司网站建设方案中企动力西安分公司
  • dedecms网站后台怎样才能上百度
  • 云互联的网站名字亚马逊雨林生物
  • 电商网站功能企查查企业信息查询网
  • 特色网站建设中国住房和城乡建设局官网
  • 长春市住房城乡建设厅网站做白酒网站
  • 自己的网站怎么做的成品免费ppt网站
  • 番禺区网站建设哪里有泰安公司
  • 网站制作详细过程网站开发最强工具
  • 孟村县做网站长春城投建设投资有限公司网站
  • 国家重大建设项目库网站wordpress安装 var
  • 供求信息网站建设报价网站制作 苏州
  • 动漫建模代做网站百度一下wordpress nginx 固定链接
  • 广州网站开发网络公司网站建设的书
  • php手机网站开发教程家政网站怎么做
  • 视频网站的建设预算通信科技网站设计
  • 糖果网站建设策划书淘宝客网站开源
  • 建站公司还有前途吗cf网站编程
  • 网站建设需求确认表建站工具 比较
  • 刚建设的网站多久能在百度查到考试系统 微网站是什么样的
  • 商城网站建设高端企业网站建设劣势
  • 网站建设征集通讯员的通知seo推广外包