使用TensorFlow进行算法设计与训练的核心步骤:

  • 准备数据
  • 构建模型
  • 训练模型
  • 进行预测

问题描述:

  通过人工数据集,随机生成一个近似采样随机分布,使得w = 2.0 ,b= 1,并加入一个噪声,噪声的最大振幅是0.4

过程描述:

  人工数据集生成

 # 在JUpiter中,使用matplotlib 显示图像需要设置为 inline 模式,否则不会出现图像
%matplotlib inline import matplotlib.pyplot as plt #载入matplotlib
import numpy as np #载入numpy
import tensorflow as tf #载入TensorFlow # 设置随机数种子
np.random.seed()
#直接采用np 生成等差数列的方法,生成100个点,每一个点的取值在 -~ 1之间
x_data = np.linspace(-,,) # y = 2x + 噪声,其中,噪声的维度与x_data一致
y_data = * x_data + 1.0 +np.random.randn(*x_data.shape) * 0.4
  #x_data.shape 是一个元组 * 加在变量前,拆分元组

  利用matplotlib画出生成结果

 # 画出随机生成数据的散点图
plt.scatter(x_data,y_data) # 画出线性函数 y = 2x +
plt.plot(x_data, * x_data + 1.0,color = 'red',linewidth = )

  构建模型

    定义训练数据的占位符,x是特征值,y是标签:

    定义模型函数:

 x = tf.placeholder("float",name = "x")
y = tf.placeholder("float",name = "y")
def model(x,w,b):
return tf.multiply(x,w) + b

    创建变量:

      TensorFlow变量的声明函数是tf.Variable

      tf.Variable的作用是保存和更新参数

      变量的初始值可以是随机数,常数,或者是通过其他的初始值计算得到的

 #构建线性函数的斜率,变量w
w = tf.Variable(2.0,name = "w0")
#构建线性函数的截距,变量b
b = tf.Variable(0.0,name = "b0")
#pred是预测值,向前计算
pred = model(x,w,b)

  训练模型

    设置训练参数:

 # 迭代次数(训练次数)
train_epochs =
#学习率
learning_rate = 0.5

      定义损失函数:

        损失函数用于描述预测值与真实值之间的误差,从而指导模型收敛方向

        常见损失函数:均方差和交叉熵

 # 采样均方差作为损失函数
loss_function = tf.reduce_mean(tf.square(y - pred))

     定义优化器:

      定义优化器Optimizer,初始化一个 GradientDescentOptimizer

      设置学习率和优化目标:最小化损失  (每次迭代优化w和b)

 # 梯度下降优化器
optimizer = tf.train.GradientDescentOptimizer(learning_rate).minimize(loss_function)

    创建会话:

      声明会话:

 sess = tf.Session()

      变量初始化:  

        在执行前,需将所有的变量初始化,通过  tf.global_variables_initializer() 实现对所有变量初始化

 init = tf.global_variables_initializer()
sess.run(init)

  迭代训练

    模型训练:设置迭代轮次,每次通过将样本逐个输入模型,进行梯度下降优化操作

    每次迭代后,绘制出模型曲线

 # 开始训练,轮次为epoch ,采样SGD随机梯度下降优化方法
for epoch in range(train_epochs):
for xs,ys in zip(x_data,y_data):
_, loss = sess.run([optimizer,loss_function],feed_dict={x:xs,y:ys})
b0temp = b.eval(session=sess)
w0temp = w.eval(session=sess)
plt.plot(x_data,w0temp * x_data + b0temp) #画图

  打印训练参数

 print("w:",sess.run(w)) #w的值应该在2附近
print("b:",sess.run(b)) # b的值应该在1附近

  结果可视化

 plt.scatter(x_data,y_data,label = 'Original data')
plt.plot(x_data,x_data * sess.run(w) + sess.run(b),label = 'Fitted line',color = 'r',linewidth = )
plt.legend(loc = ) #通过参数loc指定图例位置

  使用训练好的模型进行预测

 x_test = 3.21
predict = sess.run(pred,feed_dict={x: x_test})
print("预测值:%f" % predict)
target = * x_test + 1.0
print("目标值:%f" %target)

过程补充

  随机梯度下降:

在梯度下降法中, 批量指的是用于在单次迭代中计算梯度的样本总数

假定批量是指整个数据集,数据集通常包含很大样本(数万甚至数千亿),
此外, 数据集通常包含多个特征。因此,一个批量可能相当巨大。如果是超
大批量,则单次迭代就可能要花费很长时间进行计算

