Skip to content

Commit

Permalink
Reformat and rename hash_after_move()
Browse files Browse the repository at this point in the history
Align to standard coding style and properly use
enum types. Rename while there.

No functional change.
  • Loading branch information
mcostalba authored and zamar committed Oct 4, 2014
1 parent 4b926f2 commit 7482934
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 19 deletions.
33 changes: 19 additions & 14 deletions src/position.cpp
Expand Up @@ -1015,22 +1015,27 @@ void Position::undo_null_move() {
sideToMove = ~sideToMove;
}

// Position::hash_after_move() updates the hash key needed for the speculative prefetch.
// It doesn't recognize special moves like castling, en-passant and promotions.
Key Position::hash_after_move(Move m) const {

int from = from_sq(m);
int to = to_sq(m);
Piece p = board[from];
Piece capP = board[to];
Key ret = st->key ^ Zobrist::side;
if (capP != NO_PIECE)
ret ^= Zobrist::psq[color_of(capP)][type_of(capP)][to];
ret ^= Zobrist::psq[color_of(p)][type_of(p)][to];
ret ^= Zobrist::psq[color_of(p)][type_of(p)][from];
return ret;

/// Position::key_after() computes the new hash key after the given moven. Needed
/// for speculative prefetch. It doesn't recognize special moves like castling,
/// en-passant and promotions.

Key Position::key_after(Move m) const {

Color us = sideToMove;
Square from = from_sq(m);
Square to = to_sq(m);
PieceType pt = type_of(piece_on(from));
PieceType captured = type_of(piece_on(to));
Key k = st->key ^ Zobrist::side;

if (captured)
k ^= Zobrist::psq[~us][captured][to];

return k ^ Zobrist::psq[us][pt][to] ^ Zobrist::psq[us][pt][from];
}


/// Position::see() is a static exchange evaluator: It tries to estimate the
/// material gain or loss resulting from a move.

Expand Down
2 changes: 1 addition & 1 deletion src/position.h
Expand Up @@ -139,14 +139,14 @@ class Position {
void undo_move(Move m);
void do_null_move(StateInfo& st);
void undo_null_move();
Key hash_after_move(Move m) const;

// Static exchange evaluation
Value see(Move m) const;
Value see_sign(Move m) const;

// Accessing hash keys
Key key() const;
Key key_after(Move m) const;
Key exclusion_key() const;
Key pawn_key() const;
Key material_key() const;
Expand Down
8 changes: 4 additions & 4 deletions src/search.cpp
Expand Up @@ -788,8 +788,8 @@ namespace {
}
}

// Speculative prefetch
prefetch((char*)TT.first_entry(pos.hash_after_move(move)));
// Speculative prefetch as early as possible
prefetch((char*)TT.first_entry(pos.key_after(move)));

// Check for legality just before making the move
if (!RootNode && !SpNode && !pos.legal(move, ci.pinned))
Expand Down Expand Up @@ -1140,8 +1140,8 @@ namespace {
&& pos.see_sign(move) < VALUE_ZERO)
continue;

// Speculative prefetch
prefetch((char*)TT.first_entry(pos.hash_after_move(move)));
// Speculative prefetch as early as possible
prefetch((char*)TT.first_entry(pos.key_after(move)));

// Check for legality just before making the move
if (!pos.legal(move, ci.pinned))
Expand Down

0 comments on commit 7482934

Please sign in to comment.