7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
# File 'lib/bio-table/overlap.rb', line 7
def self.overlap_tables t1, t2, options
logger = Bio::Log::LoggerPlus['bio-table']
columns = Columns::to_list(options[:overlap])
t = Table.new(t1.)
l1 = t1.map { |row| columns.map { |i| row.all_fields[i] } }
l2 = t2.map { |row| columns.map { |i| row.all_fields[i] } }
logger.warn "Not all selected keys are unique!" if l1.uniq.size != l1.size or l2.uniq.size != l2.size
overlap = l2 & l1
idx2 = Indexer::create_index(t2,columns)
overlap.each do |values|
t.push(t2.row_by_columns(columns.zip(values),idx2))
end
t
end
|