3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-10 19:27:06 +00:00
z3/test/inf_rational.cpp
Leonardo de Moura 68269c43a6 other components
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
2012-10-02 11:48:48 -07:00

184 lines
5.2 KiB
C++

/*++
Copyright (c) 2006 Microsoft Corporation
Module Name:
tst_inf_rational.cpp
Abstract:
Test for Rational numbers with infinitesimals
Author:
Leonardo de Moura (leonardo) 2006-09-18.
Nikolaj Bjorner (nbjorner) 2006-10-24.
Revision History:
--*/
#include"inf_rational.h"
static void tst0() {
inf_rational n(rational(0), false);
TRACE("inf_rational", tout << n << "\n";);
SASSERT(n < inf_rational::zero());
SASSERT(!(n >= inf_rational::zero()));
}
void test_inc_dec(
inf_rational& r,
inf_rational const & b_8_5,
inf_rational const & b_7_5,
inf_rational const & b_7_10,
inf_rational const & b_17_10
)
{
r += rational(1,5);
SASSERT (r == b_8_5);
r -= rational(1,5);
SASSERT (r == b_7_5);
r += inf_rational(1,5);
SASSERT (r == b_8_5);
r -= inf_rational(1,5);
SASSERT (r == b_7_5);
r /= rational(2,1);
SASSERT (r == b_7_10);
inf_rational r_pre = r++;
SASSERT (r_pre == b_7_10);
SASSERT (r == b_17_10);
inf_rational r_post = --r;
SASSERT (r_post == b_7_10);
SASSERT (r == b_7_10);
r_post = ++r;
SASSERT (r_post == b_17_10);
SASSERT (r == b_17_10);
r_pre = r--;
SASSERT (r_pre == b_17_10);
SASSERT (r == b_7_10);
r_pre = r;
r_pre += inf_rational(1,2);
r_post = r_pre;
r_post -= inf_rational(1,2);
SASSERT(r == r_post);
SASSERT(r + inf_rational(1,2) == r_pre);
r_pre = r;
r_pre /= rational(2,1);
r_post = r_pre;
r_post /= rational(1,2);
SASSERT(r == r_post);
SASSERT(rational(1,2) * r == r_pre);
SASSERT(r == r_pre / rational(1,2));
}
void
tst_inf_rational()
{
tst0();
inf_rational r1;
inf_rational r2(r1);
SASSERT (r1 == r2);
inf_rational r3(1);
inf_rational r4(0);
SASSERT (r4 == r1);
SASSERT (r3 != r4);
inf_rational r5(0,1);
inf_rational r6(1,1);
inf_rational r7(2,2);
inf_rational r8(7,5);
SASSERT (r1 == r5);
SASSERT (r6 == r3);
SASSERT (r7 == r3);
inf_rational r9(rational(7,5));
SASSERT (r8 == r9);
r9.reset();
SASSERT (r1 == r9);
SASSERT (r1.is_int());
SASSERT (!r8.is_int());
SASSERT (0 == r1.get_int64());
r9 = r8;
SASSERT (r8 == r9);
inf_rational n = numerator(r7);
inf_rational d = denominator(r7);
{
inf_rational b_8_5 = inf_rational(8,5);
inf_rational b_7_5 = inf_rational(7,5);
inf_rational b_7_10 = inf_rational(7,10);
inf_rational b_17_10 = inf_rational(17,10);
inf_rational r = r9;
test_inc_dec(r, b_8_5, b_7_5, b_7_10, b_17_10);
}
{
inf_rational b_8_5 = inf_rational(rational(8,5),true);
inf_rational b_7_5 = inf_rational(rational(7,5),true);
inf_rational b_7_10 = inf_rational(rational(7,5),true) / rational(2);
inf_rational b_17_10 = b_7_10 + inf_rational(1);
inf_rational r (rational(7,5),true);
test_inc_dec(r, b_8_5, b_7_5, b_7_10, b_17_10);
}
SASSERT(inf_rational(rational(1,2),true) > inf_rational(rational(1,2)));
SASSERT(inf_rational(rational(1,2),false) < inf_rational(rational(1,2)));
SASSERT(inf_rational(rational(1,2),true) >= inf_rational(rational(1,2)));
SASSERT(inf_rational(rational(1,2)) >= inf_rational(rational(1,2),false));
SASSERT(inf_rational(rational(1,2),false) != inf_rational(rational(1,2)));
SASSERT(inf_rational(rational(1,2),true) != inf_rational(rational(1,2)));
SASSERT(inf_rational(rational(1,2),false) != inf_rational(rational(1,2),true));
inf_rational h_neg(rational(1,2),false);
inf_rational h_pos(rational(1,2),true);
h_neg.neg();
SASSERT(h_neg == -inf_rational(rational(1,2),false));
h_neg.neg();
SASSERT(h_neg == inf_rational(rational(1,2),false));
SASSERT(r1.is_zero() && !r1.is_one() && !r1.is_neg() && r1.is_nonneg() && r1.is_nonpos() && !r1.is_pos());
SASSERT(!r3.is_zero() && r3.is_one() && !r3.is_neg() && r3.is_nonneg() && !r3.is_nonpos() && r3.is_pos());
SASSERT(floor(inf_rational(rational(1,2),false)) == rational());
SASSERT(floor(inf_rational(rational(1,2))) == rational());
SASSERT(floor(inf_rational(rational(),false)) == rational(-1));
SASSERT(floor(inf_rational(rational())) == rational());
SASSERT(floor(inf_rational(rational(),true)) == rational());
SASSERT(floor(inf_rational(rational(1),false)) == rational());
SASSERT(floor(inf_rational(rational(1))) == rational(1));
SASSERT(floor(inf_rational(rational(1),true)) == rational(1));
SASSERT(ceil(inf_rational(rational(1,2),false)) == rational(1));
SASSERT(ceil(inf_rational(rational(1,2))) == rational(1));
SASSERT(ceil(inf_rational(rational(),false)) == rational());
SASSERT(ceil(inf_rational(rational())) == rational());
SASSERT(ceil(inf_rational(rational(),true)) == rational(1));
SASSERT(ceil(inf_rational(rational(1),false)) == rational(1));
SASSERT(ceil(inf_rational(rational(1))) == rational(1));
SASSERT(ceil(inf_rational(rational(1),true)) == rational(2));
unsigned h = r9.hash();
inf_rational x(rational(1,2),true);
inf_rational y(1,2);
x.swap(y);
SASSERT (x == inf_rational(1,2));
SASSERT (y == inf_rational(rational(1,2),true));
SASSERT(inf_rational(1,2) == abs(-inf_rational(1,2)));
}