source: cpp/frams/_demos/genooper_test.cpp @ 350

Last change on this file since 350 was 348, checked in by Maciej Komosinski, 10 years ago
  • explicit c_str() in SString instead of (const char*) cast
  • genetic converters and GenMan? are now thread-local which enables multi-threaded simulator separation
  • Property svn:eol-style set to native
File size: 1.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#include <frams/errmgr/stdouterr.h>
[145]6#include <frams/genetics/preconfigured.h>
[138]7
8void printGen(Geno &g)
9{
10        printf("Genotype: %s\nFormat: %c\nValid: %s\nComment: %s\n",
[348]11                g.getGene().c_str(), g.getFormat(), g.isValid() ? "yes" : "no", g.getComment().len() == 0 ? "(empty)" : g.getComment().c_str());
[138]12}
13
14void printGenAndTitle(Geno &g, const char* title)
15{
16        printf("\n--------------------- %s: ---------------------\n", title);
17        printGen(g);
18}
19
20/* Demonstrates various genetic operators applied to a sample genotype. See also oper_fx.cpp. */
21int main(int argc, char *argv[])
22{
[145]23        StdoutErrorHandler err;//the default ErrorHandler constructor automatically registers this object to receive framsg messages (and in this case, redirect them to standard output)
24        PreconfiguredGenetics genetics;
[138]25
[145]26        rndGetInstance().randomize();
27        genetics.genman.p_report(NULL, NULL);
28
[139]29        const char* src = (argc > 1) ? argv[1] : "/*9*/UUU";
[138]30        Geno gsrc(src, -1, "First");
31        printGenAndTitle(gsrc, "source genotype (gsrc)");
[145]32        char format = gsrc.getFormat();
[138]33
[145]34        Geno gmut = genetics.genman.Mutate(gsrc);
[138]35        printGenAndTitle(gmut, "mutated (gmut)");
36
[145]37        Geno gxover = genetics.genman.CrossOver(gsrc, gmut);
[138]38        printGenAndTitle(gxover, "crossed over (gsrc and gmut)");
39
[145]40        Geno gsimplest = genetics.genman.GetSimplest(format);
[138]41        printGenAndTitle(gsimplest, "simplest");
42
[145]43        Geno ginvalid("IT'S REALLY WRONG", format);
[138]44        printGenAndTitle(ginvalid, "invalid");
45
[145]46        Geno gvalidated = genetics.genman.Validate(ginvalid);
[139]47        printGenAndTitle(gvalidated, "validated");
[138]48
[348]49        printf("\nHTMLized: %s\n", genetics.genman.HTMLize(gvalidated.getGene().c_str()).c_str());
[138]50
51        return 0;
52}
Note: See TracBrowser for help on using the repository browser.