function [s, t, weights, group_labels] = stochastic_block_model(n, p, q, group_labels)
    if nargin < 4
        group_labels = randsample([1, 2], n, true);
    end
    s = [];
    t = [];
    weights = [];
    for i = 1:n
        for j = (i+1):n
            if group_labels(i) == group_labels(j)
                if rand() < p
                    s = [s; i];
                    t = [t; j];
                    weights = [weights; 1];
                end
            else
                if rand() < q
                    s = [s; i];
                    t = [t; j];
                    weights = [weights; 1];
                end
            end
        end
    end
end