Skip to content

Commit

Permalink
Merge pull request #183 from losos0/testoutput
Browse files Browse the repository at this point in the history
[Quantum Chess] Improve test failure output
  • Loading branch information
dstrain115 authored Mar 21, 2024
2 parents 97bcb1e + 406f3f8 commit cdb03c9
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 26 deletions.
10 changes: 2 additions & 8 deletions unitary/quantum_chess/quantum_board_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@
from unitary.quantum_chess.test_utils import (
assert_sample_distribution,
assert_samples_in,
assert_this_or_that,
assert_prob_about,
assert_fifty_fifty,
)
Expand Down Expand Up @@ -182,10 +181,7 @@ def test_split_move(move_type, board):
move_variant=enums.MoveVariant.BASIC,
)
)
samples = b.sample(100)
assert_this_or_that(
samples, u.squares_to_bitboard(["a3"]), u.squares_to_bitboard(["c1"])
)
assert_samples_in(b, [u.squares_to_bitboard(["a3"]), u.squares_to_bitboard(["c1"])])
probs = b.get_probability_distribution(5000)
assert_fifty_fifty(probs, qb.square_to_bit("a3"))
assert_fifty_fifty(probs, qb.square_to_bit("c1"))
Expand All @@ -200,9 +196,7 @@ def test_split_move(move_type, board):
)
assert b.do_move(m)
samples = b.sample(100)
assert_this_or_that(
samples, u.squares_to_bitboard(["a3"]), u.squares_to_bitboard(["d1"])
)
assert_samples_in(b, [u.squares_to_bitboard(["a3"]), u.squares_to_bitboard(["d1"])])
probs = b.get_probability_distribution(5000)
assert_fifty_fifty(probs, u.square_to_bit("a3"))
assert_fifty_fifty(probs, u.square_to_bit("d1"))
Expand Down
36 changes: 18 additions & 18 deletions unitary/quantum_chess/test_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,28 +17,39 @@
import unitary.quantum_chess.bit_utils as u


def print_samples(samples):
"""For debugging only. Prints all the samples as lists of squares."""
def bitboard_to_string(bitboard):
"""Returns space-separated string of square names."""
return "[" + " ".join(u.bitboard_to_squares(bitboard)) + "]"


def print_samples(samples, possibilities):
"""For debugging only. Prints expected and actual lists of squares."""
print("Expected bitboards:")
for bitboard in possibilities:
print(" " * 5, bitboard_to_string(bitboard))
print("Sample distribution:")
sample_dict = {}
for sample in samples:
if sample not in sample_dict:
sample_dict[sample] = 0
sample_dict[sample] += 1
for key in sample_dict:
print(f"{u.bitboard_to_squares(key)}: {sample_dict[key]}")
print(f"{sample_dict[key]:5} {bitboard_to_string(key)}")


def assert_samples_in(b, possibilities):
def message(message):
print_samples(samples, possibilities)
return message

samples = b.sample(500)
assert len(samples) == 500
all_in = all(sample in possibilities for sample in samples)
print(possibilities)
print(set(samples))
assert all_in, print_samples(samples)
assert all_in, message("Unexpected bitboard in samples")
# make sure each is represented at least once
for p in possibilities:
any_in = any(sample == p for sample in samples)
assert any_in, print_samples(samples)
assert any_in, message("Not all expected bitboards appeared")


def assert_sample_distribution(b, probability_map, p_significant=1e-6):
Expand Down Expand Up @@ -67,17 +78,6 @@ def assert_sample_distribution(b, probability_map, p_significant=1e-6):
), f"Observed {observed} far from expected {expected} (p = {p})"


def assert_this_or_that(samples, this, that):
"""Asserts all the samples are either equal to this or that,
and that one of each exists in the samples.
"""
assert any(sample == this for sample in samples)
assert any(sample == that for sample in samples)
assert all(sample == this or sample == that for sample in samples), print_samples(
samples
)


def assert_prob_about(probs, that, expected, atol=0.04):
"""Checks that the probability is within atol of the expected value."""
assert probs[that] > expected - atol
Expand Down

0 comments on commit cdb03c9

Please sign in to comment.