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

Last change on this file since 513 was 467, checked in by Maciej Komosinski, 8 years ago

GenMan? interface uses STL std::string instead of SString

  • Property svn:eol-style set to native
File size: 3.7 KB
RevLine 
[286]1// This file is a part of Framsticks SDK.  http://www.framsticks.com/
2// Copyright (C) 1999-2015  Maciej Komosinski and Szymon Ulatowski.
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"
14#include "oper_fx.h"
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)
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)
[247]48        uint32_t Style(const char* g, int pos); //returns Style (and validity) of a genotype char.
49        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).
[467]50        string HTMLize(const char *g); //returns colored genotype in HTML.
51        string HTMLizeShort(const char *g); //returns colored genotype (abbreviated if needed) in HTML.
[138]52        Geno GetSimplest(char format); ///<returns pointer to the simplest genotype of \e format or empty Geno()
53        const char *GetOpName(char format); ///<returns pointer to the active operator set for \e format
[145]54        const vector<GenoOperators*>& GetOperators() const { return oper_fx_list; } ///<returns the list of available genetic operators
[138]55private:
[145]56        vector<GenoOperators*> oper_fx_list;
[275]57        void saveLink(const string parent1, const string parent2, const string child, const float chg);
[145]58        GenoOperators* getOper_f(char format);
[467]59        string HTMLize(const char *g, bool shorten);
[138]60public:
[145]61        vector<GenoLink> GenoLinkList;
[138]62        int history; //remember history?
63        int hilite; //syntax highlighting (Style)
64        int extmutinfo; //extended info: the info field of the genotype will contain the name of the mutation method
65        int count; //# of the last genetic operation
66        int valid_m, valid_xo, validated_m, validated_xo, invalid_m, invalid_xo, failed_m, failed_xo;
67        double mutchg, xochg;
[145]68        SListTempl<char> operformats; //the list of supported_format, in the same order as in seloperpar
[138]69        int* seloper; //fields for seloperpar
70        Param localpar, localstats;
71        MutableParam seloperpar;
72        GeneticNeuroParam neuronsparam;
73        MutableParamList par;
74#define STATRICKCLASS GenMan
75        PARAMPROCDEF(p_clearStats);
76        PARAMPROCDEF(p_report);
77        PARAMPROCDEF(p_htmlize);
78        PARAMPROCDEF(p_htmlizeshort);
79        PARAMPROCDEF(p_validate);
80        PARAMPROCDEF(p_mutate);
81        PARAMPROCDEF(p_crossover);
82        PARAMPROCDEF(p_getsimplest);
83#undef STATRICKCLASS
84        void clearStats();
[247]85        static void onDelGen(void*, intptr_t);
[138]86};
87
88
89#endif
Note: See TracBrowser for help on using the repository browser.