function H = createInverseSimilarityHMatrix(graphStruct, values, sigma)
    N = length(values);
    if N ~= size(graphStruct.coordinates, 1)
        error('The length of values does not match the number of nodes in the graph.');
    end
    abs_diff_matrix = zeros(N, N);
    for i = 1:N
        for j = 1:N
            abs_diff_matrix(i, j) = abs(values(i) - values(j));
        end
    end
    abs_diff_list = abs_diff_matrix(triu(true(size(abs_diff_matrix)), 1));
    sorted_diffs = sort(abs_diff_list);
    sigma_similar = median(sorted_diffs);
    H = zeros(N, N);
    for i = 1:N
        for j = 1:N
            diff = values(i) - values(j);
            if abs(diff) < sigma_similar
                H(i,j) = 0;
            else
                H(i,j) =  1-exp(-(diff)^2 / (5 * sigma^2));
            end
        end
    end
end