# -*- mode: python; coding: utf-8 -*- # Copyright (C) by the Spot authors, see the AUTHORS file for details. # # 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 from unittest import TestCase tc = TestCase() # This test used to trigger an assertion (or a segfault) # in scc_filter_states(). aut = spot.automaton(""" HOA: v1 States: 3 Start: 1 AP: 1 "a" Acceptance: 1 Inf(0) --BODY-- State: 0 {0} [t] 0 State: 1 [!0] 0 [0] 2 State: 2 [t] 2 --END-- """) aut.prop_inherently_weak(True) aut = spot.dualize(aut) aut1 = spot.scc_filter_states(aut) tc.assertEqual(aut1.to_str('hoa'), """HOA: v1 States: 2 Start: 0 AP: 1 "a" acc-name: co-Buchi Acceptance: 1 Fin(0) properties: trans-labels explicit-labels state-acc deterministic properties: very-weak --BODY-- State: 0 {0} [0] 1 State: 1 [t] 1 --END--""") tc.assertEqual(aut.scc_filter_states().to_str(), aut1.to_str()) tc.assertIsNone(aut1.get_name()) aut1.set_name("test me") tc.assertEqual(aut1.get_name(), "test me") # The method is the same as the function a = spot.translate('true', 'low', 'any') tc.assertTrue(a.prop_universal().is_maybe()) tc.assertTrue(a.prop_unambiguous().is_maybe()) tc.assertTrue(a.is_deterministic()) tc.assertTrue(a.is_unambiguous()) a = spot.automaton(""" HOA: v1 States: 3 Start: 0 AP: 2 "a" "b" acc-name: Buchi Acceptance: 5 Inf(0)&Fin(4) | Inf(2)&Inf(3) | Inf(1) --BODY-- State: 0 {3} [t] 0 [0] 1 {1} [!0] 2 {0 4} State: 1 {3} [1] 0 [0&1] 1 {0} [!0&1] 2 {2 4} State: 2 [!1] 0 [0&!1] 1 {0} [!0&!1] 2 {0 4} --END-- """) b = spot.remove_fin(a) size = (b.num_states(), b.num_edges()) tc.assertEqual(size, (5, 13))