随机梯度下降法 ( SGD) 每次迭代只使用一个样本(批量大小为 1),如果
进行足够的迭代,SGD 也可以发挥作用。“随机”这一术语表示构成各个批
量的一个样本都是随机选择的

小批量随机梯度下降法(量 小批量 SGD)是介于全批量迭代与 SGD 之间的折
衷方案。小批量通常包含 10-1000 个随机选择的样本。小批量 SGD 可以减
少 SGD 中的杂乱样本数量,但仍然比全批量更高效

  在训练中显示损失值:
 # 在JUpiter中,使用matplotlib 显示图像需要设置为 inline 模式,否则不会出现图像
%matplotlib inline
import matplotlib.pyplot as plt #载入matplotlib
import numpy as np #载入numpy
import tensorflow as tf #载入TensorFlow
# 设置随机数种子
np.random.seed()
#直接采用np 生成等差数列的方法,生成100个点,每一个点的取值在 -~ 1之间
x_data = np.linspace(-,,)
# y = 2x + 噪声,其中,噪声的维度与x_data一致
y_data = * x_data + 1.0 +np.random.randn(*x_data.shape) * 0.4 # 画出随机生成数据的散点图
plt.scatter(x_data,y_data)
# 画出线性函数 y = 2x +
plt.plot(x_data, * x_data + 1.0,color = 'red',linewidth = ) x = tf.placeholder("float",name = "x")
y = tf.placeholder("float",name = "y")
def model(x,w,b):
return tf.multiply(x,w) + b #构建线性函数的斜率,变量w
w = tf.Variable(2.0,name = "w0")
#构建线性函数的截距,变量b
b = tf.Variable(0.0,name = "b0")
#pred是预测值,向前计算
pred = model(x,w,b) # 迭代次数(训练次数)
train_epochs =
#学习率
learning_rate = 0.5
# 采样均方差作为损失函数
loss_function = tf.reduce_mean(tf.square(y - pred)) # 梯度下降优化器
optimizer = tf.train.GradientDescentOptimizer(learning_rate).minimize(loss_function)
sess = tf.Session()
init = tf.global_variables_initializer()
sess.run(init) 43 # 开始训练,轮数为epoch,采用SGD随机梯度下降优化方法
44 step = 0 # 记录训练步数
45 loss_list = [] #用于保存loss值的列表
46 display_step = 10
47 for epoch in range(train_epochs):
48 for xs,ys in zip(x_data,y_data):
49 _,loss = sess.run([optimizer,loss_function],feed_dict={x:xs,y:ys})
50 #显示损失值
51 #display_step :控制报告的粒度
52 #例如:若display_step = 2,则将每训练2个样本输出依次损失粒度,与超参数不同,修改display_step 不会改变模型学习的规律
53 loss_list.append(loss)
54 step = step + 1
55 if step % display_step == 0:
56 print("训练次数:",'%02d' % (epoch + 1),"步数:%03d"%(step),"损失:","{:.9f}".format(loss))
57 b0temp = b.eval(session = sess)
58 w0temp = w.eval(session = sess)
59 plt.plot(x_data,w0temp * x_data +b0temp) #画图 plt.plot(loss_list) #图像化显示损失值
 plt.plot(loss_list,'r+') #图像化显示损失值

