source: cpp/frams/genetics/preconfigured.h @ 223

Last change on this file since 223 was 197, checked in by Maciej Komosinski, 11 years ago

GDK used by developers since 1999, distributed on the web since 2002

  • Property svn:eol-style set to native
File size: 1.6 KB
Line 
1// This file is a part of the Framsticks GDK.
2// Copyright (C) 1999-2014  Maciej Komosinski and Szymon Ulatowski.  See LICENSE.txt for details.
3// Refer to http://www.framsticks.com/ for further information.
4
5#ifndef _PRECONFIGURED_GENETICS_H_
6#define _PRECONFIGURED_GENETICS_H_
7
8#include "genman.h"
9#include "defgenoconv.h"
10
11/** This class handles a typical initialization procedure and configuration of genetics:
12- adds converters between genetic formats as configured by gen-config.h,
13- validation of genotypes by dedicated genetic operators, or by conversion to f0 if no genetic operator is found that can validate a genotype.
14*/
15class PreconfiguredGenetics
16{
17  public:
18DefaultGenoConvManager gcm;
19GenMan genman;
20ModelGenoValidator model_validator; //validation through conversion
21
22PreconfiguredGenetics()
23        {
24        gcm.addDefaultConverters(); //without converters, the application would only handle "format 0" genotypes
25        Geno::useConverters(gcm);
26
27        Geno::addValidator(&genman); //primary validation: use the extended validity checking (through dedicated genetic operators)
28        Geno::addValidator(&model_validator); //secondary validation: this simple validator handles all cases when there is no dedicated genetic validation operator, but a converter for a particular format is available. Converters may be less strict in detecting invalid genotypes but using them and checking whether they produced a valid f0 genotype is also some way to tell whether the initial genotype was valid. Otherwise, without dedicated genetic validation operator, we would have no validity check at all.
29        }
30};
31
32#endif
33
Note: See TracBrowser for help on using the repository browser.