1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
|
#include "test_static.isph"
uniform float Neg(uniform float inVal) {
return -inVal;
}
void test_uni(uniform float RET[]) {
uniform float val;
unsigned int signBit;
uniform float retval;
RET[programIndex] = 0;
val = 0.0;
signBit = signbits(val);
if (signBit != 0)
RET[programIndex] = 1;
retval = Neg(val);
signBit = signbits(retval);
if (signBit == 0)
RET[programIndex] = 1;
val = -0.0;
signBit = signbits(val);
if (signBit == 0)
RET[programIndex] = 1;
retval = Neg(val);
signBit = signbits(retval);
if (signBit != 0)
RET[programIndex] = 1;
}
task void f_v(uniform float RET[]) {
test_uni(RET);
}
task void result(uniform float RET[]) { RET[programIndex] = 0; }
|