1 | /* |
---|
2 | Copyright 2006 by Sean Luke |
---|
3 | Licensed under the Academic Free License version 3.0 |
---|
4 | See the file "LICENSE" for more information |
---|
5 | */ |
---|
6 | |
---|
7 | |
---|
8 | package ec.gp.koza; |
---|
9 | import ec.*; |
---|
10 | import ec.gp.*; |
---|
11 | import ec.util.*; |
---|
12 | |
---|
13 | /* |
---|
14 | * GrowBuilder.java |
---|
15 | * |
---|
16 | * Created: Thu Oct 7 18:03:49 1999 |
---|
17 | * By: Sean Luke |
---|
18 | */ |
---|
19 | |
---|
20 | |
---|
21 | /** GrowBuilder is a GPNodeBuilder which |
---|
22 | implements the GROW tree building method described in Koza I/II. |
---|
23 | |
---|
24 | <p>GROW works by choosing a random integer <i>d</i> between minDepth and maxDepth, inclusive. It then grows a tree of depth 1 to <i>d</i> inclusive. Unlike lil-gp and Koza's texts, ECJ defines the "depth" of a tree to be the number of <i>nodes</i> (not edges) in the longest path from the root to any node in the tree. |
---|
25 | |
---|
26 | <p>Actually, claiming to implement the Koza I/II approach is a bit of a fib -- Koza's original code is somewhat ad-hoc. In the Koza approach, <i>d</i> is chosen in a kind of round-robin fashion rather than at random, if RAMPED HALF/HALF is used. Also, for all three algorithms (RAMPED HALF/HALF, GROW, FULL), the algorithm will not generate a tree consisting of a single terminal, unless forced to. |
---|
27 | |
---|
28 | <p>This implementation instead follows lil-gp's approach, which is to choose <i>d</i> at random from between minDepth and maxDepth, inclusive, and to allow trees consisting of single terminals. |
---|
29 | |
---|
30 | <p>Determining what various algorithms do is a little confusing, mostly because the source code for lil-gp and Koza don't actually quite do what they claim. The table below lists the depth values actually used (counting nodes, rather than edges, for depth). It's probably not what you had expected! |
---|
31 | |
---|
32 | |
---|
33 | |
---|
34 | <br> |
---|
35 | <br> |
---|
36 | <div align="center"> |
---|
37 | <table border="0" cellspacing="1" cellpadding="2"> |
---|
38 | <tr> |
---|
39 | <td bgcolor="#ffffff"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff" ></font><br></td> |
---|
40 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff" >Koza I Min</font><br></td> |
---|
41 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff" >Koza I Max</font><br></td> |
---|
42 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff" >Koza II Min</font><br></td> |
---|
43 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff" >Koza II Max</font><br></td> |
---|
44 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff" >lil-gp Min</font><br></td> |
---|
45 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff" >lil-gp Max</font><br></td> |
---|
46 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff" >ECJ Min</font><br></td> |
---|
47 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff" >ECJ Max</font><br></td> |
---|
48 | </tr><tr> |
---|
49 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff">GROW (mut)</font><br></td> |
---|
50 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">5</font><br></td> |
---|
51 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">5</font><br></td> |
---|
52 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">5</font><br></td> |
---|
53 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">5</font><br></td> |
---|
54 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica"> </font><br></td> |
---|
55 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica"> </font><br></td> |
---|
56 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">5</font><br></td> |
---|
57 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">5</font><br></td> |
---|
58 | <tr></tr> |
---|
59 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff">GROW (new)</font><br></td> |
---|
60 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">7</font><br></td> |
---|
61 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">7</font><br></td> |
---|
62 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">6? 7?</font><br></td> |
---|
63 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">6? 7?</font><br></td> |
---|
64 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">3</font><br></td> |
---|
65 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">7</font><br></td> |
---|
66 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">5</font><br></td> |
---|
67 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">5</font><br></td> |
---|
68 | <tr></tr> |
---|
69 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff">FULL (new)</font><br></td> |
---|
70 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">7</font><br></td> |
---|
71 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">7</font><br></td> |
---|
72 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">6? 7?</font><br></td> |
---|
73 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">6? 7?</font><br></td> |
---|
74 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">3</font><br></td> |
---|
75 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">7</font><br></td> |
---|
76 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica"> </font><br></td> |
---|
77 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica"> </font><br></td> |
---|
78 | <tr></tr> |
---|
79 | <td bgcolor="#3366cc"><font size="-1" face="simple,geneva,arial,helvetica" color="#ffffff">HALF (new)</font><br></td> |
---|
80 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">2</font><br></td> |
---|
81 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">6</font><br></td> |
---|
82 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">2</font><br></td> |
---|
83 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">5? 6?</font><br></td> |
---|
84 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">3</font><br></td> |
---|
85 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">7</font><br></td> |
---|
86 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">2</font><br></td> |
---|
87 | <td bgcolor="#cccccc"><font size="-1" face="simple,geneva,arial,helvetica">6</font><br></td> |
---|
88 | </tr></table> |
---|
89 | </div> |
---|
90 | <br> |
---|
91 | <br> |
---|
92 | |
---|
93 | |
---|
94 | |
---|
95 | |
---|
96 | |
---|
97 | |
---|
98 | The table cell is empty when that parameter is not defined by the system by default. Koza II has two values each because of a possible typo in the text -- while page 656 gives one maximum, page 671 gives another. Note the odd fact that in Koza I/II GROW and FULL have <i>effectively</i> one-deeper tree values than HALF does, even though they use the same code parameters! This is because of a quirk in Koza's code. |
---|
99 | |
---|
100 | |
---|
101 | <p> This algorithm ignores <tt>requestedSize</tt>, so no pipelines can ask it to grow a tree of a specific fixed size. The algorithm also ignores any user-provided size distributions. |
---|
102 | |
---|
103 | <p><b>Parameters</b><br> |
---|
104 | <table> |
---|
105 | <tr><td valign=top><i>base</i>.<tt>min-depth</tt><br> |
---|
106 | <font size=-1>int >= 1</font></td> |
---|
107 | <td valign=top>(smallest "maximum" depth the builder may use for building a tree. 2 is the default.)</td></tr> |
---|
108 | |
---|
109 | <tr><td valign=top><i>base</i>.<tt>max-depth</tt><br> |
---|
110 | <font size=-1>int >= <i>base</i>.<tt>min-depth</tt></font></td> |
---|
111 | <td valign=top>(largest "maximum" depth thie builder may use for building a tree. 6 is the default.)</td></tr> |
---|
112 | </table> |
---|
113 | |
---|
114 | <p><b>Default Base</b><br> |
---|
115 | gp.koza.grow |
---|
116 | |
---|
117 | * @author Sean Luke |
---|
118 | * @version 1.0 |
---|
119 | */ |
---|
120 | |
---|
121 | |
---|
122 | |
---|
123 | public class GrowBuilder extends KozaBuilder |
---|
124 | { |
---|
125 | public static final String P_GROWBUILDER = "grow"; |
---|
126 | |
---|
127 | public Parameter defaultBase() |
---|
128 | { |
---|
129 | return GPKozaDefaults.base().push(P_GROWBUILDER); |
---|
130 | } |
---|
131 | |
---|
132 | public GPNode newRootedTree(final EvolutionState state, |
---|
133 | final GPType type, |
---|
134 | final int thread, |
---|
135 | final GPNodeParent parent, |
---|
136 | final GPFunctionSet set, |
---|
137 | final int argposition, |
---|
138 | final int requestedSize) |
---|
139 | { |
---|
140 | GPNode n = growNode(state,0,state.random[thread].nextInt(maxDepth-minDepth+1) + minDepth,type,thread,parent,argposition,set); |
---|
141 | return n; |
---|
142 | } |
---|
143 | } |
---|
144 | |
---|
145 | |
---|