function [clusters, second_smallest_eigenvalue, fiedler_vector] = spectral_clustering(s, t, weights)
    G = graph(s, t, weights);
    L = laplacian(G);
    D = degree(G);
    D_sqrt = sqrt(D);
    D_inv_sqrt = 1 ./ D_sqrt;
    D_inv_sqrt(~isfinite(D_inv_sqrt)) = 0;
    D_inv_sqrt = diag(D_inv_sqrt);
    L_norm = D_inv_sqrt * L * D_inv_sqrt;
    opts.isreal = true;
    opts.issym = true;
    [V, D_eig] = eigs(L_norm, 2, 'smallestabs', opts);
    fiedler_vector = V(:, 2);
    second_smallest_eigenvalue = D_eig(2, 2);
    clusters = kmeans(fiedler_vector, 2);
end