tensorflow的计算图总结


Posted in Python onJanuary 12, 2020

计算图

在 TensorFlow 中用计算图来表示计算任务。 计算图,是一种有向图,用来定义计算的结构,实际上就是一系列的函数的组合。 用图的方式,用户通过用一些简单的容易理解的数学函数组件,就可以建立一个复杂的运算

在 TensorFlow 使用图,分为两步:建立计算图 和 执行图

图,在形式上由结点 Nodes 和边 Edges 组成。 - Nodes,用圆圈表示,代表一些对数据进行的计算或者操作(Operation)。 - Edges,用箭头表示,是操作之间传递的实际值(Tensor)

建立图

graph = tf.Graph()

访问上下文管理器

with graph.as_default():

用 with 表示我们用 context manager 告诉 TensorFlow 我们要向某个具体的 graph 添加 Op 了

执行图图必须在会话(Session)里被启动,会话(Session)将图的 op 分发到 CPU 或 GPU 之类的设备上,同时提供执行 op 的方法,这些方法执行后,将产生的张量(tensor)返回

## 开启session

sess = tf.Session()`

一旦开启了 Session,就可以用 run() 来计算想要的 Tensor 的值

用完会话,记得关掉

sess.close()

Fetches

fetches是session.run()的一个参数,它可以接收任何一个我们想要执行的op或者Tensor,或者他们对应的list结构。

  • 如果是tensor,那么session.run()输出的就是一个Numpy 数组
  • 如果是Op,那么session.run()输出的就是None

比如:sess.run(b)就是告诉Session要把计算b所需要的结点都找到按顺序执行并且输出结果。

全局变量初始化

tf.global_variables_initializer()

表示将所有定义的Variable变量都准备好,以便于后续使用,这个Op也可以传给给session.run.比如:

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

张量Tensor和OP

在tensorflow中使用tensor来表示所有的数据结构,计算图中操作Op结点之间传递的都是Tensor

  • 定义tensor时可以直接使用numpy传递给Op结点,因为tensorflow的Op可以将python的数据类型转化为tensor包括numbers,booleans,strings或者list。
  • 图中的任何结点都叫做Operation简称:Op
  • 每个Op的输出会被传递到其他Op或者sess.run()

Variable

Variable,变量是维护图执行过程中的状态信息的,需要它来保持和更新参数数值,是需要动态调整的。

  • Tensor 和Operation都是一成不变的,而Variable是可以随着时间改变的
  • Variables可以用在任何使用tensor的Op中,它当前的值就会被传递给使用它的Op
  • Variable通常的初始值是一些很大的0,1或者随机值tensor,或者内置op:tf.zeros(),tf.ones()等
  • Variable在graph中,状态由session管理,也是在session中进行初始化,session可以追踪variable的当前值是多少。
  • session可以只初始化一部分variable
  • 使用tf.variables_initializer,传入初始化变量列表
  • variable的值是可以被改变的
  • 比如使用variable.assign(variable),或者variable.assign_add(1)
  • 每个session维护独立的variable变量值,同一个variable不同的session值可以是不同的。
  • 当各种Optimizer优化器训练机器学习模型时,variable就会随之改变,当使用variable中的trainable=False属性可以不被Optimizer改变。

name_scopes

  • name_sopes可以用来管理图,可以把一组Op放到一个组块中

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

Python 相关文章推荐
浅析Python中的多重继承
Apr 28 Python
python实现自动更换ip的方法
May 05 Python
Python实现豆瓣图片下载的方法
May 25 Python
Python中使用ElementTree解析XML示例
Jun 02 Python
在Django中进行用户注册和邮箱验证的方法
May 09 Python
python交互式图形编程实例(一)
Nov 17 Python
pycharm中使用anaconda部署python环境的方法步骤
Dec 19 Python
Python正则表达式匹配日期与时间的方法
Jul 07 Python
基于Django统计博客文章阅读量
Oct 29 Python
详解Python高阶函数
Aug 15 Python
Python 3.9的到来到底是意味着什么
Oct 14 Python
pycharm激活码2020最新分享适用pycharm2020最新版亲测可用
Nov 22 Python
python利用JMeter测试Tornado的多线程
Jan 12 #Python
Django 批量插入数据的实现方法
Jan 12 #Python
python处理RSTP视频流过程解析
Jan 11 #Python
pyftplib中文乱码问题解决方案
Jan 11 #Python
python实现实时视频流播放代码实例
Jan 11 #Python
python3下pygame如何实现显示中文
Jan 11 #Python
Pytorch 实现sobel算子的卷积操作详解
Jan 10 #Python
You might like
E路文章系统PHP
2006/12/11 PHP
php使用strtotime和date函数判断日期是否有效代码分享
2013/12/25 PHP
ThinkPHP在新浪SAE平台的部署实例
2014/10/31 PHP
JQuery live函数
2010/12/24 Javascript
js动态加载以及确定加载完成的代码
2011/07/31 Javascript
鼠标滚轮控制网页横向移动实现思路
2013/03/22 Javascript
js相册效果代码(点击创建即可)
2013/04/16 Javascript
JavaScript实现计算字符串中出现次数最多的字符和出现的次数
2015/03/12 Javascript
不间断循环滚动效果的实例代码(必看篇)
2016/10/08 Javascript
jQuery基于排序功能实现上移、下移的方法
2016/11/26 Javascript
Javascript之面向对象--封装
2016/12/02 Javascript
详解jQuery选择器
2016/12/21 Javascript
JS实现的模仿QQ头像资料卡显示与隐藏效果
2017/04/07 Javascript
微信小程序canvas.drawImage完全显示图片问题的解决
2018/11/30 Javascript
微信小程序非跳转式组件授权登录的方法示例
2019/05/22 Javascript
js console.log打印对象时属性缺失的解决方法
2019/05/23 Javascript
JavaScript实现简易计算器小功能
2020/10/22 Javascript
JavaScript如何实现防止重复的网络请求的示例
2021/01/28 Javascript
JavaScript实现筛选数组
2021/03/02 Javascript
用TensorFlow实现lasso回归和岭回归算法的示例
2018/05/02 Python
python数据挖掘需要学的内容
2019/06/23 Python
Python判断字符串是否xx开始或结尾的示例
2019/08/08 Python
Python Des加密解密如何实现软件注册码机器码
2020/01/08 Python
Python爬虫入门教程01之爬取豆瓣Top电影
2021/01/24 Python
使用CSS3制作饼状旋转载入效果的实例
2015/06/23 HTML / CSS
html5 标签
2009/07/16 HTML / CSS
欧缇丽美国官网:Caudalie美国
2016/12/31 全球购物
乌克兰在线药房:Аптека24
2019/10/30 全球购物
一组SQL面试题
2016/02/15 面试题
大学生职业生涯规划书的基本内容
2014/01/06 职场文书
自我鉴定四大框架
2014/01/17 职场文书
高中学生期末评语
2014/04/25 职场文书
职务说明书范文
2014/05/07 职场文书
教师党员先进性教育自我剖析材料思想汇报
2014/09/24 职场文书
2014年内部审计工作总结
2014/12/09 职场文书
Java基础之线程锁相关知识总结
2021/06/30 Java/Android