Skip to content

Commit

Permalink
Remove moveCountPruning in search.cpp
Browse files Browse the repository at this point in the history
The definition of moveCountPruning may cause confusion by implying that
the variable is unconstrained. However, once it is set to true, it
should not be reset to false, otherwise it would break the internal
logic of MovePicker.

Several patches have overlooked this constraint.

The implementation approach was suggested by Disservin.

No functional change
  • Loading branch information
MinetaS authored and PikaCat-OuO committed Nov 1, 2024
1 parent b95c384 commit 4776308
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 6 deletions.
4 changes: 3 additions & 1 deletion src/movepick.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -223,7 +223,7 @@ Move MovePicker::select(Pred filter) {
// This is the most important method of the MovePicker class. We emit one
// new pseudo-legal move on every call until there are no more moves left,
// picking the move with the highest score from a list of generated moves.
Move MovePicker::next_move(bool skipQuiets) {
Move MovePicker::next_move() {

auto quiet_threshold = [](Depth d) { return -3330 * d; };

Expand Down Expand Up @@ -329,4 +329,6 @@ Move MovePicker::next_move(bool skipQuiets) {
return Move::none(); // Silence warning
}

void MovePicker::skip_quiet_moves() { skipQuiets = true; }

} // namespace Stockfish
4 changes: 3 additions & 1 deletion src/movepick.h
Original file line number Diff line number Diff line change
Expand Up @@ -208,7 +208,8 @@ class MovePicker {
const PawnHistory*,
int);
MovePicker(const Position&, Move, int, const CapturePieceToHistory*);
Move next_move(bool skipQuiets = false);
Move next_move();
void skip_quiet_moves();

private:
template<PickType T, typename Pred>
Expand All @@ -230,6 +231,7 @@ class MovePicker {
int threshold;
Depth depth;
int ply;
bool skipQuiets = false;
ExtMove moves[MAX_MOVES];
};

Expand Down
8 changes: 4 additions & 4 deletions src/search.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -850,12 +850,11 @@ Value Search::Worker::search(

value = bestValue;

int moveCount = 0;
bool moveCountPruning = false;
int moveCount = 0;

// Step 12. Loop through all pseudo-legal moves until no moves remain
// or a beta cutoff occurs.
while ((move = mp.next_move(moveCountPruning)) != Move::none())
while ((move = mp.next_move()) != Move::none())
{
assert(move.is_ok());

Expand Down Expand Up @@ -901,7 +900,8 @@ Value Search::Worker::search(
if (!rootNode && pos.major_material(us) && bestValue > VALUE_MATED_IN_MAX_PLY)
{
// Skip quiet moves if movecount exceeds our FutilityMoveCount threshold (~8 Elo)
moveCountPruning = moveCount >= futility_move_count(improving, depth);
if (moveCount >= futility_move_count(improving, depth))
mp.skip_quiet_moves();

// Reduced depth of the next LMR search
int lmrDepth = newDepth - r;
Expand Down

0 comments on commit 4776308

Please sign in to comment.