Mercurial > repos > john-mccallum > ssr_marker_design
diff MISA/p3_out.pl @ 0:3006582bfc76
Uploaded V1.0 MISA tools and helper scripts
author | john-mccallum |
---|---|
date | Wed, 14 Sep 2011 23:57:57 -0400 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/MISA/p3_out.pl Wed Sep 14 23:57:57 2011 -0400 @@ -0,0 +1,76 @@ +#!/usr/bin/perl -w +# Author: Thomas Thiel +# Program name: prim_output.pl +# Description: converts the Primer3 output into an table + +open (SRC,"<$ARGV[0]") || die ("\nError: Couldn't open Primer3 results file (*.p3out) !\n\n"); +my $filename = $ARGV[0]; +$filename =~ s/\.p3out//; +open (IN,"<$ARGV[1]") || die ("\nError: Couldn't open source file containing MISA (*.misa) results !\n\n"); +open (OUT,">$ARGV[2]") || die ("nError: Couldn't create file !\n\n"); + +my ($seq_names_failed,$count_failed,$count); +print OUT "ID\tSSR nr.\tSSR type\tSSR\tsize\tstart\tend\t"; +print OUT "FORWARD PRIMER1 (5'-3')\tTm(°C)\tsize\tREVERSE PRIMER1 (5'-3')\tTm(°C)\tsize\tPRODUCT1 size (bp)\tstart (bp)\tend (bp)\t"; +print OUT "FORWARD PRIMER2 (5'-3')\tTm(°C)\tsize\tREVERSE PRIMER2 (5'-3')\tTm(°C)\tsize\tPRODUCT2 size (bp)\tstart (bp)\tend (bp)\t"; +print OUT "FORWARD PRIMER3 (5'-3')\tTm(°C)\tsize\tREVERSE PRIMER3 (5'-3')\tTm(°C)\tsize\tPRODUCT3 size (bp)\tstart (bp)\tend (bp)\n"; + +undef $/; +my $in = <IN>; +study $in; + +$/ = "=\n"; + +while (<SRC>) + { + my ($id,$ssr_nr) = (/PRIMER_SEQUENCE_ID=(\S+)_(\d+)/); + + $in =~ /($id\t$ssr_nr\t.*)\n/; + my $misa = $1; + + /PRIMER_LEFT_SEQUENCE=(.*)/ || do {$count_failed++;print OUT "$misa\n"; next}; + my $info = "$1\t"; + + /PRIMER_LEFT_TM=(.*)/; $info .= "$1\t"; + /PRIMER_LEFT=\d+,(\d+)/; $info .= "$1\t"; + + /PRIMER_RIGHT_SEQUENCE=(.*)/; $info .= "$1\t"; + /PRIMER_RIGHT_TM=(.*)/; $info .= "$1\t"; + /PRIMER_RIGHT=\d+,(\d+)/; $info .= "$1\t"; + + /PRIMER_PRODUCT_SIZE=(.*)/; $info .= "$1\t"; + /PRIMER_LEFT=(\d+),\d+/; $info .= "$1\t"; + /PRIMER_RIGHT=(\d+),\d+/; $info .= "$1\t"; + + + /PRIMER_LEFT_1_SEQUENCE=(.*)/; $info .= "$1\t"; + /PRIMER_LEFT_1_TM=(.*)/; $info .= "$1\t"; + /PRIMER_LEFT_1=\d+,(\d+)/; $info .= "$1\t"; + + /PRIMER_RIGHT_1_SEQUENCE=(.*)/; $info .= "$1\t"; + /PRIMER_RIGHT_1_TM=(.*)/; $info .= "$1\t"; + /PRIMER_RIGHT_1=\d+,(\d+)/; $info .= "$1\t"; + + /PRIMER_PRODUCT_SIZE_1=(.*)/; $info .= "$1\t"; + /PRIMER_LEFT_1=(\d+),\d+/; $info .= "$1\t"; + /PRIMER_RIGHT_1=(\d+),\d+/; $info .= "$1\t"; + + + /PRIMER_LEFT_2_SEQUENCE=(.*)/; $info .= "$1\t"; + /PRIMER_LEFT_2_TM=(.*)/; $info .= "$1\t"; + /PRIMER_LEFT_2=\d+,(\d+)/; $info .= "$1\t"; + + /PRIMER_RIGHT_2_SEQUENCE=(.*)/; $info .= "$1\t"; + /PRIMER_RIGHT_2_TM=(.*)/; $info .= "$1\t"; + /PRIMER_RIGHT_2=\d+,(\d+)/; $info .= "$1\t"; + + /PRIMER_PRODUCT_SIZE_2=(.*)/; $info .= "$1\t"; + /PRIMER_LEFT_2=(\d+),\d+/; $info .= "$1\t"; + /PRIMER_RIGHT_2=(\d+),\d+/; $info .= "$1"; + + $count++; + print OUT "$misa\t$info\n" + }; + +#print "\nPrimer modelling was successful for $count sequences.\n"; +#print "Primer modelling failed for $count_failed sequences.\n";