TensorFlow™ 是一个开放源代码软件库,用于进行高性能数值计算。借助其灵活的架构,用户可以轻松地将计算工作部署到多种平台(CPU、GPU、TPU)和设备(桌面设备、服务器集群、移动设备、边缘设备等)。TensorFlow™ 最初是由 Google Brain 团队(隶属于 Google 的 AI 部门)中的研究人员和工程师开发的,可为机器学习和深度学习提供强力支持,并且其灵活的数值计算核心广泛应用于许多其他科学领域

接下来我们通过一个线性拟合的简单实例来说明一下

第一步,通过np.random.normal 创造一批高斯分布的数据

  1. import numpy as np
  2. import matplotlib.pyplot as plt
  3. import pandas as pd
  4. import tensorflow as tf
  5.  
  6. num_points = 1000
  7. vector_sector = []
  8.  
  9. # 创造一1000个点
  10. for num_point in range(num_points):
  11. x = np.random.normal(0.0, 0.55)
  12. y = x*0.1 + 0.3 + np.random.normal(0, 0.03)
  13. vector_sector.append([x, y])
  14. #进行添加赋值操作
  15. x_data = [v[0] for v in vector_sector]
  16. y_data = [v[1] for v in vector_sector]

第二步: 初始化参数和使用估计值和真实值的均方误差来表示loss

  1. W = tf.Variable(tf.random_uniform([1], -1.0, 1.0), name='W')
  2. # 产生一个初始值为0 的b值
  3. b = tf.Variable(tf.zeros([1]), name='b')
  4. # 构造线性函数
  5. y = W * x_data + b
  6. print(np.shape(y))
  7. # 以预估值y和实际值y_data之间的均方误差作为损失
  8. loss = tf.reduce_mean(tf.square(y-y_data), name='loss')

第三步: 初始化模型,并进行迭代降低loss,优化模型

  1. optimizer = tf.train.GradientDescentOptimizer(0.5)
  2. # 训练的时候就是最小化这个参数
  3. train = optimizer.minimize(loss)
  4.  
  5. #进行初始化
  6. sess = tf.Session()
  7. init = tf.global_variables_initializer()
  8. sess.run(init)
  9. # 打印当前值
  10. print('W', sess.run(W), 'b', sess.run(b), 'loss', sess.run(loss))
  11.  
  12. #循环20次,训练train,降低loss
  13. for i in range(20):
  14. sess.run(train)
  15. print(print('W', sess.run(W), 'b', sess.run(b), 'loss', sess.run(loss)))

第四步: 做出拟合曲线的图

  1. # 做散点图的拟合曲线
  2. plt.scatter(x_data, y_data, c='r')
  3. plt.plot(x_data, x_data*sess.run(W)+ sess.run(b))
  4. plt.show()

跟我学算法-tensorflow 实现线性拟合的更多相关文章

  1. 跟我学算法- tensorflow 实现RNN操作

    对一张图片实现rnn操作,主要是通过先得到一个整体,然后进行切分,得到的最后input结果输出*_w[‘out’] + _b['out']  = 最终输出结果 第一步: 数据载入 import ten ...

  2. 跟我学算法- tensorflow VGG模型进行测试

    我们使用的VGG模型是别人已经训练好的一个19层的参数所做的一个模型 第一步:定义卷积分部操作函数 mport scipy.io import numpy as np import os import ...

  3. 跟我学算法-tensorflow 实现卷积神经网络附带保存和读取

    这里的话就不多说明了,因为上上一个博客已经说明了 import numpy as np import tensorflow as tf import matplotlib.pyplot as plt ...

  4. 跟我学算法- tensorflow模型的保存与读取 tf.train.Saver()

    save =  tf.train.Saver() 通过save. save() 实现数据的加载 通过save.restore() 实现数据的导出 第一步: 数据的载入 import tensorflo ...

  5. 跟我学算法-tensorflow 实现卷积神经网络

    我们采用的卷积神经网络是两层卷积层,两层池化层和两层全连接层 我们使用的数据是mnist数据,数据训练集的数据是50000*28*28*1 因为是黑白照片,所以通道数是1 第一次卷积采用64个filt ...

  6. 跟我学算法-tensorflow 实现神经网络

    神经网络主要是存在一个前向传播的过程,我们的目的也是使得代价函数值最小化 采用的数据是minist数据,训练集为50000*28*28 测试集为10000*28*28 lable 为50000*10, ...

  7. 跟我学算法-tensorflow 实现logistics 回归

    tensorflow每个变量封装了一个程序,需要通过sess.run 进行调用 接下来我们使用一下使用mnist数据,这是一个手写图像的数据,训练集是55000*28*28, 测试集10000* 28 ...

  8. 跟我学算法- tensorflow 卷积神经网络训练验证码

    使用captcha.image.Image 生成随机验证码,随机生成的验证码为0到9的数字,验证码有4位数字组成,这是一个自己生成验证码,自己不断训练的模型 使用三层卷积层,三层池化层,二层全连接层来 ...

  9. 深度学习原理与框架-Tensorflow基本操作-实现线性拟合

    代码:使用tensorflow进行数据点的线性拟合操作 第一步:使用np.random.normal生成正态分布的数据 第二步:将数据分为X_data 和 y_data 第三步:对参数W和b, 使用t ...

随机推荐

  1. 百度的富文本编辑器UEDITOR

    还是百度的ueditor 比较好用,文件导入后,基本不用配置就可以直接使用图片,文件上传等功能. CKeditor要注意的地方太多了 .但是相对ckeditor 样式比较好看.

  2. querySelector.. 方法相比 getElementsBy..

    querySelectorAll 返回的是一个 Static Node List,而 getElementsBy 系列的返回的是一个 Live Node List. 看看下面这个经典的例子 [5]: ...

  3. GCD 深入理解(二)

    转自@nixzhu的GitHub主页(译者:Riven.@nixzhu),原文<Grand Central Dispatch In-Depth: Part 2/2> 欢迎来到GCD深入理解 ...

  4. Java8中计算日期时间差

    一.简述 在Java8中,我们可以使用以下类来计算日期时间差异: 1.Period 2.Duration 3.ChronoUnit 二.Period类 主要是Period类方法getYears(),g ...

  5. python3.x 类和对象

    python同样支持类和对象.在python3.x中没有了经典类,只有新式类,默认创建的就是新式类.具体的新式类与经典类的不同在python3.x中已经没有意义了. 类的定义和实例化 python定义 ...

  6. java-文件流正确关闭资源

    用文件流来拷贝一个文件,用到文件字节输入流(FileInputStream)和文件字节输出流(FileOutputStream),用输入流把字节文件读到缓冲数组中,然后将缓冲数组中的字节写到文件中,就 ...

  7. Django ORM哪些操作

    一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 ...

  8. Linux 解压 压缩 tar

    tar 格式:tar   [选项]   目录或文件 // 将 test 文件夹打包成 test.tar $ tar cvf test.tar test // 将 home 目录下的 test 文件夹打 ...

  9. C语言(C99标准)在结构体的初始化上与C++的区别

    C++中由于有构造函数的概念,所以很多时候初始化工作能够很方便地进行,而且由于C++标准库中有很多实用类(往往是类模板),现代C++能十分容易地编写. 比如现在要构造一个类Object,包含两个字段, ...

  10. 怎样用java生成GUID与UUID

    GUID是一个128位长的数字,一般用16进制表示.算法的核心思想是结合机器的网卡.当地时间.一个随机数来生成GUID.从理论上讲,如果一台机器每秒产生10000000个GUID,则可以保证(概率意义 ...