assert(msb((mbSize << 20) / sizeof(TTEntry)) < 32);
- uint32_t size = 1 << msb((mbSize << 20) / sizeof(TTEntry[ClusterSize]));
+ uint32_t size = ClusterSize << msb((mbSize << 20) / sizeof(TTEntry[ClusterSize]));
- if (clusterMask == size - 1)
+ if (hashMask == size - ClusterSize)
return;
- clusterMask = size - 1;
- delete [] entries;
- entries = new (std::nothrow) TTEntry[size * ClusterSize];
+ hashMask = size - ClusterSize;
+ delete [] table;
+ table = new (std::nothrow) TTEntry[size];
- if (!entries)
+ if (!table)
{
std::cerr << "Failed to allocate " << mbSize
<< "MB for transposition table." << std::endl;
void TranspositionTable::clear() {
- memset(entries, 0, (clusterMask + 1) * sizeof(TTEntry[ClusterSize]));
+ memset(table, 0, (hashMask + ClusterSize) * sizeof(TTEntry));
}
static const unsigned ClusterSize = 4; // A cluster is 64 Bytes
public:
- ~TranspositionTable() { delete [] entries; }
+ ~TranspositionTable() { delete [] table; }
void new_search() { generation++; }
TTEntry* probe(const Key key) const;
void store(const Key key, Value v, Bound type, Depth d, Move m, Value statV, Value kingD);
private:
- uint32_t clusterMask;
- TTEntry* entries;
+ uint32_t hashMask;
+ TTEntry* table;
uint8_t generation; // Size must be not bigger then TTEntry::generation8
};
inline TTEntry* TranspositionTable::first_entry(const Key key) const {
- return entries + ((uint32_t)key & clusterMask) * ClusterSize;
+ return table + ((uint32_t)key & hashMask);
}