dimitris852 has asked for the wisdom of the Perl Monks concerning the following question:
#1 #!/usr/bin/perl $ENV{CLUSTALDIR} = 'C:\\\\\\\\\\\\\\\\\\\\\; use Bio::Tools::Run::Alignment::Clustalw; my $file = <>; # Get file name (fasta file) from command prompt. # Build a clustalw alignment factory my $factory = Bio::Tools::Run::Alignment::Clustalw->new(-matrix => 'BL +OSUM'); my $ktuple = 2; $factory->ktuple($ktuple); my $inseq = Bio::SeqIO->new( '-file' => "<$file", '-format' => 'fasta' ); my $seq; my @seq_array; while ($seq = $inseq->next_seq) { push(@seq_array, $seq); } # Now we do the actual alignment. my $seq_array_ref = \@seq_array; my $aln = $factory->align($seq_array_ref);
##### ########## ########### ################
#2 my $alnio = Bio::AlignIO->new('-file'=> 'out_file','-format' => 'clust +alw'); my $dfactory = Bio::Tree::DistanceFactory->new('-method' => 'NJ'); my $stats = Bio::Align::ProteinStatistics->new; my $treeout = Bio::TreeIO->new('-format' => 'newick'); while( my $aln = $alnio->next_aln ) { my $mat = $stats->distance('-method' => 'Kimura', '-align' => $aln); my $tree = $dfactory->make_tree($mat); $treeout->write_tree($tree); }
I want the result of the aligning to pass in the second script(NOT through a file format) and create a Tree.I want to have only one output file in the end in newick form with my Tree. (I m still working on this last one).Thanks!
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: how to combine these two scripts in perl?
by GotToBTru (Prior) on Mar 15, 2016 at 12:47 UTC | |
by dimitris852 (Acolyte) on Mar 15, 2016 at 14:20 UTC | |
by GotToBTru (Prior) on Mar 15, 2016 at 14:45 UTC | |
by dimitris852 (Acolyte) on Mar 15, 2016 at 16:25 UTC | |
by poj (Abbot) on Mar 15, 2016 at 17:11 UTC |