source: cpp/frams/genetics/genman.h @ 888

Last change on this file since 888 was 779, checked in by Maciej Komosinski, 7 years ago

Unified file names of all files involved in genetic conversions and operations so that they start with "f<format>_"

  • Property svn:eol-style set to native
File size: 4.1 KB
RevLine 
[286]1// This file is a part of Framsticks SDK.  http://www.framsticks.com/
[532]2// Copyright (C) 1999-2016  Maciej Komosinski and Szymon Ulatowski.
[286]3// See LICENSE.txt for details.
[138]4
5#ifndef _GENMAN_H_
6#define _GENMAN_H_
7
8#include <common/nonstd.h>
[145]9#include <common/nonstd_stl.h>
[138]10#include <frams/param/mutableparam.h>
11#include <frams/param/mutparamlist.h>
12#include <frams/neuro/geneticneuroparam.h>
13#include "geno.h"
[779]14#include "genooperators.h"
[138]15
16#define GENSTYLE_COMMENT GENSTYLE_RGBS(0,150,0,GENSTYLE_BOLD)
17
18struct GenoLink
19{
20        int count;
[280]21        string parent1, parent2, child; //parent2 only used in crossover, it is "" in mutation
[138]22        float chg;
23        float fit;
24};
25
26class GenMan : public GenoValidator
27{
28public:
29        GenMan();
30        ~GenMan();
31        void setDefaults();
32        /**
33        if canvalidate==false, returns GENOPER_NOOPER (cannot test), GENOPER_OK (\e g is valid), or 1-based error position.
34        if canvalidate==true, returns
35        - GENOPER_OK and canvalidate==false if \e g was already valid
36        - GENOPER_NOOPER and canvalidate==false if \e g was (probably) validated but couldn't checkValidity
37        - 1-based error position and canvalidate==false if \e g was invalid and couldn't validate
38        - 1-based error position and canvalidate==true if \e g was invalid and was validated successfully
39
40        Note: 1-based error position is always related to pure genotype (g.GetGene()), without the leading comment
41        */
42        int testValidity(Geno &g, bool &canvalidate);
43        int testGenoValidity(Geno& g); //class GenoValidator (geno.h)
[532]44        Geno validate(const Geno&); ///<returns validated (if possible) genotype
45        Geno mutate(const Geno&); //returns mutated genotype or empty if errors
46        Geno crossOver(const Geno&, const Geno&); //returns xover genotype ("child") or empty if errors
47        float similarity(const Geno&, const Geno&); //returns GENOPER_NOOPER or normalized similarity (1: identical, 0: different)
48        uint32_t getStyle(const char* g, int pos); //returns style (and validity) of a genotype char.
49        uint32_t getStyle(const char *g, const Geno *G, int pos); //returns style (and validity) of a genotype char. Assumes G is created from g.
50        void getFullStyle(const char *g, uint32_t *styletab); //optimized. Fills styletab with styles for all genotype chars. sizeof(*styletab) must be at least strlen(g).
51        void getFullStyle(const char *g, const Geno *G, uint32_t *styletab); //optimized. Assumes G is created from g. Fills styletab with styles for all genotype chars. sizeof(*styletab) must be at least strlen(g).
[467]52        string HTMLize(const char *g); //returns colored genotype in HTML.
53        string HTMLizeShort(const char *g); //returns colored genotype (abbreviated if needed) in HTML.
[532]54        Geno getSimplest(char format); ///<returns pointer to the simplest genotype of \e format or empty Geno()
55        const char *getOpName(char format); ///<returns pointer to the active operator set for \e format
[145]56        const vector<GenoOperators*>& GetOperators() const { return oper_fx_list; } ///<returns the list of available genetic operators
[138]57private:
[145]58        vector<GenoOperators*> oper_fx_list;
[275]59        void saveLink(const string parent1, const string parent2, const string child, const float chg);
[145]60        GenoOperators* getOper_f(char format);
[467]61        string HTMLize(const char *g, bool shorten);
[138]62public:
[145]63        vector<GenoLink> GenoLinkList;
[138]64        int history; //remember history?
65        int hilite; //syntax highlighting (Style)
66        int extmutinfo; //extended info: the info field of the genotype will contain the name of the mutation method
67        int count; //# of the last genetic operation
68        int valid_m, valid_xo, validated_m, validated_xo, invalid_m, invalid_xo, failed_m, failed_xo;
69        double mutchg, xochg;
[145]70        SListTempl<char> operformats; //the list of supported_format, in the same order as in seloperpar
[138]71        int* seloper; //fields for seloperpar
72        Param localpar, localstats;
73        MutableParam seloperpar;
74        GeneticNeuroParam neuronsparam;
75        MutableParamList par;
76#define STATRICKCLASS GenMan
77        PARAMPROCDEF(p_clearStats);
78        PARAMPROCDEF(p_report);
79        PARAMPROCDEF(p_htmlize);
80        PARAMPROCDEF(p_htmlizeshort);
81        PARAMPROCDEF(p_validate);
82        PARAMPROCDEF(p_mutate);
83        PARAMPROCDEF(p_crossover);
84        PARAMPROCDEF(p_getsimplest);
85#undef STATRICKCLASS
86        void clearStats();
[247]87        static void onDelGen(void*, intptr_t);
[138]88};
89
90
91#endif
Note: See TracBrowser for help on using the repository browser.