compute_hot_deals/
main.rsuse dds_bridge::contract::Strain;
use dds_bridge::deal::{Card, Deal, Hand, Seat, SmallSet as _, Suit};
use dds_bridge::solver;
use std::process::ExitCode;
fn get_random_average_hand(rng: &mut (impl rand::Rng + ?Sized)) -> Hand {
let bits: u64 = rng.random();
(0..13).fold(Hand::EMPTY, |mut hand, i| {
let suit: Suit = unsafe { core::mem::transmute((bits >> (2 * i) & 3) as u8) };
hand.insert(Card::new(suit, i + 2));
hand
})
}
fn get_random_symmetric_deal(rng: &mut (impl rand::Rng + ?Sized)) -> Deal {
let hand = get_random_average_hand(rng);
let sequence = [
hand.0[1], hand.0[2], hand.0[3], hand.0[0], hand.0[1], hand.0[2],
];
let north = hand;
let east = Hand(sequence[0..4].try_into().expect("Invalid hand"));
let south = Hand(sequence[1..5].try_into().expect("Invalid hand"));
let west = Hand(sequence[2..6].try_into().expect("Invalid hand"));
Deal([north, east, south, west])
}
fn compute_deal(
rng: &mut (impl rand::Rng + ?Sized),
) -> Result<(Deal, solver::TricksTable), solver::Error> {
const N: usize = dds_bridge_sys::MAXNOOFTABLES as usize;
loop {
let deals: [_; N] = core::array::from_fn(|_| get_random_symmetric_deal(rng));
let tables = unsafe { solver::solve_deal_segment(&deals, solver::StrainFlags::all())? };
for (i, &table) in tables.results[..N].iter().enumerate() {
let tricks = solver::TricksTable::from(table);
let pars = solver::calculate_pars(tricks, solver::Vulnerability::all())?;
if pars[0].score + pars[1].score > 0 {
return Ok((deals[i], tricks));
}
}
}
}
#[doc = include_str!("README.md")]
fn main() -> Result<ExitCode, solver::Error> {
let deals = match std::env::args().nth(1) {
Some(string) => {
if let Ok(n) = string.parse::<usize>() {
n
} else {
eprintln!("{}", include_str!("README.md"));
return Ok(ExitCode::FAILURE);
}
}
None => 1,
};
for _ in 0..deals {
let (deal, tricks) = compute_deal(&mut rand::rng())?;
println!(
"{} {:X}",
deal.display(Seat::North),
tricks.hex(Seat::North, Strain::SYS)
);
}
Ok(ExitCode::SUCCESS)
}