refactor: 为 value_t 重载运算符

This commit is contained in:
CalciteM Team 2019-09-13 13:00:44 +08:00
parent 940f119061
commit c665c64803
3 changed files with 34 additions and 14 deletions

View File

@ -43,14 +43,14 @@ value_t Evaluation::getValue(Position &dummyPosition, PositionContext *positionC
case PHASE_PLACING: case PHASE_PLACING:
// 按手中的棋子计分不要break; // 按手中的棋子计分不要break;
nPiecesInHandDiff = positionContext->nPiecesInHand_1 - positionContext->nPiecesInHand_2; nPiecesInHandDiff = positionContext->nPiecesInHand_1 - positionContext->nPiecesInHand_2;
value = (value_t)(value + nPiecesInHandDiff * VALUE_EACH_PIECE_INHAND); value += nPiecesInHandDiff * VALUE_EACH_PIECE_INHAND;
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->nPiecesInHandDiff = nPiecesInHandDiff; node->nPiecesInHandDiff = nPiecesInHandDiff;
#endif #endif
// 按场上棋子计分 // 按场上棋子计分
nPiecesOnBoardDiff = positionContext->nPiecesOnBoard_1 - positionContext->nPiecesOnBoard_2; nPiecesOnBoardDiff = positionContext->nPiecesOnBoard_1 - positionContext->nPiecesOnBoard_2;
value = (value_t)(value + nPiecesOnBoardDiff * VALUE_EACH_PIECE_ONBOARD); value += nPiecesOnBoardDiff * VALUE_EACH_PIECE_ONBOARD;
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->nPiecesOnBoardDiff = nPiecesOnBoardDiff; node->nPiecesOnBoardDiff = nPiecesOnBoardDiff;
#endif #endif
@ -65,7 +65,7 @@ value_t Evaluation::getValue(Position &dummyPosition, PositionContext *positionC
case ACTION_CAPTURE: case ACTION_CAPTURE:
nPiecesNeedRemove = (positionContext->turn == PLAYER1) ? nPiecesNeedRemove = (positionContext->turn == PLAYER1) ?
positionContext->nPiecesNeedRemove : -(positionContext->nPiecesNeedRemove); positionContext->nPiecesNeedRemove : -(positionContext->nPiecesNeedRemove);
value = (value_t)(value + nPiecesNeedRemove * VALUE_EACH_PIECE_NEEDREMOVE); value += nPiecesNeedRemove * VALUE_EACH_PIECE_NEEDREMOVE;
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->nPiecesNeedRemove = nPiecesNeedRemove; node->nPiecesNeedRemove = nPiecesNeedRemove;
#endif #endif
@ -96,7 +96,7 @@ value_t Evaluation::getValue(Position &dummyPosition, PositionContext *positionC
case ACTION_CAPTURE: case ACTION_CAPTURE:
nPiecesNeedRemove = (positionContext->turn == PLAYER1) ? nPiecesNeedRemove = (positionContext->turn == PLAYER1) ?
positionContext->nPiecesNeedRemove : -(positionContext->nPiecesNeedRemove); positionContext->nPiecesNeedRemove : -(positionContext->nPiecesNeedRemove);
value = (value_t)(value + nPiecesNeedRemove * VALUE_EACH_PIECE_NEEDREMOVE_2); value += nPiecesNeedRemove * VALUE_EACH_PIECE_NEEDREMOVE_2;
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->nPiecesNeedRemove = nPiecesNeedRemove; node->nPiecesNeedRemove = nPiecesNeedRemove;
#endif #endif
@ -114,7 +114,7 @@ value_t Evaluation::getValue(Position &dummyPosition, PositionContext *positionC
Board::N_SEATS * Board::N_RINGS) { Board::N_SEATS * Board::N_RINGS) {
if (dummyPosition.getRule()->isStartingPlayerLoseWhenBoardFull) { if (dummyPosition.getRule()->isStartingPlayerLoseWhenBoardFull) {
// winner = PLAYER2; // winner = PLAYER2;
value = value_t(value - VALUE_WIN); value -= VALUE_WIN;
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->result = -3; node->result = -3;
#endif #endif
@ -129,12 +129,12 @@ value_t Evaluation::getValue(Position &dummyPosition, PositionContext *positionC
dummyPosition.getRule()->isLoseWhenNoWay) { dummyPosition.getRule()->isLoseWhenNoWay) {
// 规则要求被“闷”判负,则对手获胜 // 规则要求被“闷”判负,则对手获胜
if (positionContext->turn == PLAYER1) { if (positionContext->turn == PLAYER1) {
value = value_t(value - VALUE_WIN); value -= VALUE_WIN;
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->result = -2; node->result = -2;
#endif #endif
} else { } else {
value = value_t(value + VALUE_WIN); value += VALUE_WIN;
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->result = 2; node->result = 2;
#endif #endif
@ -143,12 +143,12 @@ value_t Evaluation::getValue(Position &dummyPosition, PositionContext *positionC
// 剩余棋子个数判断 // 剩余棋子个数判断
if (positionContext->nPiecesOnBoard_1 < dummyPosition.getRule()->nPiecesAtLeast) { if (positionContext->nPiecesOnBoard_1 < dummyPosition.getRule()->nPiecesAtLeast) {
value = value_t(value - VALUE_WIN); value -= VALUE_WIN;
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->result = -1; node->result = -1;
#endif #endif
} else if (positionContext->nPiecesOnBoard_2 < dummyPosition.getRule()->nPiecesAtLeast) { } else if (positionContext->nPiecesOnBoard_2 < dummyPosition.getRule()->nPiecesAtLeast) {
value = value_t(value + VALUE_WIN); value += VALUE_WIN;
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
node->result = 1; node->result = 1;
#endif #endif

View File

@ -466,9 +466,9 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
// 为争取速胜value 值 +- 深度 // 为争取速胜value 值 +- 深度
if (node->value > 0) { if (node->value > 0) {
node->value = value_t(node->value + depth); node->value += depth;
} else { } else {
node->value = value_t(node->value - depth); node->value -= depth;
} }
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE
@ -491,9 +491,9 @@ value_t MillGameAi_ab::alphaBetaPruning(depth_t depth, value_t alpha, value_t be
// 为争取速胜value 值 +- 深度 (有必要?) // 为争取速胜value 值 +- 深度 (有必要?)
if (positionContext->turn == PLAYER1) { if (positionContext->turn == PLAYER1) {
node->value = (value_t)(node->value + depth); node->value += depth;
} else { } else {
node->value = (value_t)(node->value - depth); node->value -= depth;
} }
#ifdef DEBUG_AB_TREE #ifdef DEBUG_AB_TREE

View File

@ -113,6 +113,26 @@ enum value_t : int16_t
VALUE_EACH_PIECE_NEEDREMOVE_2 = 128, VALUE_EACH_PIECE_NEEDREMOVE_2 = 128,
}; };
// Additional operators to add integers to a Value
constexpr value_t operator+(value_t v, int i)
{
return value_t(int(v) + i);
}
constexpr value_t operator-(value_t v, int i)
{
return value_t(int(v) - i);
}
inline value_t &operator+=(value_t &v, int i)
{
return v = v + i;
}
inline value_t &operator-=(value_t &v, int i)
{
return v = v - i;
}
// 动作状态标识 // 动作状态标识
enum action_t : uint16_t enum action_t : uint16_t