get_rows_quant.comp 970 B

12345678910111213141516171819202122232425262728293031
  1. #version 450
  2. #include "types.comp"
  3. #include "generic_binary_head.comp"
  4. #include "dequant_funcs.comp"
  5. void main() {
  6. const uint i00 = (gl_GlobalInvocationID.x)*2;
  7. const uint i10 = gl_GlobalInvocationID.y;
  8. const uint i11 = (gl_GlobalInvocationID.z)/p.ne12;
  9. const uint i12 = (gl_GlobalInvocationID.z)%p.ne12;
  10. if (i00 >= p.ne00) {
  11. return;
  12. }
  13. const uint i01 = data_b[i10*p.nb10 + i11*p.nb11 + i12*p.nb12];
  14. const uint a_offset = i01*p.nb01 + i11*p.nb02 + i12*p.nb03;
  15. const uint d_offset = i10*p.nb21 + i11*p.nb22 + i12*p.nb23;
  16. const uint ib = a_offset + i00/QUANT_K; // block index
  17. const uint iqs = (i00%QUANT_K)/QUANT_R; // quant index
  18. const uint iybs = i00 - i00%QUANT_K; // dst block start index
  19. const uint y_offset = QUANT_R == 1 ? 1 : QUANT_K/2;
  20. vec2 v = dequantize(ib, iqs, 0);
  21. data_d[d_offset + iybs + iqs ] = D_TYPE(v.x);
  22. data_d[d_offset + iybs + iqs + y_offset] = D_TYPE(v.y);
  23. }