- All Implemented Interfaces:
- BoundedChromosome<Double,,- DoubleGene> - Chromosome<DoubleGene>,- NumericChromosome<Double,,- DoubleGene> - BaseSeq<DoubleGene>,- Factory<Chromosome<DoubleGene>>,- Verifiable,- Serializable,- Iterable<DoubleGene>,- RandomAccess
public class DoubleChromosome
extends AbstractChromosome<DoubleGene>
implements NumericChromosome<Double,DoubleGene>, Serializable 
Numeric chromosome implementation which holds 64-bit floating point numbers.
- Since:
- 1.6
- Version:
- 6.1
- See Also:
- Implementation Note:
- This class is immutable and thread-safe.
- 
Field SummaryFields inherited from class io.jenetics.AbstractChromosome_genes, _valid
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedDoubleChromosome(ISeq<DoubleGene> genes, IntRange lengthRange) Create a new chromosome from the givengenesand the allowed length range of the chromosome.
- 
Method SummaryModifier and TypeMethodDescriptionReturns a sequential stream of the alleles with this chromosome as its source.booleaninthashCode()Return the allowed length range of the chromosome.Maps the gene alleles of this chromosome, given asdouble[]array, by applying the given mapper functionf.max()Return the maximum value of thisBoundedChromosome.min()Return the minimum value of thisBoundedChromosome.Create a new instance of type T.newInstance(ISeq<DoubleGene> genes) A factory method which creates a newChromosomeof specific type and the givengenes.static DoubleChromosomeof(double min, double max) Create a new randomDoubleChromosomeof length one.static DoubleChromosomeof(double min, double max, int length) Create a new randomDoubleChromosome.static DoubleChromosomeCreate a new random chromosome.static DoubleChromosomeof(DoubleGene... genes) Create a newDoubleChromosomewith the given genes.static DoubleChromosomeof(DoubleRange range) Create a new randomDoubleChromosomeof length one.static DoubleChromosomeof(DoubleRange range, int length) Create a new randomDoubleChromosome.static DoubleChromosomeof(DoubleRange range, IntRange lengthRange) Create a new random chromosome.static DoubleChromosomeof(Iterable<DoubleGene> genes) Create a newDoubleChromosomewith the given genes.double[]toArray()Returns a double array containing all the elements in this chromosome in a proper sequence.double[]toArray(double[] array) Returns a double array containing all the elements in this chromosome in a proper sequence.Methods inherited from class io.jenetics.AbstractChromosomeget, isValid, length, toStringMethods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface io.jenetics.util.BaseSeqforEach, get, isEmpty, iterator, length, listIterator, nonEmpty, spliterator, streamMethods inherited from interface io.jenetics.BoundedChromosomemax, minMethods inherited from interface io.jenetics.Chromosomeas, gene, isValidMethods inherited from interface io.jenetics.NumericChromosomebyteValue, byteValue, doubleValue, doubleValue, floatValue, floatValue, intValue, intValue, longValue, longValue, shortValue, shortValue
- 
Constructor Details- 
DoubleChromosomeCreate a new chromosome from the givengenesand the allowed length range of the chromosome.- Parameters:
- genes- the genes that form the chromosome.
- lengthRange- the allowed length range of the chromosome
- Throws:
- NullPointerException- if one of the arguments is- null.
- IllegalArgumentException- if the length of the gene sequence is empty, doesn't match with the allowed length range, the minimum or maximum of the range is smaller or equal zero, or the given range size is zero.
- Since:
- 4.0
 
 
- 
- 
Method Details- 
newInstanceDescription copied from interface:ChromosomeA factory method which creates a newChromosomeof specific type and the givengenes.- Specified by:
- newInstancein interface- Chromosome<DoubleGene>
- Parameters:
- genes- the genes of the new chromosome. The given genes array is not copied.
- Returns:
- A new Chromosomeof the same type with the given genes.
 
- 
newInstanceDescription copied from interface:FactoryCreate a new instance of type T.- Specified by:
- newInstancein interface- Factory<Chromosome<DoubleGene>>
- Returns:
- a new instance of type T
 
- 
mapMaps the gene alleles of this chromosome, given asdouble[]array, by applying the given mapper functionf. The mapped gene values are then wrapped into a newly created chromosome.final DoubleChromosome chromosome = ...; final DoubleChromosome normalized = chromosome.map(Main::normalize); static double[] normalize(final double[] values) { final double sum = sum(values); for (int i = 0; i < values.length; ++i) { values[i] /= sum; } return values; }- Parameters:
- f- the mapper function
- Returns:
- a newly created chromosome with the mapped gene values
- Throws:
- NullPointerException- if the mapper function is- null.
- IllegalArgumentException- if the length of the mapped- double[]array is empty or doesn't match with the allowed length range
- Since:
- 6.1
 
