Fixed Mutation.
[genetic.git] / src / main.cpp
1 #include <iostream>
2 #include <vector>
3
4 #include "gene.h"
5 #include "chromosome.h"
6 #include "generation.h"
7 #include "generator/generation.h"
8
9 #include "selection/roulette.h"
10 #include "crossover/crossover.h"
11 #include "mutation/mutation.h"
12 #include "fitness/wsti.h"
13
14 #include "algorithm.h"
15 #include "condition/condition.h"
16
17 using namespace std;
18 using namespace genetic;
19
20 int main() {
21     typedef Gene<int> _Gene;
22     typedef Chromosome<_Gene> _Chromosome;
23
24     typedef WSTI<_Chromosome> _Fitness;
25     typedef Roulette<_Chromosome> _Selection;
26     typedef Crossover<_Chromosome> _Crossover;
27     typedef Mutation<_Chromosome> _Mutation;
28
29     typedef generator::Generation<_Chromosome> _Generator;
30     typedef Algorithm<_Chromosome, _Selection, _Crossover, _Mutation> _Algorithm;
31     typedef Condition<_Chromosome> _Condition;
32
33     const int chromosomeSize = 10;
34     const int generationSize = 200;
35     const double crossoverChance = 0.75;
36     const double mutationChance = 0.01;
37
38     _Fitness fitness(0.5, 2.5);
39     _Generator generationGenerator(generationSize, chromosomeSize);
40
41     _Algorithm algorithm(generationGenerator, fitness, crossoverChance, mutationChance);
42     _Condition condition;
43
44     algorithm.searchForResult(condition);
45
46     return 0;
47 }