org.jgap.impl
Class TournamentSelector

java.lang.Object
  extended byorg.jgap.NaturalSelector
      extended byorg.jgap.impl.TournamentSelector
All Implemented Interfaces:
INaturalSelector

public class TournamentSelector
extends NaturalSelector

Implementation of a NaturalSelector that plays tournaments to determine the chromosomes to be taken to the next generation.

The tournament size can be adjusted as well as the probability for selecting an individual.

Since:
2.0
Author:
Klaus Meffert

Constructor Summary
TournamentSelector(int a_tournament_size, double a_probability)
           
 
Method Summary
 void empty()
          Empty out the working pool of Chromosomes.
 boolean returnsUniqueChromosomes()
           
 void select(int a_howManyToSelect, Population a_from_pop, Population a_to_pop)
          Select a given number of Chromosomes from the pool that will move on to the next generation population.
 
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

TournamentSelector

public TournamentSelector(int a_tournament_size,
                          double a_probability)
Parameters:
a_tournament_size - int
a_probability - double
Since:
2.0
Method Detail

select

public void select(int a_howManyToSelect,
                   Population a_from_pop,
                   Population a_to_pop)
Select a given number of Chromosomes from the pool that will move on to the next generation population. This selection will be guided by the fitness values. The chromosomes with the best fitness value win.

Parameters:
a_howManyToSelect - int
a_from_pop - the population the Chromosomes will be selected from.
a_to_pop - the population the Chromosomes will be added to.
Since:
2.0

returnsUniqueChromosomes

public boolean returnsUniqueChromosomes()
Returns:
false as we allow to return the same chromosome multiple times
Since:
2.0

empty

public void empty()
Description copied from interface: INaturalSelector
Empty out the working pool of Chromosomes. This will be invoked after each evolution cycle so that the natural selector can be reused for the next one.