Biorąc pod uwagę te wejść:Generowanie sekwencji DNA syntetyczny z Subtitution Rate
my $init_seq = "AAAAAAAAAA" #length 10 bp
my $sub_rate = 0.003;
my $nof_tags = 1000;
my @dna = qw(A C G T);
Chcę, aby wygenerować:
tysiąc długości 10 Tagi
stopy Zmiana dla każdej pozycji w tag to 0,003
Plonowanie wyjście jak:
AAAAAAAAAA
AATAACAAAA
.....
AAGGAAAAGA # 1000th tags
Czy istnieje zwarty sposób to zrobić w Perl?
Ja zablokowany z logiką skryptu jako rdzeń:
#!/usr/bin/perl
my $init_seq = "AAAAAAAAAA" #length 10 bp
my $sub_rate = 0.003;
my $nof_tags = 1000;
my @dna = qw(A C G T);
$i = 0;
while ($i < length($init_seq)) {
$roll = int(rand 4) + 1; # $roll is now an integer between 1 and 4
if ($roll == 1) {$base = A;}
elsif ($roll == 2) {$base = T;}
elsif ($roll == 3) {$base = C;}
elsif ($roll == 4) {$base = G;};
print $base;
}
continue {
$i++;
}
Jest to praca, prawda? : http://birg.cs.wright.edu/resources/perl/hw3.shtml –
Nie, Mitch, to nie jest praca domowa. Naprawdę. – neversaint
Powinieneś prawdopodobnie sprawdzić duplikaty. –