#!/usr/bin/perl use warnings; use strict; my %matrix; my @symbols = qw/A R N D C Q E G + H I L K M F P S T W + Y V/; my @table = (.9799, .0002, .0009, .0010, .0003, .0008, .0017, .0021, . +0002, .0006, .0004, .0002, .0006, .0002, .0022, .0035, .0032, .0000, +.0002, .0018, .0001, .9929, .0001, .0000, .0001, .0010, .0000, .0000, . +0010, .0003, .0001, .0019, .0004, .0001, .0004, .0006, .0001, .0008, +.0000, .0001, .0004, .0001, .9867, .0036, .0000, .0004, .0006, .0006, . +0021, .0003, .0001, .0013, .0000, .0001, .0002, .0020, .0009, .0001, +.0004, .0001, .0006, .0000, .0042, .9869, .0000, .0006, .0053, .0006, . +0004, .0001, .0000, .0003, .0000, .0000, .0001, .0005, .0003, .0000, +.0000, .0001, .0001, .0001, .0000, .0000, .9987, .0000, .0000, .0000, . +0001, .0001, .0000, .0000, .0000, .0000, .0001, .0005, .0001, .0000, +.0000, .0002, .0003, .0010, .0004, .0005, .0000, .9901, .0027, .0001, . +0024, .0001, .0003, .0006, .0004, .0000, .0006, .0002, .0002, .0000, +.0000, .0001, .0010, .0000, .0007, .0056, .0000, .0035, .9865, .0004, . +0002, .0003, .0001, .0004, .0001, .0000, .0003, .0004, .0002, .0000, +.0001, .0002, .0021, .0001, .0012, .0011, .0001, .0003, .0007, .9906, . +0001, .0000, .0001, .0002, .0001, .0001, .0003, .0021, .0003, .0000, +.0000, .0005, .0001, .0008, .0018, .0003, .0001, .0020, .0001, .0000, . +9933, .0000, .0001, .0001, .0000, .0002, .0003, .0001, .0001, .0001, +.0004, .0001, .0002, .0002, .0003, .0001, .0002, .0001, .0002, .0000, . +0000, .9915, .0009, .0002, .0012, .0007, .0000, .0001, .0007, .0000, +.0001, .0033, .0003, .0001, .0003, .0000, .0000, .0006, .0001, .0001, . +0004, .0022, .9871, .0002, .0045, .0013, .0003, .0001, .0003, .0004, +.0002, .0015, .0002, .0037, .0025, .0006, .0000, .0012, .0007, .0002, . +0002, .0004, .0001, .9858, .0020, .0000, .0003, .0008, .0011, .0000, +.0001, .0001, .0001, .0001, .0000, .0000, .0000, .0002, .0000, .0000, . +0000, .0005, .0009, .0005, .9968, .0001, .0000, .0001, .0002, .0000, +.0000, .0005, .0001, .0001, .0001, .0000, .0000, .0000, .0000, .0001, . +0002, .0008, .0006, .0000, .0004, .9944, .0000, .0000, .0001, .0003, +.0028, .0000, .0013, .0005, .0002, .0001, .0001, .0008, .0003, .0002, . +0005, .0001, .0002, .0002, .0001, .0001, .9935, .0012, .0004, .0000, +.0000, .0002, .0028, .0011, .0034, .0007, .0011, .0004, .0006, .0016, . +0002, .0002, .0001, .0007, .0004, .0003, .0017, .9800, .0038, .0005, +.0002, .0002, .0022, .0002, .0013, .0004, .0001, .0003, .0002, .0002, . +0001, .0011, .0002, .0008, .0006, .0001, .0005, .0032, .9874, .0000, +.0002, .0009, .0000, .0002, .0000, .0000, .0000, .0000, .0000, .0000, . +0000, .0000, .0000, .0000, .0000, .0001, .0000, .0001, .0000, .9995, +.0001, .0000, .0001, .0000, .0003, .0000, .0003, .0000, .0001, .0000, . +0004, .0001, .0001, .0000, .0000, .0021, .0000, .0001, .0001, .0002, +.9960, .0001, .0013, .0002, .0001, .0001, .0003, .0002, .0002, .0003, . +0003, .0057, .0011, .0001, .0017, .0001, .0003, .0002, .0010, .0000, +.0002, .9866); for my $column (@symbols) { for my $row (@symbols) { $matrix{$column}{$row} = shift @table; } } my $string; $string = 'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA' +; #$string = 'SVEQRISTDIGQAYQLQGLGSNLRSIRSKTGAGEVNYIDAAKSVNDNQLLAEIG'; print "$string\n"; print map mutate($_), split //, $string; print "\n"; sub mutate { my $char = shift; my $rand = rand; my $result = 0; while ($rand > 0 and $result <= @symbols) { $rand -= $matrix{$char}{$symbols[$result++]}; } return $symbols[$result - 1]; }
In reply to Re^3: string mutation script behaving erraticaly
by choroba
in thread string mutation script behaving erraticaly
by zing
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |