Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 8 additions & 8 deletions library/src/ab_search.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -878,10 +878,10 @@ void make_3(

int aggr = posPoint->aggr[st];

posPoint->winner[st].rank = static_cast<unsigned char>(thrp->rel[aggr].abs_rank[1][st].rank);
posPoint->winner[st].hand = static_cast<unsigned char>(thrp->rel[aggr].abs_rank[1][st].hand);
posPoint->second_best[st].rank = static_cast<unsigned char>(thrp->rel[aggr].abs_rank[2][st].rank);
posPoint->second_best[st].hand = static_cast<unsigned char>(thrp->rel[aggr].abs_rank[2][st].hand);
posPoint->winner[st].rank = thrp->rel[aggr].abs_rank[1][st].rank;
posPoint->winner[st].hand = thrp->rel[aggr].abs_rank[1][st].hand;
posPoint->second_best[st].rank = thrp->rel[aggr].abs_rank[2][st].rank;
posPoint->second_best[st].hand = thrp->rel[aggr].abs_rank[2][st].hand;

}
}
Expand Down Expand Up @@ -944,10 +944,10 @@ static void make_3_ctx(

int aggr = posPoint->aggr[st];

posPoint->winner[st].rank = static_cast<unsigned char>(thrp->rel[aggr].abs_rank[1][st].rank);
posPoint->winner[st].hand = static_cast<unsigned char>(thrp->rel[aggr].abs_rank[1][st].hand);
posPoint->second_best[st].rank = static_cast<unsigned char>(thrp->rel[aggr].abs_rank[2][st].rank);
posPoint->second_best[st].hand = static_cast<unsigned char>(thrp->rel[aggr].abs_rank[2][st].hand);
posPoint->winner[st].rank = thrp->rel[aggr].abs_rank[1][st].rank;
posPoint->winner[st].hand = thrp->rel[aggr].abs_rank[1][st].hand;
posPoint->second_best[st].rank = thrp->rel[aggr].abs_rank[2][st].rank;
posPoint->second_best[st].hand = thrp->rel[aggr].abs_rank[2][st].hand;

}
}
Expand Down
63 changes: 11 additions & 52 deletions library/src/heuristic_sorting/heuristic_sorting.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -676,49 +676,17 @@ void weight_alloc_trump_void1(HeuristicContext& ctx)
unsigned short suitCount = tpos.length[curr_hand][suit];
int suitAdd;

if (suit == trump)
if (lead_suit == trump) // We pitch
{
// We trump a non-trump card.

if (tpos.length[partner_lh][lead_suit] != 0)
{
// 3rd hand will follow.
if ((tpos.rank_in_suit[rho_lh][lead_suit] >
(tpos.rank_in_suit[partner_lh][lead_suit] |
bit_map_rank[ctx.lead0_rank])) ||
((tpos.length[rho_lh][lead_suit] == 0) &&
(tpos.length[rho_lh][trump] != 0)))
{
// Partner can win with a card or by ruffing.
suitAdd = 60 + (suitCount << 6) / 44;
}
else
{
suitAdd = -2 + (suitCount << 6) / 36;
// Don't ruff from Kx.
if ((suitCount == 2) &&
(tpos.second_best[suit].hand == curr_hand))
suitAdd += -4;
}
}
else if ((tpos.length[rho_lh][lead_suit] == 0) &&
(tpos.rank_in_suit[rho_lh][trump] >
tpos.rank_in_suit[partner_lh][trump]))
{
// Partner can overruff 3rd hand.
suitAdd = 60 + (suitCount << 6) / 44;
}
else if ((tpos.length[partner_lh][trump] == 0) &&
(tpos.rank_in_suit[rho_lh][lead_suit] >
bit_map_rank[ctx.lead0_rank]))
{
// 3rd hand has no trumps, and partner has suit winner.
suitAdd = 60 + (suitCount << 6) / 44;
}
if (tpos.rank_in_suit[rho_lh][lead_suit] >
(tpos.rank_in_suit[partner_lh][lead_suit] |
bit_map_rank[ctx.lead0_rank]))
// RHO can win.
suitAdd = (suitCount << 6) / 44;
else
{
suitAdd = -2 + (suitCount << 6) / 36;
// Don't ruff from Kx.
// Don't pitch from Kx.
suitAdd = (suitCount << 6) / 36;
if ((suitCount == 2) &&
(tpos.second_best[suit].hand == curr_hand))
suitAdd += -4;
Expand Down Expand Up @@ -1245,10 +1213,7 @@ void weight_alloc_trump_void2(HeuristicContext& ctx)
mply[k].rank < ctx.move1_rank)
{
// Don't underruff.
unsigned char aggrSuit = static_cast<unsigned char>(tpos.aggr[suit]);
unsigned char moveRank = static_cast<unsigned char>(mply[k].rank);
unsigned char relRankValue = static_cast<unsigned char>(rel_rank[aggrSuit][moveRank]);
int r_rank = static_cast<int>(relRankValue);
int r_rank = rel_rank[tpos.aggr[suit]][mply[k].rank];
suitAdd = (suitCount << 6) / 40;
mply[k].weight = -32 + r_rank + suitAdd;
}
Expand Down Expand Up @@ -1418,10 +1383,7 @@ void weight_alloc_trump_void3(HeuristicContext& ctx)
{
for (int k = last_num_moves; k < num_moves; k++)
{
int r_rank = static_cast<int>(
static_cast<unsigned char>(
rel_rank[static_cast<unsigned char>(tpos.aggr[suit])]
[static_cast<unsigned char>(mply[k].rank)]));
int r_rank = rel_rank[tpos.aggr[suit]][mply[k].rank];
if (mply[k].rank > ctx.move2_rank)
mply[k].weight = 33 + r_rank; // Overruff
else
Expand All @@ -1436,10 +1398,7 @@ void weight_alloc_trump_void3(HeuristicContext& ctx)
{
for (int k = last_num_moves; k < num_moves; k++)
{
int r_rank = static_cast<int>(
static_cast<unsigned char>(
rel_rank[static_cast<unsigned char>(tpos.aggr[suit])]
[static_cast<unsigned char>(mply[k].rank)]));
int r_rank = rel_rank[tpos.aggr[suit]][mply[k].rank];
mply[k].weight = 33 + r_rank;
}
}
Expand Down
4 changes: 2 additions & 2 deletions library/src/quick_tricks.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1000,7 +1000,7 @@ int QuickTricksPartnerHandTrump(
if (ctx.thread_ptr()->rel[ranks].abs_rank[3][suit].hand == partner[hand])
{
tpos.win_ranks[depth][suit] |= bit_map_rank[
static_cast<int>(static_cast<unsigned char>(ctx.thread_ptr()->rel[ranks].abs_rank[3][suit].rank)) ];
static_cast<int>(ctx.thread_ptr()->rel[ranks].abs_rank[3][suit].rank) ];

tpos.win_ranks[depth][commSuit] |= bit_map_rank[commRank];

Expand Down Expand Up @@ -1110,7 +1110,7 @@ int QuickTricksPartnerHandNT(
if (ctx.thread_ptr()->rel[ranks].abs_rank[3][suit].hand == partner[hand])
{
tpos.win_ranks[depth][suit] |= bit_map_rank[
static_cast<int>(static_cast<unsigned char>(ctx.thread_ptr()->rel[ranks].abs_rank[3][suit].rank)) ];
static_cast<int>(ctx.thread_ptr()->rel[ranks].abs_rank[3][suit].rank) ];
qt++;
if (qt >= cutoff)
return qt;
Expand Down
Loading