annotate variant_effect_predictor/Bio/Tools/Phylo/Molphy.pm @ 1:d6778b5d8382 draft default tip

Deleted selected files
author willmclaren
date Fri, 03 Aug 2012 10:05:43 -0400
parents 21066c0abaf5
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
1 # $Id: Molphy.pm,v 1.3 2002/10/22 07:45:23 lapp Exp $
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
2 #
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
3 # BioPerl module for Bio::Tools::Phylo::Molphy
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
4 #
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
5 # Cared for by Jason Stajich <jason@bioperl.org>
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
6 #
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
7 # Copyright Jason Stajich
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
8 #
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
9 # You may distribute this module under the same terms as perl itself
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
10
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
11 # POD documentation - main docs before the code
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
12
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
13 =head1 NAME
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
14
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
15 Bio::Tools::Phylo::Molphy - DESCRIPTION of Object
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
16
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
17 =head1 SYNOPSIS
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
18
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
19 use Bio::Tools::Phylo::Molphy;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
20 my $parser = new Bio::Tools::Phylo::Molphy(-file => 'output.protml');
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
21 while( my $result = $parser->next_result ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
22
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
23 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
24
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
25 =head1 DESCRIPTION
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
26
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
27 A parser for Molphy output (protml,dnaml)
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
28
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
29 =head1 FEEDBACK
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
30
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
31 =head2 Mailing Lists
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
32
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
33 User feedback is an integral part of the evolution of this and other
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
34 Bioperl modules. Send your comments and suggestions preferably to
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
35 the Bioperl mailing list. Your participation is much appreciated.
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
36
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
37 bioperl-l@bioperl.org - General discussion
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
38 http://bioperl.org/MailList.shtml - About the mailing lists
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
39
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
40 =head2 Reporting Bugs
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
41
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
42 Report bugs to the Bioperl bug tracking system to help us keep track
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
43 of the bugs and their resolution. Bug reports can be submitted via
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
44 email or the web:
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
45
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
46 bioperl-bugs@bioperl.org
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
47 http://bugzilla.bioperl.org/
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
48
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
49 =head1 AUTHOR - Jason Stajich
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
50
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
51 Email jason@bioperl.org
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
52
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
53 Describe contact details here
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
54
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
55 =head1 CONTRIBUTORS
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
56
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
57 Additional contributors names and emails here
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
58
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
59 =head1 APPENDIX
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
60
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
61 The rest of the documentation details each of the object methods.
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
62 Internal methods are usually preceded with a _
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
63
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
64 =cut
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
65
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
66
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
67 # Let the code begin...
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
68
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
69
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
70 package Bio::Tools::Phylo::Molphy;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
71 use vars qw(@ISA);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
72 use strict;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
73
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
74 use Bio::Tools::Phylo::Molphy::Result;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
75 use Bio::Root::Root;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
76 use Bio::Root::IO;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
77 use Bio::TreeIO;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
78 use IO::String;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
79
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
80 @ISA = qw(Bio::Root::Root Bio::Root::IO );
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
81
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
82 =head2 new
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
83
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
84 Title : new
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
85 Usage : my $obj = new Bio::Tools::Phylo::Molphy();
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
86 Function: Builds a new Bio::Tools::Phylo::Molphy object
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
87 Returns : Bio::Tools::Phylo::Molphy
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
88 Args : -fh/-file => $val, # for initing input, see Bio::Root::IO
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
89
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
90
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
91 =cut
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
92
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
93 sub new {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
94 my($class,@args) = @_;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
95
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
96 my $self = $class->SUPER::new(@args);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
97 $self->_initialize_io(@args);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
98
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
99 return $self;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
100 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
101
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
102 =head2 next_result
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
103
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
104 Title : next_result
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
105 Usage : my $r = $molphy->next_result
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
106 Function: Get the next result set from parser data
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
107 Returns : Bio::Tools::Phylo::Molphy::Result object
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
108 Args : none
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
109
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
110
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
111 =cut
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
112
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
113 sub next_result{
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
114 my ($self) = @_;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
115
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
116 # A little statemachine for the parser here
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
117 my ($state,$transition_ct,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
118 @transition_matrix, %transition_mat, @resloc,) = ( 0,0);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
119 my ( %subst_matrix, @treelines, @treedata, %frequencies);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
120 my ( $treenum,$possible_trees, $model);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
121 while( defined ( $_ = $self->_readline()) ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
122 if( /^Relative Substitution Rate Matrix/ ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
123 if( %subst_matrix ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
124 $self->_pushback($_);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
125 last;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
126 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
127 $state = 0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
128 my ( @tempdata);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
129 @resloc = ();
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
130 while( defined ($_ = $self->_readline) ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
131 last if (/^\s+$/);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
132 # remove leading/trailing spaces
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
133 s/^\s+//;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
134 s/\s+$//;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
135 my @data = split;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
136 my $i = 0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
137 for my $l ( @data ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
138 if( $l =~ /\D+/ ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
139 push @resloc, $l;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
140 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
141 $i++;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
142 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
143 push @tempdata, \@data;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
144 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
145 my $i = 0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
146 for my $row ( @tempdata ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
147 my $j = 0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
148 for my $col ( @$row ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
149 if( $i == $j ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
150 # empty string for diagonals
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
151 $subst_matrix{$resloc[$i]}->{$resloc[$j]} = '';
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
152 } else {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
153 $subst_matrix{$resloc[$i]}->{$resloc[$j]} = $col;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
154 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
155 $j++;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
156 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
157 $i++;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
158 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
159 } elsif( /^Transition Probability Matrix/ ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
160 if( /1\.0e7/ ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
161 $state = 1;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
162 $transition_ct = 0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
163 } else {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
164 $state = 0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
165 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
166 } elsif ( /Acid Frequencies/ ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
167 $state = 0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
168 $self->_readline(); # skip the next line
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
169 while( defined( $_ = $self->_readline) ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
170 unless( /^\s+/) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
171 $self->_pushback($_);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
172 last;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
173 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
174 s/^\s+//;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
175 s/\s+$//;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
176 my ($index,$res,$model,$data) = split;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
177 $frequencies{$res} = [ $model,$data];
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
178 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
179 } elsif( /^(\d+)\s*\/\s*(\d+)\s+(.+)\s+model/ ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
180 my @save = ($1,$2,$3);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
181 # finish processing the transition_matrix
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
182 my $i =0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
183 foreach my $row ( @transition_matrix ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
184 my $j = 0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
185 foreach my $col ( @$row ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
186 $transition_mat{$resloc[$i]}->{$resloc[$j]} = $col;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
187 $j++;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
188 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
189 $i++;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
190 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
191
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
192 if( defined $treenum ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
193 $self->_pushback($_);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
194 last;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
195 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
196
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
197 $state = 2;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
198 ($treenum,$possible_trees, $model) = @save;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
199 $model =~ s/\s+/ /g;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
200 } elsif( $state == 1 ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
201 next if( /^\s+$/ );
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
202 s/^\s+//;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
203 s/\s+$//;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
204 # because the matrix is split up into 2-10 column sets
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
205 push @{$transition_matrix[$transition_ct++]}, split ;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
206 $transition_ct = 0 if $transition_ct % 20 == 0;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
207 } elsif( $state == 2 ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
208 if( s/^(\d+)\s+(\-?\d+(\.\d+)?)\s+// ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
209 push @treedata, [ $1,$2];
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
210 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
211 # save this for the end so that we can
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
212 # be efficient and only open one tree parser
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
213 push @treelines, $_;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
214 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
215 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
216 # waiting till the end to do this, is it better
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
217 my @trees;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
218 if( @treelines ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
219 my $strdat = IO::String->new(join('',@treelines));
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
220 my $treeio = new Bio::TreeIO(-fh => $strdat,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
221 -format => 'newick');
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
222 while( my $tree = $treeio->next_tree ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
223 if( @treedata ) {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
224 my $dat = shift @treedata;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
225 # set the associated information
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
226 $tree->id($dat->[0]);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
227 $tree->score($dat->[1]);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
228 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
229 push @trees, $tree;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
230 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
231 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
232
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
233 my $result = new Bio::Tools::Phylo::Molphy::Result
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
234 (-trees => \@trees,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
235 -substitution_matrix => \%subst_matrix,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
236 -transition_matrix => \%transition_mat,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
237 -frequencies => \%frequencies,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
238 -model => $model,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
239 -search_space => $possible_trees,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
240 );
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
241
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
242 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
243
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
244 1;