001/*
002 * Java Genetic Algorithm Library (jenetics-7.2.0).
003 * Copyright (c) 2007-2023 Franz Wilhelmstötter
004 *
005 * Licensed under the Apache License, Version 2.0 (the "License");
006 * you may not use this file except in compliance with the License.
007 * You may obtain a copy of the License at
008 *
009 *      http://www.apache.org/licenses/LICENSE-2.0
010 *
011 * Unless required by applicable law or agreed to in writing, software
012 * distributed under the License is distributed on an "AS IS" BASIS,
013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014 * See the License for the specific language governing permissions and
015 * limitations under the License.
016 *
017 * Author:
018 *    Franz Wilhelmstötter (franz.wilhelmstoetter@gmail.com)
019 */
020package io.jenetics.ext;
021
022import io.jenetics.Gene;
023import io.jenetics.engine.Engine.Builder;
024import io.jenetics.engine.Engine.Setup;
025import io.jenetics.internal.util.Requires;
026
027/**
028 * Configures the evolution engine to execute the
029 * <a href="https://en.wikipedia.org/wiki/Weasel_program">Weasel program</a>
030 * algorithm.
031 *
032 * <pre>{@code
033 * final Engine<CharacterGene, Integer> engine = Engine.builder(problem)
034 *     .setup(new WeaselProgram<>())
035 *     .build();
036 * }</pre>
037 *
038 * @see WeaselSelector
039 * @see WeaselMutator
040 * @see io.jenetics.engine.Engine.Builder#setup(Setup)
041 *
042 * @param <G> the gene type
043 * @param <C> the fitness result type
044 *
045 * @author <a href="mailto:franz.wilhelmstoetter@gmail.com">Franz Wilhelmstötter</a>
046 * @version 6.0
047 * @since 6.0
048 */
049public final class WeaselProgram<
050        G extends Gene<?, G>,
051        C extends Comparable<? super C>
052>
053        implements Setup<G, C>
054{
055
056        private final double _mutationProbability;
057
058        /**
059         * Create a new weasel program setup with the give mutation probability.
060         *
061         * @param mutationProbability the mutation probability
062         * @throws IllegalArgumentException if the {@code mutationProbability} is
063         *         not in the valid range of {@code [0, 1]}.
064         */
065        public WeaselProgram(final double mutationProbability) {
066                _mutationProbability = Requires.probability(mutationProbability);
067        }
068
069        /**
070         * Create a new weasel program setup with the <em>default</em> mutation
071         * probability of {@code 0.05}.
072         */
073        public WeaselProgram() {
074                this(0.05);
075        }
076
077        @Override
078        public void apply(final Builder<G, C> builder) {
079                builder
080                        .selector(new WeaselSelector<>())
081                        .offspringFraction(1)
082                        .alterers(new WeaselMutator<>(_mutationProbability));
083        }
084
085}