View source on GitHub
|
scan on the list of tensors unpacked from elems on dimension 0.
tf.compat.v1.scan(
fn,
elems,
initializer=None,
parallel_iterations=10,
back_prop=True,
swap_memory=False,
infer_shape=True,
reverse=False,
name=None
)
See also tf.map_fn.
The simplest version of scan repeatedly applies the callable fn to a
sequence of elements from first to last. The elements are made of the tensors
unpacked from elems on dimension 0. The callable fn takes two tensors as
arguments. The first argument is the accumulated value computed from the
preceding invocation of fn, and the second is the value at the current
position of elems. If initializer is None, elems must contain at least
one element, and its first element is used as the initializer.
Suppose that elems is unpacked into values, a list of tensors. The shape
of the result tensor is [len(values)] + fn(initializer, values[0]).shape.
If reverse=True, it's fn(initializer, values[-1]).shape.
This method also allows multi-arity elems and accumulator. If elems
is a (possibly nested) list or tuple of tensors, then each of these tensors
must have a matching first (unpack) dimension. The second argument of
fn must match the structure of elems.
If no initializer is provided, the output structure and dtypes of fn
are assumed to be the same as its input; and in this case, the first
argument of fn must match the structure of elems.
If an initializer is provided, then the output of fn must have the same
structure as initializer; and the first argument of fn must match
this structure.
For example, if elems is (t1, [t2, t3]) and initializer is
[i1, i2] then an appropriate signature for fn in python2 is:
fn = lambda (acc_p1, acc_p2), (t1, [t2, t3]): and fn must return a list,
[acc_n1, acc_n2]. An alternative correct signature for fn, and the
one that works in python3, is:
fn = lambda a, t:, where a and t correspond to the input tuples.
Returns | |
|---|---|
A tensor or (possibly nested) sequence of tensors. Each tensor packs the
results of applying fn to tensors unpacked from elems along the first
dimension, and the previous accumulator value(s), from first to last (or
last to first, if reverse=True).
|
Raises | |
|---|---|
TypeError
|
if fn is not callable or the structure of the output of
fn and initializer do not match.
|
ValueError
|
if the lengths of the output of fn and initializer
do not match.
|
Examples | |
|---|---|
|
View source on GitHub