Files
ispc/tests/soa-24.ispc
2012-05-30 10:31:12 -07:00

33 lines
747 B
Plaintext

struct Point { float x, y, z; };
struct Foo {
float<3> vec;
int8 z;
};
export uniform int width() { return programCount; }
export void f_fu(uniform float RET[], uniform float aFOO[], uniform float b) {
float a = aFOO[programIndex];
soa<8> Foo * uniform pts = uniform new soa<8> Foo[10];
foreach (i = 0 ... 80) {
pts[i].vec.x = b*i;
pts[i].vec.y = -b*i;
pts[i].vec.z = 2*b*i;
pts[i].z = i;
}
pts[programIndex+2].vec.z *= -1;
assert(programIndex < 80);
float<3> vl = pts[programIndex].vec;
RET[programIndex] = vl.z;
}
export void result(uniform float RET[]) {
RET[programIndex] = 10 * programIndex;
if (programIndex >= 2)
RET[programIndex] *= -1;
}