Added tests and documentation for soa<> rate qualifier.
This commit is contained in:
48
tests/soa-15.ispc
Normal file
48
tests/soa-15.ispc
Normal file
@@ -0,0 +1,48 @@
|
||||
|
||||
struct Point { float x, y[3], z; };
|
||||
|
||||
export uniform int width() { return programCount; }
|
||||
|
||||
static void p(uniform float *uniform ptr) {
|
||||
for (uniform int s = 0; s < 4; ++s) {
|
||||
for (uniform int i = 0; i < 5; ++i) {
|
||||
for (uniform int j = 0; j < 4; ++j, ++ptr)
|
||||
print("% ", *ptr);
|
||||
print("\n");
|
||||
}
|
||||
print("\n");
|
||||
}
|
||||
}
|
||||
|
||||
export void f_fu(uniform float RET[], uniform float aFOO[], uniform float b) {
|
||||
soa<4> Point pts[10];
|
||||
//CO uniform Point pts[40];
|
||||
//CO foreach (i = 0 ... 40) {
|
||||
for (uniform int i = 0; i < 40; ++i) {
|
||||
pts[i].x = b*i;
|
||||
pts[i].y[0] = 2*b*i;
|
||||
pts[i].y[1] = 2*b*i+1;
|
||||
pts[i].y[2] = 2*b*i+2;
|
||||
pts[i].z = 3*b*i;
|
||||
}
|
||||
|
||||
//CO p((uniform float * uniform)&pts[0]);
|
||||
|
||||
//CO print("delta %\n", ((uniform float * varying)(&pts[2+programIndex]) -
|
||||
//CO (uniform float * uniform)&pts[0]));
|
||||
|
||||
float a = aFOO[programIndex];
|
||||
a *= -1;
|
||||
Point vp = { a, { 2*a, 3*a, 4*a }, {5*a} };
|
||||
pts[2+programIndex] = vp;
|
||||
|
||||
//CO p((uniform float * uniform)&pts[0]);
|
||||
|
||||
RET[programIndex] = pts[programIndex].y[2];
|
||||
}
|
||||
|
||||
export void result(uniform float RET[]) {
|
||||
RET[programIndex] = -4 * (programIndex-1);
|
||||
RET[0] = 2;
|
||||
RET[1] = 12;
|
||||
}
|
||||
Reference in New Issue
Block a user