#!/bin/sh # -*- coding: utf-8 -*- # Copyright (C) 2016, 2017 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 the name of each pattern is correctly output by %F. opts=`genltl --help | sed -n '/=RANGE/{ s/^ *// s/[=[].*/=1/p }'` res=`genltl $opts --format="--%F=%L"` test "$opts" = "$res" run 0 genltl --dac=1..5 --eh=1..5 --pos --neg --format="%F:%L %f" >output cat >expected < (!p1 U p0) !dac-patterns:2 !(Fp0 -> (!p1 U p0)) dac-patterns:3 G(p0 -> G!p1) !dac-patterns:3 !G(p0 -> G!p1) dac-patterns:4 G((p0 & !p1 & Fp1) -> (!p2 U p1)) !dac-patterns:4 !G((p0 & !p1 & Fp1) -> (!p2 U p1)) dac-patterns:5 G((p0 & !p1) -> (!p2 W p1)) !dac-patterns:5 !G((p0 & !p1) -> (!p2 W p1)) eh-patterns:1 p0 U (p1 & Gp2) !eh-patterns:1 !(p0 U (p1 & Gp2)) eh-patterns:2 p0 U (p1 & X(p2 U p3)) !eh-patterns:2 !(p0 U (p1 & X(p2 U p3))) eh-patterns:3 p0 U (p1 & X(p2 & F(p3 & XF(p4 & XF(p5 & XFp6))))) !eh-patterns:3 !(p0 U (p1 & X(p2 & F(p3 & XF(p4 & XF(p5 & XFp6)))))) eh-patterns:4 F(p0 & XGp1) !eh-patterns:4 !F(p0 & XGp1) eh-patterns:5 F(p0 & X(p1 & XFp2)) !eh-patterns:5 !F(p0 & X(p1 & XFp2)) EOF diff expected output genltl --dac=1..5 --eh=1..5 --neg --format="%L %f" >output cat >expected < (!p1 U p0)) 3 !G(p0 -> G!p1) 4 !G((p0 & !p1 & Fp1) -> (!p2 U p1)) 5 !G((p0 & !p1) -> (!p2 W p1)) 1 !(p0 U (p1 & Gp2)) 2 !(p0 U (p1 & X(p2 U p3))) 3 !(p0 U (p1 & X(p2 & F(p3 & XF(p4 & XF(p5 & XFp6)))))) 4 !F(p0 & XGp1) 5 !F(p0 & X(p1 & XFp2)) EOF diff expected output genltl --dac=1..5 --eh=1..5 --pos --format="%f" >output cat >expected < (!p1 U p0) G(p0 -> G!p1) G((p0 & !p1 & Fp1) -> (!p2 U p1)) G((p0 & !p1) -> (!p2 W p1)) p0 U (p1 & Gp2) p0 U (p1 & X(p2 U p3)) p0 U (p1 & X(p2 & F(p3 & XF(p4 & XF(p5 & XFp6))))) F(p0 & XGp1) F(p0 & X(p1 & XFp2)) EOF diff expected output genltl --dac=1..5 --eh=1..5 >output2 diff output output2 genltl --tv-f1=1:3 --tv-f2=1:3 --tv-g1=1:3 --tv-g2=1:3 --tv-uu=1:3 \ --format=%F,%L,%f >output cat >expected < q) tv-f1,2,G(p -> (q | Xq)) tv-f1,3,G(p -> (q | Xq | XXq)) tv-f2,1,G(p -> q) tv-f2,2,G(p -> (q | Xq)) tv-f2,3,G(p -> (q | X(q | Xq))) tv-g1,1,G(p -> q) tv-g1,2,G(p -> (q & Xq)) tv-g1,3,G(p -> (q & Xq & XXq)) tv-g2,1,G(p -> q) tv-g2,2,G(p -> (q & Xq)) tv-g2,3,G(p -> (q & X(q & Xq))) tv-uu,1,G(p1 -> (p1 U p2)) tv-uu,2,G(p1 -> (p1 U (p2 & (p2 U p3)))) tv-uu,3,G(p1 -> (p1 U (p2 & (p2 U (p3 & (p3 U p4)))))) EOF diff output expected genltl --kr-n2=1..2 --kr-nlogn=1..2 --kr-n=1..2 --gxf-and=0..3 --fxg-or=0..3 \ --format=%F=%L,%f | ltl2tgba --low --det -F-/2 --stats='%<,%s' > out cat >exp<