/*
Stockfish, a UCI chess playing engine derived from Glaurung 2.1
Copyright (C) 2004-2008 Tord Romstad (Glaurung author)
- Copyright (C) 2008-2014 Marco Costalba, Joona Kiiski, Tord Romstad
+ Copyright (C) 2008-2015 Marco Costalba, Joona Kiiski, Tord Romstad
+ Copyright (C) 2015-2016 Marco Costalba, Joona Kiiski, Gary Linscott, Tord Romstad
Stockfish is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
#ifndef TIMEMAN_H_INCLUDED
#define TIMEMAN_H_INCLUDED
-/// The TimeManager class computes the optimal time to think depending on the
-/// maximum available time, the game move number and other parameters.
+#include "misc.h"
+#include "search.h"
+#include "thread.h"
-class TimeManager {
+/// The TimeManagement class computes the optimal time to think depending on
+/// the maximum available time, the game move number and other parameters.
+
+class TimeManagement {
public:
- void init(const Search::LimitsType& limits, int currentPly, Color us);
- void pv_instability(double bestMoveChanges);
- int available_time() const { return optimumSearchTime + unstablePVExtraTime; }
- int maximum_time() const { return maximumSearchTime; }
+ void init(Search::LimitsType& limits, Color us, int ply);
+ int optimum() const { return optimumTime; }
+ int maximum() const { return maximumTime; }
+ int elapsed() const { return int(Search::Limits.npmsec ? Threads.nodes_searched() : now() - startTime); }
+
+ int64_t availableNodes; // When in 'nodes as time' mode
private:
- int optimumSearchTime;
- int maximumSearchTime;
- int unstablePVExtraTime;
+ TimePoint startTime;
+ int optimumTime;
+ int maximumTime;
};
+extern TimeManagement Time;
+
#endif // #ifndef TIMEMAN_H_INCLUDED