function [G] = Gradient_snn(y, x, W, P)

    y_e = y_snn(x , W , P);
    
    [d, K] = size( W);
    
    G = zeros( d , K);
    
    for j = 1 : K
    
        G(: , j) = mean( repmat(( y_e - y ) .* (W(:,j)' * x > 0), d , 1 ) .* x, 2);
    
    end

    G = G .* P;

end

