#!/bin/sh # -*- coding: utf-8 -*- # Copyright (C) 2011, 2013, 2014, 2015 Laboratoire de Recherche et # Développement de l'Epita (LRDE). # # 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 . . ./defs set -e # Make sure degeneralization is idempotent for f in 'FGa|GFb' 'GFa & GFb & GFc' 'GF(a->FGb)&GF(c->FGd)'; do for opt in -DS -DT; do ../ikwiad $opt -H "$f" > autX.spot ../ikwiad -XH -kt autX.spot > base.size cat base.size for x in X XX XXX; do ../ikwiad -XH $opt -H aut$x.spot > autX$x.spot ../ikwiad -XH -kt autX$x.spot > new.size cat new.size cmp base.size new.size done done done # This is another 6-state degeneralized automaton that # we used the "redegeneralize" to a 8-state BA... cat > bug < out grep 'states: 6' out # This 8-state degeneralized automaton used # to be "degeneralized" to a 9-state BA... cat > bug2 <out grep 'states: 8' out # This automaton should have a 3-state BA, but it's really # easy to obtain a 4-state BA when tweaking the degeneralization # to ignore arc entering an SCC. test 3 = "`ltl2tgba -B 'G(a|G(b|Fc))' --stats=%s`" # This 7-state DRA (built with # ltlfilt -f 'F(a & GFb) | (Fc & Fa & F(c & GF!b))' -l | # ltl2dstar --ltl2nba=spin:ltl2tgba@-sD - - # should be converted in into a 5-state DBA. cat >in.dra < out.stat test 5 = "`cat out.stat`" # Only one state should be accepting. In spot 1.2.x an initial state # in a trivial SCC was marked as accepting: this is superfluous. ltl2tgba -BH 'a & GFb & GFc' > out cat out cat >expected<