TensorFlow 实例一(一元线性回归)的更多相关文章

  1. (第一章第六部分)TensorFlow框架之实现线性回归小案例

    系列博客链接: (一)TensorFlow框架介绍:https://www.cnblogs.com/kongweisi/p/11038395.html (二)TensorFlow框架之图与Tensor ...

  2. 回归分析法&一元线性回归操作和解释

    用Excel做回归分析的详细步骤 一.什么是回归分析法 "回归分析"是解析"注目变量"和"因于变量"并明确两者关系的统计方法.此时,我们把因 ...

  3. R语言解读一元线性回归模型

    转载自:http://blog.fens.me/r-linear-regression/ 前言 在我们的日常生活中,存在大量的具有相关性的事件,比如大气压和海拔高度,海拔越高大气压强越小:人的身高和体 ...

  4. 一元线性回归模型与最小二乘法及其C++实现

    原文:http://blog.csdn.net/qll125596718/article/details/8248249 监督学习中,如果预测的变量是离散的,我们称其为分类(如决策树,支持向量机等), ...

  5. R语言 一元线性回归

    #一元线性回归的基本步骤#1.载入数据 给出散点图 x<-c(0.10,0.11,0.12,0.13,0.14,0.15,0.16,0.17,0.18,0.20,0.21,0.23) y< ...

  6. machine learning 之 导论 一元线性回归

    整理自Andrew Ng 的 machine learnig 课程 week1. 目录: 什么是机器学习 监督学习 非监督学习 一元线性回归 模型表示 损失函数 梯度下降算法 1.什么是机器学习 Ar ...

  7. (转)干货|这篇TensorFlow实例教程文章告诉你GANs为何引爆机器学习?(附源码)

    干货|这篇TensorFlow实例教程文章告诉你GANs为何引爆机器学习?(附源码) 该博客来源自:https://mp.weixin.qq.com/s?__biz=MzA4NzE1NzYyMw==& ...

  8. R语言做一元线性回归

    只有两个变量,做相关性分析,先来个一元线性回归吧 因为未处理的x,y相关性不显著,于是用了ln(1+x)函数做了个处理(发现大家喜欢用ln,log,lg,指数函数做处理),处理完以后貌似就显著了..虽 ...

  9. Python实现——一元线性回归(梯度下降法)

    2019/3/25 一元线性回归--梯度下降/最小二乘法_又名:一两位小数点的悲剧_ 感觉这个才是真正的重头戏,毕竟前两者都是更倾向于直接使用公式,而不是让计算机一步步去接近真相,而这个梯度下降就不一 ...

  10. 梯度下降法及一元线性回归的python实现

    梯度下降法及一元线性回归的python实现 一.梯度下降法形象解释 设想我们处在一座山的半山腰的位置,现在我们需要找到一条最快的下山路径,请问应该怎么走?根据生活经验,我们会用一种十分贪心的策略,即在 ...

随机推荐

  1. Day 17:缓冲输出字符流和用缓冲输入输出实现登录、装饰者设计模式

    输出字符流 Writer  所有输出字符流的基类,  抽象类. FileWriter 向文件输出字符数据的输出字符流. BufferedWriter 缓冲输出字符流        缓冲输出字符流作用: ...

  2. HTML元素 和 CSS (9.23 第十天)

    HTML元素分类:块级元素和内联元素块级元素:标签元素会以新行开始或结束<h1><p><table>等内联元素:显示数据不会以新行开始<a><im ...

  3. UVA - 714 Copying Books (抄书)(二分+贪心)

    题意:把一个包含m个正整数的序列划分成k个(1<=k<=m<=500)非空的连续子序列,使得每个正整数恰好属于一个序列(所有的序列不重叠,且每个正整数都要有所属序列).设第i个序列的 ...

  4. 现在购买5G“商用手机”值不值呢?是花冤枉钱还是提前享受?

    刚刚发布的"安卓最强机皇"华为Mate 20系列依然没有支持5G,只是在收割最后的4G红利.相比之下,即将发布的小米MIX 3,看起来亮点还是颇多的.除了滑盖摄像头.屏占比更高的全 ...

  5. ORACLE异库DBLink创建以及使用

    遇到一个问题,两张库数据需要同步,但是数据量很大,落地迁移时间成本太大,这个时候找到一种方法就是DBLink 使用场景说明: A转移数据到B,需要在B上面创建此DBLink,然后使用. 创建方法: - ...

  6. hostapd 热点设置

    一.  需要安装的服务:hostapd dhcp(isc-dhcp-server) dns(dnsmasq或者bind9或者都不装设成8.8.8.8 ) 二.建hostapd.conf文件   ,su ...

  7. (6)Mat对象的一些函数和方法的使用

    首先是基本的代码整理 #include<iostream> #include<opencv.hpp> using namespace std; using namespace ...

  8. java课程之团队开发冲刺阶段1.9

    一.总结昨天进度 1.学习了简单的消息推送方法,并且能够使用进行每日定时推送 二.遇到的困难 1.在每日推送的过程中,程序必须被正常关闭,如果程序是被切到后天然后直接结束进程的话,每日推送的线程服务也 ...

  9. eclipse导入tomcat源码

    我的开发环境:windows7  64位 一.官网下载tomcat源码.在此奉上一站地址:http://archive.apache.org/dist/tomcat/: 二.编译源码生成.jar文件: ...

  10. json,pickle,shelve序列化

    import json a = [{"a":"b"}] jd = json.dumps(a) #序列化,就是对象通过内存能够存储和传输的过程 with open ...