refactor: 为 value_t 重载运算符
This commit is contained in:
parent
940f119061
commit
c665c64803
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue