X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Ftimeman.cpp;h=b8f839637ce2ef868a2d409e62c93faaddbfa5dd;hp=92d88e73cb0445f723694f67628afbb99ef361d0;hb=55df3fa2d7631ed67e46f9433aa7f3a71c18e5e7;hpb=2a21543c88f82a64ee48d00d706db102c0c4637d diff --git a/src/timeman.cpp b/src/timeman.cpp index 92d88e73..b8f83963 100644 --- a/src/timeman.cpp +++ b/src/timeman.cpp @@ -72,7 +72,7 @@ namespace { enum TimeType { OptimumTime, MaxTime }; template - int remaining(int myTime, int movesToGo, int fullMoveNumber); + int remaining(int myTime, int movesToGo, int fullMoveNumber, int slowMover); } @@ -83,7 +83,7 @@ void TimeManager::pv_instability(int curChanges, int prevChanges) { } -void TimeManager::init(const Search::LimitsType& limits, int currentPly) +void TimeManager::init(const Search::LimitsType& limits, int currentPly, Color us) { /* We support four different kind of time controls: @@ -107,25 +107,26 @@ void TimeManager::init(const Search::LimitsType& limits, int currentPly) int emergencyBaseTime = Options["Emergency Base Time"]; int emergencyMoveTime = Options["Emergency Move Time"]; int minThinkingTime = Options["Minimum Thinking Time"]; + int slowMover = Options["Slow Mover"]; // Initialize to maximum values but unstablePVExtraTime that is reset unstablePVExtraTime = 0; - optimumSearchTime = maximumSearchTime = limits.time; + optimumSearchTime = maximumSearchTime = limits.time[us]; // We calculate optimum time usage for different hypothetic "moves to go"-values and choose the // minimum of calculated search time values. Usually the greatest hypMTG gives the minimum values. - for (hypMTG = 1; hypMTG <= (limits.movesToGo ? std::min(limits.movesToGo, MoveHorizon) : MoveHorizon); hypMTG++) + for (hypMTG = 1; hypMTG <= (limits.movestogo ? std::min(limits.movestogo, MoveHorizon) : MoveHorizon); hypMTG++) { // Calculate thinking time for hypothetic "moves to go"-value - hypMyTime = limits.time - + limits.increment * (hypMTG - 1) + hypMyTime = limits.time[us] + + limits.inc[us] * (hypMTG - 1) - emergencyBaseTime - emergencyMoveTime * std::min(hypMTG, emergencyMoveHorizon); hypMyTime = std::max(hypMyTime, 0); - t1 = minThinkingTime + remaining(hypMyTime, hypMTG, currentPly); - t2 = minThinkingTime + remaining(hypMyTime, hypMTG, currentPly); + t1 = minThinkingTime + remaining(hypMyTime, hypMTG, currentPly, slowMover); + t2 = minThinkingTime + remaining(hypMyTime, hypMTG, currentPly, slowMover); optimumSearchTime = std::min(optimumSearchTime, t1); maximumSearchTime = std::min(maximumSearchTime, t2); @@ -142,12 +143,12 @@ void TimeManager::init(const Search::LimitsType& limits, int currentPly) namespace { template - int remaining(int myTime, int movesToGo, int currentPly) + int remaining(int myTime, int movesToGo, int currentPly, int slowMover) { const float TMaxRatio = (T == OptimumTime ? 1 : MaxRatio); const float TStealRatio = (T == OptimumTime ? 0 : StealRatio); - int thisMoveImportance = move_importance(currentPly); + int thisMoveImportance = move_importance(currentPly) * slowMover / 100; int otherMovesImportance = 0; for (int i = 1; i < movesToGo; i++)