clear all;
clc;
n = 200;
n_per_cluster = n / 2;
radius = 0.2;
rng(1);
cluster_distance = 0.4;
theta1 = rand(n_per_cluster, 1) * 2 * pi;
r1 = radius * sqrt(rand(n_per_cluster, 1));
x1 = [r1 .* cos(theta1), r1 .* sin(theta1)];
theta2 = rand(n_per_cluster, 1) * 2 * pi;
r2 = radius * sqrt(rand(n_per_cluster, 1));
x2 = [r2 .* cos(theta2) + cluster_distance, r2 .* sin(theta2)];
x = [x1; x2];
r_intra_G = 0.1;
r_inter_G = 0.05;
A_G = zeros(n, n);
for i = 1:n_per_cluster
    for j = i+1:n_per_cluster
        if norm(x1(i, :) - x1(j, :)) < r_intra_G
            A_G(i, j) = 1;
            A_G(j, i) = 1;
        end
        if norm(x2(i, :) - x2(j, :)) < r_intra_G
            A_G(i + n_per_cluster, j + n_per_cluster) = 1;
            A_G(j + n_per_cluster, i + n_per_cluster) = 1;
        end
    end
end
for i = 1:n_per_cluster
    for j = 1:n_per_cluster
        if norm(x1(i, :) - x2(j, :)) < r_inter_G
            A_G(i, j + n_per_cluster) = 1;
            A_G(j + n_per_cluster, i) = 1;
        end
    end
end
figure;
hold on;
[s, t] = find(triu(A_G));
for k = 1:length(s)
    plot([x(s(k), 1), x(t(k), 1)], [x(s(k), 2), x(t(k), 2)], '-k');
end
scatter(x1(:, 1), x1(:, 2), 20, 'filled', 'MarkerFaceColor', 'b');
scatter(x2(:, 1), x2(:, 2), 20, 'filled', 'MarkerFaceColor', 'r');
plot([0, 0], [0, 0.2], ':k', 'LineWidth', 1.5);
plot([0, cluster_distance], [0.2, 0.2], ':k', 'LineWidth', 1.5);
plot([cluster_distance, cluster_distance], [0.2, 0], ':k', 'LineWidth', 1.5);
text(cluster_distance/2, 0.22, 'distance of clusters', 'HorizontalAlignment', 'center', 'FontSize', 10);
set(gca, 'Color', 'w', 'XColor', 'none', 'YColor', 'none');
axis equal;
hold off;
