【发布时间】:2017-11-24 17:24:32
【问题描述】:
我尝试将 Ax^2+Bx+C 求解为 (ax+b)(cx+d),其中 A、B、C 是已知的,并求解 a、b、c、d 的值。 代码如下:
import tensorflow as tf
a = tf.Variable([.5])
b = tf.Variable([.5])
c = tf.Variable([.5])
d = tf.Variable([.5])
x = tf.placeholder(tf.float32)
y = tf.placeholder(tf.float32)
fn1 = 2*x**2+3*x+4 #A=2,B=3,C=4
fn2 = (a*x+b)*(c*x+d)
x_train = [1,2,3,4]
y_train = [9,18,31,48]
loss = tf.reduce_sum(tf.square(fn2-y))
optimizer = tf.train.GradientDescentOptimizer(0.01)
train = optimizer.minimize(loss)
init = tf.global_variables_initializer()
sess = tf.Session()
sess.run(init)
for i in range(1000):
sess.run(train, {x:x_train, y:y_train})
print(sess.run([a,b,c,d]))
结果显示所有 a、b、c 和 d 的 nan。 如何解决?我错过了什么?感谢您的帮助。
【问题讨论】:
标签: python tensorflow algebra