mirror of
https://github.com/sockspls/badfish
synced 2025-05-02 09:39:36 +00:00
Use refinedValue in ProbCut condition
After 12613 games at 20"+0.1 on QUAD Mod vs Orig 1870 - 1863 - 8880 ELO +0 (+- 3.3) So no performance change but it is a code semplification and also is more easy to understand. Signed-off-by: Marco Costalba <mcostalba@gmail.com>
This commit is contained in:
parent
3dfff5bdae
commit
e0215f3222
4 changed files with 6 additions and 12 deletions
|
@ -110,13 +110,13 @@ MovePicker::MovePicker(const Position& p, Move ttm, Depth d, const History& h)
|
||||||
go_next_phase();
|
go_next_phase();
|
||||||
}
|
}
|
||||||
|
|
||||||
MovePicker::MovePicker(const Position& p, Move ttm, const History& h, int parentCapture)
|
MovePicker::MovePicker(const Position& p, Move ttm, const History& h, int threshold)
|
||||||
: pos(p), H(h) {
|
: pos(p), H(h) {
|
||||||
|
|
||||||
assert (!pos.in_check());
|
assert (!pos.in_check());
|
||||||
|
|
||||||
// In ProbCut we consider only captures better than parent's move
|
// In ProbCut we consider only captures better than parent's move
|
||||||
captureThreshold = parentCapture;
|
captureThreshold = threshold;
|
||||||
phasePtr = ProbCutTable;
|
phasePtr = ProbCutTable;
|
||||||
|
|
||||||
if ( ttm != MOVE_NONE
|
if ( ttm != MOVE_NONE
|
||||||
|
|
|
@ -42,7 +42,7 @@ class MovePicker {
|
||||||
public:
|
public:
|
||||||
MovePicker(const Position&, Move, Depth, const History&, SearchStack*, Value);
|
MovePicker(const Position&, Move, Depth, const History&, SearchStack*, Value);
|
||||||
MovePicker(const Position&, Move, Depth, const History&);
|
MovePicker(const Position&, Move, Depth, const History&);
|
||||||
MovePicker(const Position&, Move, const History&, int parentCapture);
|
MovePicker(const Position&, Move, const History&, int threshold);
|
||||||
Move get_next_move();
|
Move get_next_move();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -213,7 +213,6 @@ public:
|
||||||
// Static exchange evaluation
|
// Static exchange evaluation
|
||||||
int see(Move m) const;
|
int see(Move m) const;
|
||||||
int see_sign(Move m) const;
|
int see_sign(Move m) const;
|
||||||
static int see_value(PieceType pt);
|
|
||||||
|
|
||||||
// Accessing hash keys
|
// Accessing hash keys
|
||||||
Key get_key() const;
|
Key get_key() const;
|
||||||
|
@ -467,10 +466,6 @@ inline bool Position::square_is_weak(Square s, Color c) const {
|
||||||
return !(pieces(PAWN, opposite_color(c)) & attack_span_mask(c, s));
|
return !(pieces(PAWN, opposite_color(c)) & attack_span_mask(c, s));
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int Position::see_value(PieceType pt) {
|
|
||||||
return seeValues[pt];
|
|
||||||
}
|
|
||||||
|
|
||||||
inline Key Position::get_key() const {
|
inline Key Position::get_key() const {
|
||||||
return st->key;
|
return st->key;
|
||||||
}
|
}
|
||||||
|
|
|
@ -903,9 +903,8 @@ namespace {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Step 9. ProbCut (is omitted in PV nodes)
|
// Step 9. ProbCut (is omitted in PV nodes)
|
||||||
// If we have a very good capture (i.e. SEE > seeValues[captured_piece_type])
|
// If we have a good capture that raises the score well above beta and a reduced
|
||||||
// and a reduced search returns a value much above beta, we can (almost) safely
|
// search confirms the score then we can (almost) safely prune the previous move.
|
||||||
// prune the previous move.
|
|
||||||
if ( !PvNode
|
if ( !PvNode
|
||||||
&& depth >= RazorDepth + ONE_PLY
|
&& depth >= RazorDepth + ONE_PLY
|
||||||
&& !inCheck
|
&& !inCheck
|
||||||
|
@ -918,7 +917,7 @@ namespace {
|
||||||
|
|
||||||
assert(rdepth >= ONE_PLY);
|
assert(rdepth >= ONE_PLY);
|
||||||
|
|
||||||
MovePicker mp(pos, ttMove, H, Position::see_value(pos.captured_piece_type()));
|
MovePicker mp(pos, ttMove, H, Max(rbeta - refinedValue, VALUE_ZERO));
|
||||||
pinned = pos.pinned_pieces(pos.side_to_move());
|
pinned = pos.pinned_pieces(pos.side_to_move());
|
||||||
|
|
||||||
while ((move = mp.get_next_move()) != MOVE_NONE)
|
while ((move = mp.get_next_move()) != MOVE_NONE)
|
||||||
|
|
Loading…
Add table
Reference in a new issue