?? transpositiontable.cpp
字號:
// COPYRIGHT NOTES
// ---------------
// This source code is a part of chess which is an example of <Game Programing guide>.
// You may use, compile or redistribute it as part of your application
// for free.
// You cannot redistribute sources without the official agreement of the author.
// If distribution of you application which contents code below was occured, place
// e-mail <hidebug@hotmail.com> on it is to be appreciated.
// This code can be used WITHOUT ANY WARRANTIES on your own risk.
//
// Spring Wang <hidebug@hotmail.com>
// ---------------
// 版權聲明
// ---------------
// 本文件所含之代碼是《人機博弈程序設計指南》的范例程序中國象棋的一部分
// 您可以免費的使用, 編譯 或者作為您應用程序的一部分。
// 但,您不能在未經作者書面許可的情況下分發此源代碼。
// 如果您的應用程序使用了這些代碼,在您的應用程序界面上
// 放入 e-mail <hidebug@hotmail.com> 是令人欣賞的做法。
// 此代碼并不含有任何保證,使用者當自承風險。
//
// 王小春 <hidebug@hotmail.com>
// TranspositionTable.cpp: implementation of the CTranspositionTable class.
//
//////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include "chess.h"
#include "TranspositionTable.h"
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
LONGLONG rand64(void)
{
return rand() ^ ((LONGLONG)rand() << 15) ^ ((LONGLONG)rand() << 30) ^
((LONGLONG)rand() << 45) ^ ((LONGLONG)rand() << 60);
}
LONG rand32(void)
{
return rand() ^ ((LONG)rand() << 15) ^ ((LONG)rand() << 30);
}
CTranspositionTable::CTranspositionTable()
{
InitializeHashKey();
}
CTranspositionTable::~CTranspositionTable()
{
delete m_pTT[0];
delete m_pTT[1];
}
void CTranspositionTable::InitializeHashKey()
{
int i,j,k;
srand( (unsigned)time( NULL ));
for (i = 0; i < 15; i++)
for (j = 0; j < 10; j++)
for (k = 0; k < 9; k++)
{
m_nHashKey32[i][j][k] = rand32();
m_ulHashKey64[i][j][k] = rand64();
}
m_pTT[0] = new HashItem[1024*1024];
m_pTT[1] = new HashItem[1024*1024];
}
void CTranspositionTable::CalculateInitHashKey(BYTE CurPosition[10][9])
{
int j,k,nChessType;
m_HashKey32 = 0;
m_HashKey32 = 0;
for (j = 0; j < 10; j++)
for (k = 0; k < 9; k++)
{
nChessType = CurPosition[j][k];
if (nChessType != NOCHESS)
{
m_HashKey32 = m_HashKey32 ^ m_nHashKey32[nChessType][j][k];
m_HashKey64 = m_HashKey64 ^ m_ulHashKey64[nChessType][j][k];
}
}
}
void CTranspositionTable::Hash_MakeMove(CHESSMOVE* move, BYTE CurPosition[10][9])
{
BYTE nToID, nFromID;
nFromID = CurPosition[move->From.y][move->From.x];
nToID = CurPosition[move->To.y][move->To.x];
m_HashKey32 = m_HashKey32 ^ m_nHashKey32[nFromID][move->From.y][move->From.x];
m_HashKey64 = m_HashKey64 ^ m_ulHashKey64[nFromID][move->From.y][move->From.x];
if (nToID != NOCHESS)
{
m_HashKey32 = m_HashKey32 ^ m_nHashKey32[nToID][move->To.y][move->To.x];
m_HashKey64 = m_HashKey64 ^ m_ulHashKey64[nToID][move->To.y][move->To.x];
}
m_HashKey32 = m_HashKey32 ^ m_nHashKey32[nFromID][move->To.y][move->To.x];
m_HashKey64 = m_HashKey64 ^ m_ulHashKey64[nFromID][move->To.y][move->To.x];
}
void CTranspositionTable::Hash_UnMakeMove(CHESSMOVE* move, BYTE nChessID, BYTE CurPosition[10][9])
{
BYTE nToID;
nToID = CurPosition[move->To.y][move->To.x];
m_HashKey32 = m_HashKey32 ^ m_nHashKey32[nToID][move->From.y][move->From.x];
m_HashKey64 = m_HashKey64 ^ m_ulHashKey64[nToID][move->From.y][move->From.x];
m_HashKey32 = m_HashKey32 ^ m_nHashKey32[nToID][move->To.y][move->To.x];
m_HashKey64 = m_HashKey64 ^ m_ulHashKey64[nToID][move->To.y][move->To.x];
if (nChessID)
{
m_HashKey32 = m_HashKey32 ^ m_nHashKey32[nChessID][move->To.y][move->To.x];
m_HashKey64 = m_HashKey64 ^ m_ulHashKey64[nChessID][move->To.y][move->To.x];
}
}
int CTranspositionTable::LookUpHashTable(int alpha, int beta, int depth,int TableNo)
{
int x;
HashItem * pht;
x = m_HashKey32 & 0xFFFFF;
pht = &m_pTT[TableNo][x];
if (pht->depth >= depth && pht->checksum == m_HashKey64)
{
switch (pht->entry_type)
{
case exact:
return pht->eval;
case lower_bound:
if (pht->eval >= beta)
return (pht->eval);
else
break;
case upper_bound:
if (pht->eval <= alpha)
return (pht->eval);
else
break;
}
}
return 66666;
}
void CTranspositionTable::EnterHashTable(ENTRY_TYPE entry_type, short eval, short depth,int TableNo)
{
int x;
HashItem * pht;
x = m_HashKey32 & 0xFFFFF;//二十位哈希地址
pht = &m_pTT[TableNo][x];
pht->checksum = m_HashKey64;
pht->entry_type = entry_type;
pht->eval = eval;
pht->depth = depth;
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -