详解Pytorch 使用Pytorch拟合多项式(多项式回归)


Posted in Python onMay 24, 2018

使用Pytorch来编写神经网络具有很多优势,比起Tensorflow,我认为Pytorch更加简单,结构更加清晰。

希望通过实战几个Pytorch的例子,让大家熟悉Pytorch的使用方法,包括数据集创建,各种网络层结构的定义,以及前向传播与权重更新方式。

比如这里给出

详解Pytorch 使用Pytorch拟合多项式(多项式回归)    

很显然,这里我们只需要假定

详解Pytorch 使用Pytorch拟合多项式(多项式回归)

这里我们只需要设置一个合适尺寸的全连接网络,根据不断迭代,求出最接近的参数即可。

但是这里需要思考一个问题,使用全连接网络结构是毫无疑问的,但是我们的输入与输出格式是什么样的呢?

只将一个x作为输入合理吗?显然是不合理的,因为每一个神经元其实模拟的是wx+b的计算过程,无法模拟幂运算,所以显然我们需要将x,x的平方,x的三次方,x的四次方组合成一个向量作为输入,假设有n个不同的x值,我们就可以将n个组合向量合在一起组成输入矩阵。

这一步代码如下:

def make_features(x): 
 x = x.unsqueeze(1) 
 return torch.cat([x ** i for i in range(1,4)] , 1)

我们需要生成一些随机数作为网络输入:

def get_batch(batch_size=32): 
 random = torch.randn(batch_size) 
 x = make_features(random) 
 '''Compute the actual results''' 
 y = f(x) 
 if torch.cuda.is_available(): 
  return Variable(x).cuda(), Variable(y).cuda() 
 else: 
  return Variable(x), Variable(y)

其中的f(x)定义如下:

w_target = torch.FloatTensor([0.5,3,2.4]).unsqueeze(1) 
b_target = torch.FloatTensor([0.9]) 
 
def f(x): 
 return x.mm(w_target)+b_target[0]

接下来定义模型:

class poly_model(nn.Module): 
 def __init__(self): 
  super(poly_model, self).__init__() 
  self.poly = nn.Linear(3,1) 
 
 def forward(self, x): 
  out = self.poly(x) 
  return out
if torch.cuda.is_available(): 
 model = poly_model().cuda() 
else: 
 model = poly_model()

接下来我们定义损失函数和优化器:

criterion = nn.MSELoss() 
optimizer = optim.SGD(model.parameters(), lr = 1e-3)

网络部件定义完后,开始训练:

epoch = 0 
while True: 
 batch_x,batch_y = get_batch() 
 output = model(batch_x) 
 loss = criterion(output,batch_y) 
 print_loss = loss.data[0] 
 optimizer.zero_grad() 
 loss.backward() 
 optimizer.step() 
 epoch+=1 
 if print_loss < 1e-3: 
  break

到此我们的所有代码就敲完了,接下来我们开始详细了解一下其中的一些代码。

在make_features()定义中,torch.cat是将计算出的向量拼接成矩阵。unsqueeze是作一个维度上的变化。

get_batch中,torch.randn是产生指定维度的随机数,如果你的机器支持GPU加速,可以将Variable放在GPU上进行运算,类似语句含义相通。

x.mm是作矩阵乘法。

模型定义是重中之重,其实当你掌握Pytorch之后,你会发现模型定义是十分简单的,各种基本的层结构都已经为你封装好了。所有的层结构和损失函数都来自torch.nn,所有的模型构建都是从这个基类 nn.Module继承的。模型定义中,__init__与forward是有模板的,大家可以自己体会。

nn.Linear是做一个线性的运算,参数的含义代表了输入层与输出层的结构,即3*1;在训练阶段,有几行是Pytorch不同于别的框架的,首先loss是一个Variable,通过loss.data可以取出一个Tensor,再通过data[0]可以得到一个int或者float类型的值,我们才可以进行基本运算或者显示。每次计算梯度之前,都需要将梯度归零,否则梯度会叠加。个人觉得别的语句还是比较好懂的,如果有疑问可以在下方评论。

下面是我们的拟合结果

详解Pytorch 使用Pytorch拟合多项式(多项式回归)

