public class ADFStack extends Object implements Prototype
When an ADF is evaluated, it first evaluates its children, then it calls push() on the ADFstack. push() either creates a new ADFContext, or it fetches one from the reserve if possible. It then pushes the context on the main stack, and also returns the context. The ADF fills the context's arguments with the results of its childrens' evaluation, and sets numargs to the number of arguments, then evaluates the ADF's associated function tree,
When an ADM is evaluated, it calls push() on the ADFstack. The ADM then fills the context's adm node with itself, and sets numargs to the number of children it has. Then it calls the ADM's associated function tree.
In that tree, if an argument terminal of value n is evaluated, the argument terminal calls evaluate(...) on the top context on the ADF stack and returns the result. This method does different things depending on whether the top context represented an ADF or an ADM. If it was an ADF, the context simply sets input to the value of argument n in the context's argument list, and returns input. If it was an ADM, the context pops itself off the stack and pushes itself on the substack (to set up the right context for evaluating an original child of the ADM), then evaluates child n of the ADM, then pops itself off the substack and pushes itself back on the stack to restore the context. Input is set to the evaluated results, and input is returned.
Parameters
base.context classname, inherits and != ec.gp.GPContext |
(the stack's GPContext class) |
Parameters
gp.adf-stack
Parameter bases
base.context | (context_proto) |
Modifier and Type | Field and Description |
---|---|
ADFContext |
context_proto |
static int |
INITIAL_STACK_SIZE |
protected int |
inReserve |
protected int |
onStack |
protected int |
onSubstack |
static String |
P_ADF |
static String |
P_ADFSTACK |
static String |
P_CONTEXT |
protected ADFContext[] |
reserve |
private static long |
serialVersionUID |
protected ADFContext[] |
stack |
protected ADFContext[] |
substack |
Constructor and Description |
---|
ADFStack() |
Modifier and Type | Method and Description |
---|---|
Object |
clone()
Creates a new individual cloned from a prototype,
and suitable to begin use in its own evolutionary
context.
|
Parameter |
defaultBase()
Returns the default base for this prototype.
|
ADFContext |
get()
Returns an ADFContext from the stack's reserve, or creates one
fresh if there are none in reserve.
|
int |
moveFromSubstack(int n)
Moves n items onto the stack (popss them off the substack and pushes them onto the stack).
|
int |
moveOntoSubstack(int n)
Moves n items onto the substack (pops them off the stack and pushes them onto the substack).
|
int |
pop(int n)
Pops off n items from the stack, if possible.
|
ADFContext |
push(ADFContext obj)
Pushes an ADFContext onto the main stack.
|
void |
reset()
Pops off all items on the stack and the substack.
|
void |
setup(EvolutionState state,
Parameter base)
Sets up the object by reading it from the parameters stored
in state, built off of the parameter base base.
|
ADFContext |
top(int n)
Returns the nth item in the stack (0-indexed), or null if
this goes to the bottom of the stack.
|
private static final long serialVersionUID
public static final String P_ADFSTACK
public static final String P_ADF
public static final String P_CONTEXT
public ADFContext context_proto
public static final int INITIAL_STACK_SIZE
protected int onStack
protected int onSubstack
protected int inReserve
protected ADFContext[] stack
protected ADFContext[] substack
protected ADFContext[] reserve
public Parameter defaultBase()
Prototype
defaultBase
in interface Prototype
public void setup(EvolutionState state, Parameter base)
Prototype
For prototypes, setup(...) is typically called once for the prototype instance; cloned instances do not receive the setup(...) call. setup(...) may be called more than once; the only guarantee is that it will get called at least once on an instance or some "parent" object from which it was ultimately cloned.
public Object clone()
Prototype
Typically this should be a full "deep" clone. However, you may share certain elements with other objects rather than clone hem, depending on the situation:
Implementations.
public Object clone()
{
try
{
return super.clone();
}
catch ((CloneNotSupportedException e)
{ throw new InternalError(); } // never happens
}
public Object clone()
{
try
{
MyObject myobj = (MyObject) (super.clone());
// put your deep-cloning code here...
}
catch ((CloneNotSupportedException e)
{ throw new InternalError(); } // never happens
return myobj;
}
public Object clone()
{
MyObject myobj = (MyObject) (super.clone());
// put your deep-cloning code here...
return myobj;
}
public final ADFContext get()
public final ADFContext push(ADFContext obj)
public final int pop(int n)
public final ADFContext top(int n)
public final int moveOntoSubstack(int n)
public final int moveFromSubstack(int n)
public final void reset()
Copyright © 2019. All rights reserved.