refactor: 将部分哈希相关重命名为置换表相关名称

This commit is contained in:
CalciteM 2019-09-09 00:19:02 +08:00
parent 3d1022f292
commit 3a043b469c
12 changed files with 102 additions and 90 deletions

View File

@ -62,12 +62,12 @@
//define DEEPER_IF_ONLY_ONE_LEGAL_MOVE //define DEEPER_IF_ONLY_ONE_LEGAL_MOVE
#define HASH_MAP_ENABLE #define TRANSPOSITION_TABLE_ENABLE
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
#define CLEAR_HASH_MAP #define CLEAR_TRANSPOSITION_TABLE
#define HASH_MAP_CUTDOWN #define TRANSPOSITION_TABLE_CUTDOWN
//#define HASH_MAP_DEBUG //#define TRANSPOSITION_TABLE_DEBUG
#endif #endif
#define MEMORY_POOL #define MEMORY_POOL
@ -99,13 +99,13 @@
#define GAME_MOVING_FIXED_DEPTH 3 #define GAME_MOVING_FIXED_DEPTH 3
#else // DEBUG #else // DEBUG
#ifdef DEAL_WITH_HORIZON_EFFECT #ifdef DEAL_WITH_HORIZON_EFFECT
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
#define GAME_MOVING_FIXED_DEPTH 9 #define GAME_MOVING_FIXED_DEPTH 9
#else #else
#define GAME_MOVING_FIXED_DEPTH 9 #define GAME_MOVING_FIXED_DEPTH 9
#endif // HASH_MAP_ENABLE #endif // TRANSPOSITION_TABLE_ENABLE
#else // DEAL_WITH_HORIZON_EFFECT #else // DEAL_WITH_HORIZON_EFFECT
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
#define GAME_MOVING_FIXED_DEPTH 11 #define GAME_MOVING_FIXED_DEPTH 11
#else #else
#define GAME_MOVING_FIXED_DEPTH 10 #define GAME_MOVING_FIXED_DEPTH 10

View File

@ -444,6 +444,7 @@
<ClInclude Include="src\ai\evaluate.h" /> <ClInclude Include="src\ai\evaluate.h" />
<ClInclude Include="src\ai\movegen.h" /> <ClInclude Include="src\ai\movegen.h" />
<ClInclude Include="src\ai\search.h" /> <ClInclude Include="src\ai\search.h" />
<ClInclude Include="src\ai\tt.h" />
<ClInclude Include="src\ai\zobrist.h" /> <ClInclude Include="src\ai\zobrist.h" />
<ClInclude Include="src\base\debug.h" /> <ClInclude Include="src\base\debug.h" />
<ClInclude Include="src\base\hashmap.h" /> <ClInclude Include="src\base\hashmap.h" />
@ -692,6 +693,7 @@
<ClCompile Include="src\ai\evaluate.cpp" /> <ClCompile Include="src\ai\evaluate.cpp" />
<ClCompile Include="src\ai\movegen.cpp" /> <ClCompile Include="src\ai\movegen.cpp" />
<ClCompile Include="src\ai\search.cpp" /> <ClCompile Include="src\ai\search.cpp" />
<ClCompile Include="src\ai\tt.cpp" />
<ClCompile Include="src\base\thread.cpp" /> <ClCompile Include="src\base\thread.cpp" />
<ClCompile Include="src\game\board.cpp" /> <ClCompile Include="src\game\board.cpp" />
<ClCompile Include="src\game\millgame.cpp" /> <ClCompile Include="src\game\millgame.cpp" />

View File

@ -108,6 +108,9 @@
<ClInclude Include="src\game\types.h"> <ClInclude Include="src\game\types.h">
<Filter>game</Filter> <Filter>game</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="src\ai\tt.h">
<Filter>ai</Filter>
</ClInclude>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<CustomBuild Include="debug\moc_predefs.h.cbt"> <CustomBuild Include="debug\moc_predefs.h.cbt">
@ -314,6 +317,9 @@
<ClCompile Include="src\game\rule.cpp"> <ClCompile Include="src\game\rule.cpp">
<Filter>game</Filter> <Filter>game</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="src\ai\tt.cpp">
<Filter>ai</Filter>
</ClCompile>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ResourceCompile Include="millgame.rc"> <ResourceCompile Include="millgame.rc">

