Package ec.parsimony
Class ProportionalTournamentSelection
java.lang.Object
ec.BreedingSource
ec.SelectionMethod
ec.select.TournamentSelection
ec.parsimony.ProportionalTournamentSelection
- All Implemented Interfaces:
Prototype,Setup,SteadyStateBSourceForm,RandomChoiceChooserD,Serializable,Cloneable
This selection method adds parsimony pressure to the regular tournament selection. The comparison of
individuals is based on fitness with probability prob, and it is based on size with probability
1-prob. For each pairwise comparsion of individuals, the ProportionalTournamentSelection randomly decides
whether to compare based on fitness or size.
Typical Number of Individuals Produced Per produce(...) call
Always 1.
Parameters
| base.size int >= 1 |
(the tournament size) |
| base.pick-worst bool = true or false (default) |
(should we pick the worst individual in the tournament instead of the best?) |
| base.fitness-prob double >= 0 and <= 1 |
(the probability of comparing individuals based on fitness, rather than size) |
Default Base
select.proportional-tournament
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptiondoubleThe probability of having the tournament based on fitnessstatic final StringThe parameter for the probability of having the tournament based on fitnessstatic final Stringdefault baseFields inherited from class ec.select.TournamentSelection
P_PICKWORST, P_SIZE, P_TOURNAMENT, pickWorst, probabilityOfPickingSizePlusOne, sizeFields inherited from class ec.SelectionMethod
INDS_PRODUCED, KEY_PARENTSFields inherited from class ec.BreedingSource
NO_PROBABILITY, P_PROB, probability -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionbooleanbetterThan(Individual first, Individual second, int subpopulation, EvolutionState state, int thread) Returns true if *first* is a better (fitter, whatever) individual than *second*.Returns the default base for this prototype.voidsetup(EvolutionState state, Parameter base) Sets up the BreedingPipeline.Methods inherited from class ec.select.TournamentSelection
getRandomIndividual, getTournamentSizeToUse, individualReplaced, produce, sourcesAreProperFormMethods inherited from class ec.SelectionMethod
finishProducing, prepareToProduce, produce, produces, produceWithoutCloning, typicalIndsProducedMethods inherited from class ec.BreedingSource
clone, fillStubs, getProbability, pickRandom, preparePipeline, setProbability, setupProbabilities
-
Field Details
-
P_PROPORTIONAL_TOURNAMENT
default base- See Also:
-
P_PROBABILITY
The parameter for the probability of having the tournament based on fitness- See Also:
-
fitnessPressureProb
public double fitnessPressureProbThe probability of having the tournament based on fitness
-
-
Constructor Details
-
ProportionalTournamentSelection
public ProportionalTournamentSelection()
-
-
Method Details
-
defaultBase
Description copied from interface:PrototypeReturns the default base for this prototype. This should generally be implemented by building off of the static base() method on the DefaultsForm object for the prototype's package. This should be callable during setup(...).- Specified by:
defaultBasein interfacePrototype- Overrides:
defaultBasein classTournamentSelection
-
setup
Description copied from class:BreedingSourceSets up the BreedingPipeline. You can use state.output.error here because the top-level caller promises to call exitIfErrors() after calling setup. Note that probability might get modified again by an external source if it doesn't normalize right.The most common modification is to normalize it with some other set of probabilities, then set all of them up in increasing summation; this allows the use of the fast static BreedingSource-picking utility method, BreedingSource.pickRandom(...). In order to use this method, for example, if four breeding source probabilities are {0.3, 0.2, 0.1, 0.4}, then they should get normalized and summed by the outside owners as: {0.3, 0.5, 0.6, 1.0}.
-
betterThan
public boolean betterThan(Individual first, Individual second, int subpopulation, EvolutionState state, int thread) Description copied from class:TournamentSelectionReturns true if *first* is a better (fitter, whatever) individual than *second*.- Overrides:
betterThanin classTournamentSelection
-