import sys
sys.path.append('../')

from model_checking import dfa
from model_checking import lt
from model_checking import pctl

n_automaton_states = 62

automaton = dfa.DFA([s for s in range(n_automaton_states)], 0, [61])
automaton.add_edge(0, 1, dfa.Atom('goal'))
''''''
automaton.add_edge(1, 11, dfa.Atom('purple'))
automaton.add_edge(1, 2, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(11, 12, dfa.Atom('purple'))
automaton.add_edge(11, 3, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(12, 13, dfa.Atom('purple'))
automaton.add_edge(12, 4, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(13, 14, dfa.Atom('purple'))
automaton.add_edge(13, 5, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(14, 15, dfa.Atom('purple'))
automaton.add_edge(14, 6, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(15, 0, dfa.Atom('purple'))
automaton.add_edge(15, 7, dfa.Neg(dfa.Atom('purple')))
''''''
''''''
automaton.add_edge(2, 16, dfa.Atom('purple'))
automaton.add_edge(2, 3, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(16, 17, dfa.Atom('purple'))
automaton.add_edge(16, 4, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(17, 18, dfa.Atom('purple'))
automaton.add_edge(17, 5, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(18, 19, dfa.Atom('purple'))
automaton.add_edge(18, 6, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(19, 20, dfa.Atom('purple'))
automaton.add_edge(19, 7, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(20, 0, dfa.Atom('purple'))
automaton.add_edge(20, 8, dfa.Neg(dfa.Atom('purple')))
''''''
''''''
automaton.add_edge(3, 21, dfa.Atom('purple'))
automaton.add_edge(3, 4, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(21, 22, dfa.Atom('purple'))
automaton.add_edge(21, 5, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(22, 23, dfa.Atom('purple'))
automaton.add_edge(22, 6, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(23, 24, dfa.Atom('purple'))
automaton.add_edge(23, 7, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(24, 25, dfa.Atom('purple'))
automaton.add_edge(24, 8, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(25, 0, dfa.Atom('purple'))
automaton.add_edge(25, 9, dfa.Neg(dfa.Atom('purple')))
''''''
''''''
automaton.add_edge(4, 26, dfa.Atom('purple'))
automaton.add_edge(4, 5, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(26, 27, dfa.Atom('purple'))
automaton.add_edge(26, 6, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(27, 28, dfa.Atom('purple'))
automaton.add_edge(27, 7, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(28, 29, dfa.Atom('purple'))
automaton.add_edge(28, 8, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(29, 30, dfa.Atom('purple'))
automaton.add_edge(29, 9, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(30, 0, dfa.Atom('purple'))
automaton.add_edge(30, 10, dfa.Neg(dfa.Atom('purple')))
''''''
''''''
automaton.add_edge(5, 31, dfa.Atom('purple'))
automaton.add_edge(5, 6, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(31, 32, dfa.Atom('purple'))
automaton.add_edge(31, 7, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(32, 33, dfa.Atom('purple'))
automaton.add_edge(32, 8, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(33, 34, dfa.Atom('purple'))
automaton.add_edge(33, 9, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(34, 35, dfa.Atom('purple'))
automaton.add_edge(34, 10, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(35, 0, dfa.Atom('purple'))
automaton.add_edge(35, 61, dfa.Neg(dfa.Atom('purple')))
''''''
''''''
automaton.add_edge(6, 36, dfa.Atom('purple'))
automaton.add_edge(6, 7, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(36, 37, dfa.Atom('purple'))
automaton.add_edge(36, 8, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(37, 38, dfa.Atom('purple'))
automaton.add_edge(37, 9, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(38, 39, dfa.Atom('purple'))
automaton.add_edge(38, 10, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(39, 40, dfa.Atom('purple'))
automaton.add_edge(39, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(40, 0, dfa.Atom('purple'))
automaton.add_edge(40, 61, dfa.Neg(dfa.Atom('purple')))
''''''
''''''
automaton.add_edge(7, 41, dfa.Atom('purple'))
automaton.add_edge(7, 8, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(41, 42, dfa.Atom('purple'))
automaton.add_edge(41, 9, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(42, 43, dfa.Atom('purple'))
automaton.add_edge(42, 10, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(43, 44, dfa.Atom('purple'))
automaton.add_edge(43, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(44, 45, dfa.Atom('purple'))
automaton.add_edge(44, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(45, 0, dfa.Atom('purple'))
automaton.add_edge(45, 61, dfa.Neg(dfa.Atom('purple')))
''''''
''''''
automaton.add_edge(8, 46, dfa.Atom('purple'))
automaton.add_edge(8, 9, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(46, 47, dfa.Atom('purple'))
automaton.add_edge(46, 10, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(47, 48, dfa.Atom('purple'))
automaton.add_edge(47, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(48, 49, dfa.Atom('purple'))
automaton.add_edge(48, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(49, 50, dfa.Atom('purple'))
automaton.add_edge(49, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(50, 0, dfa.Atom('purple'))
automaton.add_edge(50, 61, dfa.Neg(dfa.Atom('purple')))
''''''
''''''
automaton.add_edge(9, 51, dfa.Atom('purple'))
automaton.add_edge(9, 10, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(51, 52, dfa.Atom('purple'))
automaton.add_edge(51, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(52, 53, dfa.Atom('purple'))
automaton.add_edge(52, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(53, 54, dfa.Atom('purple'))
automaton.add_edge(53, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(54, 55, dfa.Atom('purple'))
automaton.add_edge(54, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(55, 0, dfa.Atom('purple'))
automaton.add_edge(55, 61, dfa.Neg(dfa.Atom('purple')))
''''''
''''''

automaton.add_edge(10, 56, dfa.Atom('purple'))
automaton.add_edge(10, 61, dfa.Neg(dfa.Atom('purple')))
''''''
automaton.add_edge(56, 57, dfa.Atom('purple'))
automaton.add_edge(56, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(57, 58, dfa.Atom('purple'))
automaton.add_edge(57, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(58, 59, dfa.Atom('purple'))
automaton.add_edge(58, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(59, 60, dfa.Atom('purple'))
automaton.add_edge(59, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(60, 0, dfa.Atom('purple'))
automaton.add_edge(60, 61, dfa.Neg(dfa.Atom('purple')))

automaton.add_edge(61, 0, dfa.Truth())

cost_function = dfa.Cost_Function(automaton)

def pctl_property(prob=0.9):
    return pctl.Implies(pctl.Atom('goal'), pctl.Eventually(prob, 10, pctl.Always(prob, 5, pctl.Atom('purple'))))

def product_pctl_property(prob=0.9):
    return pctl.Always(prob, 10, pctl.Neg(pctl.Atom('accepting')))
