* README, configure.ac, iface/ltsmin/Makefile.am, src/tests/defs.in, src/tests/.gitignore, src/tests/Makefile.am, src/Makefile.am: update references. * src/kripketest/.gitignore, src/kripketest/Makefile.am, src/kripketest/defs.in, src/graphtest/.gitignore, src/graphtest/Makefile.am, src/graphtest/defs.in, src/ltltest/.cvsignore, src/ltltest/.gitignore, src/ltltest/Makefile.am, src/ltltest/defs.in:: remove files. * src/kripketest/bad_parsing.test, src/kripketest/kripke.test, src/kripketest/origin, src/kripketest/parse_print_test.cc, src/ltltest/bare.test, src/ltltest/consterm.cc, src/ltltest/consterm.test, src/tests/defs.in, src/ltltest/equals.test, src/ltltest/equalsf.cc, src/ltltest/eventuniv.test, src/ltltest/exclusive-ltl.test, src/graphtest/graph.cc, src/graphtest/graph.test, src/ltltest/isop.test, src/ltltest/kind.cc, src/ltltest/kind.test, src/ltltest/latex.test, src/ltltest/lbt.test, src/ltltest/length.cc, src/ltltest/length.test, src/ltltest/lenient.test, src/ltltest/ltlcrossgrind.test, src/ltltest/ltlfilt.test, src/ltltest/ltlgrind.test, src/ltltest/ltlrel.cc, src/ltltest/ltlrel.test, src/ltltest/lunabbrev.test, src/ltltest/nenoform.test, src/graphtest/ngraph.cc, src/graphtest/ngraph.test, src/ltltest/parse.test, src/ltltest/parseerr.test, src/ltltest/rand.test, src/ltltest/readltl.cc, src/ltltest/reduc.cc, src/ltltest/reduc.test, src/ltltest/reduc0.test, src/ltltest/reduccmp.test, src/ltltest/reducpsl.test, src/ltltest/remove_x.test, src/ltltest/stutter-ltl.test, src/ltltest/syntimpl.cc, src/ltltest/syntimpl.test, src/graphtest/tgbagraph.test, src/ltltest/tostring.cc, src/ltltest/tostring.test, src/ltltest/tunabbrev.test, src/ltltest/tunenoform.test, src/graphtest/twagraph.cc, src/ltltest/unabbrevwm.test,src/ltltest/utf8.test, src/ltltest/uwrm.test: rename as... * src/tests/bad_parsing.test, src/tests/kripke.test, src/tests/origin, src/tests/parse_print_test.cc, src/tests/bare.test, src/tests/consterm.cc, src/tests/consterm.test, src/tests/equals.test, src/tests/equalsf.cc, src/tests/eventuniv.test, src/tests/exclusive-ltl.test, src/tests/graph.cc, src/tests/graph.test, src/tests/isop.test, src/tests/kind.cc, src/tests/kind.test, src/tests/latex.test, src/tests/lbt.test, src/tests/length.cc, src/tests/length.test, src/tests/lenient.test, src/tests/ltlcrossgrind.test, src/tests/ltlfilt.test, src/tests/ltlgrind.test, src/tests/ltlrel.cc, src/tests/ltlrel.test, src/tests/lunabbrev.test, src/tests/nenoform.test, src/tests/ngraph.cc, src/tests/ngraph.test, src/tests/parse.test, src/tests/parseerr.test, src/tests/rand.test, src/tests/readltl.cc, src/tests/reduc.cc, src/tests/reduc.test, src/tests/reduc0.test, src/tests/reduccmp.test, src/tests/reducpsl.test, src/tests/remove_x.test, src/tests/stutter-ltl.test, src/tests/syntimpl.cc, src/tests/syntimpl.test, src/tests/tgbagraph.test, src/tests/tostring.cc, src/tests/tostring.test, src/tests/tunabbrev.test, src/tests/tunenoform.test, src/tests/twagraph.cc, src/tests/unabbrevwm.test, src/tests/utf8.test, src/tests/uwrm.test: ...these!
135 lines
3.6 KiB
Bash
Executable file
135 lines
3.6 KiB
Bash
Executable file
#! /bin/sh
|
|
# -*- coding: utf-8 -*-
|
|
# Copyright (C) 2010, 2011, 2012, 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 <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
# Check for the constant_term visitor
|
|
|
|
. ./defs || exit 1
|
|
|
|
set -e
|
|
|
|
cat >input<<EOF
|
|
a,B&!xfLEPSFsgopra
|
|
a<->b,BxfLEPSFsgopra
|
|
!a,B&!xfLEPSFsgopra
|
|
!(a|b),B&xfLEPSFsgopra
|
|
F(a),&!xLPegopra
|
|
G(a),&!xLPusopra
|
|
a U b,&!xfLPgopra
|
|
a U Fb,&!xLPegopra
|
|
Ga U b,&!xLPopra
|
|
1 U a,&!xfLPegopra
|
|
a W b,&!xfLPsopra
|
|
a W 0,&!xfLPusopra
|
|
a M b,&!xfLPgopra
|
|
a M 1,&!xfLPegopra
|
|
a R b,&!xfLPsopra
|
|
0 R b,&!xfLPusopra
|
|
a R (b R (c R d)),&!xfLPsopra
|
|
a U (b U (c U d)),&!xfLPgopra
|
|
a W (b W (c W d)),&!xfLPsopra
|
|
a M (b M (c M d)),&!xfLPgopra
|
|
Fa -> Fb,xLPopra
|
|
Ga -> Fb,xLPgopra
|
|
Fa -> Gb,xLPsopra
|
|
(Ga|Fc) -> Fb,xLPopra
|
|
(Ga|Fa) -> Gb,xLPopra
|
|
{a;c*;b}|->!Xb,&fPsopra
|
|
{a;c*;b}|->X!b,&!fPsopra
|
|
{a;c*;b}|->!Fb,&Psopra
|
|
{a;c*;b}|->G!b,&!Psopra
|
|
{a;c*;b}|->!Gb,&Pra
|
|
{a;c*;b}|->F!b,&!Pra
|
|
{a;c*;b}|->GFa,&!Pra
|
|
{a;c*;b}|->FGa,&!Pa
|
|
{a[+];c[+];b*}|->!Fb,&xPsopra
|
|
{a[+];c*;b[+]}|->G!b,&!xPsopra
|
|
{a*;c[+];b[+]}|->!Gb,&xPra
|
|
{a[+];c*;b[+]}|->F!b,&!xPra
|
|
{a[+];c[+];b*}|->GFa,&!xPra
|
|
{a*;c[+];b[+]}|->FGa,&!xPa
|
|
{a;c;b|(d;e)}|->!Xb,&fPFsgopra
|
|
{a;c;b|(d;e)}|->X!b,&!fPFsgopra
|
|
{a;c;b|(d;e)}|->!Fb,&Psopra
|
|
{a;c;b|(d;e)}|->G!b,&!Psopra
|
|
{a;c;b|(d;e)}|->!Gb,&Pgopra
|
|
{a;c;b|(d;e)}|->F!b,&!Pgopra
|
|
{a;c;b|(d;e)}|->GFa,&!Pra
|
|
{a;c;b|(d;e)}|->FGa,&!Ppa
|
|
{a[+] && c[+]}|->!Xb,&fPsopra
|
|
{a[+] && c[+]}|->X!b,&!fPsopra
|
|
{a[+] && c[+]}|->!Fb,&xPsopra
|
|
{a[+] && c[+]}|->G!b,&!xPsopra
|
|
{a[+] && c[+]}|->!Gb,&xPra
|
|
{a[+] && c[+]}|->F!b,&!xPra
|
|
{a[+] && c[+]}|->GFa,&!xPra
|
|
{a[+] && c[+]}|->FGa,&!xPa
|
|
{a;c*;b}<>->!Gb,&Pgopra
|
|
{a;c*;b}<>->F!b,&!Pgopra
|
|
{a;c*;b}<>->FGb,&!Ppa
|
|
{a;c*;b}<>->!GFb,&Ppa
|
|
{a;c*;b}<>->GFb,&!Pa
|
|
{a;c*;b}<>->!FGb,&Pa
|
|
{a*;c[+];b[+]}<>->!FGb,&xPa
|
|
{a;c|d;b}<>->!Gb,&Pgopra
|
|
{a;c|d;b}<>->G!b,&!Psopra
|
|
{a;c|d;b}<>->FGb,&!Ppa
|
|
{a;c|d;b}<>->!GFb,&Ppa
|
|
{a;c|d;b}<>->GFb,&!Pra
|
|
{a;c|d;_b}<>->!FGb,&Pr
|
|
# Equivalent to a&b&c&d
|
|
{a:b:c:d}!,B&!xfLEPSFsgopra
|
|
a&b&c&d,B&!xfLEPSFsgopra
|
|
(Xa <-> XXXc) U (b & Fe),LPgopra
|
|
(!X(a|X(!b))&(FX(g xor h)))U(!G(a|b)),LPegopra
|
|
(!X(a|X(!b))&(GX(g xor h)))R(!F(a|b)),LPusopra
|
|
(!X(a|X(!b))&(GX(g xor h)))U(!G(a|b)),LPeopra
|
|
(!X(a|X(!b))&(FX(g xor h)))R(!F(a|b)),LPuopra
|
|
(!X(a|X(!b))&(GX(g xor h)))U(!F(a|b)),LPpa
|
|
(!X(a|X(!b))&(FX(g xor h)))R(!G(a|b)),LPra
|
|
(!X(a|GXF(!b))&(FGX(g xor h)))U(!F(a|b)),LPpa
|
|
(!X(a|GXF(!b))&(FGX(g xor h)))R(!F(a|b)),LPupa
|
|
(!X(a|FXG(!b))&(GFX(g xor h)))R(!G(a|b)),LPra
|
|
(!X(a|FXG(!b))&(GFX(g xor h)))U(!G(a|b)),LPera
|
|
(!X(a|GXF(!b))&(FGX(g xor h)))U(!G(a|Fb)),LPepa
|
|
(!X(a|GXF(!b))&(FGX(g xor h)))U(!F(a|Gb)),LPa
|
|
(!X(a|FXG(!b))&(GFX(g xor h)))R(!F(a|Gb)),LPura
|
|
(!X(a|FXG(!b))&(GFX(g xor h)))R(!G(a|Fb)),LPa
|
|
GFa M GFb,&!xLPeua
|
|
FGa M FGb,&!xLPeupa
|
|
Fa M GFb,&!xLPera
|
|
GFa W GFb,&!xLPeura
|
|
FGa W FGb,&!xLPeua
|
|
Ga W FGb,&!xLPupa
|
|
Ga W b,&!xLPsopra
|
|
Fa M b,&!xLPgopra
|
|
{a;b*;c},&!fPsopra
|
|
{a;b*;c}!,&!fPgopra
|
|
# The negative normal form is {a;b*;c}[]->1
|
|
!{a;b*;c}!,&fPsopra
|
|
{a;b*;p112}[]->0,&!fPsopra
|
|
!{a;b*;c.2},&!fPgopr
|
|
!{a[+];b*;c[+]},&!xfPgopra
|
|
{a[+];b*;c[+]},&!xfPsopra
|
|
{a[+] && b || c[+]},&!fPsopra
|
|
{a[+] && b[+] || c[+]},&!xfPsopra
|
|
EOF
|
|
|
|
run 0 ../kind input
|