#!/usr/bin/python3 # -*- mode: python; coding: utf-8 -*- # Copyright (C) 2018, 2019 Laboratoire de Recherche et Développement de # l'EPITA. # # This file is part of Spot, a model checking library. # # Spot is free software; you can redistribute it and/or modify it # under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 3 of the License, or # (at your option) any later version. # # Spot is distributed in the hope that it will be useful, but WITHOUT # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY # or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public # License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . import spot options = [ # No option [False, False, False, False, False, False, False, False], # Only acc clean and … # … search last [True, False, True, False, True, False, False, False], # … partial degen [False, True, True, False, False, False, False, False], # … parity equiv [False, False, True, True, False, False, False, False], # … parity prefix [False, False, True, False, False, True, False, False], # … rabin to buchi [False, False, True, False, False, False, True, False], ] i = 1 def test(aut): global i for se, par, cl, parity, last, pref, rab, pri in options: p = spot.car(aut, se, par, cl, parity, last, pref, rab, pri) assert(spot.are_equivalent(aut, p)) print(f"OK {i}") i += 1 test(spot.automaton("""HOA: v1 name: "(FGp0 & ((XFp0 & F!p1) | F(Gp1 & XG!p0))) | G(F!p0 & (XFp0 | F!p1) & F(Gp1 | G!p0))" States: 14 Start: 0 AP: 2 "p1" "p0" Acceptance: 6 (Fin(0) & Fin(1)) | ((Fin(4)|Fin(5)) & (Inf(2)&Inf(3))) properties: trans-labels explicit-labels trans-acc complete properties: deterministic --BODY-- State: 0 [!0] 1 [0] 2 State: 1 [!0&!1] 1 {0 1 2 3 5} [0&!1] 3 [!0&1] 4 [0&1] 5 State: 2 [0&!1] 2 {1} [!0&1] 4 [!0&!1] 6 [0&1] 7 State: 3 [0&!1] 3 {1 3} [!0&1] 4 [!0&!1] 6 {0 1 2 3 5} [0&1] 8 State: 4 [!0&!1] 4 {1 2 3 5} [!0&1] 4 {2 4 5} [0&!1] 5 {1 3} [0&1] 5 {4} State: 5 [!0&1] 4 {2 4 5} [0&!1] 5 {1 3} [0&1] 8 {2 4} [!0&!1] 9 {1 2 3 5} State: 6 [0&!1] 3 {1 3} [!0&1] 4 [0&1] 5 [!0&!1] 10 State: 7 [!0&1] 4 [0&!1] 7 {1 3} [!0&!1] 11 [0&1] 12 {0 4} State: 8 [!0&1] 4 {2 4 5} [0&1] 5 {4} [0&!1] 8 {1 3} [!0&!1] 11 {1 3 5} State: 9 [!0&1] 4 {2 4 5} [0&!1] 5 {1 3} [0&1] 5 {4} [!0&!1] 11 {1 3 5} State: 10 [!0&1] 4 [0&1] 8 [!0&!1] 10 {0 1 2 3 5} [0&!1] 13 {1 2 3} State: 11 [!0&1] 4 {2 4 5} [0&!1] 8 {1 2 3} [0&1] 8 {2 4} [!0&!1] 11 {1 2 3 5} State: 12 [!0&1] 4 [0&1] 7 {0 2 4} [!0&!1] 9 [0&!1] 12 {1 3} State: 13 [!0&1] 4 [0&1] 5 [!0&!1] 10 {0 1 3 5} [0&!1] 13 {1 3} --END--""")) test(spot.automaton(""" HOA: v1 States: 2 Start: 0 AP: 2 "p0" "p1" Acceptance: 5 (Inf(0)&Inf(1)) | ((Fin(2)|Fin(3)) & Fin(4)) --BODY-- State: 0 [!0 & 1] 0 {2 3} [!0 & !1] 0 {3} [0] 1 State: 1 [0&1] 1 {1 2 4} [0&!1] 1 {4} [!0&1] 1 {0 1 2 3} [!0&!1] 1 {0 3} --END--""")) test(spot.automaton(""" HOA: v1 States: 6 Start: 0 AP: 2 "p0" "p1" Acceptance: 6 Inf(5) | Fin(2) | Inf(1) | (Inf(0) & Fin(3)) | Inf(4) properties: trans-labels explicit-labels trans-acc --BODY-- State: 0 [0&1] 2 {4 5} [0&1] 4 {0 4} [!0&!1] 3 {3 5} State: 1 [0&!1] 3 {1 5} [!0&!1] 5 {0 1} State: 2 [!0&!1] 0 {0 3} [0&!1] 1 {0} State: 3 [!0&1] 4 {1 2 3} [0&1] 3 {3 4 5} State: 4 [!0&!1] 1 {2 4} State: 5 [!0&1] 4 --END-- """)) for f in spot.randltl(15, 1000): test(spot.translate(f, "det", "G")) for f in spot.randltl(5, 10000): test(spot.translate(f)) test(spot.translate('!(GFa -> (GFb & GF(!b & !Xb)))', 'gen', 'det')) test(spot.automaton(""" HOA: v1 States: 4 Start: 0 AP: 2 "p0" "p1" Acceptance: 6 ((Fin(1) | Inf(2)) & Inf(5)) | (Fin(0) & (Fin(1) | (Fin(3) & Inf(4)))) properties: trans-labels explicit-labels trans-acc complete properties: deterministic --BODY-- State: 0 [!0&!1] 0 {2} [0&1] 1 {0 5} [0&!1] 1 {0 2 5} [!0&1] 2 {1} State: 1 [0&1] 1 {0} [!0&!1] 1 {2} [0&!1] 1 {0 2} [!0&1] 2 {1} State: 2 [!0&!1] 0 {2 3} [0&!1] 0 {0 2 3 5} [!0&1] 2 {1 4} [0&1] 3 {0 5} State: 3 [!0&!1] 0 {2 3} [0&!1] 0 {0 2 3 5} [!0&1] 2 {1 4} [0&1] 3 {0} --END-- """)) test(spot.automaton(""" HOA: v1 States: 5 Start: 0 AP: 2 "p1" "p0" Acceptance: 5 (Fin(0) & Fin(1)) | (Fin(3) & (Inf(2)&Inf(4))) properties: trans-labels explicit-labels trans-acc complete properties: deterministic --BODY-- State: 0 [!0] 1 [0] 2 State: 1 [!0&!1] 1 {0 1} [!0&1] 3 [0] 4 State: 2 [!0&1] 1 [0&!1] 2 [0&1] 2 {0 1 2 4} [!0&!1] 3 State: 3 [!0&1] 3 {1 2 3} [!0&!1] 3 {4} [0&!1] 4 {3} [0&1] 4 {1 2 3} State: 4 [!0&!1] 3 {3} [!0&1] 3 {1 2 3} [0&!1] 4 [0&1] 4 {1 2 4} --END-- """)) test(spot.automaton(""" HOA: v1 States: 2 Start: 0 AP: 2 "p1" "p0" Acceptance: 5 (Fin(0) & (Fin(3)|Fin(4)) & (Inf(1)&Inf(2))) | Inf(3) properties: trans-labels explicit-labels trans-acc complete properties: deterministic stutter-invariant --BODY-- State: 0 [0&!1] 0 {2 3} [!0&!1] 0 {2 3 4} [!0&1] 1 [0&1] 1 {2 4} State: 1 [!0&!1] 0 {0 2 3 4} [!0&1] 1 {1} [0&!1] 1 {2 3} [0&1] 1 {1 2 4} --END-- """))