使用Keras实现简单线性回归模型操作


Posted in Python onJune 12, 2020

神经网络可以用来模拟回归问题 (regression),实质上是单输入单输出神经网络模型,例如给下面一组数据,用一条线来对数据进行拟合,并可以预测新输入 x 的输出值。

使用Keras实现简单线性回归模型操作

一、详细解读

我们通过这个简单的例子来熟悉Keras构建神经网络的步骤:

1.导入模块并生成数据

首先导入本例子需要的模块,numpy、Matplotlib、和keras.models、keras.layers模块。Sequential是多个网络层的线性堆叠,可以通过向Sequential模型传递一个layer的list来构造该模型,也可以通过.add()方法一个个的将layer加入模型中。layers.Dense 意思是这个神经层是全连接层。

2.建立模型

然后用 Sequential 建立 model,再用 model.add 添加神经层,添加的是 Dense 全连接神经层。参数有两个,(注意此处Keras 2.0.2版本中有变更)一个是输入数据的维度,另一个units代表神经元数,即输出单元数。如果需要添加下一个神经层的时候,不用再定义输入的纬度,因为它默认就把前一层的输出作为当前层的输入。在这个简单的例子里,只需要一层就够了。

3.激活模型

model.compile来激活模型,参数中,误差函数用的是 mse均方误差;优化器用的是 sgd 随机梯度下降法。

4.训练模型

训练的时候用 model.train_on_batch 一批一批的训练 X_train, Y_train。默认的返回值是 cost,每100步输出一下结果。

5.验证模型

用到的函数是 model.evaluate,输入测试集的x和y,输出 cost,weights 和 biases。其中 weights 和 biases 是取在模型的第一层 model.layers[0] 学习到的参数。从学习到的结果你可以看到, weights 比较接近0.5,bias 接近 2。

Weights= [[ 0.49136472]]

biases= [ 2.00405312]

6.可视化学习结果

最后可以画出预测结果,与测试集的值进行对比。

使用Keras实现简单线性回归模型操作

二、完整代码

import numpy as np
np.random.seed(1337) 
from keras.models import Sequential
from keras.layers import Dense
import matplotlib.pyplot as plt
 
# 生成数据
X = np.linspace(-1, 1, 200) #在返回(-1, 1)范围内的等差序列
np.random.shuffle(X) # 打乱顺序
Y = 0.5 * X + 2 + np.random.normal(0, 0.05, (200, )) #生成Y并添加噪声
# plot
plt.scatter(X, Y)
plt.show()
 
X_train, Y_train = X[:160], Y[:160]  # 前160组数据为训练数据集
X_test, Y_test = X[160:], Y[160:]  #后40组数据为测试数据集
 
# 构建神经网络模型
model = Sequential()
model.add(Dense(input_dim=1, units=1))
 
# 选定loss函数和优化器
model.compile(loss='mse', optimizer='sgd')
 
# 训练过程
print('Training -----------')
for step in range(501):
 cost = model.train_on_batch(X_train, Y_train)
 if step % 50 == 0:
  print("After %d trainings, the cost: %f" % (step, cost))
 
# 测试过程
print('\nTesting ------------')
cost = model.evaluate(X_test, Y_test, batch_size=40)
print('test cost:', cost)
W, b = model.layers[0].get_weights()
print('Weights=', W, '\nbiases=', b)
 
# 将训练结果绘出
Y_pred = model.predict(X_test)
plt.scatter(X_test, Y_test)
plt.plot(X_test, Y_pred)
plt.show()

三、其他补充

1. numpy.linspace

numpy.linspace(start, stop, num=50, endpoint=True,retstep=False,dtype=None)

返回等差序列,序列范围在(start,end),生成num个元素的np数组,如果endpoint为False,则生成num+1个但是返回num个,retstep=True则在其后返回步长.

>>> np.linspace(2.0, 3.0, num=5)
array([ 2. , 2.25, 2.5 , 2.75, 3. ])
>>> np.linspace(2.0, 3.0, num=5, endpoint=False)
array([ 2. , 2.2, 2.4, 2.6, 2.8])
>>> np.linspace(2.0, 3.0, num=5, retstep=True)
(array([ 2. , 2.25, 2.5 , 2.75, 3. ]), 0.25)

