Loading

Tensorflow计算模型——计算图

1.计算图的概念:

  计算图:输入和计算函数都以节点的形式出现,而节点的输出项之间的关系以有向线段表示所构成的计算图形。

如:向量a, b 相加:

 

2. 计算图的使用:

注意:Tensorflow程序一般分两步:定义计算图中所有计算;执行计算

在tensorflow代码执行的时候,tensorflow会自定定义一个默认的计算图,可以通过tf.get_default_graph函数来获取当前默认的计算图

import tensorflow as tf

'''tensorflow程序第一步:定义计算图中所有计算'''
a
=tf.constant([1.0, 2.0], name="a")
b
=tf.constant([2.0, 3.0], name="b")
result
=a+b

'''判断a节点是不是在默认节点中'''
print(a.graph
is tf.get_default_graph())
print(b.graph
is tf.get_default_graph())

输出:
True
True

当然,可以使用tf.Graph函数来生成新的计算图。

注意:计算图其实是一种数据结构,则上面的数据和运算不会相互共享。

import tensorflow as tf

'''tensorflow第一步:定义所有计算'''

g1=tf.Graph()
with g1.as_default():
'''在计算图g1中定义变量“v",并初始化为0'''
v
=tf.get_variable( "v", shape=[1,2],initializer=tf.zeros_initializer )

g2=tf.Graph()
with g2.as_default():
'''在计算图g2中定义变量“v",初始化为1'''
v
=tf.get_variable( "v", shape=[2,3],initializer=tf.ones_initializer )

'''tensorflow第二步:运行计算'''

with tf.Session(graph=g1) as sess:
tf.initialize_all_variables().run() #初始化所有变量
with tf.variable_scope(
"", reuse=True):
print(sess.run(tf.get_variable(
"v"))) #获取变量v

with tf.Session(graph=g2) as sess:
tf.initialize_all_variables().run()
with tf.variable_scope(
"", reuse=True):
print(sess.run(tf.get_variable(
"v")))

输出:
[[0. 0.]]
[[
1. 1. 1.]
[
1. 1. 1.]]

计算图由节点和关系构成,那么计算图的资源如何给用户比较方便的调用呢?

在一个计算图中可以使用集合(collection)来管理整个资源。这里的资源具体指的是张量,变量,或者队列等。

tf.add_to_collection函数将资源加入一个或者多个collection

tf.get_collection函数,获取指定collection中的所有资源

    几个常用的集合

 

posted @ 2023-02-13 22:30  青山新雨  阅读(175)  评论(0编辑  收藏  举报