Sha256: 5f813ba0d23a7dd1eb7d6e4862bd845715b8129bfa06ce800001b076a98df8df

Contents?: true

Size: 1.85 KB

Versions: 2

Compression:

Stored size: 1.85 KB

Contents

require 'rubygems'
require 'bio'
require  'snp_db_models'
require 'activerecord-import'
require 'diff/lcs'
require 'create_methods'
require 'filter_ignore_snps_methods'
require 'output_information_methods'

def find_unqiue_snps(strain_names, out, cutoff_genotype, cutoff_snp)

  *strain_names = strain_names

  where_statement = strain_names.collect{|strain_name| "strains.name = '#{strain_name}' OR "}.join("").sub(/ OR $/, "")

  outfile = File.open(out, "w")

   snps = Snp.find_by_sql("SELECT snps.* from snps INNER JOIN alleles ON alleles.snp_id = snps.id INNER JOIN genotypes ON alleles.id = genotypes.allele_id INNER JOIN strains ON strains.id = genotypes.strain_id WHERE (#{where_statement}) AND alleles.id <> snps.reference_allele_id AND genotypes.geno_qual >= #{cutoff_genotype} AND snps.qual >= #{cutoff_snp} AND (SELECT COUNT(*) from snps AS s INNER JOIN alleles ON alleles.snp_id = snps.id INNER JOIN genotypes ON alleles.id = genotypes.allele_id WHERE alleles.id <> snps.reference_allele_id and s.id = snps.id) = #{strain_names.size} GROUP BY snps.id HAVING COUNT(*) = #{strain_names.size}")
   # puts "The number of unique snps are #{snps.size}"

   output_information_methods(snps, outfile, cutoff_genotype, cutoff_snp, false)
end


def information(out, cutoff_genotype, cutoff_snp)

  puts "outputting SNP info....."
  
  strains = Strain.all

  # snps = Snp.find_by_sql("SELECT distinct snps.* from snps INNER JOIN alleles ON alleles.snp_id = snps.id INNER JOIN genotypes ON alleles.id = genotypes.allele_id INNER JOIN strains ON strains.id = genotypes.strain_id where alleles.id <> snps.reference_allele_id")

  snps = Snp.find_by_sql("SELECT distinct snps.* from snps INNER JOIN alleles ON alleles.snp_id = snps.id")
  outfile = File.open(out, "w")

  output_information_methods(snps, outfile, cutoff_genotype, cutoff_snp, true)

end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
snp-search-2.12.0 lib/snp-search.rb
snp-search-2.11.0 lib/snp-search.rb