我有一个张量流的情况。我想找到两个具有不同形状的二维张量的交集。
示例:
object_ids_ [[0 0]
[0 1]
[1 1]]
object_ids_more_07_ [[0 0]
[0 1]
[0 2]
[1 0]
[1 2]]
我正在寻找的输出是:
[[0,0],
[0,1]]
我遇到了“tf.sets.set_intersection”,张量流页面:https://www.tensorflow.org/api_docs/python/tf/sets/set_intersection
但无法为不同形状的张量执行此操作。我找到的另一个实现是:
但很难将其复制为2D张量。
感谢任何帮助,谢谢
答案 0 :(得分:2)
要做的一种方法是subtract->abs->sum
所有组合,然后获得匹配为零的索引。可以使用broadcasting
来实现。
a = tf.constant([[0,0],[0,1],[1,1]])
b = tf.constant([[0, 0],[0, 1],[0,2],[1, 0],[1, 2]])
find_match = tf.reduce_sum(tf.abs(tf.expand_dims(b,0) - tf.expand_dims(a,1)),2)
indices = tf.transpose(tf.where(tf.equal(find_match, tf.zeros_like(find_match))))[0]
out = tf.gather(a, indices)
with tf.Session() as sess:
print(sess.run(out))
#Output
#[[0 0]
#[0 1]]