Class Rand1EitherOrDEBreeder
- All Implemented Interfaces:
Setup,Singleton,Serializable
Rand1EitherOrDEBreeder requires that all individuals be DoubleVectorIndividuals.
In short, the algorithm is as follows. For each individual in the population, we produce a child by selecting three (different) individuals, none the original individual, called r0, r1, and r2. We then create an individal c, defined either c = r0 + F * (r1 - r2), or as c = r0 + 0.5 * (F+1) * (r1 + r2 - 2 * r0), depending on a coin flip of probability "PF" (if 'true', the first equation is used, else the second). Unlike the other DEBreeders in this package, we do *not* cross over the child with the original individual. In fact, if the crossover probability is specified, Rand1EitherOrDEBreeder will issue a warning that it's not using it.
This class should be used in conjunction with DEEvaluator, which allows the children to enter the population only if they're superior to their parents (the original individuals). If so, they replace their parents.
Parameters
| base.pf 0.0 <= double <= 1.0 |
The "PF" probability of mutation type |
- See Also:
-
Field Summary
FieldsFields inherited from class ec.de.DEBreeder
bestSoFarIndex, Cr, CR_UNSPECIFIED, F, P_Cr, P_F, P_OUT_OF_BOUNDS_RETRIES, previousPopulation, retriesFields inherited from class ec.Breeder
sequentialBreeding -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptioncreateIndividual(EvolutionState state, int subpop, int index, int thread) voidsetup(EvolutionState state, Parameter base) Sets up the object by reading it from the parameters stored in state, built off of the parameter base base.Methods inherited from class ec.de.DEBreeder
breedPopulation, crossover, prepareDEBreeder, validMethods inherited from class ec.Breeder
shouldBreedSubpop
-
Field Details
-
PF
public double PF -
P_PF
- See Also:
-
-
Constructor Details
-
Rand1EitherOrDEBreeder
public Rand1EitherOrDEBreeder()
-
-
Method Details
-
setup
Description copied from interface:SetupSets up the object by reading it from the parameters stored in state, built off of the parameter base base. If an ancestor implements this method, be sure to call super.setup(state,base); before you do anything else. -
createIndividual
public DoubleVectorIndividual createIndividual(EvolutionState state, int subpop, int index, int thread) - Overrides:
createIndividualin classDEBreeder
-