Class MaF9

All Implemented Interfaces:
AutoCloseable, Problem, AnalyticalProblem

public class MaF9 extends AbstractProblem implements AnalyticalProblem
The MaF9 test problem. This problem exhibits the following properties:
  • Linear Pareto front
  • Degenerate

MaF9 is unique in that it features a repair operator. As discussed in the cited paper, for polygons with 5 or more vertices, the lines forming the polygon can intersect outside the polygon, causing additional points to be non-dominated with respect to points inside the polygon. The repair operator simply resamples the point at a new, random location.

  • Constructor Details

    • MaF9

      public MaF9(int numberOfObjectives)
      Constructs an MaF9 test problem with the specified number of objectives.
      Parameters:
      numberOfObjectives - the number of objectives for this problem
  • Method Details

    • evaluate

      public void evaluate(Solution solution)
      Description copied from interface: Problem
      Evaluates the solution, updating the solution's objectives in place. Algorithms must explicitly call this method when appropriate to evaluate new solutions or reevaluate modified solutions.
      Specified by:
      evaluate in interface Problem
      Parameters:
      solution - the solution to be evaluated
    • newSolution

      public Solution newSolution()
      Description copied from interface: Problem
      Returns a new solution for this problem. Implementations must initialize the variables so that the valid range of values is defined, but typically leave the actual value at a default or undefined state.
      Specified by:
      newSolution in interface Problem
      Returns:
      a new solution for this problem
    • generate

      public Solution generate()
      Description copied from interface: AnalyticalProblem
      Returns a randomly-generated solution using the analytical solution to this problem. The exact behavior of this method depends on the implementation, but in general (1) the solutions should be non-dominated and (2) spread uniformly across the Pareto front.

      It is not always possible to guarantee these conditions. For example, a discontinuous / disconnected Pareto surface could generate dominated solutions, and a biased problem could result in non-uniform distributions. Therefore, we recommend callers filter solutions through a NondominatedPopulation, in particular one that maintains a spread of solutions.

      Furthermore, some implementations may not provide the corresponding decision variables for the solution. These implementations should indicate this by returning a solution with 0 decision variables.

      Specified by:
      generate in interface AnalyticalProblem
      Returns:
      a randomly-generated Pareto optimal solution to this problem