48 lines
1.1 KiB
GLSL
48 lines
1.1 KiB
GLSL
#version 310 es
|
|
|
|
struct Uniforms {
|
|
uvec2 aShape;
|
|
uvec2 bShape;
|
|
uvec2 outShape;
|
|
uint pad;
|
|
uint pad_1;
|
|
};
|
|
|
|
layout(binding = 0, std430) buffer Matrix_ssbo {
|
|
uint numbers[];
|
|
} firstMatrix;
|
|
|
|
layout(binding = 1, std430) buffer Matrix_ssbo_1 {
|
|
uint numbers[];
|
|
} secondMatrix;
|
|
|
|
layout(binding = 2, std430) buffer Matrix_ssbo_2 {
|
|
uint numbers[];
|
|
} resultMatrix;
|
|
|
|
layout(binding = 3, std140) uniform uniforms_block_ubo {
|
|
Uniforms inner;
|
|
} uniforms;
|
|
|
|
void tint_symbol(uvec3 global_id) {
|
|
uvec2 resultCell = uvec2(global_id.y, global_id.x);
|
|
uint dimInner = uniforms.inner.aShape.y;
|
|
uint dimOutter = uniforms.inner.outShape.y;
|
|
uint result = 0u;
|
|
{
|
|
for(uint i = 0u; (i < dimInner); i = (i + 1u)) {
|
|
uint a = (i + (resultCell.x * dimInner));
|
|
uint b = (resultCell.y + (i * dimOutter));
|
|
result = (result + (firstMatrix.numbers[a] * secondMatrix.numbers[b]));
|
|
}
|
|
}
|
|
uint index = (resultCell.y + (resultCell.x * dimOutter));
|
|
resultMatrix.numbers[index] = result;
|
|
}
|
|
|
|
layout(local_size_x = 2, local_size_y = 2, local_size_z = 1) in;
|
|
void main() {
|
|
tint_symbol(gl_GlobalInvocationID);
|
|
return;
|
|
}
|