function hat_x = gradientdescent(x, grad_f, alpha, lambda, idxes_group_free, group_indexes)

hat_x = x;

for i = 1 : length(idxes_group_free)
    group = group_indexes{idxes_group_free(i)};
    hat_x(group) = hat_x(group) - alpha * grad_f(group) - alpha * lambda * x(group) / norm(x(group));
end 

end