- 
doubleStreamReturns a sequential stream of the alleles with this chromosome as its source.- Returns:
- a sequential stream of alleles
- Since:
- 4.3
 
- 
toArrayReturns a double array containing all the elements in this chromosome in a proper sequence. If the chromosome fits in the specified array, it is returned therein. Otherwise, a new array is allocated with the length of this chromosome.- Parameters:
- array- the array into which the elements of these chromosomes are to be stored, if it is big enough; otherwise, a new array is allocated for this purpose.
- Returns:
- an array containing the elements of this chromosome
- Throws:
- NullPointerException- if the given- arrayis- null
- Since:
- 3.0
 
- 
toArrayReturns a double array containing all the elements in this chromosome in a proper sequence.- Returns:
- an array containing the elements of this chromosome
- Since:
- 3.0
 
- 
ofCreate a newDoubleChromosomewith the given genes.- Parameters:
- genes- the genes of the chromosome.
- Returns:
- a new chromosome with the given genes.
- Throws:
- IllegalArgumentException- if the length of the genes array is empty or the given- genesdoesn't have the same range.
- NullPointerException- if the given- genesarray is- null
 
- 
ofCreate a newDoubleChromosomewith the given genes.- Parameters:
- genes- the genes of the chromosome.
- Returns:
- a new chromosome with the given genes.
- Throws:
- NullPointerException- if the given- genesare- null
- IllegalArgumentException- if the of the genes iterable is empty or the given- genesdoesn't have the same range.
- Since:
- 4.3
 
- 
ofCreate a new random chromosome.- Parameters:
- min- the min value of the- DoubleGenes (inclusively).
- max- the max value of the- DoubleGenes (exclusively).
- lengthRange- the allowed length range of the chromosome.
- Returns:
- a new DoubleChromosomewith the given parameter
- Throws:
- IllegalArgumentException- if the length of the gene sequence is empty, doesn't match with the allowed length range, the minimum or maximum of the range is smaller or equal zero, or the given range size is zero.
- NullPointerException- if the given- lengthRangeis- null
- Since:
- 4.0
 
- 
ofCreate a new randomDoubleChromosome.- Parameters:
- min- the min value of the- DoubleGenes (inclusively).
- max- the max value of the- DoubleGenes (exclusively).
- length- the length of the chromosome.
- Returns:
- a new DoubleChromosomewith the given parameter
- Throws:
- IllegalArgumentException- if the- lengthis smaller than one.
 
- 
ofCreate a new random chromosome.- Parameters:
- range- the integer range of the chromosome.
- lengthRange- the allowed length range of the chromosome.
- Returns:
- a new DoubleChromosomewith the given parameter
- Throws:
- IllegalArgumentException- if the length of the gene sequence is empty, doesn't match with the allowed length range, the minimum or maximum of the range is smaller or equal zero, or the given range size is zero.
- NullPointerException- if the given- lengthRangeis- null
- Since:
- 4.0
 
- 
ofCreate a new randomDoubleChromosome.- Parameters:
- range- the integer range of the chromosome.
- length- the length of the chromosome.
- Returns:
- a new random DoubleChromosome
- Throws:
- NullPointerException- if the given- rangeis- null
- IllegalArgumentException- if the- lengthis smaller than one.
- Since:
- 3.2
 
- 
ofCreate a new randomDoubleChromosomeof length one.- Parameters:
- min- the minimal value of this chromosome (inclusively).
- max- the maximal value of this chromosome (exclusively).
- Returns:
- a new DoubleChromosomewith the given parameter
 
- 
ofCreate a new randomDoubleChromosomeof length one.- Parameters:
- range- the double range of the chromosome.
- Returns:
- a new random DoubleChromosomeof length one
- Throws:
- NullPointerException- if the given- rangeis- null
- Since:
- 3.2
 
- 
minDescription copied from interface:BoundedChromosomeReturn the minimum value of thisBoundedChromosome.- Specified by:
- minin interface- BoundedChromosome<A extends Comparable<? super A>,- G extends BoundedGene<A, - G>> 
- Returns:
- the minimum value of this BoundedChromosome.
 
- 
maxDescription copied from interface:BoundedChromosomeReturn the maximum value of thisBoundedChromosome.- Specified by:
- maxin interface- BoundedChromosome<A extends Comparable<? super A>,- G extends BoundedGene<A, - G>> 
- Returns:
- the maximum value of this BoundedChromosome.
 
- 
hashCodepublic int hashCode()
- 
equals
- 
lengthRangeReturn the allowed length range of the chromosome. The minimum value of the range is included and the maximum value is excluded.- Returns:
- the allowed length range of the chromosome
 
 
-