Module: SampleManifestExcel::Tags::ClashesFinder
- Included in:
- Pooling::TagClashReport, Validator::Uniqueness
- Defined in:
- app/sample_manifest_excel/sample_manifest_excel/tags/clashes_finder.rb
Overview
ClashesFinder
Instance Method Summary collapse
-
#create_tags_clashes_message(duplicated_tags_combinations_with_indexes, first_row = 0) ⇒ Object
This method takes a hash of not unique tags combinations with indexes, i.e ‘TT’] => [0, 3], [‘CC’, ‘GG’] => [1, 5] and returns a message, in this example: ‘Same tags ’AA’, ‘TT’ are used on rows 1, 4.
-
#find_tags_clash(tag_and_tag2_oligos_combinations) ⇒ Object
This method takes an array of tags combinations, i.e.
Instance Method Details
#create_tags_clashes_message(duplicated_tags_combinations_with_indexes, first_row = 0) ⇒ Object
This method takes a hash of not unique tags combinations with indexes, i.e ‘TT’] => [0, 3], [‘CC’, ‘GG’] => [1, 5] and returns a message, in this example: ‘Same tags ’AA’, ‘TT’ are used on rows 1, 4.
Same tags ‘CC’, ‘GG’ are used on rows 2, 6.” It is also possible to pass in the first row number (if tags combinations do not start on row 1)
27 28 29 30 31 32 33 34 35 |
# File 'app/sample_manifest_excel/sample_manifest_excel/tags/clashes_finder.rb', line 27 def (, first_row = 0) = [] .each do |combination, indexes| rows = indexes.map { |i| i + first_row + 1 }.join(', ') = combination.join(', ') unless combination.compact.empty? << "Same tags #{} are used on rows #{rows}." end .join('<br>').html_safe unless .empty? #rubocop:disable all end |
#find_tags_clash(tag_and_tag2_oligos_combinations) ⇒ Object
This method takes an array of tags combinations, i.e. [[‘AA’, ‘TT’], [‘CC’, ‘GG’], [‘ACG’, ‘CGT’], [‘AA’, ‘TT’], [‘A’, ‘TCG’], [‘CC’, ‘GG’]] and returns a hash, indicating the indexes of tags clahses, in this example ‘TT’] => [0, 3], [‘CC’, ‘GG’] => [1, 5]
13 14 15 16 17 18 19 |
# File 'app/sample_manifest_excel/sample_manifest_excel/tags/clashes_finder.rb', line 13 def (tag_and_tag2_oligos_combinations) combinations_with_indexes = {} tag_and_tag2_oligos_combinations.each_with_index do |combination, index| (combinations_with_indexes[combination] ||= []) << index end combinations_with_indexes.select { |_key, value| value.length > 1 } end |