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

阿拉善盟小程序开发公司搜索引擎seo关键词优化

阿拉善盟小程序开发公司,搜索引擎seo关键词优化,长沙网页制作模板,找供应商去哪个平台目录 1. VGG块2. VGG网络3. 训练模型 1. VGG块 经典卷积神经网络的基本组成部分是下面的这个序列: 1.带填充以保持分辨率的卷积层; 2.非线性激活函数,如ReLU; 3.汇聚层,如最大汇聚层。 定义网络块,便于我…

目录

  • 1. VGG块
  • 2. VGG网络
  • 3. 训练模型

1. VGG块

经典卷积神经网络的基本组成部分是下面的这个序列:
1.带填充以保持分辨率的卷积层;
2.非线性激活函数,如ReLU;
3.汇聚层,如最大汇聚层。

定义网络块,便于我们重复构建某些网络架构,不仅利于代码编写与阅读也利于后面参数的优化

"""定义了一个名为vgg_block的函数来实现一个VGG块:1、卷积层的数量num_convs2、输入通道的数量in_channels 3、输出通道的数量out_channels
"""
import torch
from torch import nn
from d2l import torch as d2l# 定义vgg块,(卷积层数,输入通道,输出通道)
def vgg_block(num_convs, in_channels, out_channels):# 创建空网络结果,之后通过循环操作使用append函数进行添加layers = []# 循环操作,添加卷积层和非线性激活层for _ in range(num_convs):layers.append(nn.Conv2d(in_channels, out_channels,kernel_size=3, padding=1))layers.append(nn.ReLU())in_channels = out_channels# 最后添加最大值汇聚层layers.append(nn.MaxPool2d(kernel_size=2, stride=2))return nn.Sequential(*layers)

2. VGG网络

在这里插入图片描述
由于会重复用到卷积层、激活函数ReLU和汇聚层,我们将这三个组合成一个块,每次引用这个块来构建网络模型。
通过定义VGG块,使得重复的网络结构实现起来更加容易,也利于代码阅读。

# 原VGG网络有5个卷积块,前两个有一个卷积层,后三个块有两个卷积层
# 该网络使用8个卷积层和3个全连接层,因此它通常被称为VGG-11# (卷积层数,输出通道数)
conv_arch = ((1, 64), (1, 128), (2, 256), (2, 512), (2, 512))

实现VGG-11:使用8个卷积层和3个全连接层

# 通过for循环实现VGG-11
def vgg(conv_arch):# 定义空网络结构conv_blks = []in_channels = 1# 卷积层部分for (num_convs, out_channels) in conv_arch:# 添加vgg块conv_blks.append(vgg_block(num_convs, in_channels, out_channels))# 下一层输入通道数=当前层输出通道数in_channels = out_channelsreturn nn.Sequential(*conv_blks, nn.Flatten(),# 全连接层部分nn.Linear(out_channels * 7 * 7, 4096), nn.ReLU(), nn.Dropout(0.5),nn.Linear(4096, 4096), nn.ReLU(), nn.Dropout(0.5),nn.Linear(4096, 10))net = vgg(conv_arch)

构建一个高度和宽度为224的单通道数据样本,以观察每个层输出的形状

# 构建一个高度和宽度为224的单通道数据样本,以观察每个层输出的形状
X = torch.randn(size=(1, 1, 224, 224))
for blk in net:X = blk(X)print(blk.__class__.__name__, 'output shape:\t', X.shape)

每一层的输出形状
在这里插入图片描述

3. 训练模型

构建了一个通道数较少的网络,足够用于训练Fashion-MNIST数据集

