opt_step_sgd.comp 612 B

12345678910111213141516171819202122
  1. #version 450
  2. #include "generic_head.comp"
  3. layout(local_size_x = 512, local_size_y = 1, local_size_z = 1) in;
  4. layout (binding = 0) buffer X {A_TYPE data_x[];};
  5. layout (binding = 1) readonly buffer G {A_TYPE data_grad[];};
  6. layout (binding = 2) readonly buffer P {float data_params[2];};
  7. void main() {
  8. const uint i = gl_GlobalInvocationID.z * 262144 + gl_GlobalInvocationID.y * 512 + gl_GlobalInvocationID.x;
  9. if (i >= p.KX) {
  10. return;
  11. }
  12. const float alpha = data_params[0];
  13. const float keep = 1.f - alpha * data_params[1];
  14. data_x[i] = data_x[i] * keep - alpha * data_grad[i];
  15. }