/* 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; /** * Interface used to implement conditions for when an algorithm should * terminate. The {@code initialize} method is invoked when the algorithm is * first created to collect any initial conditions, such as the starting time, * and {@code shouldTerminate} is invoked every step to check if the algorithm * should terminate. */ public interface TerminationCondition { /** * Invoked when the algorithm is created to collect any initial * conditions. Note that the algorithm may not have been initialized at * this point. * * @param algorithm the algorithm */ public void initialize(Algorithm algorithm); /** * Invoked after every step to check if the algorithm should terminate. * * @param algorithm the algorithm * @return {@code true} if the algorithm should terminate; {@code false} * otherwise */ public boolean shouldTerminate(Algorithm algorithm); }