// NOTE: works also for extinction chess because depth is 3...
getComputerMove()
{
- this.shouldReturn = false;
const maxeval = VariantRules.INFINITY;
const color = this.turn;
// Some variants may show a bigger moves list to the human (Switching),
candidates.push(j);
let currentBest = moves1[_.sample(candidates, 1)];
+ // From here, depth >= 3: may take a while, so we control time
+ const timeStart = Date.now();
+
// Skip depth 3+ if we found a checkmate (or if we are checkmated in 1...)
if (VariantRules.SEARCH_DEPTH >= 3
&& Math.abs(moves1[0].eval) < VariantRules.THRESHOLD_MATE)
{
for (let i=0; i<moves1.length; i++)
{
- if (this.shouldReturn)
- return currentBest; //depth-2, minimum
+ if (Date.now()-timeStart >= 5000) //more than 5 seconds
+ return currentBest; //depth 2 at least
this.play(moves1[i]);
// 0.1 * oldEval : heuristic to avoid some bad moves (not all...)
moves1[i].eval = 0.1*moves1[i].eval +
incheck: [],
pgnTxt: "",
expert: (getCookie("expert") === "1" ? true : false),
- gameId: "", //used to limit computer moves' time
};
},
render(h) {
}
return;
}
- this.gameId = getRandString();
this.vr = new VariantRules(fen, moves || []);
this.score = "*";
this.pgnTxt = ""; //redundant with this.score = "*", but cleaner
},
playComputerMove: function() {
const timeStart = Date.now();
- // We use moves' count to know if search finished:
- const nbMoves = this.vr.moves.length;
- const gameId = this.gameId; //to know if game was reset before timer end
- setTimeout(
- () => {
- if (gameId != this.gameId)
- return; //game stopped
- const L = this.vr.moves.length;
- if (nbMoves == L || !this.vr.moves[L-1].notation) //move search didn't finish
- this.vr.shouldReturn = true;
- }, 5000);
const compMove = this.vr.getComputerMove();
// (first move) HACK: avoid selecting elements before they appear on page:
const delay = Math.max(500-(Date.now()-timeStart), 0);