繁体   English   中英

我怎样摆脱这个ValueError

[英]How can I get rid of this ValueError

重量和偏见

self.weights = { "layer1":tensorflow.Variable(tensorflow.random_normal([self.state_size, self.neurons_layer_1])), "layer2":tensorflow.Variable(tensorflow.random_normal([self.neurons_layer_1, self.neurons_layer_2])), "layerOut":tensorflow.Variable(tensorflow.random_normal([self.neurons_layer_2, self.action_size])) }
self.biases = { "layer1":tensorflow.Variable(tensorflow.random_normal([self.neurons_layer_1])), "layer2":tensorflow.Variable(tensorflow.random_normal([self.neurons_layer_2])), "layerOut":tensorflow.Variable(tensorflow.random_normal([self.action_size])) }

模型功能

def model(self, X, weights, biases):
    layer1 = tensorflow.add(tensorflow.matmul(X, weights["layer1"]),biases["layer1"])
    layer1 = tensorflow.nn.relu(layer1)

    layer2 = tensorflow.add(tensorflow.matmul(layer1, weights["layer2"]), biases["layer2"])
    layer2 = tensorflow.nn.relu(layer2)

    layerOut = tensorflow.add(tensorflow.matmul(layer2, weights["layerOut"]), biases["layerOut"])
    layerOut = tensorflow.nn.softmax(layerOut)

    with tensorflow.Session() as sess:
        init_op = tensorflow.global_variables_initializer()
        sess.run(init_op)
        q_values = sess.run(layerOut)
        return q_values

我像这样计算预测值。 State是这样的列表:

predicted = self.model(state, self.weights, self.biases)    # state = [0.4, 0.3, 0.2, 0.9]

这些是我的占位符

X_placeholder = tensorflow.placeholder("float", [None, state_size])
Y_placeholder = tensorflow.placeholder("float", [None, action_size])

这是我的成本函数

cost = tensorflow.reduce_mean(tensorflow.square(right_prediction - predicted))

这是我的优化者

optimizer = tensorflow.train.AdamOptimizer(learning_rate=self.learning_rate).minimize(cost)

然后我初始化上面的变量

init = tensorflow.global_variables_initializer()

并运行会话

with tensorflow.Session() as sess:
                sess.run(init)

                for epoch in range(1):
                    sess.run(optimizer, feed_dict={X_placeholder:X , Y_placeholder:Y})

现在我运行此代码,它会抛出以下错误。

ValueError: No gradients provided for any variable, check your graph for ops that do not 
support gradients, between variables ["<tf.Variable 'Variable:0' shape=(4, 24) 
dtype=float32_ref>", "<tf.Variable 'Variable_1:0' shape=(24, 24) dtype=float32_ref>", 
"<tf.Variable 'Variable_2:0' shape=(24, 2) dtype=float32_ref>", "<tf.Variable 
'Variable_3:0' shape=(24,) dtype=float32_ref>", "<tf.Variable 'Variable_4:0' shape=(24,) 
dtype=float32_ref>", "<tf.Variable 'Variable_5:0' shape=(2,) dtype=float32_ref>", 
"<tf.Variable 'Variable_6:0' shape=(4, 24) dtype=float32_ref>", "<tf.Variable 
'Variable_7:0' shape=(24, 24) dtype=float32_ref>", "<tf.Variable 'Variable_8:0' 
shape=(24, 2) dtype=float32_ref>", 
"<tf.Variable 'Variable_9:0' shape=(24,) dtype=float32_ref>", 
"<tf.Variable 'Variable_10:0' shape=(24,) dtype=float32_ref>", 
"<tf.Variable 'Variable_11:0' shape=(2,) 
dtype=float32_ref>"] and loss Tensor("Mean:0", shape=(), dtype=float32).

所以请帮助我。

感谢您的关注。

编辑:好的,这是我的整个代码,我不知道这是否legito发布此链接,但在这里

错误表示从优化器到参数没有连接方式,换句话说,优化器的参数(权重和偏差)是未知的。

由于你没有发布你的整个代码,似乎你在一个类中定义你的参数和模型,并在它之外使用优化器,以同样的方式执行它们,或者在内部定义参数,模型,成本和优化器。在外面定义或定义所有这些。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM