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

科普互联网站建设我赢网客服系统

科普互联网站建设,我赢网客服系统,重庆网站如何做推广,系统的超级宗门1.Mnist分类任务 网络基本构建与训练方法,常用函数解析 torch.nn.functional模块 nn.Module模块 学习方法:边用边查,多打印,duogua 使用jupyter的优点,可以打印出每一个步骤。 2.读取数据集 自动下载 %matplotl…

1.Mnist分类任务

  • 网络基本构建与训练方法,常用函数解析

  • torch.nn.functional模块

  • nn.Module模块

学习方法:边用边查,多打印,duo'gua

使用jupyter的优点,可以打印出每一个步骤。

2.读取数据集

自动下载

%matplotlib inline
#查看本机torch的版本
import torch
print(torch.__version__)#打印torch的版本

加载并读取数据集

from pathlib import Path
import requestsDATA_PATH = Path("data")
PATH = DATA_PATH / "mnist"PATH.mkdir(parents=True, exist_ok=True)URL = "http://deeplearning.net/data/mnist/"
FILENAME = "mnist.pkl.gz"if not (PATH / FILENAME).exists():content = requests.get(URL + FILENAME).content(PATH / FILENAME).open("wb").write(content)import pickle
import gzipwith gzip.open((PATH / FILENAME).as_posix(), "rb") as f:((x_train, y_train), (x_valid, y_valid), _) = pickle.load(f, encoding="latin-1")

观察数据的结构

784是mnist数据集每个样本的像素点个数

print(x_train[0].shape)
print(x_train.shape)
y_train

显示一个记录的灰度图

from matplotlib import pyplot
import numpy as nppyplot.imshow(x_train[0].reshape((28, 28)), cmap="gray")
print(x_train.shape)

 numpy和torch的区别:
torch->gpu->tensor
numpy->cpu->ndarray

数据转化:

import torchx_train, y_train, x_valid, y_valid = map(torch.tensor, (x_train, y_train, x_valid, y_valid)
)
n, c = x_train.shape
x_train, x_train.shape, y_train.min(), y_train.max()
print(x_train, y_train)
print(x_train.shape)
print(y_train.min(), y_train.max())

3  torch.nn.functional 很多层和函数在这里都会见到

torch.nn.functional中有很多功能,后续会常用的。那什么时候使用nn.Module,什么时候使用nn.functional呢?一般情况下,如果模型有可学习的参数,最好用nn.Module,其他情nn.functional相对更简单一些

import torch.nn.functional as Floss_func = F.cross_entropydef model(xb):return xb.mm(weights) + biasbs = 64
xb = x_train[0:bs]  # a mini-batch from x
yb = y_train[0:bs]
weights = torch.randn([784, 10], dtype = torch.float,  requires_grad = True) 
#线性代数的相关知识,weights与输入想乘之后,需要输出的格式为10分类,所以的weights的矩阵为(784,10)
bs = 64
bias = torch.zeros(10, requires_grad=True)#偏执的设置,常数值作为初始化,因为这个东西对模型的影###响不是很大。print(loss_func(model(xb), yb)):#计算真实值和预测值之间的误差

4  创建一个model来更简化代码

  • 必须继承nn.Module且在其构造函数中需调用nn.Module的构造函数
  • 无需写反向传播函数,nn.Module能够利用autograd自动实现反向传播
  • Module中的可学习参数可以通过named_parameters()或者parameters()返回迭代器
from torch import nnclass Mnist_NN(nn.Module):def __init__(self):super().__init__()self.hidden1 = nn.Linear(784, 128)self.hidden2 = nn.Linear(128, 256)self.out  = nn.Linear(256, 10)#定义前向传播,torch有一个优点:前向传播自己定义,反向传播自动实现。def forward(self, x):x = F.relu(self.hidden1(x))x = F.relu(self.hidden2(x))x = self.out(x)return x
net = Mnist_NN()
print(net)

可以打印我们定义好名字里的权重和偏置项

for name, parameter in net.named_parameters():print(name, parameter,parameter.size())

5  使用TensorDataset和DataLoader来简化

from torch.utils.data import TensorDataset
from torch.utils.data import DataLoadertrain_ds = TensorDataset(x_train, y_train)
train_dl = DataLoader(train_ds, batch_size=bs, shuffle=True)#shuffle=True:洗牌的操作。
valid_ds = TensorDataset(x_valid, y_valid)
valid_dl = DataLoader(valid_ds, batch_size=bs * 2)def get_data(train_ds, valid_ds, bs):return (DataLoader(train_ds, batch_size=bs, shuffle=True),DataLoader(valid_ds, batch_size=bs * 2),)
  • 一般在训练模型时加上model.train(),这样会正常使用Batch Normalization和 Dropout
  • 测试的时候一般选择model.eval(),这样就不会使用Batch Normalization和 Dropout
http://www.dinnco.com/news/79128.html

相关文章:

  • 泉州网站的建设广东网站seo策划
  • 什么软件可以做mv视频网站seo优化教程培训
  • 网站seo的重要性国内十大4a广告公司
  • 牡丹区住房城乡建设局网站有什么平台可以发广告
  • 四川省建设厅网站川北医学院seo零基础培训
  • 阳江市建设路龙源学校网站阿里指数查询手机版
  • 上海城乡建设与交通委员会网站一套完整的运营方案
  • 无锡建设公司网站中国十大软件外包公司
  • wordpress变域名工具关键词优化排名软件
  • 郑州手机网站制作公司网络推广公司运营
  • 蛋糕方案网站建设百度账号一键登录
  • 永久域名怎么注册seo实训报告
  • 上海装修公司排名十强南宁seo外包服务
  • 光明乳业网站是谁做的指数工具
  • wordpress批量添加摘要网站优化seo培
  • 网络供应商网站网址seo公司推荐推广平台
  • 旅游官网优化大师安卓版
  • 网站开发有哪些风险企业邮箱哪个好
  • wordpress插件dflipseo关键词优化排名推广
  • wordpress 选择插件seo销售话术开场白
  • 苏州专业做网站公司有哪些百度怎么打广告在首页
  • 做百度推广是不是得有个网站先怎么做线上推广
  • 自己做网站背景图片内容营销是什么意思
  • 淘宝客网站建站教程肇庆网站搜索排名
  • 供应邢台wap网站建设郑州制作网站公司
  • 网站设计套餐百度新闻下载安装
  • 专业的led网站建设线上营销有哪些
  • 新手做电影网站百度一下首页百度
  • 广州外贸建网站职业培训网
  • 各大网站什么时候恢复彩色焦作网络推广哪家好