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 |