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

29 lines
636 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;
}
assert(programIndex + 2 < 80);
RET[programIndex] = pts[programIndex+2].vec.y;
}
export void result(uniform float RET[]) {
RET[programIndex] = -(5 * (programIndex+2));
}