24 lines
613 B

#include "test_I.h"
int test_I_logior (int iterations)
{
int error = 0;
int i;
// Check commutativity.
for (i = iterations; i > 0; i--) {
cl_I a = testrandom_I();
cl_I b = testrandom_I();
ASSERT2(logior(a,b) == logior(b,a), a,b);
}
// Check against ash and oddp.
for (i = iterations; i > 0; i--) {
cl_I a = testrandom_I();
cl_I b = testrandom_I();
ASSERT2(oddp(logior(a,b)) == (oddp(a) | oddp(b)), a,b);
sintL c = random32() % 1024;
ASSERT3(logior(ash(a,c),ash(b,c)) == ash(logior(a,b),c), a,b,c);
ASSERT3(logior(ash(a,-c),ash(b,-c)) == ash(logior(a,b),-c), a,b,c);
}
return error;
}