source: cpp/frams/_demos/multiline_f0_test.cpp @ 1329

Last change on this file since 1329 was 999, checked in by Maciej Komosinski, 4 years ago

More consistent usage of "shapetype" (vs. "shape")

  • Property svn:eol-style set to native
File size: 3.3 KB
Line 
1// This file is a part of Framsticks SDK.  http://www.framsticks.com/
2// Copyright (C) 1999-2020  Maciej Komosinski and Szymon Ulatowski.
3// See LICENSE.txt for details.
4
5#include <stdlib.h>
6#include <stdio.h>
7#include <time.h>
8#include <common/virtfile/stdiofile.h>
9
10#include <frams/genetics/preconfigured.h>
11#include <frams/model/model.h>
12#include <common/loggers/loggertostdout.h>
13#include <common/virtfile/stringfile.h>
14
15int main(int argc, char*argv[])
16{
17        LoggerToStdout messages_to_stdout(LoggerBase::Enable);
18        PreconfiguredGenetics genetics;
19
20        SString gen(argc > 1 ? argv[1] : "X[|G:1.23]");
21        if (!strcmp(gen.c_str(), "-"))
22        {
23                gen = 0;
24                StdioFILEDontClose in(stdin);
25                loadSString(&in, gen);
26        }
27        Geno g(gen);
28        printf("\nSource genotype: '%s'\n", g.getGenes().c_str());
29        printf("                  ( format %s %s)\n",
30                g.getFormat().c_str(), g.getComment().c_str());
31
32        Model m(g, Model::SHAPETYPE_UNKNOWN);//.getConverted('0'));
33
34        if (!m.isValid())
35        {
36                printf("Cannot build Model from this genotype!\n");
37                return 2;
38        }
39        printf("Converted to f0:\n%s\n", m.getF0Geno().getGenes().c_str());
40
41        printf("\nUsing Param::saveMultiLine() to create the \"expanded\" form of the f0 genotype...\n(MultiParamLoader should be able to load this)");
42
43        StringFILE2 f;
44
45        static Param modelparam(f0_model_paramtab);
46        static Param partparam(f0_part_paramtab);
47        static Param jointparam(f0_joint_paramtab);
48        static Param neuroparam(f0_neuro_paramtab);
49        static Param connparam(f0_neuroconn_paramtab);
50
51        modelparam.select(&m);
52        modelparam.saveMultiLine(&f, "m");
53
54        Part *p;
55        Joint *j;
56        Neuro *n;
57
58        for (int i = 0; p = (Part*)m.getPart(i); i++)
59        {
60                partparam.select(p);
61                partparam.saveMultiLine(&f, "p");
62        }
63        for (int i = 0; j = (Joint*)m.getJoint(i); i++)
64        {
65                jointparam.select(j);
66                jointparam.setParamTab(j->usedelta ? f0_joint_paramtab : f0_nodeltajoint_paramtab);
67                jointparam.saveMultiLine(&f, "j");
68        }
69        for (int i = 0; n = (Neuro*)m.getNeuro(i); i++)
70        {
71                neuroparam.select(n);
72                neuroparam.saveMultiLine(&f, "n");
73        }
74        for (int a = 0; n = (Neuro*)m.getNeuro(a); a++)
75        { // inputs
76                for (int b = 0; b < n->getInputCount(); b++)
77                {
78                        double w;
79                        NeuroConn nc;
80                        Neuro* n2 = n->getInput(b, w);
81                        nc.n1_refno = n->refno; nc.n2_refno = n2->refno;
82                        nc.weight = w;
83                        nc.info = n->getInputInfo(b);
84                        connparam.select(&nc);
85                        connparam.saveMultiLine(&f, "c");
86                }
87        }
88
89        printf("\n============================\n%s\n", f.getString().c_str());
90
91        return 0;
92}
93
94/*********************** EXAMPLE OUTPUT *********************************
95
96Source genotype: 'X[|G:1.23]'
97                                  ( format 1 )
98Converted to f0:
99p:
100p:1
101j:0, 1, dx=1
102n:p=1
103n:j=0, d="|:p=0.25,r=1"
104n:j=0, d=G
105c:0, 2, 1.23
106c:1, 0
107
108
109Using Param::saveMultiLine() to create the "expanded" form of the f0 genotype...
110(MultiParamLoader should be able to load this)
111============================
112m:
113se:1
114Vstyle:
115
116p:
117x:0
118y:0
119z:0
120m:1
121s:1
122dn:1
123fr:0.4
124ing:0.25
125as:0.25
126rx:0
127ry:0
128rz:0
129i:
130Vstyle:part
131
132p:
133x:1
134y:0
135z:0
136m:1
137s:1
138dn:1
139fr:0.4
140ing:0.25
141as:0.25
142rx:0
143ry:0
144rz:0
145i:
146Vstyle:part
147
148j:
149p1:0
150p2:1
151rx:0
152ry:0
153rz:0
154dx:1
155dy:0
156dz:0
157stif:1
158rotstif:1
159stam:0.25
160i:
161Vstyle:joint
162
163n:
164p:1
165j:-1
166d:N
167i:
168Vstyle:neuro
169
170n:
171p:-1
172j:0
173d:|:p=0.25,r=1
174i:
175Vstyle:neuro
176
177n:
178p:-1
179j:0
180d:G
181i:
182Vstyle:neuro
183
184c:
185n1:0
186n2:2
187w:1.23
188i:
189
190c:
191n1:1
192n2:0
193w:1
194i:
195
196
197*************************************************************************/
Note: See TracBrowser for help on using the repository browser.