import sys
sys.path.append('../../../')

from model_checking import dfa

n_automaton_states = 12

automaton = dfa.DFA([s for s in range(n_automaton_states)], 0, [11])
automaton.add_edge(0, 1, dfa.And(dfa.Atom('goal'), dfa.Neg(dfa.Atom('blue'))))
automaton.add_edge(1, 0, dfa.Atom('blue'))
automaton.add_edge(1, 2, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(2, 0, dfa.Atom('blue'))
automaton.add_edge(2, 3, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(3, 0, dfa.Atom('blue'))
automaton.add_edge(3, 4, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(4, 0, dfa.Atom('blue'))
automaton.add_edge(4, 5, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(5, 0, dfa.Atom('blue'))
automaton.add_edge(5, 6, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(6, 0, dfa.Atom('blue'))
automaton.add_edge(6, 7, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(7, 0, dfa.Atom('blue'))
automaton.add_edge(7, 8, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(8, 0, dfa.Atom('blue'))
automaton.add_edge(8, 9, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(9, 0, dfa.Atom('blue'))
automaton.add_edge(9, 10, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(10, 0, dfa.Atom('blue'))
automaton.add_edge(10, 11, dfa.Neg(dfa.Atom('blue')))

automaton.add_edge(11, 0, dfa.Truth())

cost_function = dfa.Cost_Function(automaton)