mirror of
https://github.com/sockspls/badfish
synced 2025-04-30 08:43:09 +00:00
TT entry value based on depth and relative age
Calculate TT replace value as depth minus eight times relative age. STC 2MB LLR: 2.96 (-2.94,2.94) [0.00,4.00] Total: 45258 W: 8595 L: 8279 D: 28384 LTC 8MB LLR: 2.95 (-2.94,2.94) [0.00,4.00] Total: 56401 W: 8809 L: 8489 D: 39103 STC 16MB LLR: 2.96 (-2.94,2.94) [-4.00,0.00] Total: 34764 W: 6565 L: 6529 D: 21670 Bench: 9069474 Resolves #395
This commit is contained in:
parent
f4ace94f91
commit
9dbb3ae8b2
1 changed files with 5 additions and 6 deletions
11
src/tt.cpp
11
src/tt.cpp
|
@ -66,9 +66,9 @@ void TranspositionTable::clear() {
|
||||||
/// TranspositionTable::probe() looks up the current position in the transposition
|
/// TranspositionTable::probe() looks up the current position in the transposition
|
||||||
/// table. It returns true and a pointer to the TTEntry if the position is found.
|
/// table. It returns true and a pointer to the TTEntry if the position is found.
|
||||||
/// Otherwise, it returns false and a pointer to an empty or least valuable TTEntry
|
/// Otherwise, it returns false and a pointer to an empty or least valuable TTEntry
|
||||||
/// to be replaced later. A TTEntry t1 is considered to be more valuable than a
|
/// to be replaced later. The replace value of an entry is calculated as its depth
|
||||||
/// TTEntry t2 if t1 is from the current search and t2 is from a previous search,
|
/// minus 8 times its relative age. TTEntry t1 is considered more valuable than
|
||||||
/// or if the depth of t1 is bigger than the depth of t2.
|
/// TTEntry t2 if its replace value is greater than that of t2.
|
||||||
|
|
||||||
TTEntry* TranspositionTable::probe(const Key key, bool& found) const {
|
TTEntry* TranspositionTable::probe(const Key key, bool& found) const {
|
||||||
|
|
||||||
|
@ -87,9 +87,8 @@ TTEntry* TranspositionTable::probe(const Key key, bool& found) const {
|
||||||
// Find an entry to be replaced according to the replacement strategy
|
// Find an entry to be replaced according to the replacement strategy
|
||||||
TTEntry* replace = tte;
|
TTEntry* replace = tte;
|
||||||
for (int i = 1; i < ClusterSize; ++i)
|
for (int i = 1; i < ClusterSize; ++i)
|
||||||
if ( (( tte[i].genBound8 & 0xFC) == generation8)
|
if ( replace->depth8 - ((259 + generation8 - replace->genBound8) & 0xFC) * 2 * ONE_PLY
|
||||||
- ((replace->genBound8 & 0xFC) == generation8)
|
> tte[i].depth8 - ((259 + generation8 - tte[i].genBound8) & 0xFC) * 2 * ONE_PLY)
|
||||||
- (tte[i].depth8 < replace->depth8) < 0)
|
|
||||||
replace = &tte[i];
|
replace = &tte[i];
|
||||||
|
|
||||||
return found = false, replace;
|
return found = false, replace;
|
||||||
|
|
Loading…
Add table
Reference in a new issue