24 lines
613 B
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;
|
|
}
|