function [L_norm] = add_selfloops_to_H(s, t, weights, ~)
    G = graph(s, t, weights);
    A = adjacency(G, 'weighted');
    degrees = sum(abs(adjacency(G, 'weighted')), 2);
    D = diag(degrees);
    for i = 1:length(s)
        if s(i) == t(i)
            degree_v = degrees(s(i));
            if degree_v > 0
                A(s(i), t(i)) = 2 * (weights(i) / degree_v);
            end
        end
    end
    L = D - A;
    D_inv_sqrt = diag(1 ./ sqrt(degrees));
    L_norm = D_inv_sqrt * L * D_inv_sqrt;
end
