X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=src%2Fsearch.cpp;h=ed1cdc7faa0187184d3a1ac14df6a2b7ab269d2e;hb=eba8925d810fe9c30db18038830d427c655cdd50;hp=0763cd37e31a9cdf98abf0d6c9e6a9b25f372dee;hpb=7daaf03b397f6ac2b6b9436b1b80054a2fea7c81;p=stockfish diff --git a/src/search.cpp b/src/search.cpp index 0763cd37..ed1cdc7f 100644 --- a/src/search.cpp +++ b/src/search.cpp @@ -238,14 +238,14 @@ namespace { Depth depth, int ply, int threadID); void sp_search(SplitPoint *sp, int threadID); void sp_search_pv(SplitPoint *sp, int threadID); - void init_search_stack(SearchStack ss); + void init_search_stack(SearchStack& ss); void init_search_stack(SearchStack ss[]); void init_node(const Position &pos, SearchStack ss[], int ply, int threadID); void update_pv(SearchStack ss[], int ply); void sp_update_pv(SearchStack *pss, SearchStack ss[], int ply); bool connected_moves(const Position &pos, Move m1, Move m2); bool move_is_killer(Move m, const SearchStack& ss); - Depth extension(const Position &pos, Move m, bool pvNode, bool check, bool singleReply, bool mateThreat); + Depth extension(const Position &pos, Move m, bool pvNode, bool check, bool singleReply, bool mateThreat, bool* extendable); bool ok_to_do_nullmove(const Position &pos); bool ok_to_prune(const Position &pos, Move m, Move threat, Depth d); bool ok_to_use_TT(const TTEntry* tte, Depth depth, Value beta, int ply); @@ -430,8 +430,8 @@ void think(const Position &pos, bool infinite, bool ponder, int side_to_move, TimeAdvantage = myTime - oppTime; if (!movesToGo) // Sudden death time control - { - if (increment) + { + if (myIncrement) { MaxSearchTime = myTime / 30 + myIncrement; AbsoluteMaxSearchTime = Max(myTime / 4, myIncrement - 100); @@ -778,7 +778,8 @@ namespace { << " currmovenumber " << i + 1 << std::endl; // Decide search depth for this move - ext = extension(pos, move, true, pos.move_is_check(move), false, false); + bool dummy; + ext = extension(pos, move, true, pos.move_is_check(move), false, false, &dummy); newDepth = (Iteration - 2) * OnePly + ext + InitialDepth; // Make the move, and search it @@ -795,7 +796,7 @@ namespace { if (Problem && StopOnPonderhit) StopOnPonderhit = false; - } + } else { value = -search(pos, ss, -alpha, newDepth, 1, true, 0); @@ -978,7 +979,8 @@ namespace { ss[ply].currentMoveCaptureValue = Value(0); // Decide the new search depth - Depth ext = extension(pos, move, true, moveIsCheck, singleReply, mateThreat); + bool extendable; + Depth ext = extension(pos, move, true, moveIsCheck, singleReply, mateThreat, &extendable); Depth newDepth = depth - OnePly + ext; // Make and search the move @@ -992,7 +994,7 @@ namespace { // Try to reduce non-pv search depth by one ply if move seems not problematic, // if the move fails high will be re-searched at full depth. if ( depth >= 2*OnePly - && ext == Depth(0) + && !extendable && moveCount >= LMRPVMoves && !moveIsCapture && !move_promotion(move) @@ -1080,7 +1082,7 @@ namespace { if (ok_to_history(pos, m)) // Only non capture moves are considered { update_history(pos, m, depth, movesSearched, moveCount); - update_killers(m, ss[ply]); + update_killers(m, ss[ply]); } TT.store(pos, value_to_tt(bestValue, ply), depth, m, VALUE_TYPE_LOWER); } @@ -1225,12 +1227,13 @@ namespace { movesSearched[moveCount++] = ss[ply].currentMove = move; // Decide the new search depth - Depth ext = extension(pos, move, false, moveIsCheck, singleReply, mateThreat); + bool extendable; + Depth ext = extension(pos, move, false, moveIsCheck, singleReply, mateThreat, &extendable); Depth newDepth = depth - OnePly + ext; // Futility pruning if ( useFutilityPruning - && ext == Depth(0) + && !extendable && !moveIsCapture && !moveIsPassedPawnPush && !move_promotion(move)) @@ -1261,7 +1264,7 @@ namespace { // Try to reduce non-pv search depth by one ply if move seems not problematic, // if the move fails high will be re-searched at full depth. if ( depth >= 2*OnePly - && ext == Depth(0) + && !extendable && moveCount >= LMRNonPVMoves && !moveIsCapture && !move_promotion(move) @@ -1430,7 +1433,6 @@ namespace { // Don't search captures and checks with negative SEE values if ( !isCheck && !move_promotion(move) - && !pvNode && (pos.midgame_value_of_piece_on(move_from(move)) > pos.midgame_value_of_piece_on(move_to(move))) && pos.see(move) < 0) @@ -1516,12 +1518,13 @@ namespace { ss[sp->ply].currentMove = move; // Decide the new search depth. - Depth ext = extension(pos, move, false, moveIsCheck, false, false); + bool extendable; + Depth ext = extension(pos, move, false, moveIsCheck, false, false, &extendable); Depth newDepth = sp->depth - OnePly + ext; // Prune? if ( useFutilityPruning - && ext == Depth(0) + && !extendable && !moveIsCapture && !moveIsPassedPawnPush && !move_promotion(move) @@ -1535,7 +1538,7 @@ namespace { // Try to reduce non-pv search depth by one ply if move seems not problematic, // if the move fails high will be re-searched at full depth. - if ( ext == Depth(0) + if ( !extendable && moveCount >= LMRNonPVMoves && !moveIsCapture && !moveIsPassedPawnPush @@ -1633,7 +1636,8 @@ namespace { ss[sp->ply].currentMove = move; // Decide the new search depth. - Depth ext = extension(pos, move, true, moveIsCheck, false, false); + bool extendable; + Depth ext = extension(pos, move, true, moveIsCheck, false, false, &extendable); Depth newDepth = sp->depth - OnePly + ext; // Make and search the move. @@ -1642,7 +1646,7 @@ namespace { // Try to reduce non-pv search depth by one ply if move seems not problematic, // if the move fails high will be re-searched at full depth. - if ( ext == Depth(0) + if ( !extendable && moveCount >= LMRPVMoves && !moveIsCapture && !moveIsPassedPawnPush @@ -1879,7 +1883,7 @@ namespace { // init_search_stack() initializes a search stack at the beginning of a // new search from the root. - void init_search_stack(SearchStack ss) { + void init_search_stack(SearchStack& ss) { ss.pv[0] = MOVE_NONE; ss.pv[1] = MOVE_NONE; @@ -1887,7 +1891,7 @@ namespace { ss.threatMove = MOVE_NONE; ss.reduction = Depth(0); for (int j = 0; j < KILLER_MAX; j++) - ss.killers[j] = MOVE_NONE; + ss.killers[j] = MOVE_NONE; } void init_search_stack(SearchStack ss[]) { @@ -1924,7 +1928,6 @@ namespace { NodesSincePoll = 0; } } - ss[ply].pv[ply] = ss[ply].pv[ply+1] = ss[ply].currentMove = MOVE_NONE; ss[ply+2].mateKiller = MOVE_NONE; ss[ply].threatMove = MOVE_NONE; @@ -2038,7 +2041,7 @@ namespace { // killer moves of that ply. bool move_is_killer(Move m, const SearchStack& ss) { - + const Move* k = ss.killers; for (int i = 0; i < KILLER_MAX; i++, k++) if (*k == m) @@ -2053,9 +2056,10 @@ namespace { // particular) are searched with bigger depth than ordinary moves. Depth extension(const Position &pos, Move m, bool pvNode, - bool check, bool singleReply, bool mateThreat) { + bool check, bool singleReply, bool mateThreat, bool* extendable) { Depth result = Depth(0); + *extendable = check || singleReply || mateThreat; if (check) result += CheckExtension[pvNode]; @@ -2063,26 +2067,37 @@ namespace { if (singleReply) result += SingleReplyExtension[pvNode]; + if (mateThreat) + result += MateThreatExtension[pvNode]; + if (pos.move_is_pawn_push_to_7th(m)) + { result += PawnPushTo7thExtension[pvNode]; - + *extendable = true; + } if (pos.move_is_passed_pawn_push(m)) + { result += PassedPawnExtension[pvNode]; - - if (mateThreat) - result += MateThreatExtension[pvNode]; + *extendable = true; + } if ( pos.midgame_value_of_piece_on(move_to(m)) >= RookValueMidgame && ( pos.non_pawn_material(WHITE) + pos.non_pawn_material(BLACK) - pos.midgame_value_of_piece_on(move_to(m)) == Value(0)) && !move_promotion(m)) + { result += PawnEndgameExtension[pvNode]; - + *extendable = true; + } + if ( pvNode && pos.move_is_capture(m) && pos.type_of_piece_on(move_to(m)) != PAWN && pos.see(m) >= 0) + { result += OnePly/2; + *extendable = true; + } return Min(result, OnePly); } @@ -2205,9 +2220,9 @@ namespace { return; for (int i = KILLER_MAX - 1; i > 0; i--) - ss.killers[i] = ss.killers[i - 1]; - - ss.killers[0] = m; + ss.killers[i] = ss.killers[i - 1]; + + ss.killers[0] = m; } // fail_high_ply_1() checks if some thread is currently resolving a fail