ECJ-INTEREST-L Archives

February 2010

ECJ-INTEREST-L@LISTSERV.GMU.EDU

Options: Use Monospaced Font
Show Text Part by Default
Show All Mail Headers

Message: [<< First] [< Prev] [Next >] [Last >>]
Topic: [<< First] [< Prev] [Next >] [Last >>]
Author: [<< First] [< Prev] [Next >] [Last >>]

Print Reply
Subject:
From:
Sean Luke <[log in to unmask]>
Reply To:
ECJ Evolutionary Computation Toolkit <[log in to unmask]>
Date:
Sun, 28 Feb 2010 15:26:47 -0500
Content-Type:
text/plain
Parts/Attachments:
text/plain (41 lines)
On Feb 28, 2010, at 12:46 PM, Beto Roth wrote:

> The problem I have is how to tell ECJ to build a tree with that  
> specific
> structure. When ECJ creates a tree, it puts the terminals on the  
> leaves, and
> non-terminals on the remainder nodes. But how can I specify that the  
> nodes
> previous to the leaves have to have a comparator?

Norberto, ECJ's set types are good for this.  I'm going to presume  
from your diagram that you want to have terminals on the left of the  
">" or "<" and numbers on the right.  It's easy to modify if this is  
not the case.  Here's what you do:

ATOMIC TYPE 1: numbers
ATOMIC TYPE 2: variables
ATOMIC TYPE 3: comparisons
ATOMIC TYPE 4: logic

SET TYPE 1: booleans = {comparisons, logic}

TREE RETURN TYPE: logic

"&" RETURN TYPE: logic
"&" CHILD TYPES: booleans	(that is, either comparisons or logic)

">" etc. RETURN TYPE: comparisons
">" etc. LEFT CHILD TYPE: variables
">" etc. RIGHT CHILD TYPE: numbers

"A" etc. RETURN TYPE: variables
"5" etc. RETURN TYPE: numbers

This sets things up so that "&" nodes can have *either* "<" etc. *or*  
"&" nodes as their children.  But the tree must have an "&" node as  
its root.  Furthermore, "<" etc. must have variables as their left  
children and numbers as their right children.

Sean

ATOM RSS1 RSS2