#! /bin/sh # -*- 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 . # Check several options of ltlfilt . ./defs || exit 1 set -e checkopt() { cat >exp run 0 ltlfilt "$@" formulas > out diff -u exp out } # The empty lines in the file are meant, we want to make sure that # they are ignored. cat >formulas <b {a[->2:3]}|->b {a[->1];a*}|->b /* becomes {(!a)*;a[+]}|->b */ {a*;(!a)*;a*}|->b {a*;(!a)[+];a*}|->b {a[+];(!a)*;a*}|->b {a*;(!a)*;a[+]}|->b {a*;(!a)[+];a[+]}|->b {a*;(!c)[+];a[+]}|->b {a* ##0 b*}|->c EOF checkopt --boolean < b {a[*];{!a}[*];a[*]}[]-> b {a[*];{!a}[+];a[*]}[]-> b {a[+];{!a}[*];a[*]}[]-> b {a[*];{!a}[*];a[+]}[]-> b {a[*];{!a}[+];a[+]}[]-> b {a[*]:b[*]}[]-> c EOF checkopt -c --stutter-invariant < b {a[*];{!a}[*];a[*]}[]-> b {a[*];{!a}[+];a[*]}[]-> b {a[+];{!a}[*];a[*]}[]-> b {a[*];{!a}[*];a[+]}[]-> b {a[*]:b[*]}[]-> c EOF checkopt --simplify <1..2]}[]-> (b & X(b W a)))) a R (!a | X({a[->1..2]}[]-> b)) a R (b W !a) {a[*];{!a}[*];a[*]}[]-> b !a R ((b & X(b W !a)) W a) (b & X((b W !a) & ((b & X(b W !a)) W a))) W !a !a R (a R (b W !a)) !a R (a | X(a R (b W !a))) !a R (c | X(c R (b W !a))) (c W !b) W !a EOF checkopt --simplify --eventual --unique < b {a[->2..3]}[]-> b {{!a}[*];a[+]}[]-> b {a[*];{!a}[*];a[*]}[]-> b {a[*];{!a}[+];a[*]}[]-> b {a[+];{!a}[*];a[*]}[]-> b {a[*];{!a}[*];a[+]}[]-> b {a[*];{!a}[+];a[+]}[]-> b {a[*];{!c}[+];a[+]}[]-> b {a[*]:b[*]}[]-> c EOF checkopt --obligation < b {a[->2..3]}[]-> b {{!a}[*];a[+]}[]-> b {a[*];{!a}[*];a[*]}[]-> b {a[*];{!a}[+];a[*]}[]-> b {a[+];{!a}[*];a[*]}[]-> b {a[*];{!a}[*];a[+]}[]-> b {a[*];{!a}[+];a[+]}[]-> b {a[*];{!c}[+];a[+]}[]-> b {a[*]:b[*]}[]-> c EOF checkopt --guarantee < b {a[->2..3]}[]-> b {{!a}[*];a[+]}[]-> b {a[*];{!a}[*];a[*]}[]-> b {a[*];{!a}[+];a[*]}[]-> b {a[+];{!a}[*];a[*]}[]-> b {a[*];{!a}[*];a[+]}[]-> b {a[*];{!a}[+];a[+]}[]-> b {a[*];{!c}[+];a[+]}[]-> b {a[*]:b[*]}[]-> c EOF checkopt -v --ap=3 < b {a[->2..3]}[]-> b {{!a}[*];a[+]}[]-> b {a[*];{!a}[*];a[*]}[]-> b {a[*];{!a}[+];a[*]}[]-> b {a[+];{!a}[*];a[*]}[]-> b {a[*];{!a}[*];a[+]}[]-> b {a[*];{!a}[+];a[+]}[]-> b EOF checkopt --ap=2..3 < b {a[->2..3]}[]-> b {{!a}[*];a[+]}[]-> b {a[*];{!a}[*];a[*]}[]-> b {a[*];{!a}[+];a[*]}[]-> b {a[+];{!a}[*];a[*]}[]-> b {a[*];{!a}[*];a[+]}[]-> b {a[*];{!a}[+];a[+]}[]-> b {a[*];{!c}[+];a[+]}[]-> b {a[*]:b[*]}[]-> c EOF checkopt -v --stutter-invariant < b {a[->2..3]}[]-> b {a[*];{!c}[+];a[+]}[]-> b EOF checkopt --equivalent-to 'GFa | FGb' <in < b) -> (c xor d) (a & b & c) U (c & d & e) (a & b & c) U !(a & b & c) (a & b & c) U (!c & d & e) ((a | b) & c & d) U (!d & e & f) ((a | b) & d) U (!d & e & f) (a & !a) | (b & !b) | (c & !c) ((a & !a) | (b & !b) | (c & !c)) U d ((a & !a) | (b & !b) | (c & e)) U d ((a & !b) | (!a & b)) U c ((a & !b) | (a->b)) U c EOF cat >exp <out diff exp out cat >exp <(p0 || p2) && <>[](p0 || p2) #define p0 (b) #define p1 (a || c) p0 && []<>p1 && <>[]p1 #define p0 (h || i) #define p1 (d && e) #define p2 (!c) #define p3 (f) p0 || []p1 || <>[](p2 || Xp3) #define p0 ((c && !d) || (!c && d)) #define p1 ((a && !b) || (!a && b)) p0 || []p1 #define p0 (a && b) #define p1 (c) #define p2 (d && e) (p0 && p1) U (p1 && p2) #define p0 (a) #define p1 (b) #define p2 (c) (p0 && p1 && p2) U (!p0 || !p1 || !p2) #define p0 (a && b) #define p1 (c) #define p2 (d && e) (p0 && p1) U (!p1 && p2) #define p0 (d) #define p1 (a || b) #define p2 (e && f) (p0 && p1) U (!p0 && p2) false #define p0 (d) p0 #define p0 ((a && !a) || (b && !b) || (c && e)) #define p1 (d) p0 U p1 #define p0 (c) true U p0 EOF run 0 ltlfilt -s -u --nnf --relabel-bool=pnn --define in >out diff exp out cat >exp <(p0 || p2) && <>[](p0 || p2) #define p0 (b) #define p1 (a) #define p2 (c) p0 && []<>(p1 || p2) && <>[](p1 || p2) #define p0 (h) #define p1 (i) #define p2 (d) #define p3 (e) #define p4 (c) #define p5 (f) p0 || p1 || [](p2 && p3) || <>[](!p4 || Xp5) #define p0 (b) #define p1 (e) #define p2 (f) #define p3 (g) #define p4 (c) p0 && p1 && (p2 || p3) && !Xp4 #define p0 (b) #define p1 (a) #define p2 (c) p0 && []<>(p1 || p2) && ![]<>!(p1 || p2) #define p0 (a) #define p1 (b) #define p2 (c) #define p3 (d) <>(p0 <-> p1) -> !(p2 <-> p3) #define p0 (a) #define p1 (b) #define p2 (c) #define p3 (d) #define p4 (e) (p0 && p1 && p2) U (p2 && p3 && p4) #define p0 (a) #define p1 (b) #define p2 (c) (p0 && p1 && p2) U !(p0 && p1 && p2) #define p0 (a) #define p1 (b) #define p2 (c) #define p3 (d) #define p4 (e) (p0 && p1 && p2) U (!p2 && p3 && p4) #define p0 (c) #define p1 (d) #define p2 (a) #define p3 (b) #define p4 (e) #define p5 (f) (p0 && p1 && (p2 || p3)) U (!p1 && p4 && p5) #define p0 (d) #define p1 (a) #define p2 (b) #define p3 (e) #define p4 (f) (p0 && (p1 || p2)) U (!p0 && p3 && p4) #define p0 (a) #define p1 (b) #define p2 (c) (p0 && !p0) || (p1 && !p1) || (p2 && !p2) #define p0 (a) #define p1 (b) #define p2 (c) #define p3 (d) ((p0 && !p0) || (p1 && !p1) || (p2 && !p2)) U p3 #define p0 (a) #define p1 (b) #define p2 (c) #define p3 (e) #define p4 (d) ((p2 && p3) || (p0 && !p0) || (p1 && !p1)) U p4 #define p0 (a) #define p1 (b) #define p2 (c) ((p0 && !p1) || (!p0 && p1)) U p2 #define p0 (a) #define p1 (b) #define p2 (c) ((p0 && !p1) || (p0 -> p1)) U p2 EOF run 0 ltlfilt -s -u --relabel=pnn --define in >out diff exp out cat >exp <(i0 || o0) && <>[](i0 || o0) #define i0 (a) #define i1 (b) #define o0 (c) i1 && []<>(i0 || o0) && <>[](i0 || o0) #define o0 (c) #define o1 (d) #define o2 (e) #define o3 (f) #define o4 (h) #define o5 (i) o4 || o5 || [](o1 && o2) || <>[](!o0 || Xo3) #define i0 (b) #define o0 (c) #define o1 (e) #define o2 (f) #define o3 (g) i0 && o1 && (o2 || o3) && !Xo0 #define i0 (a) #define i1 (b) #define o0 (c) i1 && []<>(i0 || o0) && ![]<>!(i0 || o0) #define i0 (a) #define i1 (b) #define o0 (c) #define o1 (d) <>(i0 <-> i1) -> !(o0 <-> o1) #define i0 (a) #define i1 (b) #define o0 (c) #define o1 (d) #define o2 (e) (i0 && i1 && o0) U (o0 && o1 && o2) #define i0 (a) #define i1 (b) #define o0 (c) (i0 && i1 && o0) U !(i0 && i1 && o0) #define i0 (a) #define i1 (b) #define o0 (c) #define o1 (d) #define o2 (e) (i0 && i1 && o0) U (!o0 && o1 && o2) #define i0 (a) #define i1 (b) #define o0 (c) #define o1 (d) #define o2 (e) #define o3 (f) (o0 && o1 && (i0 || i1)) U (!o1 && o2 && o3) #define i0 (a) #define i1 (b) #define o0 (d) #define o1 (e) #define o2 (f) (o0 && (i0 || i1)) U (!o0 && o1 && o2) #define i0 (a) #define i1 (b) #define o0 (c) (i0 && !i0) || (i1 && !i1) || (o0 && !o0) #define i0 (a) #define i1 (b) #define o0 (c) #define o1 (d) ((i0 && !i0) || (i1 && !i1) || (o0 && !o0)) U o1 #define i0 (a) #define i1 (b) #define o0 (c) #define o1 (d) #define o2 (e) ((i0 && !i0) || (i1 && !i1) || (o0 && o2)) U o1 #define i0 (a) #define i1 (b) #define o0 (c) ((i0 && !i1) || (!i0 && i1)) U o0 #define i0 (a) #define i1 (b) #define o0 (c) ((i0 && !i1) || (i0 -> i1)) U o0 EOF run 0 ltlfilt -s -u --relabel=io --ins=a,b --define in >out diff exp out run 0 ltlfilt -s -u --relabel=io --ins='/[ab]/' --define in >out diff exp out run 0 ltlfilt -s -u --relabel=io --outs='/[^ab]/' --define in >out diff exp out cat >exp < b) #define p1 (c xor d) Fp0 -> p1 #define p0 (a & b & c) #define p1 (c & d & e) p0 U p1 #define p0 (a & b & c) p0 U !p0 #define p0 ((a & !a) | (b & !b) | (c & !c)) p0 EOF run 0 ltlfilt -u --relabel-over=pnn --define in >out diff exp out toolong='((p2=0) * (p3=1))' # work around the 80-col check cat >exp <out diff exp out run 0 ltlfilt -0 in > out $PERL -i -pe 's/\0/@\n/g' out cat >exp < b) -> (c xor d)@ (a & b & c) U (c & d & e)@ (a & b & c) U !(a & b & c)@ (a & b & c) U (!c & d & e)@ (c & d & (a | b)) U (!d & e & f)@ (d & (a | b)) U (!d & e & f)@ (a & !a) | (b & !b) | (c & !c)@ ((a & !a) | (b & !b) | (c & !c)) U d@ ((a & !a) | (b & !b) | (c & e)) U d@ ((a & !b) | (!a & b)) U c@ ((a -> b) | (a & !b)) U c@ EOF diff exp out SPOT_STUTTER_CHECK=0 \ ltlfilt --stutter-invariant -f '!{a:b*:c}' 2> stderr && exit 1 test $? = 2 grep 'non-LTL' stderr SPOT_STUTTER_CHECK=555 \ ltlfilt --stutter-invariant -f '!{a:b*:c}' 2> stderr && exit 1 test $? = 2 grep 'invalid' stderr SPOT_STUTTER_CHECK=5 \ ltlfilt --stutter-invariant -f '!{a:b*:c}' # This one was incorrectly diagnosed as stutter invariant because of a # bug in the bitvectors. ltlfilt --stutter-invariant -f 'F(a & XXXXXX!a)' && exit 1 ltlfilt --syntactic-stutter-invariant -f 'GFa <-> GFb' ltlfilt --syntactic-stutter-invariant -f 'GXa <-> GFb' && exit 1 ltlfilt -c -o 'foo' -f a 2>stderr && exit 1 grep 'ltlfilt: options --output and --count are incompatible' stderr out=`ltlfilt -f 'G(a xor b) -> F(c <-> Xd)' --unabbreviate='^iF'` exp='(1 U (c <-> Xd)) | !G!(a <-> b)' test "$out" = "$exp" ltlfilt -f 'GF"a\"\\b"' > out test "`cat out`" = 'GF"a\"\\b"' ltlfilt --lbt-input -f 'G F "a\"\\b"' -l > out test "`cat out`" = 'G F "a\"\\b"' ltlfilt --size=foo=2..3 2>stderr && exit 1 grep 'invalid range.*should start with' stderr cat >out < out.1 ltlfilt out/2 > out.2 diff out out.1 diff out out.2 test a = `ltlfilt -r2 -f a` ltlfilt -r4 -f a 2>err && exit 1 grep "invalid simplification level '4'" err ltlfilt -ra -f a 2>err && exit 1 grep "invalid simplification level 'a'" err ltlfilt --ignore-errors -f 'F' > out 2> out && exit 1 test $? = 1 cat >exp < out cat >exp < out cat >exp < file run 0 ltlfilt -Ffile/1 -Ffile/2 --stats=%f >out cat >expected <