以上这篇使用Keras实现简单线性回归模型操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
进一步了解Python中的XML 工具
Apr 13 Python
python基于xmlrpc实现二进制文件传输的方法
Jun 02 Python
python实现二叉树的遍历
Dec 11 Python
python创建文件时去掉非法字符的方法
Oct 31 Python
Python实现删除排序数组中重复项的两种方法示例
Jan 31 Python
对django的User模型和四种扩展/重写方法小结
Aug 17 Python
python实现批量处理将图片粘贴到另一张图片上并保存
Dec 12 Python
如何在 Django 模板中输出 "{{"
Jan 24 Python
解决jupyter运行pyqt代码内核重启的问题
Apr 16 Python
使用已经得到的keras模型识别自己手写的数字方式
Jun 29 Python
Python getsizeof()和getsize()区分详解
Nov 20 Python
使用python求解迷宫问题的三种实现方法
Mar 17 Python
Python实现Keras搭建神经网络训练分类模型教程
Jun 12 #Python
简单了解Python变量作用域正确使用方法
Jun 12 #Python
keras 读取多标签图像数据方式
Jun 12 #Python
Python数据可视化图实现过程详解
Jun 12 #Python
浅谈cv2.imread()和keras.preprocessing中的image.load_img()区别
Jun 12 #Python
升级keras解决load_weights()中的未定义skip_mismatch关键字问题
Jun 12 #Python
解决Tensorflow2.0 tf.keras.Model.load_weights() 报错处理问题
Jun 12 #Python
You might like
PHP数学运算函数大汇总(经典值得收藏)
2016/04/01 PHP
详解PHP如何更好的利用PHPstorm的自动提示
2017/08/18 PHP
PHP如何防止XSS攻击与XSS攻击原理的讲解
2019/03/22 PHP
PHP的垃圾回收机制代码实例讲解
2021/02/27 PHP
jQuery中与toggleClass等价的程序段 以及未来学习的方向
2010/03/18 Javascript
javascript基础知识大全 便于大家学习,也便于我自己查看
2012/08/17 Javascript
提交表单时执行func方法实现代码
2013/03/17 Javascript
20行代码实现的一个CSS覆盖率测试脚本
2013/07/07 Javascript
jQuery实现鼠标经过购物车出现下拉框代码(推荐)
2016/07/21 Javascript
js仿搜狐视频记录片列表展示效果
2020/05/30 Javascript
利用CSS、JavaScript及Ajax实现图片预加载的三大方法
2017/01/22 Javascript
前端把html表格生成为excel表格的实例
2017/09/19 Javascript
vue.js使用代理和使用Nginx来解决跨域的问题
2018/02/03 Javascript
JavaScript中this的全面解析及常见实例
2019/05/14 Javascript
vuex根据不同的用户权限展示不同的路由列表功能
2019/09/20 Javascript
js实现鼠标拖曳效果
2020/12/30 Javascript
[56:57]LGD vs VP 2019DOTA2国际邀请赛淘汰赛 胜者组赛BO3 第一场 8.20.mp4
2019/08/22 DOTA
python实现从字典中删除元素的方法
2015/05/04 Python
Python对列表排序的方法实例分析
2015/05/16 Python
Pycharm学习教程(3) 代码运行调试
2017/05/03 Python
浅谈python requests 的put, post 请求参数的问题
2019/01/02 Python
对Python生成汉字字库文字,以及转换为文字图片的实例详解
2019/01/29 Python
Django urls.py重构及参数传递详解
2019/07/23 Python
Python的互斥锁与信号量详解
2019/09/12 Python
Python打印特殊符号及对应编码解析
2020/05/07 Python
Python JSON常用编解码方法代码实例
2020/09/05 Python
html5需遵循的6个设计原则
2016/04/27 HTML / CSS
伦敦一家西班牙童装精品店:La Coqueta
2018/02/02 全球购物
学生学习总结的自我评价
2013/10/22 职场文书
优秀中专生推荐信
2013/11/17 职场文书
义务教育学校标准化建设汇报材料
2014/08/16 职场文书
我的大学四年规划书范文2014
2014/09/26 职场文书
2016党员干部反腐倡廉心得体会
2016/01/13 职场文书
Nginx服务器添加Systemd自定义服务过程解析
2021/03/31 Servers
详解python的内存分配机制
2021/05/10 Python
python使用BeautifulSoup 解析HTML
2022/04/24 Python