python人工智能tensorflow函数tf.assign使用方法

2022-07-15,,,,

参数数量及其作用

函数共有五个参数,分别是:

  • 被赋值的变量 ref
  • 要分配给变量的值 value、
  • 是否验证形状 validate_shape
  • 是否进行锁定保护 use_locking
  • 名称 name
def assign(ref, value, validate_shape=none, use_locking=none, name=none)
update 'ref' by assigning 'value' to it.
this operation outputs a tensor that holds the new value of 'ref' after 
the value has been assigned. this makes it easier to chain operations  
that need to use the reset value.  
args:
  ref: a mutable `tensor`.  
	should be from a `variable` node. may be uninitialized.  
  value: a `tensor`. must have the same type as `ref`.  
    the value to be assigned to the variable.  
  validate_shape: an optional `bool`. defaults to `true`.  
    if true, the operation will validate that the shape  
    of 'value' matches the shape of the tensor being assigned to.  if false,  
    'ref' will take on the shape of 'value'.  
  use_locking: an optional `bool`. defaults to `true`.  
    if true, the assignment will be protected by a lock;  
    otherwise the behavior is undefined, but may exhibit less contention.  
  name: a name for the operation (optional).  
returns:
  a `tensor` that will hold the new value of 'ref' after  
  the assignment has completed.    

该函数的作用是将一个要分配给变量的值value赋予被赋值的变量ref,用于tensorflow各个参数的变量赋值。

例子

该例子将举例如何进行变量之间的数据赋值和如何进行集合间的数据赋值。

import tensorflow as tf;  
import numpy as np;  
c1 = ['c1', tf.graphkeys.global_variables]
c2 = ['c2', tf.graphkeys.global_variables]
#常量初始化器
v1_cons = tf.get_variable('v1_cons',dtype = tf.float32,shape=[1,4], initializer=tf.constant_initializer(), collections = c1)
v2_cons = tf.get_variable('v2_cons',dtype = tf.float32,shape=[1,4], initializer=tf.constant_initializer(9), collections = c1)
#正太分布初始化器
v1_nor = tf.get_variable('v1_nor',dtype = tf.float32, shape=[1,4], initializer=tf.random_normal_initializer(mean=0, stddev=5), collections = c2)
v2_nor = tf.get_variable('v2_nor',dtype = tf.float32, shape=[1,4], initializer=tf.random_normal_initializer(mean=0, stddev=5), collections = c2)
assign1 = tf.assign(v1_cons,v2_cons)    #将v2_cons赋予v1_cons
c1_get = tf.get_collection('c1')        #获得c1集合
c2_get = tf.get_collection('c2')        #获得c2集合
assign2 = [tf.assign(cg1,cg2) for cg1,cg2 in zip(c1_get,c2_get) ]   #将c2赋予c1
with tf.session() as sess:
    sess.run(tf.global_variables_initializer())
    print("v1_cons:",sess.run(v1_cons))
    print("v2_cons:",sess.run(v2_cons))
    print(sess.run(assign1))            #显示赋值后的结果
    print("将v2_cons赋予v1_cons:",sess.run(v1_cons))
    print("c1_get_collection:",sess.run(c1_get))
    print("c2_get_collection:",sess.run(c2_get))
    print(sess.run(assign2))            #显示赋值后的结果
    print("将c2赋予c1:",sess.run(c1_get))

其输出为:

v1_cons: [[0. 0. 0. 0.]]
v2_cons: [[9. 9. 9. 9.]]
[[9. 9. 9. 9.]]
将v2_cons赋予v1_cons: [[9. 9. 9. 9.]]
c1_get_collection: [array([[9., 9., 9., 9.]], dtype=float32), array([[9., 9., 9., 9.]], dtype=float32)]
c2_get_collection: [array([[-3.9746916, -7.5332146,  2.4480317, -1.3282107]], dtype=float32), array([[10.687443 ,  3.6653206,  1.7079141, -4.524155 ]], dtype=float32)]
[array([[-3.9746916, -7.5332146,  2.4480317, -1.3282107]], dtype=float32), array([[10.687443 ,  3.6653206,  1.7079141, -4.524155 ]], dtype=float32)]
将c2赋予c1: [array([[-3.9746916, -7.5332146,  2.4480317, -1.3282107]], dtype=float32), array([[10.687443 ,  3.6653206,  1.7079141, -4.524155 ]], dtype=float32)]

以上就是python人工智能tensorflow函数tf.assign使用方法的详细内容,更多关于tensorflow函数tf.assign的资料请关注其它相关文章!

《python人工智能tensorflow函数tf.assign使用方法.doc》

下载本文的Word格式文档,以方便收藏与打印。