NAME

Tree - A Direct Acyclic Graph, or tree, useful for Genetic Programming-Style stuff

SYNOPSIS

    use Algorithm::Evolutionary::Individual::Tree;
    #Hash with primitives, arity, and range for constants that multiply it

    my $primitives = { sum => [2, -1, 1],
				   multiply => [2, -1, 1],
				   substract => [2, -1, 1],
				   divide => [2, -1, 1],
				   x => [0, -10, 10],
				   y => [0, -10, 10] };

    my $indi = new Algorithm::Evolutionary::Individual::Tree $primitives, 5 ; # Build random tree with knwo primitives
                                           # and depth up to 5

    my $indi5 = $indi->clone(); #Creates a copy of the individual

    print $indi3->asString(); #Prints the individual
    print $indi3->asXML() #Prints it as XML. See L<XML> for more info on this

Base Class

Algorithm::Evolutionary::Individual::Base

DESCRIPTION

Array individual for a genetic programming. Uses Direct Acyclic graphs as representation for trees, which is very convenient.

METHODS

new

Creates a new tree

set

Sets values of an individual; takes a hash as input

randomize

Assigns random values to the elements

fromString

Probably useless, in this case. To be evolved.

clone

Similar to a copy ctor: creates a new individual from another one

asString

Prints it

asXML

Prints it as XML. It prints the tree as String, which does not mean you will be able to get it back from this form. It's done just for compatibity, reading from this format will be available. In the future.

lolprint

Print the list of lists that composes the tree, using prefix notation

growSubTree

Grows a random tree, with primitives as indicated, and a certain depth. Depth defaults to 4

Copyright

This file is released under the GPL. See the LICENSE file included in this distribution,
or go to http://www.fsf.org/licenses/gpl.txt

CVS Info: $Date: 2008/02/12 17:49:39 $ 
$Header: /cvsroot/opeal/Algorithm-Evolutionary/lib/Algorithm/Evolutionary/Individual/Tree.pm,v 1.1.1.1 2008/02/12 17:49:39 jmerelo Exp $ 
$Author: jmerelo $ 
$Revision: 1.1.1.1 $
$Name $