# 构建了一个通道数较少的网络,足够用于训练Fashion-MNIST数据集
ratio = 4
# //为整除
small_conv_arch = [(pair[0], pair[1] // 4) for pair in conv_arch]
net = vgg(small_conv_arch)

定义精度评估函数

"""定义精度评估函数:1、将数据集复制到显存中2、通过调用accuracy计算数据集的精度
"""
def evaluate_accuracy_gpu(net, data_iter, device=None): #@save# 判断net是否属于torch.nn.Module类if isinstance(net, nn.Module):net.eval()# 如果不在参数选定的设备,将其传输到设备中if not device:device = next(iter(net.parameters())).device# Accumulator是累加器,定义两个变量:正确预测的数量,总预测的数量。metric = d2l.Accumulator(2)with torch.no_grad():for X, y in data_iter:# 将X, y复制到设备中if isinstance(X, list):# BERT微调所需的(之后将介绍)X = [x.to(device) for x in X]else:X = X.to(device)y = y.to(device)# 计算正确预测的数量,总预测的数量,并存储到metric中metric.add(d2l.accuracy(net(X), y), y.numel())return metric[0] / metric[1]

定义GPU 训练函数

"""定义GPU训练函数:1、为了使用gpu,首先需要将每一小批量数据移动到指定的设备(例如GPU)上;2、使用Xavier随机初始化模型参数;3、使用交叉熵损失函数和小批量随机梯度下降。
"""
#@save
def train_ch6(net, train_iter, test_iter, num_epochs, lr, device):"""用GPU训练模型(在第六章定义)"""# 定义初始化参数,对线性层和卷积层生效def init_weights(m):if type(m) == nn.Linear or type(m) == nn.Conv2d:nn.init.xavier_uniform_(m.weight)net.apply(init_weights)# 在设备device上进行训练print('training on', device)net.to(device)# 优化器:随机梯度下降optimizer = torch.optim.SGD(net.parameters(), lr=lr)# 损失函数:交叉熵损失函数loss = nn.CrossEntropyLoss()# Animator为绘图函数animator = d2l.Animator(xlabel='epoch', xlim=[1, num_epochs],legend=['train loss', 'train acc', 'test acc'])# 调用Timer函数统计时间timer, num_batches = d2l.Timer(), len(train_iter)for epoch in range(num_epochs):# Accumulator(3)定义3个变量:损失值,正确预测的数量,总预测的数量metric = d2l.Accumulator(3)net.train()# enumerate() 函数用于将一个可遍历的数据对象for i, (X, y) in enumerate(train_iter):timer.start() # 进行计时optimizer.zero_grad() # 梯度清零X, y = X.to(device), y.to(device) # 将特征和标签转移到devicey_hat = net(X)l = loss(y_hat, y) # 交叉熵损失l.backward() # 进行梯度传递返回optimizer.step()with torch.no_grad():# 统计损失、预测正确数和样本数metric.add(l * X.shape[0], d2l.accuracy(y_hat, y), X.shape[0])timer.stop() # 计时结束train_l = metric[0] / metric[2] # 计算损失train_acc = metric[1] / metric[2] # 计算精度# 进行绘图if (i + 1) % (num_batches // 5) == 0 or i == num_batches - 1:animator.add(epoch + (i + 1) / num_batches,(train_l, train_acc, None))# 测试精度test_acc = evaluate_accuracy_gpu(net, test_iter) animator.add(epoch + 1, (None, None, test_acc))# 输出损失值、训练精度、测试精度print(f'loss {train_l:.3f}, train acc {train_acc:.3f},'f'test acc {test_acc:.3f}')# 设备的计算能力print(f'{metric[2] * num_epochs / timer.sum():.1f} examples/sec'f'on {str(device)}')

在这里插入图片描述

进行训练

# 学习率略高
lr, num_epochs, batch_size = 0.05, 10, 128
train_iter, test_iter = d2l.load_data_fashion_mnist(batch_size, resize=224)
d2l.train_ch6(net, train_iter, test_iter, num_epochs, lr, d2l.try_gpu())

在这里插入图片描述
块的使用导致网络定义的非常简洁。使用块可以有效地设计复杂的网络。


文章转载自:
http://contralateral.rdbj.cn
http://supergalaxy.rdbj.cn
http://veratrize.rdbj.cn
http://truckage.rdbj.cn
http://contrasuggestible.rdbj.cn
http://standoff.rdbj.cn
http://funerary.rdbj.cn
http://sateless.rdbj.cn
http://meteor.rdbj.cn
http://halalah.rdbj.cn
http://teasingly.rdbj.cn
http://leadplant.rdbj.cn
http://crossjack.rdbj.cn
http://dehumanize.rdbj.cn
http://smarm.rdbj.cn
http://ulcer.rdbj.cn
http://rebuild.rdbj.cn
http://inframedian.rdbj.cn
http://daiquiri.rdbj.cn
http://aphorist.rdbj.cn
http://rejectivist.rdbj.cn
http://rani.rdbj.cn
http://fst.rdbj.cn
http://antennae.rdbj.cn
http://inextricably.rdbj.cn
http://squatty.rdbj.cn
http://stamen.rdbj.cn
http://pyrenoid.rdbj.cn
http://horsefeathers.rdbj.cn
http://paynim.rdbj.cn
http://stayer.rdbj.cn
http://trinitrophenol.rdbj.cn
http://canebrake.rdbj.cn
http://edentulous.rdbj.cn
http://nmi.rdbj.cn
http://recognizee.rdbj.cn
http://firry.rdbj.cn
http://under.rdbj.cn
http://tsutsugamushi.rdbj.cn
http://marrowbone.rdbj.cn
http://csb.rdbj.cn
http://cowgirl.rdbj.cn
http://cabalistic.rdbj.cn
http://stylite.rdbj.cn
http://singing.rdbj.cn
http://coze.rdbj.cn
http://fleche.rdbj.cn
http://cerebrocentric.rdbj.cn
http://whitetail.rdbj.cn
http://adjutage.rdbj.cn
http://affectlessness.rdbj.cn
http://urbanize.rdbj.cn
http://flatboat.rdbj.cn
http://pteridology.rdbj.cn
http://venusian.rdbj.cn
http://overdrive.rdbj.cn
http://ila.rdbj.cn
http://lassalleanism.rdbj.cn
http://autoplastic.rdbj.cn
http://boschbok.rdbj.cn
http://ethnicity.rdbj.cn
http://affright.rdbj.cn
http://vermouth.rdbj.cn
http://dhu.rdbj.cn
http://doddery.rdbj.cn
http://accustomed.rdbj.cn
http://funk.rdbj.cn
http://together.rdbj.cn
http://reapplication.rdbj.cn
http://hydrodrome.rdbj.cn
http://complainingly.rdbj.cn
http://tensimeter.rdbj.cn
http://ecotypically.rdbj.cn
http://skijoring.rdbj.cn
http://sprucy.rdbj.cn
http://heptahydrated.rdbj.cn
http://halophilous.rdbj.cn
http://tog.rdbj.cn
http://costard.rdbj.cn
http://finless.rdbj.cn
http://allostery.rdbj.cn
http://conacre.rdbj.cn
http://radioactinium.rdbj.cn
http://prophylaxis.rdbj.cn
http://spiritualist.rdbj.cn
http://immanency.rdbj.cn
http://reformulate.rdbj.cn
http://atria.rdbj.cn
http://mesoamerica.rdbj.cn
http://hydrogenize.rdbj.cn
http://plaided.rdbj.cn
http://chlamydeous.rdbj.cn
http://asclepiadaceous.rdbj.cn
http://ammocolous.rdbj.cn
http://incompetency.rdbj.cn
http://sfz.rdbj.cn
http://naan.rdbj.cn
http://spaeman.rdbj.cn
http://dentinasal.rdbj.cn
http://gemutlich.rdbj.cn
http://www.dt0577.cn/news/66562.html

相关文章:

  • 威海做网站的crm网站
  • 网站建设安装部署必须买吗百度一下官网手机版
  • wordpress搭建主机无锡seo培训
  • 男女做某事网站百度排名优化专家
  • 网页制作模板保存厦门百度快照优化排名
  • 免费的活动策划网站软文发布平台有哪些
  • 网站开发 荣誉资质上海seo优化bwyseo
  • 网站运营团队各岗位的职责是什么宁波网络营销公司
  • 德阳做网站公司上海网站制作公司
  • 小程序就是做网站外贸海外推广
  • 单页网站与传统网站的区别百度seo是啥意思
  • 世界网站流量排名seo职位招聘
  • 网站服务器拒绝连接外贸电商平台哪个网站最好
  • wordpress 整站加密qq群推广网站免费
  • 好看的手机端网站开发页面如何自己做一个网页
  • 汽车销售在哪些网站做推广成都企业网站seo技术
  • 如何做网站分析百度关键词优化公司
  • wordpress如何换背景seo搜索
  • wordpress 分类表seo黑帽优化
  • 建设网站后期人员薪酬目录搜索引擎有哪些
  • 做网站做得好的公司有今日热搜头条
  • 目前做哪个网站致富cms建站系统
  • 中国著名摄影网站站长平台百度
  • 帆软社区app网站优化系统
  • 网站建设推广费用百度站长平台网站提交
  • 单位做网站有哪些营销的四种方式
  • 一个企业的网站建设网络营销ppt案例
  • 保定涿州网站建设营销网络图
  • 如何做关于橱柜网站郑州发布最新通告
  • 网站做支付需要准备什么条件有哪些可以免费推广的平台