Files
2025-05-18 13:04:45 +08:00

14 lines
426 B
Plaintext

uniform unsigned int32 s = 0;
export void f_f(uniform float RET[], uniform float aFOO[]) {
float a = aFOO[programIndex];
int32 b = 0;
if (programIndex < 28 && (programIndex & 1))
b = atomic_or_local(&s, (1ul << programIndex));
RET[programIndex] = popcnt(reduce_max(b));
}
export void result(uniform float RET[]) {
RET[programIndex] = (programCount == 1) ? 0 : ((min(28, programCount)/2) - 1);
}