#! /bin/sh # Copyright (C) 2003 Laboratoire d'Informatique de Paris 6 (LIP6), # département Systèmes Répartis Coopératifs (SRC), Université Pierre # et Marie Curie. # # 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 2 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 Spot; see the file COPYING. If not, write to the Free # Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA # 02111-1307, USA. # Check for the negative_normal_form visitor . ./defs || exit 1 set -e # A few things that do not change run 0 ./nenoform 'a' 'a' run 0 ./nenoform '1' '1' run 0 ./nenoform '0' '0' run 0 ./nenoform '!a' '!a' run 0 ./nenoform 'a U b' 'a U b' run 0 ./nenoform 'a & b' 'a & b' run 0 ./nenoform 'a & b' 'b & a' run 0 ./nenoform 'a & !b & c' 'c & a & !b' run 0 ./nenoform 'a & b & c' 'b & c & a' run 0 ./nenoform 'Xa & b & Xa' 'b & Xa & b' run 0 ./nenoform 'a & b' 'b & a & b' run 0 ./nenoform 'a & !b' '!b & a & a' run 0 ./nenoform 'a & b & (Xc |(f U !g)| e)' 'b & a & a & (Xc | e |(f U !g)| e | Xc) & b' run 0 ./nenoform 'GFa => FGb' 'GFa => FGb' # Basic rewritings run 0 ./nenoform '!!a' 'a' run 0 ./nenoform '!!!!!a' '!a' run 0 ./nenoform '!Xa' 'X!a' run 0 ./nenoform '!Fa' 'G!a' run 0 ./nenoform '!Ga' 'F!a' run 0 ./nenoform '!(a ^ b)' 'a <=> b' run 0 ./nenoform '!(a <=> b)' '(((a) ^ (b)))' run 0 ./nenoform '!(a => b)' 'a&!b' run 0 ./nenoform '!(!a => !b)' '!a&b' run 0 ./nenoform '!(a U b)' '!a R !b' run 0 ./nenoform '!(a R b)' '!a U !b' run 0 ./nenoform '!(!a R !b)' 'a U b' run 0 ./nenoform '!(a & b & c & d & b)' '!a | !b | !c | !d' run 0 ./nenoform '!(a | b | c | d)' '!a & !b & !c & !d' # Nested rewritings run 0 ./nenoform '!(a U (!b U ((a & b & c) R d)))' '!a R (b R ((!a | !b | !c) U !d))' run 0 ./nenoform '!(GF a => FG b)' 'GFa & GF!b'