如何在1D十中找到重复元素

2024-06-02 06:20:23 发布

您现在位置:Python中文网/ 问答频道 /正文

我想得到在1D张量中多次出现的元素。确切地说,我想创建一个与tf.unique相反的函数。例如,如果x = [1, 1, 2, 3, 4, 5, 6, 7, 4, 5, 4]我需要输出是[1,1,4,4,4,5,5],同时还要检索源张量中这些元素的索引。 我的最终目标是在一批中获取标签出现不止一次的示例。在


Tags: 函数元素示例tf标签unique
1条回答
网友
1楼 · 发布于 2024-06-02 06:20:23

您可以使用现有的Tensorflow操作以稍微迂回的方式来完成,方法是计算唯一项以创建唯一项的密集索引集,然后使用tf.unsorted_segment_sum对其进行计数。一旦您有了计数,使用tf.greater选择带有> N的项,并将它们收集回一个密集列表中:

import tensorflow as tf

a = tf.constant([8, 7, 8, 1, 3, 4, 5, 9, 5, 0, 5])
init = tf.initialize_all_variables()

unique_a_vals, unique_idx = tf.unique(a)
count_a_unique = tf.unsorted_segment_sum(tf.ones_like(a),                   
                                         unique_idx,                        
                                         tf.shape(a)[0])                    

more_than_one = tf.greater(count_a_unique, 1)                               
more_than_one_idx = tf.squeeze(tf.where(more_than_one))                     
more_than_one_vals = tf.squeeze(tf.gather(unique_a_vals, more_than_one_idx))

# If you want the original indexes:                                         
not_duplicated, _ = tf.listdiff(a, more_than_one_vals)                      
dups_in_a, indexes_in_a = tf.listdiff(a, not_duplicated)                    

with tf.Session() as s:                                                     
    s.run(init)                                                             
    a, dupvals, dupidxes, dia = s.run([a, more_than_one_vals,                    
                                  indexes_in_a, dups_in_a])                            
    print "Input: ", a                                                      
    print "Duplicate values: ", dupvals                                     
    print "Indexes of duplicates in a: ", dupidxes
    print "Dup vals with dups: ", dia

Input: [8 7 8 1 3 4 5 9 5 0 5]

Duplicate values: [8 5]

Indexes of duplicates in a: [ 0 2 6 8 10]

Dup vals with dups: [8 8 5 5 5]

相关问题 更多 >