其实效果肯定会很好,因为只是一个非常简单的全连接网络,希望大家通过这个小例子可以学到Pytorch的一些基本操作。往后我们会继续更新,完整代码请戳,https://github.com/ZhichaoDuan/PytorchCourse

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
简化Python的Django框架代码的一些示例
Apr 20 Python
python登录pop3邮件服务器接收邮件的方法
Apr 30 Python
Python如何抓取天猫商品详细信息及交易记录
Feb 23 Python
Python实现的读取/更改/写入xml文件操作示例
Aug 30 Python
Python multiprocessing多进程原理与应用示例
Feb 28 Python
python issubclass 和 isinstance函数
Jul 25 Python
python内存管理机制原理详解
Aug 12 Python
谈一谈数组拼接tf.concat()和np.concatenate()的区别
Feb 07 Python
深入浅析Python 函数注解与匿名函数
Feb 24 Python
解决jupyter notebook 出现In[*]的问题
Apr 13 Python
Python检测端口IP字符串是否合法
Jun 05 Python
Golang Web 框架Iris安装部署
Aug 14 Python
Python获取系统所有进程PID及进程名称的方法示例
May 24 #Python
好的Python培训机构应该具备哪些条件
May 23 #Python
Python实现的根据IP地址计算子网掩码位数功能示例
May 23 #Python
Python加载带有注释的Json文件实例
May 23 #Python
Python实现判断一行代码是否为注释的方法
May 23 #Python
对python的文件内注释 help注释方法
May 23 #Python
Python基于生成器迭代实现的八皇后问题示例
May 23 #Python
You might like
php模仿qq空间或朋友圈发布动态、评论动态、回复评论、删除动态或评论的功能(中)
2017/06/11 PHP
JS模板实现方法
2013/04/03 Javascript
使用jQuery不判断浏览器高度解决iframe自适应高度问题
2014/12/16 Javascript
JavaScript实现查找字符串中第一个不重复的字符
2014/12/29 Javascript
jQuery源码分析之jQuery.fn.each与jQuery.each用法
2015/01/23 Javascript
jquery实现清新实用的网页菜单效果
2015/08/28 Javascript
Javascript基础_标记文字的实现方法
2016/06/14 Javascript
Bootstrap的class样式小结
2016/12/01 Javascript
Mobile Web开发基础之四--处理手机设备的横竖屏问题
2017/08/11 Javascript
JS如何设置元素样式的方法示例
2017/08/28 Javascript
详解Vue文档中几个易忽视部分的剖析
2018/03/24 Javascript
vue 取出v-for循环中的index值实例
2019/11/09 Javascript
Vue自动构建发布脚本的方法示例
2020/07/24 Javascript
[10:24]郎朗助力完美“圣”典,天籁交织奏响序曲
2016/12/18 DOTA
Python OpenCV实现图片上输出中文
2018/01/22 Python
Python Scapy随心所欲研究TCP协议栈
2018/11/20 Python
python多进程并行代码实例
2019/09/30 Python
深入浅析Python科学计算库Scipy及安装步骤
2019/10/12 Python
Python中文分词库jieba,pkusegwg性能准确度比较
2020/02/11 Python
python将dict中的unicode打印成中文实例
2020/05/11 Python
python中pyplot基础图标函数整理
2020/11/10 Python
python 获取计算机的网卡信息
2021/02/18 Python
介绍一下gcc特性
2012/01/20 面试题
jQuery treeview树形结构应用
2021/03/24 jQuery
出纳岗位职责范本
2013/12/01 职场文书
教导处工作制度
2014/01/18 职场文书
借款协议书范本
2014/04/22 职场文书
党的群众路线教育实践活动对照检查材料范文
2014/09/24 职场文书
2014年销售内勤工作总结
2014/12/01 职场文书
财务总监岗位职责
2015/02/03 职场文书
2015毕业生自我评价范文
2015/03/02 职场文书
被告代理词范文
2015/05/25 职场文书
患者身份识别制度
2015/08/06 职场文书
PyQt5结合QtDesigner实现文本框读写操作
2021/06/11 Python
vue递归实现树形组件
2022/07/15 Vue.js
CSS实现鼠标悬浮动画特效
2023/05/07 HTML / CSS