org.jenetics.engine.EvolutionStream Maven / Gradle / Ivy
/*
* Java Genetic Algorithm Library (jenetics-3.9.0).
* Copyright (c) 2007-2017 Franz Wilhelmstötter
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* Author:
* Franz Wilhelmstötter ([email protected])
*/
package org.jenetics.engine;
import java.util.function.Function;
import java.util.function.Predicate;
import java.util.function.Supplier;
import java.util.stream.Stream;
import org.jenetics.Gene;
/**
* The {@code EvolutionStream} class extends the Java {@link Stream} and adds a
* method for limiting the evolution by a given predicate.
*
* @see java.util.stream.Stream
* @see Engine
*
* @author Franz Wilhelmstötter
* @since 3.0
* @version 3.1
*/
public interface EvolutionStream<
G extends Gene, G>,
C extends Comparable super C>
>
extends Stream>
{
/**
* Returns a stream consisting of the elements of this stream, truncated
* when the given {@code proceed} predicate returns {@code false}.
*
* General usage example:
*
{@code
* final Phenotype result = engine.stream()
* // Truncate the evolution stream after 5 "steady" generations.
* .limit(bySteadyFitness(5))
* // The evolution will stop after maximal 100 generations.
* .limit(100)
* .collect(toBestPhenotype());
* }
*
* @see limit
*
* @param proceed the predicate which determines whether the stream is
* truncated or not. If the predicate returns {@code false}, the
* evolution stream is truncated.
* @return the new stream
* @throws NullPointerException if the given predicate is {@code null}.
*/
public EvolutionStream
limit(final Predicate super EvolutionResult> proceed);
/**
* Create a new {@code EvolutionStream} from the given {@code start}
* population and {@code evolution} function. The main purpose of this
* factory method is to simplify the creation of an {@code EvolutionStream}
* from an own evolution (GA) engine.
*
* {@code
* final Supplier> start = ...
* final EvolutionStream stream =
* EvolutionStream.of(start, new MySpecialEngine());
* }
*
* A more complete example for would look like as:
*
* {@code
* public final class SpecialEngine {
*
* // The fitness function.
* private static Double fitness(final Genotype gt) {
* return gt.getGene().getAllele();
* }
*
* // Create new evolution start object.
* private static EvolutionStart
* start(final int populationSize, final long generation) {
* final Population population =
* Genotype.of(DoubleChromosome.of(0, 1)).instances()
* .map(gt -> Phenotype.of(gt, generation, SpecialEngine::fitness))
* .limit(populationSize)
* .collect(Population.toPopulation());
*
* return EvolutionStart.of(population, generation);
* }
*
* // The special evolution function.
* private static EvolutionResult
* evolve(final EvolutionStart start) {
* // Your special evolution implementation comes here!
* return null;
* }
*
* public static void main(final String[] args) {
* final Genotype best = EvolutionStream
* .of(() -> start(50, 0), SpecialEngine::evolve)
* .limit(limit.bySteadyFitness(10))
* .limit(1000)
* .collect(EvolutionResult.toBestGenotype());
*
* System.out.println(String.format("Best Genotype: %s", best));
* }
* }
* }
*
*
* @since 3.1
*
* @param the gene type
* @param the fitness type
* @param start the evolution start
* @param evolution the evolution function
* @return a new {@code EvolutionStream} with the given {@code start} and
* {@code evolution} function
* @throws java.lang.NullPointerException if one of the arguments is
* {@code null}
*/
public static , C extends Comparable super C>>
EvolutionStream of(
final Supplier> start,
final Function super EvolutionStart, EvolutionResult> evolution
) {
return new EvolutionStreamImpl<>(start, evolution);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy