data:image/s3,"s3://crabby-images/71cbc/71cbcac6d6a8e3c4a3a4a9be0b0465f806b5221a" alt="Compute shader example opengl 4.3"
data:image/s3,"s3://crabby-images/613ff/613ff6887b7396e04cbaadce64ec9036b416451d" alt="compute shader example opengl 4.3 compute shader example opengl 4.3"
That creates 2 x 3 x 4 = 24 different work groups, as shows in the picture above.
data:image/s3,"s3://crabby-images/ea0f0/ea0f02ffe69b5b30c4605d586c4a467a9abc0d29" alt="compute shader example opengl 4.3 compute shader example opengl 4.3"
Note that you need a recent OS to run this. Total number of compute shader invocations = Number of Work Groups x Local SizeĪ compute shader cant be executed on its own, it must first be linked to a "program object": Simple tests of OpenGL 4.3 compute shaders. Each invocation can be considered as 1 thread which is executed in parallel to all the other invocations within that work group.
data:image/s3,"s3://crabby-images/1ab93/1ab938f139134d88bc1072c04d44b95195c1c70f" alt="compute shader example opengl 4.3 compute shader example opengl 4.3"
Here there are 5 x 6 x 7 = 210 different invocations per work group.Īll compute shader invocations within 1 work group can share processed data. OpenGL got computer shader support in version 4.3 but we are going with version 4.5. Since it is kinda easy and I know it at the basic level, we can go with that. In this implementation, I am going to use OpenGL. Now, each of those small cubes is 1 compute shader invocation. The fragment shader is going to gamma correct our image and render the image to the screen.
data:image/s3,"s3://crabby-images/71cbc/71cbcac6d6a8e3c4a3a4a9be0b0465f806b5221a" alt="Compute shader example opengl 4.3"