Sha256: 6fb48bbbb20a9ebc2fe3ee3c0cddd184345cb20cd5d4d15da96c422f151c9e26

Contents?: true

Size: 1.33 KB

Versions: 1

Compression:

Stored size: 1.33 KB

Contents

#!/usr/bin/env ruby
require "bio"
require "thor"


class AcnfpTransCounter < Thor
  desc "analyse FILENAME", "Run acnfp-trans-counter on a given alignment"
  def analyse(filename)
    alignments = Bio::FlatFile.open(filename)
    
    alignments.to_a.combination(2) do |a,b|
      transition_count = 0
      transversion_count = 0
      indel_count = 0
      
      alignment = Bio::Alignment::OriginalAlignment.new([a,b])
      alignment.each_site do |site|
        next if site[0] == site[1]
        next if site.has_gap?
        next if site.include? "N"

        case site.sort.map{|char| char.upcase}
        when %w{C T}, %w{A G}
          transition_count += 1
        when %w{A C}, %w{A T}, %w{C G}, %w{G T}
          transversion_count += 1
        else
          raise "Unknown pairing: #{site}"
        end
      end

      mutation_count = transversion_count + transition_count.to_f
      
      header = "%s vs %s" % [a.definition, b.definition]
      puts header
      puts "=" * header.length

      puts "Transversions: %d (%.2f%%)" % [transversion_count, 100 * transversion_count / mutation_count]
      puts "Transitions:   %d (%.2f%%)" % [transition_count, 100 * transition_count / mutation_count]

      puts "Transversions / Transitions: %.2f" % [transversion_count.to_f / transition_count]
      puts
    end
  end
end


AcnfpTransCounter.start

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
acnfp-trans-counter-0.1.0 bin/acnfp-trans-counter