Package org.moeaframework.algorithm
Class EpsilonMOEA
java.lang.Object
org.moeaframework.algorithm.AbstractAlgorithm
org.moeaframework.algorithm.AbstractEvolutionaryAlgorithm
org.moeaframework.algorithm.EpsilonMOEA
- All Implemented Interfaces:
Algorithm
,EpsilonBoxEvolutionaryAlgorithm
,EvolutionaryAlgorithm
,Extensible
,Configurable
,Named
,Stateful
public class EpsilonMOEA
extends AbstractEvolutionaryAlgorithm
implements EpsilonBoxEvolutionaryAlgorithm
Implementation of the ε-MOEA algorithm. The ε-MOEA is a steady-state algorithm, meaning only one
individual in the population is evolved per step, and uses an ε-dominance archive to maintain a well-spread
set of Pareto-optimal solutions.
References:
- Deb et al. "A Fast Multi-Objective Evolutionary Algorithm for Finding Well-Spread Pareto-Optimal Solutions." KanGAL Report No 2003002. Feb 2003.
-
Field Summary
Fields inherited from class org.moeaframework.algorithm.AbstractAlgorithm
initialized, numberOfEvaluations, problem, terminated
-
Constructor Summary
ConstructorDescriptionEpsilonMOEA
(Problem problem) Constructs the ε-MOEA algorithm with default settings.EpsilonMOEA
(Problem problem, int initialPopulationSize, Population population, EpsilonBoxDominanceArchive archive, Selection selection, Variation variation, Initialization initialization) Constructs the ε-MOEA algorithm with the specified components.EpsilonMOEA
(Problem problem, int initialPopulationSize, Population population, EpsilonBoxDominanceArchive archive, Selection selection, Variation variation, Initialization initialization, DominanceComparator dominanceComparator) Constructs the ε-MOEA algorithm with the specified components. -
Method Summary
Modifier and TypeMethodDescriptionprotected void
addToPopulation
(Solution newSolution) Adds the new solution to the population if is non-dominated with the current population, removing either a randomly-selected dominated solution or a non-dominated solution.void
applyConfiguration
(TypedProperties properties) Applies the properties to this instance.Returns the current non-dominated archive of the best solutions generated by this evolutionary algorithm, ornull
if no archive is used.Gets the current configuration of this instance.getName()
Returns the name of this algorithm.void
iterate()
Performs one iteration of the algorithm.void
setArchive
(EpsilonBoxDominanceArchive archive) Sets the archive used by this algorithm.void
setInitialPopulationSize
(int initialPopulationSize) Sets the initial population size.void
setVariation
(Variation variation) Replaces the variation operator to be used by this algorithm.Methods inherited from class org.moeaframework.algorithm.AbstractEvolutionaryAlgorithm
getInitialization, getInitialPopulationSize, getPopulation, getResult, getVariation, initialize, loadState, saveState, setArchive, setInitialization, setPopulation
Methods inherited from class org.moeaframework.algorithm.AbstractAlgorithm
assertNotInitialized, evaluate, getExtensions, getNumberOfEvaluations, getProblem, isInitialized, isTerminated, step, terminate
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.moeaframework.algorithm.Algorithm
evaluate, evaluateAll, evaluateAll, getNumberOfEvaluations, getProblem, getResult, initialize, isInitialized, isTerminated, run, run, step, terminate
Methods inherited from interface org.moeaframework.algorithm.EvolutionaryAlgorithm
getPopulation
Methods inherited from interface org.moeaframework.algorithm.extension.Extensible
addExtension, getExtensions, removeExtension
-
Constructor Details
-
EpsilonMOEA
Constructs the ε-MOEA algorithm with default settings.- Parameters:
problem
- the problem
-
EpsilonMOEA
public EpsilonMOEA(Problem problem, int initialPopulationSize, Population population, EpsilonBoxDominanceArchive archive, Selection selection, Variation variation, Initialization initialization) Constructs the ε-MOEA algorithm with the specified components.- Parameters:
problem
- the problem being solvedinitialPopulationSize
- the initial population sizepopulation
- the population used to store solutionsarchive
- the archive used to store the resultselection
- the selection operatorvariation
- the variation operatorinitialization
- the initialization method
-
EpsilonMOEA
public EpsilonMOEA(Problem problem, int initialPopulationSize, Population population, EpsilonBoxDominanceArchive archive, Selection selection, Variation variation, Initialization initialization, DominanceComparator dominanceComparator) Constructs the ε-MOEA algorithm with the specified components.- Parameters:
problem
- the problem being solvedinitialPopulationSize
- the initial population sizepopulation
- the population used to store solutionsarchive
- the archive used to store the resultselection
- the selection operatorvariation
- the variation operatorinitialization
- the initialization methoddominanceComparator
- the dominance comparator used by theaddToPopulation(org.moeaframework.core.Solution)
method
-
-
Method Details
-
getName
Description copied from interface:Algorithm
Returns the name of this algorithm. Whenever possible, this name should match the name recognized byAlgorithmFactory
. -
iterate
public void iterate()Description copied from class:AbstractAlgorithm
Performs one iteration of the algorithm. This method should be overridden by implementations to perform each logical iteration of the algorithm.- Specified by:
iterate
in classAbstractAlgorithm
-
addToPopulation
Adds the new solution to the population if is non-dominated with the current population, removing either a randomly-selected dominated solution or a non-dominated solution.- Parameters:
newSolution
- the new solution being added to the population
-
getArchive
Description copied from interface:EvolutionaryAlgorithm
Returns the current non-dominated archive of the best solutions generated by this evolutionary algorithm, ornull
if no archive is used.- Specified by:
getArchive
in interfaceEpsilonBoxEvolutionaryAlgorithm
- Specified by:
getArchive
in interfaceEvolutionaryAlgorithm
- Overrides:
getArchive
in classAbstractEvolutionaryAlgorithm
- Returns:
- the current non-dominated archive of the best solutions generated by this evolutionary algorithm,
or
null
if no archive is used
-
setArchive
Sets the archive used by this algorithm. This value can not be set after initialization.- Parameters:
archive
- the archive
-
setVariation
Description copied from class:AbstractEvolutionaryAlgorithm
Replaces the variation operator to be used by this algorithm.- Overrides:
setVariation
in classAbstractEvolutionaryAlgorithm
- Parameters:
variation
- the variation operator
-
setInitialPopulationSize
public void setInitialPopulationSize(int initialPopulationSize) Description copied from class:AbstractEvolutionaryAlgorithm
Sets the initial population size. This value can not be set after initialization.- Overrides:
setInitialPopulationSize
in classAbstractEvolutionaryAlgorithm
- Parameters:
initialPopulationSize
- the initial population size
-
applyConfiguration
Description copied from interface:Configurable
Applies the properties to this instance. It is strongly recommended to apply a configuration immediately after creating the instance, as some properties can not be changed after the class is used. Exceptions may be thrown if attempting to set such properties.After calling this method, we encourage users to call
TypedProperties.warnIfUnaccessedProperties()
to verify all properties were processed. This can identify simple mistakes like typos.If overriding this method, properties should only be updated if a new value is provided. Additionally, if updating any
Configurable
objects inside this object, they should be updated before callingsuper.applyConfiguration(properties)
.- Specified by:
applyConfiguration
in interfaceConfigurable
- Parameters:
properties
- the user-defined properties
-
getConfiguration
Description copied from interface:Configurable
Gets the current configuration of this instance. In theory, these properties should be able to create a duplicate instance. Note however, they are unlikely to behave identically due to random numbers and other transient fields.- Specified by:
getConfiguration
in interfaceConfigurable
- Returns:
- the properties defining this instance
-