import random

from recognizers.automata.finite_automaton import (
    FiniteAutomatonContainer,
    FiniteAutomatonTransition,
    State
)
from recognizers.automata.trim_dfa import trim_dfa
from recognizers.random_utils import (
    sample_from_negative_binomial,
    sample_from_bernoulli
)

def sample_podfa(
    mean_num_states: float,
    mean_alphabet_size: float,
    transition_probability: float,
    accept_probability: float,
    generator: random.Random
) -> FiniteAutomatonContainer:
    num_states = sample_from_negative_binomial(mean_num_states, 1, generator)
    alphabet_size = sample_from_negative_binomial(mean_alphabet_size, 1, generator)
    M = FiniteAutomatonContainer(
        num_states=num_states,
        alphabet_size=alphabet_size
    )
    for q in range(num_states):
        for a in M.alphabet():
            if sample_from_bernoulli(transition_probability, generator):
                r = State(generator.randrange(q, num_states))
                M.add_transition(FiniteAutomatonTransition(State(q), a, r))
        if sample_from_bernoulli(accept_probability, generator):
            M.add_accept_state(q)
    M = trim_dfa(M)
    print(f"num states: {M.num_states()}, alphabet size: {M.alphabet_size()}")
    return M
