-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMutation.html
More file actions
78 lines (68 loc) · 1.67 KB
/
Mutation.html
File metadata and controls
78 lines (68 loc) · 1.67 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
<!DOCTYPE html>
<html>
<head>
<script>
var bases=['A','G','C','T'];
var sequence_len=20;
var original_sequence=[];
var sequences=[]; //population
var num_of_sequences=100;
var number_of_generations=100;
var mutation_rate=0.0001;
function Generate_first_generation(){
generate_first_sequence();
for(var i=0;i<num_of_sequences;i++)
{
sequences.push(original_sequence.slice()); //this will create and push copies of original sequence into sequencez.
}
}
function generate_first_sequence(){
for(var i=0;i<sequence_len;i++)
{
original_sequence.push(random_base(""));
}
}
function random_base(current_base){
var new_base;
do{
new_base=bases[Math.floor(Math.random()*4)];
}while(new_base==current_base);
return new_base;
}
function print_sequences(str){
console.log(str);
for(var i=0;i<num_of_sequences;i++)
{
print_sequence(sequences[i]);
}
}
function print_sequence(sequence){
var sequence_str='';
for(var j=0;j<sequence_len;j++)
{
sequence_str=sequence_str+sequence[j];
}
console.log(sequence_str);
}
function run_generations(){
for(var i=0;i<number_of_generations;i++)
{
for(var j=0;j<sequences.length;j++){
for(var k=0;k<sequences[j].length;k++){
//each base
if(Math.random()<mutation_rate){
sequences[j][k]=random_base(sequences[j][k]);
}
}
}
}
}
Generate_first_generation();
print_sequences("Generation 0");
run_generations();
print_sequences("After 100 generations");
</script>
</head>
<body>
</body>
</html>