Class VectorSpecies
- All Implemented Interfaces:
Prototype,Setup,Serializable,Cloneable
- Direct Known Subclasses:
BitVectorSpecies,FloatVectorSpecies,GeneVectorSpecies,IntegerVectorSpecies
VectorSpecies supports the following recombination methods:
- One-point crossover.
- Two-point crossover.
- Uniform crossover - inaccurately called "any-point".
- Line recombination - children are random points on a line between the two parents.
- Intermediate recombination - the value of each component of the vector is between the values of that component of the parent vectors.
Note that BitVectorIndividuals (which use VectorSpecies) and GeneVectorIndividuals (which use GeneVectorSpecies, a subclass of VectorSpecies) do not support Line or Intermediate Recombination.
Also note that for LongVectorIndividuals, there are certain values that will never be created by line and intermediate recombination, because the recombination is calculated using doubles and then rounded to the nearest long. For large enough values (but still smaller than the maximum long), the difference between one double and the next is greater than one.
VectorSpecies has three wasy to determine the initial size of the individual:
- A fixed size.
- Geometric distribution.
- Uniform distribution
If the algorithm used is the geometric distribution, the VectorSpecies starts at a minimum size and continues flipping a coin with a certain "resize probability", increasing the size each time, until the coin comes up tails (fails). The chunk size must be 1 in this case.
If the algorithm used is the uniform distribution, the VectorSpecies picks a random size between a provided minimum and maximum size, inclusive. The chunk size must be 1 in this case.
If the size is fixed, then you can also provide a "chunk size" which constrains the locations in which crossover can be performed (only along chunk boundaries). The genome size must be a multiple of the chunk size in this case.
VectorSpecies also contains a number of parameters guiding how the individual crosses over and mutates.
Per-Gene and Per-Segment Specification. VectorSpecies and its subclasses specify a lot of parameters, notably mutation and initialization parameters, in one of three ways. We will use the mutation-probability parameter as an example.
- Globally for all genes in the genome.
This is done by specifying:
base.mutation-probability
base.max-geneNote: you must provide these values even if you don't use them, as they're used as defaults by #2 and #3 below.
- You may provide parameters for genes in segments (regions) along
the genome. The idea is to allow you to specify large chunks of genes
all having the same parameter features.
To do this you must first specify how many segments there are:
base.num-segments
The segments then may be defined by either start or end indices of genes. This is controlled by specifying the value of:
base.segment-type
...which can assume the value of start or end, with start being the default. The indices are defined using Java array style, i.e. the first gene has the index of 0, and the last gene has the index of genome-size - 1.
Using this method, each segment is specified byj...
base.segment.j.start
base.segment.j.mutation-probability if segment-type value was chosen as start or by:base.segment.j.end
base.segment.j.mutation-probability if segment-type value is equal to end. - You may parameters for each separate gene.
This is done by specifying (for each gene location i you wish to specify)
base.mutation-probability.i
Any settings for #3 override #2, and both override #1.
The only parameter which can be specified this way in VectorSpecies is at present mutation-probability. However a number of parameters are specified this way in subclasses.
Parameters
| base.genome-size int >= 1 or one of: geometric, uniform |
(size of the genome, or if 'geometric' or 'uniform', the algorithm used to size the initial genome) |
| base.chunk-size 1 <= int <= genome-size (default=1) |
(the chunk size for crossover (crossover will only occur on chunk boundaries)) |
| base.geometric-prob 0.0 <= double < 1.0 |
(the coin-flip probability for increasing the initial size using the geometric distribution) |
| base.min-initial-size int >= 0 |
(the minimum initial size of the genome) |
| base.max-initial-size int >= min-initial-size |
(the maximum initial size of the genome) |
| base.crossover-type string, one of: one, two, any |
(default crossover type (one-point, one-point-nonempty, two-point, two-point-nonempty, any-point (uniform), line, or intermediate) |
| base.crossover-prob 0.0 >= double >= 1.0 |
(probability that a gene will get crossed over during any-point (uniform) or simulated binary crossover) |
| base.line-extension double >= 0.0 |
(for line and intermediate recombination, how far along the line or outside of the hypercube children can be. If this value is zero, all children must be within the hypercube.) |
| base.mutation-prob or | |
| base.segment.segment-number.mutation-prob or | |
| base.mutation-prob.gene-number 0.0 <= double <= 1.0 |
(probability that a gene will get mutated over default mutation) |
Default Base
vector.species
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intstatic final intintHow big of chunks should we define for crossover?intWhat should the SBX distribution index be?doubleProbability that a gene will cross over -- ONLY used in V_ANY_POINT crossoverintWhat kind of crossover do we have?protected int[]How often do we retry until we get a non-duplicate gene?booleanWas the initial size determined dynamically?doubleWith what probability would our genome be at least 1 larger than it is now during initialization?intHow should we reset the genome?intHow big of a genome should we create on initialization?doubleHow far along the long a child can be located for line or intermediate recombinationintWhat's the largest legal genome?intWhat's the smallest legal genome?protected double[]Probability that a gene will mutate, per gene.static final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final StringFields inherited from class ec.Species
f_prototype, i_prototype, P_FITNESS, P_INDIVIDUAL, P_PIPE, pipe_prototype -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected intcontains(boolean[] array, boolean val) Utility method: returns the first array slot which contains the given value, else -1.protected intcontains(double[] array, double val) Utility method: returns the first array slot which contains the given value, else -1.protected intcontains(int[] array, int val) Utility method: returns the first array slot which contains the given value, else -1.protected intcontains(long[] array, long val) Utility method: returns the first array slot which contains the given value, else -1.Returns the default base for this prototype.intduplicateRetries(int gene) protected boolean[]fill(boolean[] array, boolean val) Utility method: fills the array with the given value and returns it.protected double[]fill(double[] array, double val) Utility method: fills the array with the given value and returns it.protected int[]fill(int[] array, int val) Utility method: fills the array with the given value and returns it.protected long[]fill(long[] array, long val) Utility method: fills the array with the given value and returns it.protected voidinitializeGenomeSegmentsByEndIndices(EvolutionState state, Parameter base, Parameter def, int numSegments) Looks up genome segments using end indices.protected voidinitializeGenomeSegmentsByStartIndices(EvolutionState state, Parameter base, Parameter def, int numSegments) Looks up genome segments using start indices.protected voidloadParametersForGene(EvolutionState state, int index, Parameter base, Parameter def, String postfix) Called when VectorSpecies is setting up per-gene and per-segment parameters.doublemutationProbability(int gene) newIndividual(EvolutionState state, int thread) Provides a brand-new individual to fill in a population.voidsetup(EvolutionState state, Parameter base) The default version of setup(...) loads requested pipelines and calls setup(...) on them and normalizes their probabilities.protected voidsetupGenome(EvolutionState state, Parameter base) Methods inherited from class ec.Species
buildMisc, clone, newIndividual, newIndividual, updateIndividual, updateSubpopulation
-
Field Details
-
P_VECTORSPECIES
- See Also:
-
P_CROSSOVERTYPE
- See Also:
-
P_CHUNKSIZE
- See Also:
-
V_ONE_POINT
- See Also:
-
V_ONE_POINT_NO_NOP
- See Also:
-
V_TWO_POINT
- See Also:
-
V_TWO_POINT_NO_NOP
- See Also:
-
V_ANY_POINT
- See Also:
-
V_LINE_RECOMB
- See Also:
-
V_INTERMED_RECOMB
- See Also:
-
V_SIMULATED_BINARY
- See Also:
-
P_CROSSOVER_DISTRIBUTION_INDEX
- See Also:
-
P_MUTATIONPROB
- See Also:
-
P_CROSSOVERPROB
- See Also:
-
P_GENOMESIZE
- See Also:
-
P_LINEDISTANCE
- See Also:
-
V_GEOMETRIC
- See Also:
-
P_GEOMETRIC_PROBABILITY
- See Also:
-
V_UNIFORM
- See Also:
-
P_UNIFORM_MIN
- See Also:
-
P_UNIFORM_MAX
- See Also:
-
P_NUM_SEGMENTS
- See Also:
-
P_SEGMENT_TYPE
- See Also:
-
P_SEGMENT_START
- See Also:
-
P_SEGMENT_END
- See Also:
-
P_SEGMENT
- See Also:
-
P_DUPLICATE_RETRIES
- See Also:
-
C_ONE_POINT
public static final int C_ONE_POINT- See Also:
-
C_ONE_POINT_NO_NOP
public static final int C_ONE_POINT_NO_NOP- See Also:
-
C_TWO_POINT
public static final int C_TWO_POINT- See Also:
-
C_TWO_POINT_NO_NOP
public static final int C_TWO_POINT_NO_NOP- See Also:
-
C_ANY_POINT
public static final int C_ANY_POINT- See Also:
-
C_LINE_RECOMB
public static final int C_LINE_RECOMB- See Also:
-
C_INTERMED_RECOMB
public static final int C_INTERMED_RECOMB- See Also:
-
C_SIMULATED_BINARY
public static final int C_SIMULATED_BINARY- See Also:
-
C_NONE
public static final int C_NONE- See Also:
-
C_GEOMETRIC
public static final int C_GEOMETRIC- See Also:
-
C_UNIFORM
public static final int C_UNIFORM- See Also:
-
duplicateRetries
protected int[] duplicateRetriesHow often do we retry until we get a non-duplicate gene? -
mutationProbability
protected double[] mutationProbabilityProbability that a gene will mutate, per gene. This array is one longer than the standard genome length. The top element in the array represents the parameters for genes in genomes which have extended beyond the genome length. -
crossoverProbability
public double crossoverProbabilityProbability that a gene will cross over -- ONLY used in V_ANY_POINT crossover -
crossoverType
public int crossoverTypeWhat kind of crossover do we have? -
genomeSize
public int genomeSizeHow big of a genome should we create on initialization? -
crossoverDistributionIndex
public int crossoverDistributionIndexWhat should the SBX distribution index be? -
genomeResizeAlgorithm
public int genomeResizeAlgorithmHow should we reset the genome? -
minInitialSize
public int minInitialSizeWhat's the smallest legal genome? -
maxInitialSize
public int maxInitialSizeWhat's the largest legal genome? -
genomeIncreaseProbability
public double genomeIncreaseProbabilityWith what probability would our genome be at least 1 larger than it is now during initialization? -
chunksize
public int chunksizeHow big of chunks should we define for crossover? -
lineDistance
public double lineDistanceHow far along the long a child can be located for line or intermediate recombination -
dynamicInitialSize
public boolean dynamicInitialSizeWas the initial size determined dynamically?
-
-
Constructor Details
-
VectorSpecies
public VectorSpecies()
-
-
Method Details
-
mutationProbability
public double mutationProbability(int gene) -
duplicateRetries
public int duplicateRetries(int gene) -
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(...). -
setupGenome
-
setup
Description copied from class:SpeciesThe default version of setup(...) loads requested pipelines and calls setup(...) on them and normalizes their probabilities. If your individual prototype might need to know special things about the species (like parameters stored in it), then when you override this setup method, you'll need to set those parameters BEFORE you call super.setup(...), because the setup(...) code in Species sets up the prototype. -
loadParametersForGene
protected void loadParametersForGene(EvolutionState state, int index, Parameter base, Parameter def, String postfix) Called when VectorSpecies is setting up per-gene and per-segment parameters. The index is the current gene whose parameter is getting set up. The Parameters in question are the bases for the gene. The postfix should be appended to the end of any parameter looked up (it often contains a number indicating the gene in question), such as state.parameters.exists(base.push(P_PARAM).push(postfix), def.push(P_PARAM).push(postfix)If you override this method, be sure to call super(...) at some point, ideally first.
-
initializeGenomeSegmentsByStartIndices
protected void initializeGenomeSegmentsByStartIndices(EvolutionState state, Parameter base, Parameter def, int numSegments) Looks up genome segments using start indices. Segments run up to the next declared start index. -
initializeGenomeSegmentsByEndIndices
protected void initializeGenomeSegmentsByEndIndices(EvolutionState state, Parameter base, Parameter def, int numSegments) Looks up genome segments using end indices. Segments run from the previously declared end index. -
newIndividual
Description copied from class:SpeciesProvides a brand-new individual to fill in a population. The default form simply calls clone(), creates a fitness, sets evaluated to false, and sets the species. If you need to make a more custom genotype (as is the case for GPSpecies, which requires a light rather than deep clone), you will need to override this method as you see fit.- Overrides:
newIndividualin classSpecies
-
fill
protected long[] fill(long[] array, long val) Utility method: fills the array with the given value and returns it. -
fill
protected int[] fill(int[] array, int val) Utility method: fills the array with the given value and returns it. -
fill
protected boolean[] fill(boolean[] array, boolean val) Utility method: fills the array with the given value and returns it. -
fill
protected double[] fill(double[] array, double val) Utility method: fills the array with the given value and returns it. -
contains
protected int contains(boolean[] array, boolean val) Utility method: returns the first array slot which contains the given value, else -1. -
contains
protected int contains(long[] array, long val) Utility method: returns the first array slot which contains the given value, else -1. -
contains
protected int contains(int[] array, int val) Utility method: returns the first array slot which contains the given value, else -1. -
contains
protected int contains(double[] array, double val) Utility method: returns the first array slot which contains the given value, else -1.
-