• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1#version 450 core
2#define PRECISION ${PRECISION}
3#define FORMAT ${FORMAT}
4
5layout(std430) buffer;
6
7/* Qualifiers: layout - storage - precision - memory */
8
9layout(set = 0, binding = 0, FORMAT) uniform PRECISION restrict image3D uOutput;
10layout(set = 0, binding = 1)         uniform PRECISION restrict Block {
11  ivec4 size;
12  float lambd;
13} uBlock;
14
15layout(local_size_x_id = 0, local_size_y_id = 1, local_size_z_id = 2) in;
16
17void main() {
18  const ivec3 pos = ivec3(gl_GlobalInvocationID);
19
20  if (all(lessThan(pos, uBlock.size.xyz))) {
21    const vec4 inval = imageLoad(uOutput, pos);
22    const vec4 mask = vec4(greaterThanEqual(inval, vec4(-uBlock.lambd)))*vec4(lessThanEqual(inval, vec4(uBlock.lambd)));
23    const vec4 outval = (vec4(1.0) - mask)*inval;
24    imageStore(uOutput, pos, outval);
25  }
26}
27