對TensorFlow的assign賦值用法詳解
更新時(shí)間:2018年07月30日 09:16:30 作者:mustar_2017
今天小編就為大家分享一篇對TensorFlow的assign賦值用法詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
TensorFlow修改變量值后,需要重新賦值,assign用起來有點(diǎn)小技巧,就是需要需要弄個(gè)操作子,運(yùn)行一下。
下面這么用是不行的
import tensorflow as tf import numpy as np x = tf.Variable(0) init = tf.initialize_all_variables() sess = tf.InteractiveSession() sess.run(init) print(x.eval()) x.assign(1) print(x.eval())
正確用法
1.
import tensorflow as tf x = tf.Variable(0) y = tf.assign(x, 1) with tf.Session() as sess: sess.run(tf.global_variables_initializer()) print sess.run(x) print sess.run(y) print sess.run(x)
2.
In [212]: w = tf.Variable(12) In [213]: w_new = w.assign(34) In [214]: with tf.Session() as sess: ...: sess.run(w_new) ...: print(w_new.eval()) # output 34
3.
import tensorflow as tf x = tf.Variable(0) sess = tf.Session() sess.run(tf.global_variables_initializer()) print(sess.run(x)) # Prints 0. x.load(1, sess) print(sess.run(x)) # Prints 1.
我的方法
import numpy as np #這是Python的一種開源的數(shù)值計(jì)算擴(kuò)展,非常強(qiáng)大 import tensorflow as tf #導(dǎo)入tensorflow ##構(gòu)造數(shù)據(jù)## x_data=np.random.rand(100).astype(np.float32) #隨機(jī)生成100個(gè)類型為float32的值 y_data=x_data*0.1+0.3 #定義方程式y(tǒng)=x_data*A+B ##-------## ##建立TensorFlow神經(jīng)計(jì)算結(jié)構(gòu)## weight=tf.Variable(tf.random_uniform([1],-1.0,1.0)) biases=tf.Variable(tf.zeros([1])) y=weight*x_data+biases w1=weight*2 loss=tf.reduce_mean(tf.square(y-y_data)) #判斷與正確值的差距 optimizer=tf.train.GradientDescentOptimizer(0.5) #根據(jù)差距進(jìn)行反向傳播修正參數(shù) train=optimizer.minimize(loss) #建立訓(xùn)練器 init=tf.global_variables_initializer() #初始化TensorFlow訓(xùn)練結(jié)構(gòu) #sess=tf.Session() #建立TensorFlow訓(xùn)練會(huì)話 sess = tf.InteractiveSession() sess.run(init) #將訓(xùn)練結(jié)構(gòu)裝載到會(huì)話中 print('weight',weight.eval()) for step in range(400): #循環(huán)訓(xùn)練400次 sess.run(train) #使用訓(xùn)練器根據(jù)訓(xùn)練結(jié)構(gòu)進(jìn)行訓(xùn)練 if step%20==0: #每20次打印一次訓(xùn)練結(jié)果 print(step,sess.run(weight),sess.run(biases)) #訓(xùn)練次數(shù),A值,B值 print(sess.run(loss)) print('weight new',weight.eval()) #wop=weight.assign([3]) #wop.eval() weight.load([1],sess) print('w1',w1.eval())
以上這篇對TensorFlow的assign賦值用法詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python實(shí)現(xiàn)找出數(shù)組中第2大數(shù)字的方法示例
這篇文章主要介紹了Python實(shí)現(xiàn)找出數(shù)組中第2大數(shù)字的方法,涉及Python針對數(shù)組的排序、遍歷等相關(guān)操作技巧,需要的朋友可以參考下2018-03-03Python語言的12個(gè)基礎(chǔ)知識(shí)點(diǎn)小結(jié)
這篇文章主要介紹了Python語言的12個(gè)基礎(chǔ)知識(shí)點(diǎn)小結(jié),包含正則表達(dá)式替換、遍歷目錄方法、列表按列排序、去重、字典排序等,需要的朋友可以參考下2014-07-07