acc: make sure unit_propagate preserve the number of sets
* spot/twa/acc.hh: Here. * tests/core/accsimpl.test, tests/core/ltl2tgba2.test: Add test cases.
This commit is contained in:
parent
d8506ded52
commit
fe642bc9ad
3 changed files with 39 additions and 7 deletions
|
|
@ -1,6 +1,6 @@
|
|||
#!/bin/sh
|
||||
# -*- coding: utf-8 -*-
|
||||
# Copyright (C) 2018 Laboratoire de Recherche et Développement de
|
||||
# Copyright (C) 2018, 2020 Laboratoire de Recherche et Développement de
|
||||
# l'Epita (LRDE).
|
||||
#
|
||||
# This file is part of Spot, a model checking library.
|
||||
|
|
@ -51,3 +51,25 @@ EOF
|
|||
autfilt --simplify-acceptance 325 > 325s
|
||||
exp='3 Fin(0) | (Fin(1) & Inf(2))'
|
||||
test "$exp" = "`autfilt --stats='%a %g' 325s`"
|
||||
|
||||
# This automaton used to cause some issue at some point, because
|
||||
# simplify_acceptance would simplify the acceptance condition without
|
||||
# removing the unnecessary set from the resulting automaton.
|
||||
cat >frenkin <<EOF
|
||||
HOA: v1
|
||||
States: 1
|
||||
Start: 0
|
||||
AP: 2 "a" "b"
|
||||
Acceptance: 4 Fin(0) & (Fin(1) | (Inf(2)&Inf(3)))
|
||||
properties: trans-labels explicit-labels trans-acc complete
|
||||
properties: deterministic stutter-invariant
|
||||
--BODY--
|
||||
State: 0
|
||||
[!0&1] 0
|
||||
[!0&!1] 0 {1 3}
|
||||
[0&1] 0 {0 1 2}
|
||||
[0&!1] 0 {0 1 2 3}
|
||||
--END--
|
||||
EOF
|
||||
autcross --language-preserved 'autfilt --simplify-acc' -F frenkin
|
||||
test 1,4,2 = "`autfilt --simplify-acc frenkin --stats=%s,%e,%a`"
|
||||
|
|
|
|||
|
|
@ -441,4 +441,11 @@ ltl2tgba '!b & e U (a & b & c)' | grep '\[f\]' && exit 1
|
|||
ltl2tgba '!b & e U (a & b & c)' --stats=%w | grep 0 && exit 1
|
||||
ltl2tgba 'X!c & X(b & c & d & a U e)' | grep '\[f\]' && exit 1
|
||||
ltl2tgba 'X!c & X(b & c & d & a U e)' --stats=%w | grep 0 && exit 1
|
||||
|
||||
# This caused issue at some point, because simplify_acceptance would
|
||||
# leave some undeclared acceptance set in the automaton, which would
|
||||
# cause simulation-based reduction to produce garbage output, which
|
||||
# would in turn cause the HOA printer to choke.
|
||||
ltlcross -f 'G(F(Gb ^ Fa) & FG!a)' 'ltl2tgba -G -D'
|
||||
|
||||
:
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue