/* Copyright 2009-2016 David Hadka * * This file is part of the MOEA Framework. * * The MOEA Framework is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or (at your * option) any later version. * * The MOEA Framework is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public * License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with the MOEA Framework. If not, see <http://www.gnu.org/licenses/>. */ package org.moeaframework.core; /** * Evaluates a population and assigns fitness values to its solutions. This * class is intended to be used by indicator-based algorithms. */ public interface FitnessEvaluator { /** * Attribute key for the fitness of a solution. */ public static final String FITNESS_ATTRIBUTE = "fitness"; /** * Evaluates the solutions in the specified population assigning the * {@code FITNESS_ATTRIBUTE} attribute. * * @param population the population to be evaluated */ public void evaluate(Population population); /** * Returns {@code true} if larger fitness values are preferred; otherwise * smaller fitness values are preferred. * * @return {@code true} if larger fitness values are preferred; otherwise * smaller fitness values are preferred */ public boolean areLargerValuesPreferred(); }