function L_norm = compute_normalized_laplacian(s, t, weights, num_nodes)
    A = zeros(num_nodes, num_nodes);
    for i = 1:length(s)
        A(s(i), t(i)) = A(s(i), t(i)) + weights(i);
        A(t(i), s(i)) = A(t(i), s(i)) + weights(i);
    end
    degrees = sum(A, 2);
    D = diag(degrees);
    L = D - A;
    D_inv_sqrt_values = 1 ./ sqrt(degrees);
    D_inv_sqrt_values(~isfinite(D_inv_sqrt_values)) = 0;
    D_inv_sqrt = diag(D_inv_sqrt_values);
    L_norm = D_inv_sqrt * L * D_inv_sqrt;
end
