В производственной среде у меня есть данные, поступающие от N производителей, которые должны пройти через сеть.Я нашел этот комментарий о распараллеливании tf.data.Dataset.from_generator , который действительно описывает то, что я хочу.
def generator(n):
# returns n-th generator function
def dataset(n):
return tf.data.Dataset.from_generator(generator(n))
ds = tf.data.Dataset.range(N).apply(tf.contrib.data.parallel_interleave(dataset, cycle_lenght=N))
# where N is the number of generators you use
Однако как должна выглядеть функция generator (n).Потому что, когда я запускаю этот пример с
def generator(n):
"""Returns the n-th generator function (for consumer n)
"""
consumer = self.consumers[n]
def gen():
for item in consumer:
yield item
return gen
с self.consumers списком Python, я получаю ошибку:
TypeError: индексы списка должны быть целыми или кусочками, а неТензор