// Author: Daniel Tischner, Christian Schilling, Matthias Heizmann // Date: 2016-03-17 // // Example used to find out how the old algorithm communicates progress measures // between SCCs. // // We want to check if the fair simulation game graph looks as expected. // Afterward we can delete it. // // Contains a dead end. NestedWordAutomaton preprocessed = removeUnreachable(nwa); int minimizeSevpaSize = numberOfStates(minimizeSevpa(preprocessed)); int shrinkNwaSize = numberOfStates(shrinkNwa(preprocessed)); int minimizeNwaPmaxSatDirectBiSize = numberOfStates(minimizeNwaPmaxSatDirectBi(preprocessed)); int minimizeNwaPmaxSatDirectSize = numberOfStates(minimizeNwaPmaxSatDirect(preprocessed)); int minimizeDfaSimulationSize = numberOfStates(minimizeDfaSimulation(preprocessed)); int reduceNwaDirectSimulationSize = numberOfStates(reduceNwaDirectSimulation(preprocessed)); int reduceNwaDirectSimulationBSize = numberOfStates(reduceNwaDirectSimulationB(preprocessed)); int reduceNwaDirectFullMultipebbleSimulationSize = numberOfStates(reduceNwaDirectFullMultipebbleSimulation(preprocessed)); int buchiReduceSize = numberOfStates(buchiReduce(preprocessed)); int reduceNwaDelayedSimulationSize = numberOfStates(reduceNwaDelayedSimulation(preprocessed)); int reduceNwaDelayedSimulationBSize = numberOfStates(reduceNwaDelayedSimulationB(preprocessed)); // int reduceNwaDelayedFullMultipebbleSimulationSize = numberOfStates(reduceNwaDelayedFullMultipebbleSimulation(preprocessed)); int reduceBuchiFairDirectSimulationSize = numberOfStates(reduceBuchiFairDirectSimulation(preprocessed)); int reduceBuchiFairSimulationSize = numberOfStates(reduceBuchiFairSimulation(preprocessed)); assert(minimizeSevpaSize == 3); assert(shrinkNwaSize == 3); assert(minimizeNwaPmaxSatDirectBiSize == 3); assert(minimizeNwaPmaxSatDirectSize == 3); assert(minimizeDfaSimulationSize == 3); assert(reduceNwaDirectSimulationSize == 3); assert(reduceNwaDirectSimulationBSize == 3); assert(reduceNwaDirectFullMultipebbleSimulationSize == 3); assert(buchiReduceSize == 3); assert(reduceNwaDelayedSimulationSize == 3); assert(reduceNwaDelayedSimulationBSize == 3); // assert(reduceNwaDelayedFullMultipebbleSimulationSize == 3); assert(reduceBuchiFairDirectSimulationSize == 3); assert(reduceBuchiFairSimulationSize == 3); NestedWordAutomaton nwa = ( callAlphabet = {}, internalAlphabet = {a b }, returnAlphabet = {}, states = {q0 q1 q2 }, initialStates = {q0 q1 q2 }, finalStates = {q1 }, callTransitions = { }, internalTransitions = { (q0 a q0) (q0 b q0) (q2 b q1) (q1 a q1) }, returnTransitions = { } );