X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmovepick.cpp;h=a7e5bdac78ba0a9bf17304de41380cd667a9f5f6;hp=264d941f602b45368c5871afa87e6a6d16691da0;hb=afae86bfb49471113f14f9f0f56f2a08d052242f;hpb=9f626725aeb770a38be093a9a47a461053cf7008 diff --git a/src/movepick.cpp b/src/movepick.cpp index 264d941f..a7e5bdac 100644 --- a/src/movepick.cpp +++ b/src/movepick.cpp @@ -18,11 +18,6 @@ along with this program. If not, see . */ - -//// -//// Includes -//// - #include #include "history.h" @@ -31,11 +26,6 @@ #include "search.h" #include "value.h" - -//// -//// Local definitions -//// - namespace { enum MovegenPhase { @@ -51,18 +41,13 @@ namespace { }; CACHE_LINE_ALIGNMENT - const int MainSearchPhaseTable[] = { PH_TT_MOVES, PH_GOOD_CAPTURES, PH_KILLERS, PH_NONCAPTURES, PH_BAD_CAPTURES, PH_STOP}; - const int EvasionsPhaseTable[] = { PH_TT_MOVES, PH_EVASIONS, PH_STOP}; - const int QsearchWithChecksPhaseTable[] = { PH_TT_MOVES, PH_QCAPTURES, PH_QCHECKS, PH_STOP}; - const int QsearchWithoutChecksPhaseTable[] = { PH_TT_MOVES, PH_QCAPTURES, PH_STOP}; + const uint8_t MainSearchPhaseTable[] = { PH_TT_MOVES, PH_GOOD_CAPTURES, PH_KILLERS, PH_NONCAPTURES, PH_BAD_CAPTURES, PH_STOP}; + const uint8_t EvasionsPhaseTable[] = { PH_TT_MOVES, PH_EVASIONS, PH_STOP}; + const uint8_t QsearchWithChecksPhaseTable[] = { PH_TT_MOVES, PH_QCAPTURES, PH_QCHECKS, PH_STOP}; + const uint8_t QsearchWithoutChecksPhaseTable[] = { PH_TT_MOVES, PH_QCAPTURES, PH_STOP}; } -//// -//// Functions -//// - - /// Constructor for the MovePicker class. Apart from the position for which /// it is asked to pick legal moves, MovePicker also wants some information /// to help it to return the presumably good moves first, to decide which @@ -77,21 +62,22 @@ MovePicker::MovePicker(const Position& p, Move ttm, Depth d, const History& h, badCaptureThreshold = 0; badCaptures = moves + MOVES_MAX; + assert(d > DEPTH_ZERO); + pinned = p.pinned_pieces(pos.side_to_move()); - if (ss && !p.is_check()) + if (p.is_check()) + { + ttMoves[1].move = killers[0].move = killers[1].move = MOVE_NONE; + phasePtr = EvasionsPhaseTable; + } + else { ttMoves[1].move = (ss->mateKiller == ttm) ? MOVE_NONE : ss->mateKiller; searchTT |= ttMoves[1].move; killers[0].move = ss->killers[0]; killers[1].move = ss->killers[1]; - } else - ttMoves[1].move = killers[0].move = killers[1].move = MOVE_NONE; - if (p.is_check()) - phasePtr = EvasionsPhaseTable; - else if (d > DEPTH_ZERO) - { // Consider sligtly negative captures as good if at low // depth and far from beta. if (ss && ss->eval < beta - PawnValueMidgame && d < 3 * ONE_PLY) @@ -99,7 +85,24 @@ MovePicker::MovePicker(const Position& p, Move ttm, Depth d, const History& h, phasePtr = MainSearchPhaseTable; } - else if (d == DEPTH_ZERO) + + phasePtr += int(!searchTT) - 1; + go_next_phase(); +} + +MovePicker::MovePicker(const Position& p, Move ttm, Depth d, const History& h) + : pos(p), H(h) { + int searchTT = ttm; + ttMoves[0].move = ttm; + ttMoves[1].move = MOVE_NONE; + + assert(d <= DEPTH_ZERO); + + pinned = p.pinned_pieces(pos.side_to_move()); + + if (p.is_check()) + phasePtr = EvasionsPhaseTable; + else if (d >= DEPTH_QS_CHECKS) phasePtr = QsearchWithChecksPhaseTable; else { @@ -132,7 +135,7 @@ void MovePicker::go_next_phase() { return; case PH_GOOD_CAPTURES: - lastMove = generate_captures(pos, moves); + lastMove = generate(pos, moves); score_captures(); return; @@ -142,7 +145,7 @@ void MovePicker::go_next_phase() { return; case PH_NONCAPTURES: - lastMove = generate_noncaptures(pos, moves); + lastMove = generate(pos, moves); score_noncaptures(); sort_moves(moves, lastMove, &lastGoodNonCapture); return; @@ -156,17 +159,17 @@ void MovePicker::go_next_phase() { case PH_EVASIONS: assert(pos.is_check()); - lastMove = generate_evasions(pos, moves); + lastMove = generate(pos, moves); score_evasions(); return; case PH_QCAPTURES: - lastMove = generate_captures(pos, moves); + lastMove = generate(pos, moves); score_captures(); return; case PH_QCHECKS: - lastMove = generate_non_capture_checks(pos, moves); + lastMove = generate(pos, moves); return; case PH_STOP: @@ -247,10 +250,10 @@ void MovePicker::score_evasions() { { m = cur->move; if ((seeScore = pos.see_sign(m)) < 0) - cur->score = seeScore - HistoryMax; // Be sure are at the bottom + cur->score = seeScore - History::MaxValue; // Be sure we are at the bottom else if (pos.move_is_capture(m)) cur->score = pos.midgame_value_of_piece_on(move_to(m)) - - pos.type_of_piece_on(move_from(m)) + HistoryMax; + - pos.type_of_piece_on(move_from(m)) + History::MaxValue; else cur->score = H.value(pos.piece_on(move_from(m)), move_to(m)); } @@ -313,7 +316,7 @@ Move MovePicker::get_next_move() { // Sort negative scored moves only when we get there if (curMove == lastGoodNonCapture) - insertion_sort(lastGoodNonCapture, lastMove); + insertion_sort(lastGoodNonCapture, lastMove); move = (curMove++)->move; if ( move != ttMoves[0].move @@ -354,4 +357,3 @@ Move MovePicker::get_next_move() { go_next_phase(); } } -