import pathlib
import argparse
import torch

if __name__ == '__main__':

    parser = argparse.ArgumentParser()
    parser.add_argument('--language-file', type=pathlib.Path, required=True, help='A .pt language file.')
    args = parser.parse_args()
    language_file = args.language_file

    data = torch.load(language_file, weights_only=False, map_location=torch.device('cpu'))
    depth = data['depth']
    dfa = data['language']
    transitions = dfa.transitions()
    alphabet_size = dfa.alphabet_size()
    num_states = dfa.num_states()
    sink_state = num_states
    dfa_dict = {
        a: [sink_state] * (num_states + 1) for a in range(alphabet_size)
    }
    for t in transitions:
        p, a, q = t.state_from, t.symbol, t.state_to
        dfa_dict[a][p] = q
    print(f'Upper bound dot depth: {depth}')
    for sym, trans in dfa_dict.items():
        gap_list = [q + 1 for q in trans]
        print(f"a{sym} := Transformation({gap_list});")