View File

@ -32,10 +32,10 @@
using namespace CTSL; using namespace CTSL;
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
static constexpr int hashsize = 0x2000000; // 8-128M:102s, 4-64M:93s 2-32M:91s 1-16M: 冲突 static constexpr int TRANSPOSITION_TABLE_SIZE = 0x2000000; // 8-128M:102s, 4-64M:93s 2-32M:91s 1-16M: 冲突
HashMap<hash_t, MillGameAi_ab::HashValue> hashmap(hashsize); HashMap<hash_t, MillGameAi_ab::HashValue> transpositionTable(TRANSPOSITION_TABLE_SIZE);
#endif // HASH_MAP_ENABLE #endif // TRANSPOSITION_TABLE_ENABLE
#ifdef BOOK_LEARNING #ifdef BOOK_LEARNING
static constexpr int bookHashsize = 0x1000000; // 16M static constexpr int bookHashsize = 0x1000000; // 16M
@ -65,20 +65,20 @@ depth_t MillGameAi_ab::changeDepth(depth_t originalDepth)
if ((gameTemp.context.stage) & (GAME_PLACING)) { if ((gameTemp.context.stage) & (GAME_PLACING)) {
#ifdef GAME_PLACING_DYNAMIC_DEPTH #ifdef GAME_PLACING_DYNAMIC_DEPTH
#ifdef DEAL_WITH_HORIZON_EFFECT #ifdef DEAL_WITH_HORIZON_EFFECT
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
depth_t depthTable[] = { 4, 11, 12, 13, 14, 14, 14, 12, 11, 10, 6, 6, 1 }; depth_t depthTable[] = { 4, 11, 12, 13, 14, 14, 14, 12, 11, 10, 6, 6, 1 };
#else // HASH_MAP_ENABLE #else // TRANSPOSITION_TABLE_ENABLE
depth_t depthTable[] = { 2, 11, 11, 11, 11, 10, 9, 8, 8, 8, 7, 7, 1 }; depth_t depthTable[] = { 2, 11, 11, 11, 11, 10, 9, 8, 8, 8, 7, 7, 1 };
#endif // HASH_MAP_ENABLE #endif // TRANSPOSITION_TABLE_ENABLE
#else // DEAL_WITH_HORIZON_EFFECT #else // DEAL_WITH_HORIZON_EFFECT
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
#ifdef RAPID_GAME #ifdef RAPID_GAME
depth_t depthTable[] = { 6, 14, 15, 16, 15, 15, 15, 13, 10, 9, 8, 7, 1 }; depth_t depthTable[] = { 6, 14, 15, 16, 15, 15, 15, 13, 10, 9, 8, 7, 1 };
#else #else
depth_t depthTable[] = { 6, 15, 16, 17, 16, 16, 16, 14, 13, 12, 9, 7, 1 }; depth_t depthTable[] = { 6, 15, 16, 17, 16, 16, 16, 14, 13, 12, 9, 7, 1 };
//depth_t depthTable[] = { 6, 15, 16, 17, 16, 16, 16, 12, 12, 12, 9, 7, 1 }; //depth_t depthTable[] = { 6, 15, 16, 17, 16, 16, 16, 12, 12, 12, 9, 7, 1 };
#endif // RAPID_GAME #endif // RAPID_GAME
#else // HASH_MAP_ENABLE #else // TRANSPOSITION_TABLE_ENABLE
depth_t depthTable[] = { 2, 13, 13, 13, 12, 11, 10, 9, 9, 8, 8, 7, 1 }; depth_t depthTable[] = { 2, 13, 13, 13, 12, 11, 10, 9, 9, 8, 8, 7, 1 };
#endif #endif
#endif // DEAL_WITH_HORIZON_EFFECT #endif // DEAL_WITH_HORIZON_EFFECT
@ -133,13 +133,13 @@ struct MillGameAi_ab::Node *MillGameAi_ab::addNode(
#endif #endif
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
newNode->hash = 0; newNode->hash = 0;
#endif #endif
#endif #endif
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
newNode->isHash = false; newNode->isHash = false;
#endif #endif
#endif #endif
@ -271,9 +271,9 @@ void MillGameAi_ab::setGame(const MillGame &game)
{ {
// 如果规则改变重建hashmap // 如果规则改变重建hashmap
if (strcmp(this->game_.currentRule.name, game.currentRule.name) != 0) { if (strcmp(this->game_.currentRule.name, game.currentRule.name) != 0) {
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
clearHashMap(); clearTranspositionTable();
#endif // HASH_MAP_ENABLE #endif // TRANSPOSITION_TABLE_ENABLE
#ifdef BOOK_LEARNING #ifdef BOOK_LEARNING
// TODO: 规则改变时清空学习表 // TODO: 规则改变时清空学习表
@ -362,9 +362,9 @@ int MillGameAi_ab::alphaBetaPruning(depth_t depth)
#ifdef IDS_SUPPORT #ifdef IDS_SUPPORT
// 深化迭代 // 深化迭代
for (depth_t i = 2; i < d; i += 1) { for (depth_t i = 2; i < d; i += 1) {
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
#ifdef CLEAR_HASH_MAP #ifdef CLEAR_TRANSPOSITION_TABLE
clearHashMap(); // 每次走子前清空哈希表 clearTranspositionTable(); // 每次走子前清空哈希表
#endif #endif
#endif #endif
alphaBetaPruning(i, -INF_VALUE, INF_VALUE, rootNode); alphaBetaPruning(i, -INF_VALUE, INF_VALUE, rootNode);
@ -374,9 +374,9 @@ int MillGameAi_ab::alphaBetaPruning(depth_t depth)
loggerDebug("IDS Time: %llus\n", chrono::duration_cast<chrono::seconds>(timeEnd - timeStart).count()); loggerDebug("IDS Time: %llus\n", chrono::duration_cast<chrono::seconds>(timeEnd - timeStart).count());
#endif /* IDS_SUPPORT */ #endif /* IDS_SUPPORT */
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
#ifdef CLEAR_HASH_MAP #ifdef CLEAR_TRANSPOSITION_TABLE
clearHashMap(); // 每次走子前清空哈希表 clearTranspositionTable(); // 每次走子前清空哈希表
#endif #endif
#endif #endif
@ -404,7 +404,7 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
// 子节点的最优着法 // 子节点的最优着法
move_t bestMove = 0; move_t bestMove = 0;
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING))
// 哈希值 // 哈希值
HashValue hashValue {}; HashValue hashValue {};
memset(&hashValue, 0, sizeof(hashValue)); memset(&hashValue, 0, sizeof(hashValue));
@ -419,16 +419,13 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
#endif #endif
#endif #endif
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
// 检索 hashmap
//hashMapMutex.lock();
HashType type = hashfEMPTY; HashType type = hashfEMPTY;
value_t probeVal = probeHash(hash, depth, alpha, beta, bestMove, type); value_t probeVal = probeHash(hash, depth, alpha, beta, bestMove, type);
if (probeVal != INT16_MIN /* TODO: valUNKOWN */ && node != rootNode) { if (probeVal != INT16_MIN /* TODO: valUNKOWN */ && node != rootNode) {
#ifdef HASH_MAP_DEBUG #ifdef TRANSPOSITION_TABLE_DEBUG
hashHitCount++; hashHitCount++;
#endif #endif
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
@ -454,7 +451,7 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
} }
//hashMapMutex.unlock(); //hashMapMutex.unlock();
#endif /* HASH_MAP_ENABLE */ #endif /* TRANSPOSITION_TABLE_ENABLE */
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->depth = depth; node->depth = depth;
@ -464,10 +461,10 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
node->isLeaf = false; node->isLeaf = false;
node->isTimeout = false; node->isTimeout = false;
node->visited = true; node->visited = true;
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
node->isHash = false; node->isHash = false;
node->hash = 0; node->hash = 0;
#endif // HASH_MAP_ENABLE #endif // TRANSPOSITION_TABLE_ENABLE
#endif // DEBUG_AB_TREE #endif // DEBUG_AB_TREE
// 搜索到叶子节点(决胜局面) // TODO: 对哈希进行特殊处理 // 搜索到叶子节点(决胜局面) // TODO: 对哈希进行特殊处理
@ -487,7 +484,7 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
node->isLeaf = true; node->isLeaf = true;
#endif #endif
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
// 记录确切的哈希值 // 记录确切的哈希值
recordHash(node->value, depth, hashfEXACT, hash, 0); recordHash(node->value, depth, hashfEXACT, hash, 0);
#endif #endif
@ -524,7 +521,7 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
} }
#endif #endif
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
// 记录确切的哈希值 // 记录确切的哈希值
recordHash(node->value, depth, hashfEXACT, hash, 0); recordHash(node->value, depth, hashfEXACT, hash, 0);
#endif #endif
@ -578,7 +575,7 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
// 如果某个着法的结果小于或等于 α,那么它就是很差的着法,因此可以抛弃 // 如果某个着法的结果小于或等于 α,那么它就是很差的着法,因此可以抛弃
if (value > alpha) { if (value > alpha) {
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
hashf = hashfEXACT; hashf = hashfEXACT;
#endif #endif
alpha = value; alpha = value;
@ -606,7 +603,7 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
#if 0 #if 0
if (value < beta) { if (value < beta) {
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
hashf = hashfBETA; hashf = hashfBETA;
#endif #endif
beta = value; beta = value;
@ -647,10 +644,10 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
sortLegalMoves(node); sortLegalMoves(node);
#endif // IDS_SUPPORT #endif // IDS_SUPPORT
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
// 记录不一定确切的哈希值 // 记录不一定确切的哈希值
recordHash(node->value, depth, hashf, hash, node->children[0]->move); recordHash(node->value, depth, hashf, hash, node->children[0]->move);
#endif /* HASH_MAP_ENABLE */ #endif /* TRANSPOSITION_TABLE_ENABLE */
// 返回 // 返回
return node->value; return node->value;
@ -741,8 +738,8 @@ const char* MillGameAi_ab::bestMove()
nodeCount = 0; nodeCount = 0;
evaluatedNodeCount = 0; evaluatedNodeCount = 0;
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
#ifdef HASH_MAP_DEBUG #ifdef TRANSPOSITION_TABLE_DEBUG
loggerDebug(""Hash hit count: %llu\n", hashHitCount); loggerDebug(""Hash hit count: %llu\n", hashHitCount);
#endif #endif
#endif #endif
@ -774,7 +771,7 @@ const char *MillGameAi_ab::move2string(move_t move)
return cmdline; return cmdline;
} }
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
value_t MillGameAi_ab::probeHash(hash_t hash, value_t MillGameAi_ab::probeHash(hash_t hash,
depth_t depth, value_t alpha, value_t beta, depth_t depth, value_t alpha, value_t beta,
move_t &bestMove, HashType &type) move_t &bestMove, HashType &type)
@ -782,7 +779,7 @@ value_t MillGameAi_ab::probeHash(hash_t hash,
const value_t valUNKNOWN = INT16_MIN; const value_t valUNKNOWN = INT16_MIN;
HashValue hashValue {}; HashValue hashValue {};
if (!hashmap.find(hash, hashValue)) { if (!transpositionTable.find(hash, hashValue)) {
return valUNKNOWN; return valUNKNOWN;
} }
@ -813,7 +810,7 @@ out:
bool MillGameAi_ab::findHash(hash_t hash, HashValue &hashValue) bool MillGameAi_ab::findHash(hash_t hash, HashValue &hashValue)
{ {
return hashmap.find(hash, hashValue); return transpositionTable.find(hash, hashValue);
// TODO: 变换局面 // TODO: 变换局面
#if 0 #if 0
@ -860,20 +857,20 @@ int MillGameAi_ab::recordHash(value_t value, depth_t depth, HashType type, hash_
hashValue.type = type; hashValue.type = type;
hashValue.bestMove = bestMove; hashValue.bestMove = bestMove;
hashmap.insert(hash, hashValue); transpositionTable.insert(hash, hashValue);
//hashMapMutex.unlock(); //hashMapMutex.unlock();
return 0; return 0;
} }
void MillGameAi_ab::clearHashMap() void MillGameAi_ab::clearTranspositionTable()
{ {
//hashMapMutex.lock(); //hashMapMutex.lock();
hashmap.clear(); transpositionTable.clear();
//hashMapMutex.unlock(); //hashMapMutex.unlock();
} }
#endif /* HASH_MAP_ENABLE */ #endif /* TRANSPOSITION_TABLE_ENABLE */
#ifdef BOOK_LEARNING #ifdef BOOK_LEARNING

View File

@ -82,16 +82,16 @@ public:
int nPiecesNeedRemove; // 手中有多少可去的子,如对手有可去的子则为负数 int nPiecesNeedRemove; // 手中有多少可去的子,如对手有可去的子则为负数
int result; // 终局结果,-1为负0为未到终局1为胜走棋阶段被闷棋则为 -2/2布局阶段闷棋为 -3 int result; // 终局结果,-1为负0为未到终局1为胜走棋阶段被闷棋则为 -2/2布局阶段闷棋为 -3
struct Node* root; // 根节点 struct Node* root; // 根节点
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
bool isHash; // 是否从 Hash 读取 bool isHash; // 是否从 Hash 读取
#endif /* HASH_MAP_ENABLE */ #endif /* TRANSPOSITION_TABLE_ENABLE */
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
hash_t hash; // 哈希值 hash_t hash; // 哈希值
#endif #endif
#endif /* DEBUG_AB_TREE */ #endif /* DEBUG_AB_TREE */
}; };
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING))
// 定义哈希值的类型 // 定义哈希值的类型
enum HashType : uint8_t enum HashType : uint8_t
{ {
@ -133,9 +133,9 @@ public:
// 返回最佳走法的命令行 // 返回最佳走法的命令行
const char *bestMove(); const char *bestMove();
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING))
// 清空哈希表 // 清空哈希表
void clearHashMap(); void clearTranspositionTable();
#endif #endif
// 比较函数 // 比较函数
@ -205,14 +205,14 @@ protected:
// 篡改深度 // 篡改深度
depth_t changeDepth(depth_t originalDepth); depth_t changeDepth(depth_t originalDepth);
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
// 查找哈希表 // 查找哈希表
bool findHash(hash_t hash, HashValue &hashValue); bool findHash(hash_t hash, HashValue &hashValue);
value_t probeHash(hash_t hash, depth_t depth, value_t alpha, value_t beta, move_t &bestMove, HashType &type); value_t probeHash(hash_t hash, depth_t depth, value_t alpha, value_t beta, move_t &bestMove, HashType &type);
// 插入哈希表 // 插入哈希表
int recordHash(value_t value, depth_t depth, HashType type, hash_t hash, move_t bestMove); int recordHash(value_t value, depth_t depth, HashType type, hash_t hash, move_t bestMove);
#endif // HASH_MAP_ENABLE #endif // TRANSPOSITION_TABLE_ENABLE
private: private:
// 原始模型 // 原始模型
@ -235,8 +235,8 @@ private:
// 评估过的结点个数 // 评估过的结点个数
size_t evaluatedNodeCount {0}; size_t evaluatedNodeCount {0};
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
#ifdef HASH_MAP_DEBUG #ifdef TRANSPOSITION_TABLE_DEBUG
// Hash 统计数据 // Hash 统计数据
size_t hashEntryCount; size_t hashEntryCount;
size_t hashHitCount; size_t hashHitCount;
@ -262,9 +262,9 @@ private:
char cmdline[64] {}; char cmdline[64] {};
}; };
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
extern HashMap<hash_t, MillGameAi_ab::HashValue> hashmap; extern HashMap<hash_t, MillGameAi_ab::HashValue> transpositionTable;
#endif /* #ifdef HASH_MAP_ENABLE */ #endif /* TRANSPOSITION_TABLE_ENABLE */
#ifdef THREEFOLD_REPETITION #ifdef THREEFOLD_REPETITION
extern vector<hash_t> positions; extern vector<hash_t> positions;

2
src/ai/tt.cpp Normal file
View File

@ -0,0 +1,2 @@
#include "tt.h"

5
src/ai/tt.h Normal file
View File

@ -0,0 +1,5 @@
#ifndef TT_H
#define TT_H
#endif /* TT_H */

View File

@ -23,7 +23,7 @@
#include "millgame.h" #include "millgame.h"
static const hash_t zobrist0[Board::N_POINTS][POINT_TYPE_COUNT] = { static const hash_t zobrist0[Board::N_POINTS][POINT_TYPE_COUNT] = {
#ifdef HASH_MAP_CUTDOWN #ifdef TRANSPOSITION_TABLE_CUTDOWN
{0x4E421A00, 0x3962FF00, 0x6DB6EE00, 0x219AE100}, {0x4E421A00, 0x3962FF00, 0x6DB6EE00, 0x219AE100},
{0x1F3DE200, 0xD9AACB00, 0xD5173300, 0xD3F9EA00}, {0x1F3DE200, 0xD9AACB00, 0xD5173300, 0xD3F9EA00},
{0xF5A7BB00, 0xDC410900, 0xEE431900, 0x7CDA7A00}, {0xF5A7BB00, 0xDC410900, 0xEE431900, 0x7CDA7A00},
@ -105,7 +105,7 @@ static const hash_t zobrist0[Board::N_POINTS][POINT_TYPE_COUNT] = {
{0xFD34EA18D01A6E00, 0xFA1300F7BCD93500, 0xAAC5CC6817565900, 0xE0C64BA5AD5A7300}, {0xFD34EA18D01A6E00, 0xFA1300F7BCD93500, 0xAAC5CC6817565900, 0xE0C64BA5AD5A7300},
{0x5ECF7987B04E7D00, 0xAB38FFE6815F5300, 0x94EA1A1812469A00, 0x20EDFF94B2F25C00}, {0x5ECF7987B04E7D00, 0xAB38FFE6815F5300, 0x94EA1A1812469A00, 0x20EDFF94B2F25C00},
{0x0B2D4606564E4B00, 0x83381E3CD1943700, 0xD3DB04A0A4F63C00, 0x789C60EF7169E500} {0x0B2D4606564E4B00, 0x83381E3CD1943700, 0xD3DB04A0A4F63C00, 0x789C60EF7169E500}
#endif /* HASH_MAP_CUTDOWN */ #endif /* TRANSPOSITION_TABLE_CUTDOWN */
}; };
#ifdef ONLY_USED_FOR_CONVERT #ifdef ONLY_USED_FOR_CONVERT

View File

@ -66,10 +66,10 @@ void AiThread::setAi(const MillGame &game)
this->game_ = &game; this->game_ = &game;
ai_ab.setGame(*(this->game_)); ai_ab.setGame(*(this->game_));
#ifdef HASH_MAP_ENABLE #ifdef TRANSPOSITION_TABLE_ENABLE
// 新下一盘前清除哈希表 (注意可能同时存在每步之前清除) // 新下一盘前清除哈希表 (注意可能同时存在每步之前清除)
#ifdef CLEAR_HASH_MAP #ifdef CLEAR_TRANSPOSITION_TABLE
ai_ab.clearHashMap(); ai_ab.clearTranspositionTable();
#endif #endif
#endif #endif

View File

@ -29,7 +29,7 @@ MillGame::MillGame()
// 单独提出 board 等数据,免得每次都写 context.board; // 单独提出 board 等数据,免得每次都写 context.board;
board_ = context.board.board_; board_ = context.board.board_;
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
// 创建哈希数据 // 创建哈希数据
constructHash(); constructHash();
#endif #endif
@ -173,7 +173,7 @@ bool MillGame::setContext(const struct Rule *rule, step_t maxStepsLedToDraw, int
// 当前棋局3×8 // 当前棋局3×8
if (board == nullptr) { if (board == nullptr) {
memset(context.board.board_, 0, sizeof(context.board.board_)); memset(context.board.board_, 0, sizeof(context.board.board_));
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
context.hash = 0; context.hash = 0;
#endif #endif
} else { } else {
@ -328,7 +328,7 @@ bool MillGame::reset()
// 用时置零 // 用时置零
elapsedSeconds_1 = elapsedSeconds_2 = 0; elapsedSeconds_1 = elapsedSeconds_2 = 0;
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
// 哈希归零 // 哈希归零
context.hash = 0; context.hash = 0;
#endif #endif
@ -426,7 +426,7 @@ bool MillGame::place(int pos, int time_p, int8_t rs)
board_[pos] = piece; board_[pos] = piece;
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
updateHash(pos); updateHash(pos);
#endif #endif
move_ = pos; move_ = pos;
@ -524,13 +524,13 @@ bool MillGame::place(int pos, int time_p, int8_t rs)
board_[pos] = board_[currentPos]; board_[pos] = board_[currentPos];
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
updateHash(pos); updateHash(pos);
#endif #endif
board_[currentPos] = '\x00'; board_[currentPos] = '\x00';
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
revertHash(currentPos); revertHash(currentPos);
#endif #endif
@ -620,15 +620,15 @@ bool MillGame::capture(int pos, int time_p, int8_t cp)
// 去子(设置禁点) // 去子(设置禁点)
if (currentRule.hasForbiddenPoint && context.stage == GAME_PLACING) { if (currentRule.hasForbiddenPoint && context.stage == GAME_PLACING) {
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
revertHash(pos); revertHash(pos);
#endif #endif
board_[pos] = '\x0f'; board_[pos] = '\x0f';
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
updateHash(pos); updateHash(pos);
#endif #endif
} else { // 去子 } else { // 去子
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
revertHash(pos); revertHash(pos);
#endif #endif
board_[pos] = '\x00'; board_[pos] = '\x00';
@ -651,7 +651,7 @@ bool MillGame::capture(int pos, int time_p, int8_t cp)
currentPos = 0; currentPos = 0;
context.nPiecesNeedRemove--; context.nPiecesNeedRemove--;
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
updateHash(pos); updateHash(pos);
#endif #endif
@ -1093,7 +1093,7 @@ void MillGame::cleanForbiddenPoints()
pos = r * Board::N_SEATS + s; pos = r * Board::N_SEATS + s;
if (board_[pos] == '\x0f') { if (board_[pos] == '\x0f') {
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
revertHash(pos); revertHash(pos);
#endif #endif
board_[pos] = '\x00'; board_[pos] = '\x00';
@ -1184,7 +1184,7 @@ void MillGame::getElapsedTime(time_t &p1_ms, time_t &p2_ms)
p2_ms = elapsedSeconds_2; p2_ms = elapsedSeconds_2;
} }
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
#if 0 #if 0
/* /*
@ -1275,4 +1275,4 @@ hash_t MillGame::updateHashMisc()
return context.hash; return context.hash;
} }
#endif /* HASH_MAP_ENABLE etc. */ #endif /* TRANSPOSITION_TABLE_ENABLE etc. */

View File

@ -41,13 +41,13 @@ class GameContext
public: public:
Board board; Board board;
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
// 局面的哈希值 // 局面的哈希值
hash_t hash{}; hash_t hash{};
// Zobrist 数组 // Zobrist 数组
hash_t zobrist[Board::N_POINTS][POINT_TYPE_COUNT]{}; hash_t zobrist[Board::N_POINTS][POINT_TYPE_COUNT]{};
#endif /* HASH_MAP_ENABLE */ #endif /* TRANSPOSITION_TABLE_ENABLE */
// 局面阶段标识 // 局面阶段标识
enum GameStage stage; enum GameStage stage;
@ -322,7 +322,7 @@ public:
bool place(int pos, int time_p = -1, int8_t cp = 0); bool place(int pos, int time_p = -1, int8_t cp = 0);
bool capture(int pos, int time_p = -1, int8_t cp = 0); bool capture(int pos, int time_p = -1, int8_t cp = 0);
#if ((defined HASH_MAP_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION)) #if ((defined TRANSPOSITION_TABLE_ENABLE) || (defined BOOK_LEARNING) || (defined THREEFOLD_REPETITION))
// hash相关 // hash相关
hash_t getHash(); hash_t getHash();
hash_t revertHash(int pos); hash_t revertHash(int pos);

View File

@ -29,11 +29,11 @@ using step_t = uint16_t;
using value_t = int16_t; using value_t = int16_t;
using depth_t = uint8_t; using depth_t = uint8_t;
#ifdef HASH_MAP_CUTDOWN #ifdef TRANSPOSITION_TABLE_CUTDOWN
using hash_t = uint32_t; using hash_t = uint32_t;
#else #else
using hash_t = uint64_t; using hash_t = uint64_t;
#endif /* HASH_MAP_CUTDOWN */ #endif /* TRANSPOSITION_TABLE_CUTDOWN */
// 移动方向包括顺时针、逆时针、向内、向外4个方向 // 移动方向包括顺时针、逆时针、向内、向外4个方向
enum MoveDirection enum MoveDirection