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
)
from recognizers.automata.podfa_check import is_podfa
from recognizers.dataset_generation.weighted_language import PODFALanguageError

def sample_dfa(
    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 M.states():
        for a in M.alphabet():
            if sample_from_bernoulli(transition_probability, generator):
                r = State(generator.randrange(num_states))
                M.add_transition(FiniteAutomatonTransition(q, a, r))
        if sample_from_bernoulli(accept_probability, generator):
            M.add_accept_state(q)
    M = trim_dfa(M)
    if is_podfa(M):
        raise PODFALanguageError('star-free language, subset of regular')
    return M
