/*
$Id$
Copyright (C) 2006-2007 by David Cotton
This program is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free Software
Foundation; either version 2 of the License, or (at your option) any later
version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License along with
this program; if not, write to the Free Software Foundation, Inc., 51 Franklin
Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
package fr.free.jchecs.ai;
import java.util.Comparator;
import fr.free.jchecs.core.Move;
import fr.free.jchecs.core.MoveGenerator;
/**
* Interface présentée par les moteurs d'IA pour le jeu d'échecs.
*
* @author David Cotton
*/
public interface Engine
{
/**
* Renvoi le temps total passé en traitement par le moteur.
*
* @return Temps total de traitement par le moteur (en ms).
*/
long getElapsedTime();
/**
* Renvoi le nombre total de demi-coups évalués par le moteur.
*
* @return Nombre total de demi-coups évalués par le moteur.
*/
int getHalfmoveCount();
/**
* Renvoi la fonction d'évaluation utilisée par le moteur.
*
* @return Fonction d'évaluation utilisée.
*/
Heuristic getHeuristic();
/**
* Renvoi la limite haute de la profondeur de recherche supportées par le moteur.
*
* @return Limite haute de la profondeur de recherche (>= getMinimalSearchDepth()).
*/
int getMaximalSearchDepth();
/**
* Renvoi la limite basse de la profondeur de recherche supportées par le moteur.
*
* @return Limite basse de la profondeur de recherche (>= 1).
*/
int getMinimalSearchDepth();
/**
* Recherche un mouvement répondant à un état de l'échiquier.
*
* @param pEtat Etat de l'échiquier.
* @return Mouvement trouvé.
*/
Move getMoveFor(final MoveGenerator pEtat);
/**
* Renvoi la fonction de tri des mouvements.
*
* @return Fonction de tri des mouvements.
*/
Comparator<Move> getMoveSorter();
/**
* Renvoi le score obtenu par le dernier mouvement calculé.
*
* @return Score du dernier mouvement.
*/
int getScore();
/**
* Renvoi la valeur limite de la profondeur de recherche (en demi-coups).
*
* @return Limite de la profondeur de recherche ([getMinimalSearchDepth(),
* getMaximalSearchDepth()]).
*/
int getSearchDepthLimit();
/**
* Indique si l'utilisation de la bibliothèque d'ouvertures est activée.
*
* @return "true" si les ouvertures sont utilisées, "false" sinon.
*/
boolean isOpeningsEnabled();
/**
* Modifie la fonction d'évaluation utilisée par le moteur.
*
* @param pHeuristique Nouvelle fonction d'évaluation à utiliser.
*/
void setHeuristic(final Heuristic pHeuristique);
/**
* Modifie la fonction d'ordenancement des mouvements.
*
* @param pComparateur Nouvelle fonction de tri des mouvements.
*/
void setMoveSorter(final Comparator<Move> pComparateur);
/**
* Active / désactive l'utilisation de la bibliothèque d'ouvertures.
*
* @param pActif A "true" pour activer l'utilisation des ouvertures, à "false" sinon.
*/
void setOpeningsEnabled(final boolean pActif);
/**
* Aliment la valeur de la limite de la profondeur de recherche (en demi-coups).
*
* @param pLimite Limite de la profondeur de recherche ([getMinimalSearchDepth(),
* getMaximalSearchDepth()]).
*/
void setSearchDepthLimit(final int pLimite);
}