#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!
In reply to how to combine these two scripts in perl? by dimitris852
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |