Acme::BloodType - For those obsessed with celebrities' blood types


Acme-BloodType documentation Contained in the Acme-BloodType distribution.

Index


Code Index:

NAME

Top

Acme::BloodType - For those obsessed with celebrities' blood types

VERSION

Top

Version 0.01

SYNOPSIS

Top

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";

METHODS

Top

Acme::BloodType->new(\%specifier)

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.

$bt->get_bloodtype

Get the bloodtype (phenotype) of this person. Returns "A", "B", "AB", or "O".

$bt->get_genotype

Get the genotype of this person. Returns a string of two characters, which may be "A", "B", or "O".

$bt1->cross($bt2)

"Mate" one person with the other, producing a result chosen randomly in the style of Mendel.

AUTHOR

Top

Andrew Rodland, <ARODLAND at cpan.org>

BUGS

Top

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.

SUPPORT

Top

You can find documentation for this module with the perldoc command.

    perldoc Acme::BloodType

You can also look for information at:

* AnnoCPAN: Annotated CPAN documentation

http://annocpan.org/dist/Acme-BloodType

* CPAN Ratings

http://cpanratings.perl.org/d/Acme-BloodType

* RT: CPAN's request tracker

http://rt.cpan.org/NoAuth/Bugs.html?Dist=Acme-BloodType

* Search CPAN

http://search.cpan.org/dist/Acme-BloodType

ACKNOWLEDGEMENTS

Top

COPYRIGHT & LICENSE

Top


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