function A = generate_geometric_graph_adjacency(n_per_cluster, r_intra, r_inter, noise_prob, x1, x2)
    x = [x1; x2];
    n = 2 * n_per_cluster;
    A = zeros(n, n);
    for i = 1:n_per_cluster
        for j = i+1:n_per_cluster  
            if norm(x1(i, :) - x1(j, :)) < r_intra
                A(i, j) = 1;
            end
            if norm(x2(i, :) - x2(j, :)) < r_intra
                A(i + n_per_cluster, j + n_per_cluster) = 1;
            end
        end
    end
    for i = 1:n_per_cluster
        for j = 1:n_per_cluster
            if rand() < noise_prob && norm(x1(i, :) - x2(j, :)) < r_inter
                A(i, j + n_per_cluster) = 1;
            end
        end
    end
end
