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
|
#include "test_static.isph"
struct Vector { float x, y, z; };
struct Ray { Vector o; float t; Vector d; };
void init(uniform Ray rays[], uniform int count, float v) {
for (uniform int i = 0; i < count; ++i) {
rays[i].o.x = i;
rays[i].o.y = 2*i;
rays[i].o.z = 3*i;
rays[i].t = 4*i;
rays[i].d.x = 5*i;
rays[i].d.y = 6*i;
rays[i].d.z = 7*i;
}
}
void zero_dx(Ray &r) {
r.d.x = 0;
}
task void f_fu(uniform float RET[], uniform float aFOO[], uniform float b) {
float v = aFOO[programIndex];
uniform Ray rays[programCount+1];
init(rays, programCount+1, v);
#pragma ignore warning(perf)
Ray rg = rays[v];
zero_dx(rg);
RET[programIndex] = rg.o.z + rg.d.x;
}
task void result(uniform float RET[]) {
RET[programIndex] = 3 + 3*programIndex;
}
|