プレースホルダーがあるとしましょう
ph_input = tf.placeholder(dtype=tf.int32, [None, 1])
とベクトル
h = tf.zeros([1,2], dtype=tf.int32)
この例では、簡単にするためにh
はゼロで埋められていますが、実際の場合、他の変数によって変更され、異なる値になります。
ph_input
でconcat
を効率的に実行し、次元1
でh
を実行して、形状[None, 1+2]
の新しいテンソルを取得したいと思います。残念ながら、concat
は、私の例では満たされないconcat_dim
を除いて、すべての入力テンソルが同じ形状である必要があります。
h
をph_input
にフィードするデータと同じ形状に展開することを検討していましたが、プレースホルダー自体でそれを行う方法が正確にはわかりません。入力データから直接形状を取得する場合は、プレースホルダーを使用する必要はないと思います。
最も一般的な解決策は、 tf.shape()
opを使用してプレースホルダーの実行時サイズを取得し、 tf.tile()
を使用することです。 h
を適切なサイズに拡張するためのop:
ph_input = tf.placeholder(dtype=tf.int32, shape=[None, 1])
h = tf.zeros([1, 2], dtype=tf.int32) # ...or some other tensor of shape [1, 2]
# Get the number of rows in the fed value at run-time.
ph_num_rows = tf.shape(ph_input)[0]
# Makes a `ph_num_rows x 2` matrix, by tiling `h` along the row dimension.
h_tiled = tf.tile(h, tf.pack([ph_num_rows, 1]))
result = tf.concat(1, [ph_input, h_tiled])