diffblue-cbmc/regression/cbmc-with-incr/Float-no-simp2/main.c

66 lines
1.3 KiB
C

int main()
{
double f, f2;
// the following rely on f not being a NaN
__CPROVER_assume(!__CPROVER_isnand(f2));
__CPROVER_assume(__CPROVER_isfinited(f2));
f=f2;
// addition
assert(100.0+10==110);
assert(0+f==f);
// assert(f+0==f);
assert(100+0.5==100.5);
// assert(0.0+0.0+f==f);
// subtraction
assert(100.0-10==90);
// assert(0-f==-f);
// assert(f-0==f);
assert(100-0.5==99.5);
// assert(0.0-0.0-f==-f);
// unary minus
assert(-(-100.0)==100);
assert(-(1-2.0)==1);
assert(-(-f)==f);
// multiplication
assert(100.0*10==1000);
assert(0*f==0);
assert(f*0==0);
assert(100*0.5==50);
assert(f*1==f);
// assert(1*f==f);
// assert(1.0*1.0*f==f);
// division
assert(100.0/1.0==100);
assert(100.1/1.0==100.1);
assert(100.0/2.0==50);
assert(100.0/0.5==200);
assert(0/1.0==0);
assert(f/1.0==f);
// conversion
assert(((double)(float)100)==100.0);
assert(((unsigned int)100.0)==100.0);
assert(100.0);
assert(!0.0);
assert((int)0.5==0);
assert((int)0.49==0);
assert((int)-1.5==-1);
assert((int)-10.49==-10);
// relations
assert(1.0<2.5);
assert(1.0<=2.5);
assert(1.01<=1.01);
assert(2.5>1.0);
assert(2.5>=1.0);
assert(1.01>=1.01);
assert(!(1.0>=2.5));
assert(!(1.0>2.5));
assert(1.0!=2.5);
}