Tensorflow 中的 while_loop 错误

pro*_*mer 4 while-loop python-3.5 tensorflow

我尝试在Tensorflow中使用while_loop,但是当我尝试从 while 循环中的可调用返回目标输出时,它会给我一个错误,因为形状每次都会增加。

输出应包含基于数据值(输入数组)的(0 或 1)值。如果数据值大于 5,则返回1,否则返回0。返回值必须添加到输出中

这是代码::

import numpy as np
import tensorflow as tf

data = np.random.randint(10, size=(30))
data = tf.constant(data, dtype= tf.float32)

global output
output= tf.constant([], dtype= tf.float32)
i = tf.constant(0)
c = lambda i: tf.less(i, 30)


def b(i):
   i= tf.add(i,1)
   cond= tf.cond(tf.greater(data[i-1], tf.constant(5.)), lambda: tf.constant(1.0), lambda: tf.constant([0.0]))
   output =tf.expand_dims(cond, axis = i-1)
   return i, output

r,out = tf.while_loop(c, b, [i])
print(out)
sess=  tf.Session()
sess.run(out) 
Run Code Online (Sandbox Code Playgroud)

错误::

r, out = tf.while_loop(c, b, [i])

ValueError:两个结构体的元素数量不同。

第一个结构(1个元素):[tf.Tensor 'while/Identity:0' shape=() dtype=int32]

第二个结构(2个元素): [tf.Tensor 'while/Add:0' shape=() dtype=int32, tf.Tensor 'while/ExpandDims:0' shape=unknown dtype=float32>]

我使用tensorflow-1.1.3python-3.5

如何更改我的代码以获得目标结果?

编辑::

我根据@mrry答案编辑代码,但仍然有一个问题,即输出不正确答案输出是数字求和

a = tf.ones([10,4])
print(a)
a = tf.reduce_sum(a, axis = 1)
i =tf.constant(0)
c = lambda i, _:tf.less(i,10)

def Smooth(x):
   return tf.add(x,2)

summ = tf.constant(0.)
def b(i,_):
   global summ
   summ = tf.add(summ, tf.cast(Smooth(a[i]), tf.float32))
   i= tf.add(i,1)
   return i, summ

r, smooth_l1 = tf.while_loop(c, b, [i, smooth_l1])

print(smooth_l1)

sess = tf.Session()
print(sess.run(smooth_l1))
Run Code Online (Sandbox Code Playgroud)

输出是6.0(错误)。

mrr*_*rry 6

tf.while_loop()函数要求以下四个列表具有相同的长度,并且每个元素的类型相同:

  • 函数的参数列表condc在本例中)。
  • 函数的参数列表bodyb在本例中)。
  • 函数的返回值列表body
  • loop_vars表示循环变量的列表。

因此,如果循环体有两个输出,则必须向b和添加相应的参数c,并向 添加相应的元素loop_vars

c = lambda i, _: tf.less(i, 30)

def b(i, _):
  i = tf.add(i, 1)
  cond = tf.cond(tf.greater(data[i-1], tf.constant(5.)),
                 lambda: tf.constant(1.0),
                 lambda: tf.constant([0.0]))

  # NOTE: This line fails with a shape error, because the output of `cond` has
  # a rank of either 0 or 1, but axis may be as large as 28.
  output = tf.expand_dims(cond, axis=i-1)
  return i, output

# NOTE: Use a shapeless `tf.placeholder_with_default()` because the shape
# of the output will vary from one iteration to the next.
r, out = tf.while_loop(c, b, [i, tf.placeholder_with_default(0., None)])
Run Code Online (Sandbox Code Playgroud)

正如评论中所指出的,循环体(特别是对 的调用tf.expand_dims())似乎不正确,并且该程序无法按原样工作,但希望这足以让您开始。