Bio
Species
Toolbar
Summary
Bio::Species - Generic species object
Package variables
No package variables defined.
Included modules
Inherit
Synopsis
$species = Bio::Species->new(-classification => [@classification]);
# Can also pass classification
# array to new as below
$species->classification(qw( sapiens Homo Hominidae
Catarrhini Primates Eutheria
Mammalia Vertebrata Chordata
Metazoa Eukaryota ));
$genus = $species->genus();
$bi = $species->binomial(); # $bi is now "Homo sapiens"
# For storing common name
$species->common_name("human");
# For storing subspecies
$species->sub_species("accountant");
Description
Provides a very simple object for storing phylogenetic
information. The classification is stored in an array,
which is a list of nodes in a phylogenetic tree. Access to
getting and setting species and genus is provided, but not
to any of the other node types (eg: "phylum", "class",
"order", "family"). There's plenty of scope for making the
model more sophisticated, if this is ever needed.
A methods are also provided for storing common
names, and subspecies.
Methods
Methods description
Title : binomial Usage : $binomial = $self->binomial(); $binomial = $self->binomial('FULL'); Function: Returns a string "Genus species", or "Genus species subspecies", the first argument is 'FULL' (and the species has a subspecies). Args : Optionally the string 'FULL' to get the full name including the subspecies. |
Title : classification Usage : $self->classification(@class_array); @classification = $self->classification(); Function: Fills or returns the classification list in the object. The array provided must be in the order SPECIES, GENUS ---> KINGDOM. Checks are made that species is in lower case, and all other elements are in title case. Example : $obj->classification(qw( sapiens Homo Hominidae Catarrhini Primates Eutheria Mammalia Vertebrata Chordata Metazoa Eukaryota)); Returns : Classification array Args : Classification array OR A reference to the classification array. In the latter case if there is a second argument and it evaluates to true, names will not be validated. |
Title : common_name Usage : $self->common_name( $common_name ); $common_name = $self->common_name(); Function: Get or set the common name of the species Example : $self->common_name('human') Returns : The common name in a string Args : String, which is the common name (optional) |
Title : genus Usage : $self->genus( $genus ); $genus = $self->genus(); Function: Get or set the scientific genus name. The genus must be in title case. Example : $self->genus( 'Homo' ); Returns : Scientific genus name as string Args : Scientific genus name as string |
Title : ncbi_taxid Usage : $obj->ncbi_taxid($newval) Function: Get/set the NCBI Taxon ID Returns : the NCBI Taxon ID as a string Args : newvalue to set or undef to unset (optional) |
Title : organelle Usage : $self->organelle( $organelle ); $organelle = $self->organelle(); Function: Get or set the organelle name Example : $self->organelle('Chloroplast') Returns : The organelle name in a string Args : String, which is the organelle name |
Title : species Usage : $self->species( $species ); $species = $self->species(); Function: Get or set the scientific species name. The species name must be in lower case. Example : $self->species( 'sapiens' ); Returns : Scientific species name as string Args : Scientific species name as string |
Title : sub_species Usage : $obj->sub_species($newval) Function: Returns : value of sub_species Args : newvalue (optional) |
Title : variant Usage : $obj->variant($newval) Function: Get/set variant information for this species object (strain, isolate, etc). Example : Returns : value of variant (a scalar) Args : new value (a scalar or undef, optional) |
Methods code
sub binomial
{ my( $self, $full ) = @_;
my( $species, $genus ) = $self->classification();
unless( defined $species) {
$species = 'sp.';
$self->warn("classification was not set");
}
$genus = '' unless( defined $genus);
my $bi = "$genus $species";
if (defined($full) && ((uc $full) eq 'FULL')) {
my $ssp = $self->sub_species;
$bi .= " $ssp" if $ssp;
}
return $bi; } |
sub classification
{ my ($self,@args) = @_;
if (@args) {
my ($classif,$force);
if(ref($args[0])) {
$classif = shift(@args);
$force = shift(@args);
} else {
$classif =\@ args;
}
if(! $force) {
$self->validate_species_name($classif->[0]);
foreach (@$classif) {
$self->validate_name( $_ );
}
}
$self->{'classification'} = $classif;
}
return @{$self->{'classification'}}; } |
sub common_name
{ my $self = shift;
return $self->{'common_name'} = shift if @_;
return $self->{'common_name'}; } |
sub genus
{ my($self, $genus) = @_;
if ($genus) {
$self->validate_name( $genus );
$self->{'classification'}[1] = $genus;
}
return $self->{'classification'}[1]; } |
sub ncbi_taxid
{ my $self = shift;
return $self->{'_ncbi_taxid'} = shift if @_;
return $self->{'_ncbi_taxid'};
}
1;
__END__ } |
sub new
{ my($class,@args) = @_;
my $self = $class->SUPER::new(@args);
$self->{'classification'} = [];
$self->{'common_name'} = undef;
my ($classification) = $self->_rearrange([qw(CLASSIFICATION)], @args);
if( defined $classification &&
(ref($classification) eq "ARRAY") ) {
$self->classification(@$classification);
}
return $self; } |
sub organelle
{ my($self, $name) = @_;
if ($name) {
$self->{'organelle'} = $name;
} else {
return $self->{'organelle'}
} } |
sub species
{ my($self, $species) = @_;
if ($species) {
$self->validate_species_name( $species );
$self->{'classification'}[0] = $species;
}
return $self->{'classification'}[0]; } |
sub sub_species
{ my( $self, $sub ) = @_;
if ($sub) {
$self->{'_sub_species'} = $sub;
}
return $self->{'_sub_species'}; } |
sub validate_name
{ return 1;
} |
sub validate_species_name
{ my( $self, $string ) = @_;
return 1 if $string eq "sp.";
return 1 if $string =~ /^[a-z][\w\s]+$/i;
$self->throw("Invalid species name '$string'"); } |
sub variant
{ my $self = shift;
return $self->{'variant'} = shift if @_;
return $self->{'variant'}; } |
General documentation
James Gilbert email jgrg@sanger.ac.uk
The rest of the documentation details each of the object
methods. Internal methods are usually preceded with a _