zoukankan      html  css  js  c++  java
  • tensorflow的graph和session

    参考:https://blog.csdn.net/u013510838/article/details/84111031
      Session是TensorFlow前后端连接的桥梁。用户利用session使得client能够与master的执行引擎建立连接,并通过session.run()来触发一次计算。它建立了一套上下文环境,封装了operation计算以及tensor求值的环境。
      session之间采用共享graph的方式来提高运行效率。一个session只能运行一个graph实例,但一个graph可以运行在多个session中。一般情况下,创建session时如果不指定Graph实例,则会使用系统默认Graph。常见情况下,我们都是使用一个graph,即默认graph。当session创建时,不会重新创建graph实例,而是默认graph引用计数加1。当session close时,引用计数减1。只有引用计数为0时,graph才会被回收。这种graph共享的方式,大大减少了graph创建和回收的资源消耗,优化了TensorFlow运行效率。

      tf通过运行时维护的session本地线程栈,来管理默认session。故不同的线程会有不同的默认session,默认session是线程作用域的。

      可以显示创建Graph,并调用as_default()使他替换默认Graph。在该上下文管理器中创建的op都会注册到这个graph中。退出上下文管理器后,则恢复原来的默认graph。一般情况下,我们不用显式创建Graph,使用系统创建的那个默认Graph即可。

    1 import tensorflow as tf
    2 
    3 print(tf.get_default_graph())  # 打印最初的默认图
    4 
    5 with tf.Graph().as_default() as g:
    6     print(tf.get_default_graph() is g) # 测试替换的默认图
    7     print(tf.get_default_graph())
    8 print(tf.get_default_graph())  # 恢复的默认图

    输出如下:

    <tensorflow.python.framework.ops.Graph object at 0x000002C9553DDC50>
    True
    <tensorflow.python.framework.ops.Graph object at 0x000002C9553CE240>
    <tensorflow.python.framework.ops.Graph object at 0x000002C9553DDC50>

    由此可见,在上下文管理器中,当前线程的默认图被替换了,而退出上下文管理后,则恢复为了原来的默认图。

    默认graph和默认session一样,也是线程作用域的。

  • 相关阅读:
    03-HTML之body标签
    02-HTML之head标签
    01-HTML介绍
    第十五章 并发编程
    第十四章 网络编程
    第十三章 模块和包
    第十二章 异常和错误
    第十一章 面向对象进阶
    第九章 常用模块(续)
    003 配置负载均衡
  • 原文地址:https://www.cnblogs.com/jianglinliu/p/10576339.html
Copyright © 2011-2022 走看看