| Acme-BloodType documentation | Contained in the Acme-BloodType distribution. |
Acme::BloodType - For those obsessed with celebrities' blood types
Version 0.01
Allows you to model people with different blood-types and see what would happen if they had a kid. Alpha version handles ABO only for now.
use Acme::BloodType;
# Hooray for gene sequencers
$mary = Acme::BloodType->new({ genotype => "AA" });
$bill = Acme::BloodType->new({ phenotype => "O" });
$baby = $mary->cross($bill);
print "It's a ", $baby->get_bloodtype, "!\n";
Create an Acme::Bloodtype object representing a person. You may specify genotype, phenotype (in which case a genotype is chosen at random), or nothing, in which case it's all random. Probabilities don't (yet) model real-world distributions.
Get the bloodtype (phenotype) of this person. Returns "A", "B", "AB", or "O".
Get the genotype of this person. Returns a string of two characters, which may be "A", "B", or "O".
"Mate" one person with the other, producing a result chosen randomly in the style of Mendel.
Andrew Rodland, <ARODLAND at cpan.org>
Please report any bugs or feature requests to
bug-acme-bloodtype at rt.cpan.org, or through the web interface at
http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Acme-BloodType.
I will be notified, and then you'll automatically be notified of progress on
your bug as I make changes.
You can find documentation for this module with the perldoc command.
perldoc Acme::BloodType
You can also look for information at:
Copyright 2006 Andrew Rodland, all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
| Acme-BloodType documentation | Contained in the Acme-BloodType distribution. |
package Acme::BloodType; use warnings; use strict;
our $VERSION = '0.01';
my $alleles = [ "O", "A", "B" ]; my $phenotypes = [ "O", "A", "B", "AB" ]; my $geno_pheno = { "OO" => "O", "OA" => "A", "AO" => "A", "AA" => "A", "OB" => "B", "BO" => "B", "BB" => "B", "AB" => "AB", "BA" => "AB" };
sub new { my ($class, $init) = @_; my $self = {}; if (defined $init && defined $init->{'genotype'}) { return undef unless $geno_pheno->{ $init->{'genotype'} }; $self->{'genotype'} = $init->{'genotype'}; } elsif (defined $init && defined $init->{'phenotype'}) { my @possible = grep { $geno_pheno->{$_} eq $init->{'phenotype'} } keys %$geno_pheno; return undef unless @possible; $self->{'genotype'} = $possible[rand @possible]; } else { my @possible = keys %$geno_pheno; $self->{'genotype'} = $possible[rand @possible]; } return bless $self, $class; }
sub get_bloodtype { my ($self) = @_; return $geno_pheno->{ $self->{'genotype'} }; }
sub get_genotype { my ($self) = @_; return $self->{'genotype'}; }
sub cross { my ($self, $other) = @_; die "Uh?" unless $other->isa(__PACKAGE__); my $from_self = substr $self->get_genotype, int rand 2, 1; my $from_other = substr $other->get_genotype, int rand 2, 1; return __PACKAGE__->new({ genotype => $from_self . $from_other }); }
1; # End of Acme::BloodType