/usr/bin/java -ea -Xmx8000000000 -Xss4m -jar ./plugins/org.eclipse.equinox.launcher_1.3.100.v20150511-1540.jar -data @noDefault -ultimatedata ./data -tc ../../../trunk/examples/toolchains/AutomizerC.xml -s ../../../trunk/examples/settings/default/automizer/svcomp-Reach-32bit-Automizer_Default.epf -i ../../../trunk/examples/svcomp/product-lines/minepump_spec4_product33.cil.c -------------------------------------------------------------------------------- This is Ultimate 0.1.25-267fbe0 [2020-07-17 21:30:53,685 INFO L177 SettingsManager]: Resetting all preferences to default values... [2020-07-17 21:30:53,688 INFO L181 SettingsManager]: Resetting UltimateCore preferences to default values [2020-07-17 21:30:53,703 INFO L184 SettingsManager]: Ultimate Commandline Interface provides no preferences, ignoring... [2020-07-17 21:30:53,704 INFO L181 SettingsManager]: Resetting Boogie Preprocessor preferences to default values [2020-07-17 21:30:53,705 INFO L181 SettingsManager]: Resetting Boogie Procedure Inliner preferences to default values [2020-07-17 21:30:53,706 INFO L181 SettingsManager]: Resetting Abstract Interpretation preferences to default values [2020-07-17 21:30:53,708 INFO L181 SettingsManager]: Resetting LassoRanker preferences to default values [2020-07-17 21:30:53,710 INFO L181 SettingsManager]: Resetting Reaching Definitions preferences to default values [2020-07-17 21:30:53,710 INFO L181 SettingsManager]: Resetting SyntaxChecker preferences to default values [2020-07-17 21:30:53,711 INFO L181 SettingsManager]: Resetting Sifa preferences to default values [2020-07-17 21:30:53,712 INFO L184 SettingsManager]: Büchi Program Product provides no preferences, ignoring... [2020-07-17 21:30:53,713 INFO L181 SettingsManager]: Resetting LTL2Aut preferences to default values [2020-07-17 21:30:53,714 INFO L181 SettingsManager]: Resetting PEA to Boogie preferences to default values [2020-07-17 21:30:53,715 INFO L181 SettingsManager]: Resetting BlockEncodingV2 preferences to default values [2020-07-17 21:30:53,716 INFO L181 SettingsManager]: Resetting ChcToBoogie preferences to default values [2020-07-17 21:30:53,716 INFO L181 SettingsManager]: Resetting AutomataScriptInterpreter preferences to default values [2020-07-17 21:30:53,717 INFO L181 SettingsManager]: Resetting BuchiAutomizer preferences to default values [2020-07-17 21:30:53,719 INFO L181 SettingsManager]: Resetting CACSL2BoogieTranslator preferences to default values [2020-07-17 21:30:53,721 INFO L181 SettingsManager]: Resetting CodeCheck preferences to default values [2020-07-17 21:30:53,722 INFO L181 SettingsManager]: Resetting InvariantSynthesis preferences to default values [2020-07-17 21:30:53,723 INFO L181 SettingsManager]: Resetting RCFGBuilder preferences to default values [2020-07-17 21:30:53,724 INFO L181 SettingsManager]: Resetting Referee preferences to default values [2020-07-17 21:30:53,725 INFO L181 SettingsManager]: Resetting TraceAbstraction preferences to default values [2020-07-17 21:30:53,728 INFO L184 SettingsManager]: TraceAbstractionConcurrent provides no preferences, ignoring... [2020-07-17 21:30:53,728 INFO L184 SettingsManager]: TraceAbstractionWithAFAs provides no preferences, ignoring... [2020-07-17 21:30:53,728 INFO L181 SettingsManager]: Resetting TreeAutomizer preferences to default values [2020-07-17 21:30:53,729 INFO L181 SettingsManager]: Resetting IcfgToChc preferences to default values [2020-07-17 21:30:53,729 INFO L181 SettingsManager]: Resetting IcfgTransformer preferences to default values [2020-07-17 21:30:53,730 INFO L184 SettingsManager]: ReqToTest provides no preferences, ignoring... [2020-07-17 21:30:53,730 INFO L181 SettingsManager]: Resetting Boogie Printer preferences to default values [2020-07-17 21:30:53,731 INFO L181 SettingsManager]: Resetting ChcSmtPrinter preferences to default values [2020-07-17 21:30:53,732 INFO L181 SettingsManager]: Resetting ReqPrinter preferences to default values [2020-07-17 21:30:53,732 INFO L181 SettingsManager]: Resetting Witness Printer preferences to default values [2020-07-17 21:30:53,733 INFO L184 SettingsManager]: Boogie PL CUP Parser provides no preferences, ignoring... [2020-07-17 21:30:53,734 INFO L181 SettingsManager]: Resetting CDTParser preferences to default values [2020-07-17 21:30:53,734 INFO L184 SettingsManager]: AutomataScriptParser provides no preferences, ignoring... [2020-07-17 21:30:53,734 INFO L184 SettingsManager]: ReqParser provides no preferences, ignoring... [2020-07-17 21:30:53,735 INFO L181 SettingsManager]: Resetting SmtParser preferences to default values [2020-07-17 21:30:53,735 INFO L181 SettingsManager]: Resetting Witness Parser preferences to default values [2020-07-17 21:30:53,736 INFO L188 SettingsManager]: Finished resetting all preferences to default values... [2020-07-17 21:30:53,737 INFO L101 SettingsManager]: Beginning loading settings from /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/settings/default/automizer/svcomp-Reach-32bit-Automizer_Default.epf [2020-07-17 21:30:53,751 INFO L113 SettingsManager]: Loading preferences was successful [2020-07-17 21:30:53,752 INFO L115 SettingsManager]: Preferences different from defaults after loading the file: [2020-07-17 21:30:53,753 INFO L136 SettingsManager]: Preferences of BlockEncodingV2 differ from their defaults: [2020-07-17 21:30:53,753 INFO L138 SettingsManager]: * Create parallel compositions if possible=false [2020-07-17 21:30:53,753 INFO L138 SettingsManager]: * Use SBE=true [2020-07-17 21:30:53,753 INFO L136 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2020-07-17 21:30:53,754 INFO L138 SettingsManager]: * sizeof long=4 [2020-07-17 21:30:53,754 INFO L138 SettingsManager]: * Overapproximate operations on floating types=true [2020-07-17 21:30:53,754 INFO L138 SettingsManager]: * sizeof POINTER=4 [2020-07-17 21:30:53,754 INFO L138 SettingsManager]: * Check division by zero=IGNORE [2020-07-17 21:30:53,754 INFO L138 SettingsManager]: * Pointer to allocated memory at dereference=IGNORE [2020-07-17 21:30:53,755 INFO L138 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=IGNORE [2020-07-17 21:30:53,755 INFO L138 SettingsManager]: * Check array bounds for arrays that are off heap=IGNORE [2020-07-17 21:30:53,755 INFO L138 SettingsManager]: * sizeof long double=12 [2020-07-17 21:30:53,755 INFO L138 SettingsManager]: * Check if freed pointer was valid=false [2020-07-17 21:30:53,755 INFO L138 SettingsManager]: * Use constant arrays=true [2020-07-17 21:30:53,755 INFO L138 SettingsManager]: * Pointer base address is valid at dereference=IGNORE [2020-07-17 21:30:53,756 INFO L136 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2020-07-17 21:30:53,756 INFO L138 SettingsManager]: * Size of a code block=SequenceOfStatements [2020-07-17 21:30:53,756 INFO L138 SettingsManager]: * To the following directory=./dump/ [2020-07-17 21:30:53,756 INFO L138 SettingsManager]: * SMT solver=External_DefaultMode [2020-07-17 21:30:53,756 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2020-07-17 21:30:53,757 INFO L136 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2020-07-17 21:30:53,757 INFO L138 SettingsManager]: * Compute Interpolants along a Counterexample=FPandBP [2020-07-17 21:30:53,757 INFO L138 SettingsManager]: * Positions where we compute the Hoare Annotation=LoopsAndPotentialCycles [2020-07-17 21:30:53,757 INFO L138 SettingsManager]: * Trace refinement strategy=CAMEL [2020-07-17 21:30:53,757 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in [2020-07-17 21:30:53,758 INFO L138 SettingsManager]: * Compute Hoare Annotation of negated interpolant automaton, abstraction and CFG=true [2020-07-17 21:30:53,758 INFO L138 SettingsManager]: * Trace refinement exception blacklist=NONE [2020-07-17 21:30:53,758 INFO L138 SettingsManager]: * SMT solver=External_ModelsAndUnsatCoreMode [2020-07-17 21:30:54,028 INFO L81 nceAwareModelManager]: Repository-Root is: /tmp [2020-07-17 21:30:54,052 INFO L258 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2020-07-17 21:30:54,055 INFO L214 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2020-07-17 21:30:54,057 INFO L271 PluginConnector]: Initializing CDTParser... [2020-07-17 21:30:54,057 INFO L275 PluginConnector]: CDTParser initialized [2020-07-17 21:30:54,058 INFO L429 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/svcomp/product-lines/minepump_spec4_product33.cil.c [2020-07-17 21:30:54,143 INFO L220 CDTParser]: Created temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/a75b6fd40/5926f890e5cc419b94458f377abff2ec/FLAGa5b791996 [2020-07-17 21:30:54,729 INFO L306 CDTParser]: Found 1 translation units. [2020-07-17 21:30:54,730 INFO L160 CDTParser]: Scanning /storage/repos/ultimate/trunk/examples/svcomp/product-lines/minepump_spec4_product33.cil.c [2020-07-17 21:30:54,754 INFO L349 CDTParser]: About to delete temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/a75b6fd40/5926f890e5cc419b94458f377abff2ec/FLAGa5b791996 [2020-07-17 21:30:54,958 INFO L357 CDTParser]: Successfully deleted /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/a75b6fd40/5926f890e5cc419b94458f377abff2ec [2020-07-17 21:30:54,972 INFO L296 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2020-07-17 21:30:54,975 INFO L131 ToolchainWalker]: Walking toolchain with 4 elements. [2020-07-17 21:30:54,981 INFO L113 PluginConnector]: ------------------------CACSL2BoogieTranslator---------------------------- [2020-07-17 21:30:54,982 INFO L271 PluginConnector]: Initializing CACSL2BoogieTranslator... [2020-07-17 21:30:54,985 INFO L275 PluginConnector]: CACSL2BoogieTranslator initialized [2020-07-17 21:30:54,987 INFO L185 PluginConnector]: Executing the observer ACSLObjectContainerObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 17.07 09:30:54" (1/1) ... [2020-07-17 21:30:54,990 INFO L205 PluginConnector]: Invalid model from CACSL2BoogieTranslator for observer de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator.ACSLObjectContainerObserver@3fa8b4f1 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:54, skipping insertion in model container [2020-07-17 21:30:54,991 INFO L185 PluginConnector]: Executing the observer CACSL2BoogieTranslatorObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 17.07 09:30:54" (1/1) ... [2020-07-17 21:30:54,999 INFO L145 MainTranslator]: Starting translation in SV-COMP mode [2020-07-17 21:30:55,040 INFO L178 MainTranslator]: Built tables and reachable declarations [2020-07-17 21:30:55,407 INFO L206 PostProcessor]: Analyzing one entry point: main [2020-07-17 21:30:55,534 INFO L203 MainTranslator]: Completed pre-run [2020-07-17 21:30:55,665 INFO L206 PostProcessor]: Analyzing one entry point: main [2020-07-17 21:30:55,699 INFO L208 MainTranslator]: Completed translation [2020-07-17 21:30:55,700 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55 WrapperNode [2020-07-17 21:30:55,700 INFO L132 PluginConnector]: ------------------------ END CACSL2BoogieTranslator---------------------------- [2020-07-17 21:30:55,701 INFO L113 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2020-07-17 21:30:55,701 INFO L271 PluginConnector]: Initializing Boogie Preprocessor... [2020-07-17 21:30:55,701 INFO L275 PluginConnector]: Boogie Preprocessor initialized [2020-07-17 21:30:55,720 INFO L185 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55" (1/1) ... [2020-07-17 21:30:55,722 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55" (1/1) ... [2020-07-17 21:30:55,761 INFO L185 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55" (1/1) ... [2020-07-17 21:30:55,761 INFO L185 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55" (1/1) ... [2020-07-17 21:30:55,835 INFO L185 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55" (1/1) ... [2020-07-17 21:30:55,848 INFO L185 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55" (1/1) ... [2020-07-17 21:30:55,859 INFO L185 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55" (1/1) ... [2020-07-17 21:30:55,870 INFO L132 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2020-07-17 21:30:55,871 INFO L113 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2020-07-17 21:30:55,871 INFO L271 PluginConnector]: Initializing RCFGBuilder... [2020-07-17 21:30:55,871 INFO L275 PluginConnector]: RCFGBuilder initialized [2020-07-17 21:30:55,872 INFO L185 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55" (1/1) ... No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 Starting monitored process 1 with z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (exit command is (exit), workingDir is null) Waiting until toolchain timeout for monitored process 1 with z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2020-07-17 21:30:55,946 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.init [2020-07-17 21:30:55,947 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2020-07-17 21:30:55,947 INFO L138 BoogieDeclarations]: Found implementation of procedure ##fun~int~X~int~TO~int [2020-07-17 21:30:55,947 INFO L138 BoogieDeclarations]: Found implementation of procedure __utac__exception__cf_handler_set [2020-07-17 21:30:55,947 INFO L138 BoogieDeclarations]: Found implementation of procedure __utac__exception__cf_handler_free [2020-07-17 21:30:55,947 INFO L138 BoogieDeclarations]: Found implementation of procedure __utac__exception__cf_handler_reset [2020-07-17 21:30:55,948 INFO L138 BoogieDeclarations]: Found implementation of procedure __utac__error_stack_mgt [2020-07-17 21:30:55,948 INFO L138 BoogieDeclarations]: Found implementation of procedure __utac__get_this_arg [2020-07-17 21:30:55,948 INFO L138 BoogieDeclarations]: Found implementation of procedure __utac__get_this_argtype [2020-07-17 21:30:55,948 INFO L138 BoogieDeclarations]: Found implementation of procedure cleanup [2020-07-17 21:30:55,948 INFO L138 BoogieDeclarations]: Found implementation of procedure Specification2 [2020-07-17 21:30:55,948 INFO L138 BoogieDeclarations]: Found implementation of procedure setup [2020-07-17 21:30:55,949 INFO L138 BoogieDeclarations]: Found implementation of procedure runTest [2020-07-17 21:30:55,949 INFO L138 BoogieDeclarations]: Found implementation of procedure main [2020-07-17 21:30:55,949 INFO L138 BoogieDeclarations]: Found implementation of procedure select_one [2020-07-17 21:30:55,949 INFO L138 BoogieDeclarations]: Found implementation of procedure select_features [2020-07-17 21:30:55,949 INFO L138 BoogieDeclarations]: Found implementation of procedure select_helpers [2020-07-17 21:30:55,949 INFO L138 BoogieDeclarations]: Found implementation of procedure valid_product [2020-07-17 21:30:55,949 INFO L138 BoogieDeclarations]: Found implementation of procedure test [2020-07-17 21:30:55,950 INFO L138 BoogieDeclarations]: Found implementation of procedure lowerWaterLevel [2020-07-17 21:30:55,950 INFO L138 BoogieDeclarations]: Found implementation of procedure waterRise [2020-07-17 21:30:55,950 INFO L138 BoogieDeclarations]: Found implementation of procedure changeMethaneLevel [2020-07-17 21:30:55,950 INFO L138 BoogieDeclarations]: Found implementation of procedure isMethaneLevelCritical [2020-07-17 21:30:55,950 INFO L138 BoogieDeclarations]: Found implementation of procedure printEnvironment [2020-07-17 21:30:55,950 INFO L138 BoogieDeclarations]: Found implementation of procedure getWaterLevel [2020-07-17 21:30:55,951 INFO L138 BoogieDeclarations]: Found implementation of procedure isHighWaterSensorDry [2020-07-17 21:30:55,951 INFO L138 BoogieDeclarations]: Found implementation of procedure timeShift [2020-07-17 21:30:55,951 INFO L138 BoogieDeclarations]: Found implementation of procedure processEnvironment__wrappee__base [2020-07-17 21:30:55,951 INFO L138 BoogieDeclarations]: Found implementation of procedure processEnvironment [2020-07-17 21:30:55,951 INFO L138 BoogieDeclarations]: Found implementation of procedure activatePump [2020-07-17 21:30:55,951 INFO L138 BoogieDeclarations]: Found implementation of procedure deactivatePump [2020-07-17 21:30:55,952 INFO L138 BoogieDeclarations]: Found implementation of procedure isMethaneAlarm [2020-07-17 21:30:55,952 INFO L138 BoogieDeclarations]: Found implementation of procedure isPumpRunning [2020-07-17 21:30:55,952 INFO L138 BoogieDeclarations]: Found implementation of procedure printPump [2020-07-17 21:30:55,952 INFO L138 BoogieDeclarations]: Found implementation of procedure isHighWaterLevel [2020-07-17 21:30:55,952 INFO L138 BoogieDeclarations]: Found implementation of procedure __automaton_fail [2020-07-17 21:30:55,952 INFO L138 BoogieDeclarations]: Found implementation of procedure __utac_acc__Specification4_spec__1 [2020-07-17 21:30:55,953 INFO L130 BoogieDeclarations]: Found specification of procedure __VERIFIER_error [2020-07-17 21:30:55,953 INFO L130 BoogieDeclarations]: Found specification of procedure __VERIFIER_nondet_int [2020-07-17 21:30:55,953 INFO L130 BoogieDeclarations]: Found specification of procedure printf [2020-07-17 21:30:55,953 INFO L130 BoogieDeclarations]: Found specification of procedure __assert_fail [2020-07-17 21:30:55,953 INFO L130 BoogieDeclarations]: Found specification of procedure malloc [2020-07-17 21:30:55,953 INFO L130 BoogieDeclarations]: Found specification of procedure free [2020-07-17 21:30:55,953 INFO L130 BoogieDeclarations]: Found specification of procedure __utac__exception__cf_handler_set [2020-07-17 21:30:55,954 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocOnHeap [2020-07-17 21:30:55,954 INFO L130 BoogieDeclarations]: Found specification of procedure write~$Pointer$ [2020-07-17 21:30:55,954 INFO L130 BoogieDeclarations]: Found specification of procedure write~int [2020-07-17 21:30:55,954 INFO L130 BoogieDeclarations]: Found specification of procedure read~$Pointer$ [2020-07-17 21:30:55,954 INFO L130 BoogieDeclarations]: Found specification of procedure __utac__exception__cf_handler_free [2020-07-17 21:30:55,954 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.dealloc [2020-07-17 21:30:55,954 INFO L130 BoogieDeclarations]: Found specification of procedure __utac__exception__cf_handler_reset [2020-07-17 21:30:55,955 INFO L130 BoogieDeclarations]: Found specification of procedure ##fun~int~X~int~TO~int [2020-07-17 21:30:55,955 INFO L130 BoogieDeclarations]: Found specification of procedure read~int [2020-07-17 21:30:55,955 INFO L130 BoogieDeclarations]: Found specification of procedure __utac__error_stack_mgt [2020-07-17 21:30:55,955 INFO L130 BoogieDeclarations]: Found specification of procedure __utac__get_this_arg [2020-07-17 21:30:55,955 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocOnStack [2020-07-17 21:30:55,955 INFO L130 BoogieDeclarations]: Found specification of procedure __utac__get_this_argtype [2020-07-17 21:30:55,955 INFO L130 BoogieDeclarations]: Found specification of procedure timeShift [2020-07-17 21:30:55,956 INFO L130 BoogieDeclarations]: Found specification of procedure cleanup [2020-07-17 21:30:55,956 INFO L130 BoogieDeclarations]: Found specification of procedure printPump [2020-07-17 21:30:55,956 INFO L130 BoogieDeclarations]: Found specification of procedure waterRise [2020-07-17 21:30:55,956 INFO L130 BoogieDeclarations]: Found specification of procedure changeMethaneLevel [2020-07-17 21:30:55,956 INFO L130 BoogieDeclarations]: Found specification of procedure Specification2 [2020-07-17 21:30:55,956 INFO L130 BoogieDeclarations]: Found specification of procedure setup [2020-07-17 21:30:55,956 INFO L130 BoogieDeclarations]: Found specification of procedure test [2020-07-17 21:30:55,957 INFO L130 BoogieDeclarations]: Found specification of procedure runTest [2020-07-17 21:30:55,957 INFO L130 BoogieDeclarations]: Found specification of procedure select_helpers [2020-07-17 21:30:55,957 INFO L130 BoogieDeclarations]: Found specification of procedure select_features [2020-07-17 21:30:55,957 INFO L130 BoogieDeclarations]: Found specification of procedure valid_product [2020-07-17 21:30:55,957 INFO L130 BoogieDeclarations]: Found specification of procedure main [2020-07-17 21:30:55,957 INFO L130 BoogieDeclarations]: Found specification of procedure select_one [2020-07-17 21:30:55,958 INFO L130 BoogieDeclarations]: Found specification of procedure lowerWaterLevel [2020-07-17 21:30:55,958 INFO L130 BoogieDeclarations]: Found specification of procedure isMethaneLevelCritical [2020-07-17 21:30:55,958 INFO L130 BoogieDeclarations]: Found specification of procedure getWaterLevel [2020-07-17 21:30:55,958 INFO L130 BoogieDeclarations]: Found specification of procedure printEnvironment [2020-07-17 21:30:55,958 INFO L130 BoogieDeclarations]: Found specification of procedure isHighWaterSensorDry [2020-07-17 21:30:55,958 INFO L130 BoogieDeclarations]: Found specification of procedure activatePump [2020-07-17 21:30:55,958 INFO L130 BoogieDeclarations]: Found specification of procedure deactivatePump [2020-07-17 21:30:55,959 INFO L130 BoogieDeclarations]: Found specification of procedure isPumpRunning [2020-07-17 21:30:55,959 INFO L130 BoogieDeclarations]: Found specification of procedure __utac_acc__Specification4_spec__1 [2020-07-17 21:30:55,959 INFO L130 BoogieDeclarations]: Found specification of procedure processEnvironment [2020-07-17 21:30:55,959 INFO L130 BoogieDeclarations]: Found specification of procedure processEnvironment__wrappee__base [2020-07-17 21:30:55,959 INFO L130 BoogieDeclarations]: Found specification of procedure isHighWaterLevel [2020-07-17 21:30:55,959 INFO L130 BoogieDeclarations]: Found specification of procedure isMethaneAlarm [2020-07-17 21:30:55,959 INFO L130 BoogieDeclarations]: Found specification of procedure __automaton_fail [2020-07-17 21:30:55,960 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.init [2020-07-17 21:30:55,960 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~int [2020-07-17 21:30:55,960 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2020-07-17 21:30:57,786 INFO L290 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2020-07-17 21:30:57,786 INFO L295 CfgBuilder]: Removed 5 assume(true) statements. [2020-07-17 21:30:57,792 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 17.07 09:30:57 BoogieIcfgContainer [2020-07-17 21:30:57,792 INFO L132 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2020-07-17 21:30:57,794 INFO L113 PluginConnector]: ------------------------TraceAbstraction---------------------------- [2020-07-17 21:30:57,794 INFO L271 PluginConnector]: Initializing TraceAbstraction... [2020-07-17 21:30:57,798 INFO L275 PluginConnector]: TraceAbstraction initialized [2020-07-17 21:30:57,798 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "CDTParser AST 17.07 09:30:54" (1/3) ... [2020-07-17 21:30:57,799 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@137c25a0 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 17.07 09:30:57, skipping insertion in model container [2020-07-17 21:30:57,799 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 17.07 09:30:55" (2/3) ... [2020-07-17 21:30:57,800 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@137c25a0 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 17.07 09:30:57, skipping insertion in model container [2020-07-17 21:30:57,800 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 17.07 09:30:57" (3/3) ... [2020-07-17 21:30:57,802 INFO L109 eAbstractionObserver]: Analyzing ICFG minepump_spec4_product33.cil.c [2020-07-17 21:30:57,814 INFO L157 ceAbstractionStarter]: Automizer settings: Hoare:true NWA Interpolation:FPandBP Determinization: PREDICATE_ABSTRACTION [2020-07-17 21:30:57,823 INFO L169 ceAbstractionStarter]: Appying trace abstraction to program that has 1 error locations. [2020-07-17 21:30:57,839 INFO L251 AbstractCegarLoop]: Starting to check reachability of 1 error locations. [2020-07-17 21:30:57,867 INFO L375 AbstractCegarLoop]: Interprodecural is true [2020-07-17 21:30:57,867 INFO L376 AbstractCegarLoop]: Hoare is true [2020-07-17 21:30:57,867 INFO L377 AbstractCegarLoop]: Compute interpolants for FPandBP [2020-07-17 21:30:57,867 INFO L378 AbstractCegarLoop]: Backedges is STRAIGHT_LINE [2020-07-17 21:30:57,868 INFO L379 AbstractCegarLoop]: Determinization is PREDICATE_ABSTRACTION [2020-07-17 21:30:57,868 INFO L380 AbstractCegarLoop]: Difference is false [2020-07-17 21:30:57,868 INFO L381 AbstractCegarLoop]: Minimize is MINIMIZE_SEVPA [2020-07-17 21:30:57,869 INFO L385 AbstractCegarLoop]: ======== Iteration 0==of CEGAR loop == AllErrorsAtOnce======== [2020-07-17 21:30:57,893 INFO L276 IsEmpty]: Start isEmpty. Operand 148 states. [2020-07-17 21:30:57,904 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 47 [2020-07-17 21:30:57,905 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:30:57,906 INFO L422 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:30:57,907 INFO L427 AbstractCegarLoop]: === Iteration 1 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:30:57,914 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:30:57,914 INFO L82 PathProgramCache]: Analyzing trace with hash 1120421974, now seen corresponding path program 1 times [2020-07-17 21:30:57,927 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:30:57,927 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1835289261] [2020-07-17 21:30:57,928 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:30:58,212 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:30:58,681 WARN L193 SmtUtils]: Spent 300.00 ms on a formula simplification that was a NOOP. DAG size: 184 [2020-07-17 21:30:58,722 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:30:58,779 INFO L280 TraceCheckUtils]: 0: Hoare triple {171#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {151#true} is VALID [2020-07-17 21:30:58,780 INFO L280 TraceCheckUtils]: 1: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,780 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {151#true} {151#true} #479#return; {151#true} is VALID [2020-07-17 21:30:58,783 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:30:58,786 INFO L280 TraceCheckUtils]: 0: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,786 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {151#true} {151#true} #401#return; {151#true} is VALID [2020-07-17 21:30:58,787 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:30:58,790 INFO L280 TraceCheckUtils]: 0: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,790 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {151#true} {151#true} #403#return; {151#true} is VALID [2020-07-17 21:30:58,792 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:30:58,795 INFO L280 TraceCheckUtils]: 0: Hoare triple {151#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {151#true} is VALID [2020-07-17 21:30:58,796 INFO L280 TraceCheckUtils]: 1: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,796 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {151#true} {151#true} #405#return; {151#true} is VALID [2020-07-17 21:30:58,797 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:30:58,800 INFO L280 TraceCheckUtils]: 0: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,800 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {151#true} {151#true} #407#return; {151#true} is VALID [2020-07-17 21:30:58,801 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:30:58,805 INFO L280 TraceCheckUtils]: 0: Hoare triple {151#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {151#true} is VALID [2020-07-17 21:30:58,805 INFO L280 TraceCheckUtils]: 1: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,806 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {151#true} {152#false} #395#return; {152#false} is VALID [2020-07-17 21:30:58,807 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:30:58,810 INFO L280 TraceCheckUtils]: 0: Hoare triple {151#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {151#true} is VALID [2020-07-17 21:30:58,810 INFO L280 TraceCheckUtils]: 1: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,810 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {151#true} {152#false} #397#return; {152#false} is VALID [2020-07-17 21:30:58,817 INFO L263 TraceCheckUtils]: 0: Hoare triple {151#true} call ULTIMATE.init(); {171#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} is VALID [2020-07-17 21:30:58,818 INFO L280 TraceCheckUtils]: 1: Hoare triple {171#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {151#true} is VALID [2020-07-17 21:30:58,818 INFO L280 TraceCheckUtils]: 2: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,818 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {151#true} {151#true} #479#return; {151#true} is VALID [2020-07-17 21:30:58,819 INFO L263 TraceCheckUtils]: 4: Hoare triple {151#true} call #t~ret72 := main(); {151#true} is VALID [2020-07-17 21:30:58,819 INFO L280 TraceCheckUtils]: 5: Hoare triple {151#true} havoc ~retValue_acc~3;havoc ~tmp~3; {151#true} is VALID [2020-07-17 21:30:58,819 INFO L263 TraceCheckUtils]: 6: Hoare triple {151#true} call select_helpers(); {151#true} is VALID [2020-07-17 21:30:58,820 INFO L280 TraceCheckUtils]: 7: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,820 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {151#true} {151#true} #401#return; {151#true} is VALID [2020-07-17 21:30:58,820 INFO L263 TraceCheckUtils]: 9: Hoare triple {151#true} call select_features(); {151#true} is VALID [2020-07-17 21:30:58,821 INFO L280 TraceCheckUtils]: 10: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,821 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {151#true} {151#true} #403#return; {151#true} is VALID [2020-07-17 21:30:58,821 INFO L263 TraceCheckUtils]: 12: Hoare triple {151#true} call #t~ret35 := valid_product(); {151#true} is VALID [2020-07-17 21:30:58,822 INFO L280 TraceCheckUtils]: 13: Hoare triple {151#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {151#true} is VALID [2020-07-17 21:30:58,822 INFO L280 TraceCheckUtils]: 14: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,822 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {151#true} {151#true} #405#return; {151#true} is VALID [2020-07-17 21:30:58,823 INFO L280 TraceCheckUtils]: 16: Hoare triple {151#true} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {151#true} is VALID [2020-07-17 21:30:58,823 INFO L280 TraceCheckUtils]: 17: Hoare triple {151#true} assume 0 != ~tmp~3; {151#true} is VALID [2020-07-17 21:30:58,823 INFO L263 TraceCheckUtils]: 18: Hoare triple {151#true} call setup(); {151#true} is VALID [2020-07-17 21:30:58,824 INFO L280 TraceCheckUtils]: 19: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,824 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {151#true} {151#true} #407#return; {151#true} is VALID [2020-07-17 21:30:58,824 INFO L263 TraceCheckUtils]: 21: Hoare triple {151#true} call runTest(); {151#true} is VALID [2020-07-17 21:30:58,825 INFO L263 TraceCheckUtils]: 22: Hoare triple {151#true} call test(); {151#true} is VALID [2020-07-17 21:30:58,825 INFO L280 TraceCheckUtils]: 23: Hoare triple {151#true} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {151#true} is VALID [2020-07-17 21:30:58,826 INFO L280 TraceCheckUtils]: 24: Hoare triple {151#true} assume false; {152#false} is VALID [2020-07-17 21:30:58,826 INFO L263 TraceCheckUtils]: 25: Hoare triple {152#false} call cleanup(); {152#false} is VALID [2020-07-17 21:30:58,827 INFO L280 TraceCheckUtils]: 26: Hoare triple {152#false} havoc ~i~0;havoc ~__cil_tmp2~0; {152#false} is VALID [2020-07-17 21:30:58,827 INFO L263 TraceCheckUtils]: 27: Hoare triple {152#false} call timeShift(); {152#false} is VALID [2020-07-17 21:30:58,827 INFO L280 TraceCheckUtils]: 28: Hoare triple {152#false} assume !(0 != ~pumpRunning~0); {152#false} is VALID [2020-07-17 21:30:58,828 INFO L280 TraceCheckUtils]: 29: Hoare triple {152#false} assume !(0 != ~systemActive~0); {152#false} is VALID [2020-07-17 21:30:58,828 INFO L263 TraceCheckUtils]: 30: Hoare triple {152#false} call __utac_acc__Specification4_spec__1(); {152#false} is VALID [2020-07-17 21:30:58,828 INFO L280 TraceCheckUtils]: 31: Hoare triple {152#false} havoc ~tmp~7;havoc ~tmp___0~2; {152#false} is VALID [2020-07-17 21:30:58,829 INFO L263 TraceCheckUtils]: 32: Hoare triple {152#false} call #t~ret70 := getWaterLevel(); {151#true} is VALID [2020-07-17 21:30:58,829 INFO L280 TraceCheckUtils]: 33: Hoare triple {151#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {151#true} is VALID [2020-07-17 21:30:58,829 INFO L280 TraceCheckUtils]: 34: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,830 INFO L275 TraceCheckUtils]: 35: Hoare quadruple {151#true} {152#false} #395#return; {152#false} is VALID [2020-07-17 21:30:58,830 INFO L280 TraceCheckUtils]: 36: Hoare triple {152#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {152#false} is VALID [2020-07-17 21:30:58,830 INFO L280 TraceCheckUtils]: 37: Hoare triple {152#false} assume 0 == ~tmp~7; {152#false} is VALID [2020-07-17 21:30:58,831 INFO L263 TraceCheckUtils]: 38: Hoare triple {152#false} call #t~ret71 := isPumpRunning(); {151#true} is VALID [2020-07-17 21:30:58,831 INFO L280 TraceCheckUtils]: 39: Hoare triple {151#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {151#true} is VALID [2020-07-17 21:30:58,831 INFO L280 TraceCheckUtils]: 40: Hoare triple {151#true} assume true; {151#true} is VALID [2020-07-17 21:30:58,832 INFO L275 TraceCheckUtils]: 41: Hoare quadruple {151#true} {152#false} #397#return; {152#false} is VALID [2020-07-17 21:30:58,832 INFO L280 TraceCheckUtils]: 42: Hoare triple {152#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {152#false} is VALID [2020-07-17 21:30:58,833 INFO L280 TraceCheckUtils]: 43: Hoare triple {152#false} assume 0 != ~tmp___0~2; {152#false} is VALID [2020-07-17 21:30:58,833 INFO L263 TraceCheckUtils]: 44: Hoare triple {152#false} call __automaton_fail(); {152#false} is VALID [2020-07-17 21:30:58,833 INFO L280 TraceCheckUtils]: 45: Hoare triple {152#false} assume !false; {152#false} is VALID [2020-07-17 21:30:58,844 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2020-07-17 21:30:58,845 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1835289261] [2020-07-17 21:30:58,846 INFO L220 FreeRefinementEngine]: Constructing automaton from 1 perfect and 0 imperfect interpolant sequences. [2020-07-17 21:30:58,846 INFO L233 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [] total 3 [2020-07-17 21:30:58,847 INFO L156 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [884790289] [2020-07-17 21:30:58,854 INFO L78 Accepts]: Start accepts. Automaton has 3 states. Word has length 46 [2020-07-17 21:30:58,857 INFO L84 Accepts]: Finished accepts. word is accepted. [2020-07-17 21:30:58,861 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 3 states. [2020-07-17 21:30:58,942 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 46 edges. 46 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:30:58,942 INFO L459 AbstractCegarLoop]: Interpolant automaton has 3 states [2020-07-17 21:30:58,942 INFO L143 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2020-07-17 21:30:58,951 INFO L142 InterpolantAutomaton]: Constructing interpolant automaton starting with 3 interpolants. [2020-07-17 21:30:58,952 INFO L144 InterpolantAutomaton]: CoverageRelationStatistics Valid=3, Invalid=3, Unknown=0, NotChecked=0, Total=6 [2020-07-17 21:30:58,954 INFO L87 Difference]: Start difference. First operand 148 states. Second operand 3 states. [2020-07-17 21:31:02,817 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:02,817 INFO L93 Difference]: Finished difference Result 249 states and 331 transitions. [2020-07-17 21:31:02,818 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 3 states. [2020-07-17 21:31:02,818 INFO L78 Accepts]: Start accepts. Automaton has 3 states. Word has length 46 [2020-07-17 21:31:02,818 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2020-07-17 21:31:02,820 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 3 states. [2020-07-17 21:31:02,862 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 331 transitions. [2020-07-17 21:31:02,862 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 3 states. [2020-07-17 21:31:02,890 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 331 transitions. [2020-07-17 21:31:02,891 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 3 states and 331 transitions. [2020-07-17 21:31:04,026 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 331 edges. 331 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:31:04,052 INFO L225 Difference]: With dead ends: 249 [2020-07-17 21:31:04,052 INFO L226 Difference]: Without dead ends: 135 [2020-07-17 21:31:04,057 INFO L675 BasicCegarLoop]: 0 DeclaredPredicates, 16 GetRequests, 15 SyntacticMatches, 0 SemanticMatches, 1 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.3s TimeCoverageRelationStatistics Valid=3, Invalid=3, Unknown=0, NotChecked=0, Total=6 [2020-07-17 21:31:04,075 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 135 states. [2020-07-17 21:31:05,127 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 135 to 105. [2020-07-17 21:31:05,127 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2020-07-17 21:31:05,128 INFO L82 GeneralOperation]: Start isEquivalent. First operand 135 states. Second operand 105 states. [2020-07-17 21:31:05,128 INFO L74 IsIncluded]: Start isIncluded. First operand 135 states. Second operand 105 states. [2020-07-17 21:31:05,128 INFO L87 Difference]: Start difference. First operand 135 states. Second operand 105 states. [2020-07-17 21:31:05,143 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:05,143 INFO L93 Difference]: Finished difference Result 135 states and 171 transitions. [2020-07-17 21:31:05,143 INFO L276 IsEmpty]: Start isEmpty. Operand 135 states and 171 transitions. [2020-07-17 21:31:05,147 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:31:05,147 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:31:05,147 INFO L74 IsIncluded]: Start isIncluded. First operand 105 states. Second operand 135 states. [2020-07-17 21:31:05,147 INFO L87 Difference]: Start difference. First operand 105 states. Second operand 135 states. [2020-07-17 21:31:05,162 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:05,162 INFO L93 Difference]: Finished difference Result 135 states and 171 transitions. [2020-07-17 21:31:05,162 INFO L276 IsEmpty]: Start isEmpty. Operand 135 states and 171 transitions. [2020-07-17 21:31:05,166 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:31:05,166 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:31:05,166 INFO L88 GeneralOperation]: Finished isEquivalent. [2020-07-17 21:31:05,166 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2020-07-17 21:31:05,166 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 105 states. [2020-07-17 21:31:05,172 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 105 states to 105 states and 123 transitions. [2020-07-17 21:31:05,174 INFO L78 Accepts]: Start accepts. Automaton has 105 states and 123 transitions. Word has length 46 [2020-07-17 21:31:05,174 INFO L84 Accepts]: Finished accepts. word is rejected. [2020-07-17 21:31:05,175 INFO L479 AbstractCegarLoop]: Abstraction has 105 states and 123 transitions. [2020-07-17 21:31:05,175 INFO L480 AbstractCegarLoop]: Interpolant automaton has 3 states. [2020-07-17 21:31:05,175 INFO L276 IsEmpty]: Start isEmpty. Operand 105 states and 123 transitions. [2020-07-17 21:31:05,177 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 48 [2020-07-17 21:31:05,177 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:31:05,177 INFO L422 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:31:05,178 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable0 [2020-07-17 21:31:05,178 INFO L427 AbstractCegarLoop]: === Iteration 2 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:31:05,178 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:31:05,178 INFO L82 PathProgramCache]: Analyzing trace with hash 1195015831, now seen corresponding path program 1 times [2020-07-17 21:31:05,179 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:31:05,179 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1542963995] [2020-07-17 21:31:05,179 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:31:05,220 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:05,533 WARN L193 SmtUtils]: Spent 227.00 ms on a formula simplification that was a NOOP. DAG size: 184 [2020-07-17 21:31:05,562 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:05,593 INFO L280 TraceCheckUtils]: 0: Hoare triple {960#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {939#true} is VALID [2020-07-17 21:31:05,593 INFO L280 TraceCheckUtils]: 1: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,594 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {939#true} {939#true} #479#return; {939#true} is VALID [2020-07-17 21:31:05,594 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:05,598 INFO L280 TraceCheckUtils]: 0: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,598 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {939#true} {939#true} #401#return; {939#true} is VALID [2020-07-17 21:31:05,598 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:05,600 INFO L280 TraceCheckUtils]: 0: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,601 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {939#true} {939#true} #403#return; {939#true} is VALID [2020-07-17 21:31:05,602 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:05,608 INFO L280 TraceCheckUtils]: 0: Hoare triple {939#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {939#true} is VALID [2020-07-17 21:31:05,609 INFO L280 TraceCheckUtils]: 1: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,609 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {939#true} {939#true} #405#return; {939#true} is VALID [2020-07-17 21:31:05,610 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:05,617 INFO L280 TraceCheckUtils]: 0: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,617 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {939#true} {939#true} #407#return; {939#true} is VALID [2020-07-17 21:31:05,618 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:05,620 INFO L280 TraceCheckUtils]: 0: Hoare triple {939#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {939#true} is VALID [2020-07-17 21:31:05,620 INFO L280 TraceCheckUtils]: 1: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,620 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {939#true} {940#false} #395#return; {940#false} is VALID [2020-07-17 21:31:05,621 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:05,626 INFO L280 TraceCheckUtils]: 0: Hoare triple {939#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {939#true} is VALID [2020-07-17 21:31:05,626 INFO L280 TraceCheckUtils]: 1: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,627 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {939#true} {940#false} #397#return; {940#false} is VALID [2020-07-17 21:31:05,631 INFO L263 TraceCheckUtils]: 0: Hoare triple {939#true} call ULTIMATE.init(); {960#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} is VALID [2020-07-17 21:31:05,632 INFO L280 TraceCheckUtils]: 1: Hoare triple {960#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {939#true} is VALID [2020-07-17 21:31:05,632 INFO L280 TraceCheckUtils]: 2: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,633 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {939#true} {939#true} #479#return; {939#true} is VALID [2020-07-17 21:31:05,633 INFO L263 TraceCheckUtils]: 4: Hoare triple {939#true} call #t~ret72 := main(); {939#true} is VALID [2020-07-17 21:31:05,633 INFO L280 TraceCheckUtils]: 5: Hoare triple {939#true} havoc ~retValue_acc~3;havoc ~tmp~3; {939#true} is VALID [2020-07-17 21:31:05,633 INFO L263 TraceCheckUtils]: 6: Hoare triple {939#true} call select_helpers(); {939#true} is VALID [2020-07-17 21:31:05,634 INFO L280 TraceCheckUtils]: 7: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,634 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {939#true} {939#true} #401#return; {939#true} is VALID [2020-07-17 21:31:05,634 INFO L263 TraceCheckUtils]: 9: Hoare triple {939#true} call select_features(); {939#true} is VALID [2020-07-17 21:31:05,634 INFO L280 TraceCheckUtils]: 10: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,635 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {939#true} {939#true} #403#return; {939#true} is VALID [2020-07-17 21:31:05,635 INFO L263 TraceCheckUtils]: 12: Hoare triple {939#true} call #t~ret35 := valid_product(); {939#true} is VALID [2020-07-17 21:31:05,635 INFO L280 TraceCheckUtils]: 13: Hoare triple {939#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {939#true} is VALID [2020-07-17 21:31:05,636 INFO L280 TraceCheckUtils]: 14: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,636 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {939#true} {939#true} #405#return; {939#true} is VALID [2020-07-17 21:31:05,636 INFO L280 TraceCheckUtils]: 16: Hoare triple {939#true} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {939#true} is VALID [2020-07-17 21:31:05,636 INFO L280 TraceCheckUtils]: 17: Hoare triple {939#true} assume 0 != ~tmp~3; {939#true} is VALID [2020-07-17 21:31:05,637 INFO L263 TraceCheckUtils]: 18: Hoare triple {939#true} call setup(); {939#true} is VALID [2020-07-17 21:31:05,637 INFO L280 TraceCheckUtils]: 19: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,637 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {939#true} {939#true} #407#return; {939#true} is VALID [2020-07-17 21:31:05,638 INFO L263 TraceCheckUtils]: 21: Hoare triple {939#true} call runTest(); {939#true} is VALID [2020-07-17 21:31:05,638 INFO L263 TraceCheckUtils]: 22: Hoare triple {939#true} call test(); {939#true} is VALID [2020-07-17 21:31:05,639 INFO L280 TraceCheckUtils]: 23: Hoare triple {939#true} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {953#(= 0 test_~splverifierCounter~0)} is VALID [2020-07-17 21:31:05,640 INFO L280 TraceCheckUtils]: 24: Hoare triple {953#(= 0 test_~splverifierCounter~0)} assume !false; {953#(= 0 test_~splverifierCounter~0)} is VALID [2020-07-17 21:31:05,640 INFO L280 TraceCheckUtils]: 25: Hoare triple {953#(= 0 test_~splverifierCounter~0)} assume !(~splverifierCounter~0 < 4); {940#false} is VALID [2020-07-17 21:31:05,641 INFO L263 TraceCheckUtils]: 26: Hoare triple {940#false} call cleanup(); {940#false} is VALID [2020-07-17 21:31:05,641 INFO L280 TraceCheckUtils]: 27: Hoare triple {940#false} havoc ~i~0;havoc ~__cil_tmp2~0; {940#false} is VALID [2020-07-17 21:31:05,641 INFO L263 TraceCheckUtils]: 28: Hoare triple {940#false} call timeShift(); {940#false} is VALID [2020-07-17 21:31:05,642 INFO L280 TraceCheckUtils]: 29: Hoare triple {940#false} assume !(0 != ~pumpRunning~0); {940#false} is VALID [2020-07-17 21:31:05,642 INFO L280 TraceCheckUtils]: 30: Hoare triple {940#false} assume !(0 != ~systemActive~0); {940#false} is VALID [2020-07-17 21:31:05,642 INFO L263 TraceCheckUtils]: 31: Hoare triple {940#false} call __utac_acc__Specification4_spec__1(); {940#false} is VALID [2020-07-17 21:31:05,642 INFO L280 TraceCheckUtils]: 32: Hoare triple {940#false} havoc ~tmp~7;havoc ~tmp___0~2; {940#false} is VALID [2020-07-17 21:31:05,643 INFO L263 TraceCheckUtils]: 33: Hoare triple {940#false} call #t~ret70 := getWaterLevel(); {939#true} is VALID [2020-07-17 21:31:05,643 INFO L280 TraceCheckUtils]: 34: Hoare triple {939#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {939#true} is VALID [2020-07-17 21:31:05,643 INFO L280 TraceCheckUtils]: 35: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,643 INFO L275 TraceCheckUtils]: 36: Hoare quadruple {939#true} {940#false} #395#return; {940#false} is VALID [2020-07-17 21:31:05,644 INFO L280 TraceCheckUtils]: 37: Hoare triple {940#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {940#false} is VALID [2020-07-17 21:31:05,644 INFO L280 TraceCheckUtils]: 38: Hoare triple {940#false} assume 0 == ~tmp~7; {940#false} is VALID [2020-07-17 21:31:05,644 INFO L263 TraceCheckUtils]: 39: Hoare triple {940#false} call #t~ret71 := isPumpRunning(); {939#true} is VALID [2020-07-17 21:31:05,645 INFO L280 TraceCheckUtils]: 40: Hoare triple {939#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {939#true} is VALID [2020-07-17 21:31:05,645 INFO L280 TraceCheckUtils]: 41: Hoare triple {939#true} assume true; {939#true} is VALID [2020-07-17 21:31:05,645 INFO L275 TraceCheckUtils]: 42: Hoare quadruple {939#true} {940#false} #397#return; {940#false} is VALID [2020-07-17 21:31:05,645 INFO L280 TraceCheckUtils]: 43: Hoare triple {940#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {940#false} is VALID [2020-07-17 21:31:05,646 INFO L280 TraceCheckUtils]: 44: Hoare triple {940#false} assume 0 != ~tmp___0~2; {940#false} is VALID [2020-07-17 21:31:05,646 INFO L263 TraceCheckUtils]: 45: Hoare triple {940#false} call __automaton_fail(); {940#false} is VALID [2020-07-17 21:31:05,646 INFO L280 TraceCheckUtils]: 46: Hoare triple {940#false} assume !false; {940#false} is VALID [2020-07-17 21:31:05,652 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2020-07-17 21:31:05,652 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1542963995] [2020-07-17 21:31:05,653 INFO L220 FreeRefinementEngine]: Constructing automaton from 1 perfect and 0 imperfect interpolant sequences. [2020-07-17 21:31:05,653 INFO L233 FreeRefinementEngine]: Number of different interpolants: perfect sequences [4] imperfect sequences [] total 4 [2020-07-17 21:31:05,653 INFO L156 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1391265979] [2020-07-17 21:31:05,655 INFO L78 Accepts]: Start accepts. Automaton has 4 states. Word has length 47 [2020-07-17 21:31:05,656 INFO L84 Accepts]: Finished accepts. word is accepted. [2020-07-17 21:31:05,656 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 4 states. [2020-07-17 21:31:05,744 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 47 edges. 47 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:31:05,744 INFO L459 AbstractCegarLoop]: Interpolant automaton has 4 states [2020-07-17 21:31:05,745 INFO L143 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2020-07-17 21:31:05,745 INFO L142 InterpolantAutomaton]: Constructing interpolant automaton starting with 4 interpolants. [2020-07-17 21:31:05,745 INFO L144 InterpolantAutomaton]: CoverageRelationStatistics Valid=5, Invalid=7, Unknown=0, NotChecked=0, Total=12 [2020-07-17 21:31:05,746 INFO L87 Difference]: Start difference. First operand 105 states and 123 transitions. Second operand 4 states. [2020-07-17 21:31:07,003 WARN L193 SmtUtils]: Spent 224.00 ms on a formula simplification that was a NOOP. DAG size: 187 [2020-07-17 21:31:09,734 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:09,734 INFO L93 Difference]: Finished difference Result 182 states and 222 transitions. [2020-07-17 21:31:09,734 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2020-07-17 21:31:09,734 INFO L78 Accepts]: Start accepts. Automaton has 4 states. Word has length 47 [2020-07-17 21:31:09,735 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2020-07-17 21:31:09,735 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 4 states. [2020-07-17 21:31:09,745 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 222 transitions. [2020-07-17 21:31:09,745 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 4 states. [2020-07-17 21:31:09,754 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 222 transitions. [2020-07-17 21:31:09,754 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 5 states and 222 transitions. [2020-07-17 21:31:10,607 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 222 edges. 222 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:31:10,613 INFO L225 Difference]: With dead ends: 182 [2020-07-17 21:31:10,613 INFO L226 Difference]: Without dead ends: 119 [2020-07-17 21:31:10,614 INFO L675 BasicCegarLoop]: 0 DeclaredPredicates, 18 GetRequests, 15 SyntacticMatches, 0 SemanticMatches, 3 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.5s TimeCoverageRelationStatistics Valid=9, Invalid=11, Unknown=0, NotChecked=0, Total=20 [2020-07-17 21:31:10,615 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 119 states. [2020-07-17 21:31:11,646 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 119 to 96. [2020-07-17 21:31:11,647 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2020-07-17 21:31:11,647 INFO L82 GeneralOperation]: Start isEquivalent. First operand 119 states. Second operand 96 states. [2020-07-17 21:31:11,647 INFO L74 IsIncluded]: Start isIncluded. First operand 119 states. Second operand 96 states. [2020-07-17 21:31:11,647 INFO L87 Difference]: Start difference. First operand 119 states. Second operand 96 states. [2020-07-17 21:31:11,655 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:11,655 INFO L93 Difference]: Finished difference Result 119 states and 147 transitions. [2020-07-17 21:31:11,655 INFO L276 IsEmpty]: Start isEmpty. Operand 119 states and 147 transitions. [2020-07-17 21:31:11,657 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:31:11,657 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:31:11,657 INFO L74 IsIncluded]: Start isIncluded. First operand 96 states. Second operand 119 states. [2020-07-17 21:31:11,657 INFO L87 Difference]: Start difference. First operand 96 states. Second operand 119 states. [2020-07-17 21:31:11,664 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:11,664 INFO L93 Difference]: Finished difference Result 119 states and 147 transitions. [2020-07-17 21:31:11,664 INFO L276 IsEmpty]: Start isEmpty. Operand 119 states and 147 transitions. [2020-07-17 21:31:11,665 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:31:11,665 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:31:11,666 INFO L88 GeneralOperation]: Finished isEquivalent. [2020-07-17 21:31:11,666 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2020-07-17 21:31:11,666 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 96 states. [2020-07-17 21:31:11,670 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 96 states to 96 states and 111 transitions. [2020-07-17 21:31:11,670 INFO L78 Accepts]: Start accepts. Automaton has 96 states and 111 transitions. Word has length 47 [2020-07-17 21:31:11,671 INFO L84 Accepts]: Finished accepts. word is rejected. [2020-07-17 21:31:11,671 INFO L479 AbstractCegarLoop]: Abstraction has 96 states and 111 transitions. [2020-07-17 21:31:11,671 INFO L480 AbstractCegarLoop]: Interpolant automaton has 4 states. [2020-07-17 21:31:11,671 INFO L276 IsEmpty]: Start isEmpty. Operand 96 states and 111 transitions. [2020-07-17 21:31:11,672 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 52 [2020-07-17 21:31:11,673 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:31:11,673 INFO L422 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:31:11,673 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable1 [2020-07-17 21:31:11,673 INFO L427 AbstractCegarLoop]: === Iteration 3 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:31:11,674 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:31:11,674 INFO L82 PathProgramCache]: Analyzing trace with hash -234309885, now seen corresponding path program 1 times [2020-07-17 21:31:11,674 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:31:11,674 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1755286743] [2020-07-17 21:31:11,675 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:31:11,733 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:12,099 WARN L193 SmtUtils]: Spent 217.00 ms on a formula simplification that was a NOOP. DAG size: 184 [2020-07-17 21:31:12,147 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:12,218 INFO L280 TraceCheckUtils]: 0: Hoare triple {1624#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,219 INFO L280 TraceCheckUtils]: 1: Hoare triple {1605#(= 1 ~systemActive~0)} assume true; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,219 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {1605#(= 1 ~systemActive~0)} {1600#true} #479#return; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,221 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:12,228 INFO L280 TraceCheckUtils]: 0: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,228 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {1600#true} {1605#(= 1 ~systemActive~0)} #401#return; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,230 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:12,235 INFO L280 TraceCheckUtils]: 0: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,236 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {1600#true} {1605#(= 1 ~systemActive~0)} #403#return; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,239 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:12,304 INFO L280 TraceCheckUtils]: 0: Hoare triple {1600#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {1625#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} is VALID [2020-07-17 21:31:12,306 INFO L280 TraceCheckUtils]: 1: Hoare triple {1625#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} assume true; {1625#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} is VALID [2020-07-17 21:31:12,308 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {1625#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} {1605#(= 1 ~systemActive~0)} #405#return; {1613#(= |main_#t~ret35| ~systemActive~0)} is VALID [2020-07-17 21:31:12,309 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:12,312 INFO L280 TraceCheckUtils]: 0: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,312 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {1600#true} {1615#(not (= 0 ~systemActive~0))} #407#return; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,313 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:12,316 INFO L280 TraceCheckUtils]: 0: Hoare triple {1600#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {1600#true} is VALID [2020-07-17 21:31:12,317 INFO L280 TraceCheckUtils]: 1: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,317 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {1600#true} {1601#false} #395#return; {1601#false} is VALID [2020-07-17 21:31:12,318 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:12,320 INFO L280 TraceCheckUtils]: 0: Hoare triple {1600#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {1600#true} is VALID [2020-07-17 21:31:12,320 INFO L280 TraceCheckUtils]: 1: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,320 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {1600#true} {1601#false} #397#return; {1601#false} is VALID [2020-07-17 21:31:12,324 INFO L263 TraceCheckUtils]: 0: Hoare triple {1600#true} call ULTIMATE.init(); {1624#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} is VALID [2020-07-17 21:31:12,329 INFO L280 TraceCheckUtils]: 1: Hoare triple {1624#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,330 INFO L280 TraceCheckUtils]: 2: Hoare triple {1605#(= 1 ~systemActive~0)} assume true; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,331 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {1605#(= 1 ~systemActive~0)} {1600#true} #479#return; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,331 INFO L263 TraceCheckUtils]: 4: Hoare triple {1605#(= 1 ~systemActive~0)} call #t~ret72 := main(); {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,331 INFO L280 TraceCheckUtils]: 5: Hoare triple {1605#(= 1 ~systemActive~0)} havoc ~retValue_acc~3;havoc ~tmp~3; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,332 INFO L263 TraceCheckUtils]: 6: Hoare triple {1605#(= 1 ~systemActive~0)} call select_helpers(); {1600#true} is VALID [2020-07-17 21:31:12,332 INFO L280 TraceCheckUtils]: 7: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,333 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {1600#true} {1605#(= 1 ~systemActive~0)} #401#return; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,333 INFO L263 TraceCheckUtils]: 9: Hoare triple {1605#(= 1 ~systemActive~0)} call select_features(); {1600#true} is VALID [2020-07-17 21:31:12,333 INFO L280 TraceCheckUtils]: 10: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,334 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {1600#true} {1605#(= 1 ~systemActive~0)} #403#return; {1605#(= 1 ~systemActive~0)} is VALID [2020-07-17 21:31:12,334 INFO L263 TraceCheckUtils]: 12: Hoare triple {1605#(= 1 ~systemActive~0)} call #t~ret35 := valid_product(); {1600#true} is VALID [2020-07-17 21:31:12,338 INFO L280 TraceCheckUtils]: 13: Hoare triple {1600#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {1625#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} is VALID [2020-07-17 21:31:12,338 INFO L280 TraceCheckUtils]: 14: Hoare triple {1625#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} assume true; {1625#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} is VALID [2020-07-17 21:31:12,341 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {1625#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} {1605#(= 1 ~systemActive~0)} #405#return; {1613#(= |main_#t~ret35| ~systemActive~0)} is VALID [2020-07-17 21:31:12,347 INFO L280 TraceCheckUtils]: 16: Hoare triple {1613#(= |main_#t~ret35| ~systemActive~0)} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {1614#(= main_~tmp~3 ~systemActive~0)} is VALID [2020-07-17 21:31:12,348 INFO L280 TraceCheckUtils]: 17: Hoare triple {1614#(= main_~tmp~3 ~systemActive~0)} assume 0 != ~tmp~3; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,348 INFO L263 TraceCheckUtils]: 18: Hoare triple {1615#(not (= 0 ~systemActive~0))} call setup(); {1600#true} is VALID [2020-07-17 21:31:12,348 INFO L280 TraceCheckUtils]: 19: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,349 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {1600#true} {1615#(not (= 0 ~systemActive~0))} #407#return; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,349 INFO L263 TraceCheckUtils]: 21: Hoare triple {1615#(not (= 0 ~systemActive~0))} call runTest(); {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,350 INFO L263 TraceCheckUtils]: 22: Hoare triple {1615#(not (= 0 ~systemActive~0))} call test(); {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,350 INFO L280 TraceCheckUtils]: 23: Hoare triple {1615#(not (= 0 ~systemActive~0))} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,351 INFO L280 TraceCheckUtils]: 24: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume !false; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,351 INFO L280 TraceCheckUtils]: 25: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume ~splverifierCounter~0 < 4; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,352 INFO L280 TraceCheckUtils]: 26: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,353 INFO L280 TraceCheckUtils]: 27: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume !(0 != ~tmp~4); {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,353 INFO L280 TraceCheckUtils]: 28: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,354 INFO L280 TraceCheckUtils]: 29: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume !(0 != ~tmp___0~0); {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,355 INFO L280 TraceCheckUtils]: 30: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,355 INFO L280 TraceCheckUtils]: 31: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume 0 != ~tmp___2~0; {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,356 INFO L263 TraceCheckUtils]: 32: Hoare triple {1615#(not (= 0 ~systemActive~0))} call timeShift(); {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,356 INFO L280 TraceCheckUtils]: 33: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume !(0 != ~pumpRunning~0); {1615#(not (= 0 ~systemActive~0))} is VALID [2020-07-17 21:31:12,356 INFO L280 TraceCheckUtils]: 34: Hoare triple {1615#(not (= 0 ~systemActive~0))} assume !(0 != ~systemActive~0); {1601#false} is VALID [2020-07-17 21:31:12,357 INFO L263 TraceCheckUtils]: 35: Hoare triple {1601#false} call __utac_acc__Specification4_spec__1(); {1601#false} is VALID [2020-07-17 21:31:12,357 INFO L280 TraceCheckUtils]: 36: Hoare triple {1601#false} havoc ~tmp~7;havoc ~tmp___0~2; {1601#false} is VALID [2020-07-17 21:31:12,357 INFO L263 TraceCheckUtils]: 37: Hoare triple {1601#false} call #t~ret70 := getWaterLevel(); {1600#true} is VALID [2020-07-17 21:31:12,357 INFO L280 TraceCheckUtils]: 38: Hoare triple {1600#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {1600#true} is VALID [2020-07-17 21:31:12,358 INFO L280 TraceCheckUtils]: 39: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,358 INFO L275 TraceCheckUtils]: 40: Hoare quadruple {1600#true} {1601#false} #395#return; {1601#false} is VALID [2020-07-17 21:31:12,359 INFO L280 TraceCheckUtils]: 41: Hoare triple {1601#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {1601#false} is VALID [2020-07-17 21:31:12,359 INFO L280 TraceCheckUtils]: 42: Hoare triple {1601#false} assume 0 == ~tmp~7; {1601#false} is VALID [2020-07-17 21:31:12,359 INFO L263 TraceCheckUtils]: 43: Hoare triple {1601#false} call #t~ret71 := isPumpRunning(); {1600#true} is VALID [2020-07-17 21:31:12,360 INFO L280 TraceCheckUtils]: 44: Hoare triple {1600#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {1600#true} is VALID [2020-07-17 21:31:12,360 INFO L280 TraceCheckUtils]: 45: Hoare triple {1600#true} assume true; {1600#true} is VALID [2020-07-17 21:31:12,360 INFO L275 TraceCheckUtils]: 46: Hoare quadruple {1600#true} {1601#false} #397#return; {1601#false} is VALID [2020-07-17 21:31:12,360 INFO L280 TraceCheckUtils]: 47: Hoare triple {1601#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {1601#false} is VALID [2020-07-17 21:31:12,360 INFO L280 TraceCheckUtils]: 48: Hoare triple {1601#false} assume 0 != ~tmp___0~2; {1601#false} is VALID [2020-07-17 21:31:12,361 INFO L263 TraceCheckUtils]: 49: Hoare triple {1601#false} call __automaton_fail(); {1601#false} is VALID [2020-07-17 21:31:12,361 INFO L280 TraceCheckUtils]: 50: Hoare triple {1601#false} assume !false; {1601#false} is VALID [2020-07-17 21:31:12,370 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2020-07-17 21:31:12,370 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1755286743] [2020-07-17 21:31:12,371 INFO L220 FreeRefinementEngine]: Constructing automaton from 1 perfect and 0 imperfect interpolant sequences. [2020-07-17 21:31:12,371 INFO L233 FreeRefinementEngine]: Number of different interpolants: perfect sequences [8] imperfect sequences [] total 8 [2020-07-17 21:31:12,371 INFO L156 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [765164000] [2020-07-17 21:31:12,371 INFO L78 Accepts]: Start accepts. Automaton has 8 states. Word has length 51 [2020-07-17 21:31:12,372 INFO L84 Accepts]: Finished accepts. word is accepted. [2020-07-17 21:31:12,372 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 8 states. [2020-07-17 21:31:12,437 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 51 edges. 51 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:31:12,437 INFO L459 AbstractCegarLoop]: Interpolant automaton has 8 states [2020-07-17 21:31:12,437 INFO L143 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2020-07-17 21:31:12,437 INFO L142 InterpolantAutomaton]: Constructing interpolant automaton starting with 8 interpolants. [2020-07-17 21:31:12,438 INFO L144 InterpolantAutomaton]: CoverageRelationStatistics Valid=14, Invalid=42, Unknown=0, NotChecked=0, Total=56 [2020-07-17 21:31:12,438 INFO L87 Difference]: Start difference. First operand 96 states and 111 transitions. Second operand 8 states. [2020-07-17 21:31:13,118 WARN L193 SmtUtils]: Spent 221.00 ms on a formula simplification that was a NOOP. DAG size: 186 [2020-07-17 21:31:14,064 WARN L193 SmtUtils]: Spent 229.00 ms on a formula simplification that was a NOOP. DAG size: 190 [2020-07-17 21:31:14,468 WARN L193 SmtUtils]: Spent 236.00 ms on a formula simplification that was a NOOP. DAG size: 188 [2020-07-17 21:31:14,788 WARN L193 SmtUtils]: Spent 220.00 ms on a formula simplification that was a NOOP. DAG size: 188 [2020-07-17 21:31:20,249 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:20,249 INFO L93 Difference]: Finished difference Result 191 states and 236 transitions. [2020-07-17 21:31:20,249 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 8 states. [2020-07-17 21:31:20,250 INFO L78 Accepts]: Start accepts. Automaton has 8 states. Word has length 51 [2020-07-17 21:31:20,250 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2020-07-17 21:31:20,250 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 8 states. [2020-07-17 21:31:20,256 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 236 transitions. [2020-07-17 21:31:20,256 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 8 states. [2020-07-17 21:31:20,261 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 236 transitions. [2020-07-17 21:31:20,261 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 8 states and 236 transitions. [2020-07-17 21:31:21,095 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 236 edges. 236 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:31:21,101 INFO L225 Difference]: With dead ends: 191 [2020-07-17 21:31:21,101 INFO L226 Difference]: Without dead ends: 119 [2020-07-17 21:31:21,102 INFO L675 BasicCegarLoop]: 0 DeclaredPredicates, 24 GetRequests, 14 SyntacticMatches, 0 SemanticMatches, 10 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 5 ImplicationChecksByTransitivity, 1.5s TimeCoverageRelationStatistics Valid=40, Invalid=92, Unknown=0, NotChecked=0, Total=132 [2020-07-17 21:31:21,103 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 119 states. [2020-07-17 21:31:22,211 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 119 to 96. [2020-07-17 21:31:22,211 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2020-07-17 21:31:22,211 INFO L82 GeneralOperation]: Start isEquivalent. First operand 119 states. Second operand 96 states. [2020-07-17 21:31:22,211 INFO L74 IsIncluded]: Start isIncluded. First operand 119 states. Second operand 96 states. [2020-07-17 21:31:22,212 INFO L87 Difference]: Start difference. First operand 119 states. Second operand 96 states. [2020-07-17 21:31:22,217 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:22,218 INFO L93 Difference]: Finished difference Result 119 states and 145 transitions. [2020-07-17 21:31:22,218 INFO L276 IsEmpty]: Start isEmpty. Operand 119 states and 145 transitions. [2020-07-17 21:31:22,219 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:31:22,219 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:31:22,219 INFO L74 IsIncluded]: Start isIncluded. First operand 96 states. Second operand 119 states. [2020-07-17 21:31:22,219 INFO L87 Difference]: Start difference. First operand 96 states. Second operand 119 states. [2020-07-17 21:31:22,225 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:22,226 INFO L93 Difference]: Finished difference Result 119 states and 145 transitions. [2020-07-17 21:31:22,226 INFO L276 IsEmpty]: Start isEmpty. Operand 119 states and 145 transitions. [2020-07-17 21:31:22,227 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:31:22,227 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:31:22,227 INFO L88 GeneralOperation]: Finished isEquivalent. [2020-07-17 21:31:22,227 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2020-07-17 21:31:22,227 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 96 states. [2020-07-17 21:31:22,231 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 96 states to 96 states and 110 transitions. [2020-07-17 21:31:22,231 INFO L78 Accepts]: Start accepts. Automaton has 96 states and 110 transitions. Word has length 51 [2020-07-17 21:31:22,232 INFO L84 Accepts]: Finished accepts. word is rejected. [2020-07-17 21:31:22,232 INFO L479 AbstractCegarLoop]: Abstraction has 96 states and 110 transitions. [2020-07-17 21:31:22,232 INFO L480 AbstractCegarLoop]: Interpolant automaton has 8 states. [2020-07-17 21:31:22,232 INFO L276 IsEmpty]: Start isEmpty. Operand 96 states and 110 transitions. [2020-07-17 21:31:22,233 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 60 [2020-07-17 21:31:22,233 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:31:22,233 INFO L422 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:31:22,233 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable2 [2020-07-17 21:31:22,234 INFO L427 AbstractCegarLoop]: === Iteration 4 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:31:22,234 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:31:22,234 INFO L82 PathProgramCache]: Analyzing trace with hash -962632878, now seen corresponding path program 1 times [2020-07-17 21:31:22,234 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:31:22,235 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1087726888] [2020-07-17 21:31:22,235 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:31:22,270 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,569 WARN L193 SmtUtils]: Spent 216.00 ms on a formula simplification that was a NOOP. DAG size: 184 [2020-07-17 21:31:22,611 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,650 INFO L280 TraceCheckUtils]: 0: Hoare triple {2310#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,650 INFO L280 TraceCheckUtils]: 1: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume true; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,651 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {2287#(= 0 ~pumpRunning~0)} {2282#true} #479#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,652 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,654 INFO L280 TraceCheckUtils]: 0: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,655 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {2282#true} {2287#(= 0 ~pumpRunning~0)} #401#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,656 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,659 INFO L280 TraceCheckUtils]: 0: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,660 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {2282#true} {2287#(= 0 ~pumpRunning~0)} #403#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,661 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,668 INFO L280 TraceCheckUtils]: 0: Hoare triple {2282#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {2282#true} is VALID [2020-07-17 21:31:22,668 INFO L280 TraceCheckUtils]: 1: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,669 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {2282#true} {2287#(= 0 ~pumpRunning~0)} #405#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,670 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,673 INFO L280 TraceCheckUtils]: 0: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,673 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {2282#true} {2287#(= 0 ~pumpRunning~0)} #407#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,684 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,700 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,703 INFO L280 TraceCheckUtils]: 0: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,704 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {2282#true} {2312#(not (= 0 |old(~pumpRunning~0)|))} #447#return; {2312#(not (= 0 |old(~pumpRunning~0)|))} is VALID [2020-07-17 21:31:22,704 INFO L280 TraceCheckUtils]: 0: Hoare triple {2311#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {2311#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:31:22,705 INFO L280 TraceCheckUtils]: 1: Hoare triple {2311#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} assume !(0 == ~pumpRunning~0); {2312#(not (= 0 |old(~pumpRunning~0)|))} is VALID [2020-07-17 21:31:22,705 INFO L263 TraceCheckUtils]: 2: Hoare triple {2312#(not (= 0 |old(~pumpRunning~0)|))} call processEnvironment__wrappee__base(); {2282#true} is VALID [2020-07-17 21:31:22,706 INFO L280 TraceCheckUtils]: 3: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,706 INFO L275 TraceCheckUtils]: 4: Hoare quadruple {2282#true} {2312#(not (= 0 |old(~pumpRunning~0)|))} #447#return; {2312#(not (= 0 |old(~pumpRunning~0)|))} is VALID [2020-07-17 21:31:22,707 INFO L280 TraceCheckUtils]: 5: Hoare triple {2312#(not (= 0 |old(~pumpRunning~0)|))} assume true; {2312#(not (= 0 |old(~pumpRunning~0)|))} is VALID [2020-07-17 21:31:22,708 INFO L275 TraceCheckUtils]: 6: Hoare quadruple {2312#(not (= 0 |old(~pumpRunning~0)|))} {2287#(= 0 ~pumpRunning~0)} #461#return; {2283#false} is VALID [2020-07-17 21:31:22,709 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,711 INFO L280 TraceCheckUtils]: 0: Hoare triple {2282#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {2282#true} is VALID [2020-07-17 21:31:22,711 INFO L280 TraceCheckUtils]: 1: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,711 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {2282#true} {2283#false} #395#return; {2283#false} is VALID [2020-07-17 21:31:22,712 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:22,715 INFO L280 TraceCheckUtils]: 0: Hoare triple {2282#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {2282#true} is VALID [2020-07-17 21:31:22,715 INFO L280 TraceCheckUtils]: 1: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,715 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {2282#true} {2283#false} #397#return; {2283#false} is VALID [2020-07-17 21:31:22,720 INFO L263 TraceCheckUtils]: 0: Hoare triple {2282#true} call ULTIMATE.init(); {2310#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} is VALID [2020-07-17 21:31:22,726 INFO L280 TraceCheckUtils]: 1: Hoare triple {2310#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,727 INFO L280 TraceCheckUtils]: 2: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume true; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,728 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {2287#(= 0 ~pumpRunning~0)} {2282#true} #479#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,729 INFO L263 TraceCheckUtils]: 4: Hoare triple {2287#(= 0 ~pumpRunning~0)} call #t~ret72 := main(); {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,729 INFO L280 TraceCheckUtils]: 5: Hoare triple {2287#(= 0 ~pumpRunning~0)} havoc ~retValue_acc~3;havoc ~tmp~3; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,729 INFO L263 TraceCheckUtils]: 6: Hoare triple {2287#(= 0 ~pumpRunning~0)} call select_helpers(); {2282#true} is VALID [2020-07-17 21:31:22,730 INFO L280 TraceCheckUtils]: 7: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,730 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {2282#true} {2287#(= 0 ~pumpRunning~0)} #401#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,731 INFO L263 TraceCheckUtils]: 9: Hoare triple {2287#(= 0 ~pumpRunning~0)} call select_features(); {2282#true} is VALID [2020-07-17 21:31:22,731 INFO L280 TraceCheckUtils]: 10: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,731 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {2282#true} {2287#(= 0 ~pumpRunning~0)} #403#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,732 INFO L263 TraceCheckUtils]: 12: Hoare triple {2287#(= 0 ~pumpRunning~0)} call #t~ret35 := valid_product(); {2282#true} is VALID [2020-07-17 21:31:22,732 INFO L280 TraceCheckUtils]: 13: Hoare triple {2282#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {2282#true} is VALID [2020-07-17 21:31:22,732 INFO L280 TraceCheckUtils]: 14: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,733 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {2282#true} {2287#(= 0 ~pumpRunning~0)} #405#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,734 INFO L280 TraceCheckUtils]: 16: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,734 INFO L280 TraceCheckUtils]: 17: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume 0 != ~tmp~3; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,735 INFO L263 TraceCheckUtils]: 18: Hoare triple {2287#(= 0 ~pumpRunning~0)} call setup(); {2282#true} is VALID [2020-07-17 21:31:22,735 INFO L280 TraceCheckUtils]: 19: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,736 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {2282#true} {2287#(= 0 ~pumpRunning~0)} #407#return; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,736 INFO L263 TraceCheckUtils]: 21: Hoare triple {2287#(= 0 ~pumpRunning~0)} call runTest(); {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,737 INFO L263 TraceCheckUtils]: 22: Hoare triple {2287#(= 0 ~pumpRunning~0)} call test(); {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,738 INFO L280 TraceCheckUtils]: 23: Hoare triple {2287#(= 0 ~pumpRunning~0)} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,738 INFO L280 TraceCheckUtils]: 24: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume !false; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,739 INFO L280 TraceCheckUtils]: 25: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume ~splverifierCounter~0 < 4; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,739 INFO L280 TraceCheckUtils]: 26: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,740 INFO L280 TraceCheckUtils]: 27: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume !(0 != ~tmp~4); {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,741 INFO L280 TraceCheckUtils]: 28: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,741 INFO L280 TraceCheckUtils]: 29: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume !(0 != ~tmp___0~0); {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,742 INFO L280 TraceCheckUtils]: 30: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,742 INFO L280 TraceCheckUtils]: 31: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume 0 != ~tmp___2~0; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,743 INFO L263 TraceCheckUtils]: 32: Hoare triple {2287#(= 0 ~pumpRunning~0)} call timeShift(); {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,744 INFO L280 TraceCheckUtils]: 33: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume !(0 != ~pumpRunning~0); {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,744 INFO L280 TraceCheckUtils]: 34: Hoare triple {2287#(= 0 ~pumpRunning~0)} assume 0 != ~systemActive~0; {2287#(= 0 ~pumpRunning~0)} is VALID [2020-07-17 21:31:22,745 INFO L263 TraceCheckUtils]: 35: Hoare triple {2287#(= 0 ~pumpRunning~0)} call processEnvironment(); {2311#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:31:22,746 INFO L280 TraceCheckUtils]: 36: Hoare triple {2311#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {2311#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:31:22,746 INFO L280 TraceCheckUtils]: 37: Hoare triple {2311#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} assume !(0 == ~pumpRunning~0); {2312#(not (= 0 |old(~pumpRunning~0)|))} is VALID [2020-07-17 21:31:22,746 INFO L263 TraceCheckUtils]: 38: Hoare triple {2312#(not (= 0 |old(~pumpRunning~0)|))} call processEnvironment__wrappee__base(); {2282#true} is VALID [2020-07-17 21:31:22,747 INFO L280 TraceCheckUtils]: 39: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,747 INFO L275 TraceCheckUtils]: 40: Hoare quadruple {2282#true} {2312#(not (= 0 |old(~pumpRunning~0)|))} #447#return; {2312#(not (= 0 |old(~pumpRunning~0)|))} is VALID [2020-07-17 21:31:22,748 INFO L280 TraceCheckUtils]: 41: Hoare triple {2312#(not (= 0 |old(~pumpRunning~0)|))} assume true; {2312#(not (= 0 |old(~pumpRunning~0)|))} is VALID [2020-07-17 21:31:22,749 INFO L275 TraceCheckUtils]: 42: Hoare quadruple {2312#(not (= 0 |old(~pumpRunning~0)|))} {2287#(= 0 ~pumpRunning~0)} #461#return; {2283#false} is VALID [2020-07-17 21:31:22,749 INFO L263 TraceCheckUtils]: 43: Hoare triple {2283#false} call __utac_acc__Specification4_spec__1(); {2283#false} is VALID [2020-07-17 21:31:22,749 INFO L280 TraceCheckUtils]: 44: Hoare triple {2283#false} havoc ~tmp~7;havoc ~tmp___0~2; {2283#false} is VALID [2020-07-17 21:31:22,749 INFO L263 TraceCheckUtils]: 45: Hoare triple {2283#false} call #t~ret70 := getWaterLevel(); {2282#true} is VALID [2020-07-17 21:31:22,750 INFO L280 TraceCheckUtils]: 46: Hoare triple {2282#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {2282#true} is VALID [2020-07-17 21:31:22,750 INFO L280 TraceCheckUtils]: 47: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,750 INFO L275 TraceCheckUtils]: 48: Hoare quadruple {2282#true} {2283#false} #395#return; {2283#false} is VALID [2020-07-17 21:31:22,750 INFO L280 TraceCheckUtils]: 49: Hoare triple {2283#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {2283#false} is VALID [2020-07-17 21:31:22,750 INFO L280 TraceCheckUtils]: 50: Hoare triple {2283#false} assume 0 == ~tmp~7; {2283#false} is VALID [2020-07-17 21:31:22,751 INFO L263 TraceCheckUtils]: 51: Hoare triple {2283#false} call #t~ret71 := isPumpRunning(); {2282#true} is VALID [2020-07-17 21:31:22,751 INFO L280 TraceCheckUtils]: 52: Hoare triple {2282#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {2282#true} is VALID [2020-07-17 21:31:22,751 INFO L280 TraceCheckUtils]: 53: Hoare triple {2282#true} assume true; {2282#true} is VALID [2020-07-17 21:31:22,751 INFO L275 TraceCheckUtils]: 54: Hoare quadruple {2282#true} {2283#false} #397#return; {2283#false} is VALID [2020-07-17 21:31:22,751 INFO L280 TraceCheckUtils]: 55: Hoare triple {2283#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {2283#false} is VALID [2020-07-17 21:31:22,752 INFO L280 TraceCheckUtils]: 56: Hoare triple {2283#false} assume 0 != ~tmp___0~2; {2283#false} is VALID [2020-07-17 21:31:22,752 INFO L263 TraceCheckUtils]: 57: Hoare triple {2283#false} call __automaton_fail(); {2283#false} is VALID [2020-07-17 21:31:22,752 INFO L280 TraceCheckUtils]: 58: Hoare triple {2283#false} assume !false; {2283#false} is VALID [2020-07-17 21:31:22,760 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2020-07-17 21:31:22,761 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1087726888] [2020-07-17 21:31:22,761 INFO L220 FreeRefinementEngine]: Constructing automaton from 1 perfect and 0 imperfect interpolant sequences. [2020-07-17 21:31:22,761 INFO L233 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2020-07-17 21:31:22,761 INFO L156 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [625875115] [2020-07-17 21:31:22,762 INFO L78 Accepts]: Start accepts. Automaton has 6 states. Word has length 59 [2020-07-17 21:31:22,762 INFO L84 Accepts]: Finished accepts. word is accepted. [2020-07-17 21:31:22,762 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 6 states. [2020-07-17 21:31:22,838 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 59 edges. 59 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:31:22,839 INFO L459 AbstractCegarLoop]: Interpolant automaton has 6 states [2020-07-17 21:31:22,839 INFO L143 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2020-07-17 21:31:22,839 INFO L142 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2020-07-17 21:31:22,839 INFO L144 InterpolantAutomaton]: CoverageRelationStatistics Valid=10, Invalid=20, Unknown=0, NotChecked=0, Total=30 [2020-07-17 21:31:22,840 INFO L87 Difference]: Start difference. First operand 96 states and 110 transitions. Second operand 6 states. [2020-07-17 21:31:23,443 WARN L193 SmtUtils]: Spent 216.00 ms on a formula simplification that was a NOOP. DAG size: 186 [2020-07-17 21:31:28,438 WARN L193 SmtUtils]: Spent 208.00 ms on a formula simplification that was a NOOP. DAG size: 187 [2020-07-17 21:31:30,501 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:30,502 INFO L93 Difference]: Finished difference Result 274 states and 340 transitions. [2020-07-17 21:31:30,502 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 9 states. [2020-07-17 21:31:30,502 INFO L78 Accepts]: Start accepts. Automaton has 6 states. Word has length 59 [2020-07-17 21:31:30,503 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2020-07-17 21:31:30,503 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 6 states. [2020-07-17 21:31:30,510 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 340 transitions. [2020-07-17 21:31:30,510 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 6 states. [2020-07-17 21:31:30,517 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 340 transitions. [2020-07-17 21:31:30,517 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 9 states and 340 transitions. [2020-07-17 21:31:31,643 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 340 edges. 340 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:31:31,650 INFO L225 Difference]: With dead ends: 274 [2020-07-17 21:31:31,651 INFO L226 Difference]: Without dead ends: 202 [2020-07-17 21:31:31,652 INFO L675 BasicCegarLoop]: 0 DeclaredPredicates, 31 GetRequests, 23 SyntacticMatches, 0 SemanticMatches, 8 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 7 ImplicationChecksByTransitivity, 0.8s TimeCoverageRelationStatistics Valid=30, Invalid=60, Unknown=0, NotChecked=0, Total=90 [2020-07-17 21:31:31,652 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 202 states. [2020-07-17 21:31:33,274 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 202 to 161. [2020-07-17 21:31:33,275 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2020-07-17 21:31:33,275 INFO L82 GeneralOperation]: Start isEquivalent. First operand 202 states. Second operand 161 states. [2020-07-17 21:31:33,275 INFO L74 IsIncluded]: Start isIncluded. First operand 202 states. Second operand 161 states. [2020-07-17 21:31:33,275 INFO L87 Difference]: Start difference. First operand 202 states. Second operand 161 states. [2020-07-17 21:31:33,285 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:33,286 INFO L93 Difference]: Finished difference Result 202 states and 244 transitions. [2020-07-17 21:31:33,286 INFO L276 IsEmpty]: Start isEmpty. Operand 202 states and 244 transitions. [2020-07-17 21:31:33,287 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:31:33,287 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:31:33,287 INFO L74 IsIncluded]: Start isIncluded. First operand 161 states. Second operand 202 states. [2020-07-17 21:31:33,287 INFO L87 Difference]: Start difference. First operand 161 states. Second operand 202 states. [2020-07-17 21:31:33,296 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:33,296 INFO L93 Difference]: Finished difference Result 202 states and 244 transitions. [2020-07-17 21:31:33,297 INFO L276 IsEmpty]: Start isEmpty. Operand 202 states and 244 transitions. [2020-07-17 21:31:33,298 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:31:33,298 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:31:33,298 INFO L88 GeneralOperation]: Finished isEquivalent. [2020-07-17 21:31:33,298 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2020-07-17 21:31:33,298 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 161 states. [2020-07-17 21:31:33,304 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 161 states to 161 states and 185 transitions. [2020-07-17 21:31:33,305 INFO L78 Accepts]: Start accepts. Automaton has 161 states and 185 transitions. Word has length 59 [2020-07-17 21:31:33,305 INFO L84 Accepts]: Finished accepts. word is rejected. [2020-07-17 21:31:33,305 INFO L479 AbstractCegarLoop]: Abstraction has 161 states and 185 transitions. [2020-07-17 21:31:33,305 INFO L480 AbstractCegarLoop]: Interpolant automaton has 6 states. [2020-07-17 21:31:33,305 INFO L276 IsEmpty]: Start isEmpty. Operand 161 states and 185 transitions. [2020-07-17 21:31:33,306 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 74 [2020-07-17 21:31:33,306 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:31:33,307 INFO L422 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:31:33,307 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable3 [2020-07-17 21:31:33,307 INFO L427 AbstractCegarLoop]: === Iteration 5 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:31:33,307 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:31:33,307 INFO L82 PathProgramCache]: Analyzing trace with hash 869233952, now seen corresponding path program 1 times [2020-07-17 21:31:33,308 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:31:33,308 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1285093917] [2020-07-17 21:31:33,308 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:31:33,339 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,682 WARN L193 SmtUtils]: Spent 183.00 ms on a formula simplification that was a NOOP. DAG size: 184 [2020-07-17 21:31:33,719 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,773 INFO L280 TraceCheckUtils]: 0: Hoare triple {3385#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,774 INFO L280 TraceCheckUtils]: 1: Hoare triple {3343#(= 1 ~waterLevel~0)} assume true; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,775 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {3343#(= 1 ~waterLevel~0)} {3338#true} #479#return; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,776 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,781 INFO L280 TraceCheckUtils]: 0: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,782 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {3338#true} {3343#(= 1 ~waterLevel~0)} #401#return; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,783 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,786 INFO L280 TraceCheckUtils]: 0: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,787 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {3338#true} {3343#(= 1 ~waterLevel~0)} #403#return; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,789 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,839 INFO L280 TraceCheckUtils]: 0: Hoare triple {3338#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {3386#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} is VALID [2020-07-17 21:31:33,840 INFO L280 TraceCheckUtils]: 1: Hoare triple {3386#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} assume true; {3386#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} is VALID [2020-07-17 21:31:33,841 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {3386#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} {3343#(= 1 ~waterLevel~0)} #405#return; {3351#(= |main_#t~ret35| ~waterLevel~0)} is VALID [2020-07-17 21:31:33,842 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,845 INFO L280 TraceCheckUtils]: 0: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,846 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {3338#true} {3353#(not (= 0 ~waterLevel~0))} #407#return; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,863 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,874 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,890 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,895 INFO L280 TraceCheckUtils]: 0: Hoare triple {3338#true} havoc ~retValue_acc~8; {3338#true} is VALID [2020-07-17 21:31:33,895 INFO L280 TraceCheckUtils]: 1: Hoare triple {3338#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {3338#true} is VALID [2020-07-17 21:31:33,896 INFO L280 TraceCheckUtils]: 2: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,896 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {3338#true} {3338#true} #457#return; {3338#true} is VALID [2020-07-17 21:31:33,896 INFO L280 TraceCheckUtils]: 0: Hoare triple {3338#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {3338#true} is VALID [2020-07-17 21:31:33,897 INFO L263 TraceCheckUtils]: 1: Hoare triple {3338#true} call #t~ret69 := isHighWaterSensorDry(); {3338#true} is VALID [2020-07-17 21:31:33,897 INFO L280 TraceCheckUtils]: 2: Hoare triple {3338#true} havoc ~retValue_acc~8; {3338#true} is VALID [2020-07-17 21:31:33,897 INFO L280 TraceCheckUtils]: 3: Hoare triple {3338#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {3338#true} is VALID [2020-07-17 21:31:33,898 INFO L280 TraceCheckUtils]: 4: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,898 INFO L275 TraceCheckUtils]: 5: Hoare quadruple {3338#true} {3338#true} #457#return; {3338#true} is VALID [2020-07-17 21:31:33,905 INFO L280 TraceCheckUtils]: 6: Hoare triple {3338#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {3338#true} is VALID [2020-07-17 21:31:33,905 INFO L280 TraceCheckUtils]: 7: Hoare triple {3338#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {3338#true} is VALID [2020-07-17 21:31:33,905 INFO L280 TraceCheckUtils]: 8: Hoare triple {3338#true} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {3338#true} is VALID [2020-07-17 21:31:33,906 INFO L280 TraceCheckUtils]: 9: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,906 INFO L275 TraceCheckUtils]: 10: Hoare quadruple {3338#true} {3338#true} #441#return; {3338#true} is VALID [2020-07-17 21:31:33,907 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,911 INFO L280 TraceCheckUtils]: 0: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,911 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {3338#true} {3338#true} #445#return; {3338#true} is VALID [2020-07-17 21:31:33,911 INFO L280 TraceCheckUtils]: 0: Hoare triple {3387#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {3338#true} is VALID [2020-07-17 21:31:33,912 INFO L280 TraceCheckUtils]: 1: Hoare triple {3338#true} assume 0 == ~pumpRunning~0; {3338#true} is VALID [2020-07-17 21:31:33,912 INFO L263 TraceCheckUtils]: 2: Hoare triple {3338#true} call #t~ret51 := isHighWaterLevel(); {3338#true} is VALID [2020-07-17 21:31:33,912 INFO L280 TraceCheckUtils]: 3: Hoare triple {3338#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {3338#true} is VALID [2020-07-17 21:31:33,912 INFO L263 TraceCheckUtils]: 4: Hoare triple {3338#true} call #t~ret69 := isHighWaterSensorDry(); {3338#true} is VALID [2020-07-17 21:31:33,913 INFO L280 TraceCheckUtils]: 5: Hoare triple {3338#true} havoc ~retValue_acc~8; {3338#true} is VALID [2020-07-17 21:31:33,913 INFO L280 TraceCheckUtils]: 6: Hoare triple {3338#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {3338#true} is VALID [2020-07-17 21:31:33,913 INFO L280 TraceCheckUtils]: 7: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,914 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {3338#true} {3338#true} #457#return; {3338#true} is VALID [2020-07-17 21:31:33,914 INFO L280 TraceCheckUtils]: 9: Hoare triple {3338#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {3338#true} is VALID [2020-07-17 21:31:33,914 INFO L280 TraceCheckUtils]: 10: Hoare triple {3338#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {3338#true} is VALID [2020-07-17 21:31:33,914 INFO L280 TraceCheckUtils]: 11: Hoare triple {3338#true} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {3338#true} is VALID [2020-07-17 21:31:33,915 INFO L280 TraceCheckUtils]: 12: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,915 INFO L275 TraceCheckUtils]: 13: Hoare quadruple {3338#true} {3338#true} #441#return; {3338#true} is VALID [2020-07-17 21:31:33,915 INFO L280 TraceCheckUtils]: 14: Hoare triple {3338#true} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {3338#true} is VALID [2020-07-17 21:31:33,916 INFO L280 TraceCheckUtils]: 15: Hoare triple {3338#true} assume !(0 != ~tmp~5); {3338#true} is VALID [2020-07-17 21:31:33,917 INFO L263 TraceCheckUtils]: 16: Hoare triple {3338#true} call processEnvironment__wrappee__base(); {3338#true} is VALID [2020-07-17 21:31:33,917 INFO L280 TraceCheckUtils]: 17: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,918 INFO L275 TraceCheckUtils]: 18: Hoare quadruple {3338#true} {3338#true} #445#return; {3338#true} is VALID [2020-07-17 21:31:33,918 INFO L280 TraceCheckUtils]: 19: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,919 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {3338#true} {3353#(not (= 0 ~waterLevel~0))} #461#return; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,921 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,956 INFO L280 TraceCheckUtils]: 0: Hoare triple {3338#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {3405#(= |getWaterLevel_#res| ~waterLevel~0)} is VALID [2020-07-17 21:31:33,956 INFO L280 TraceCheckUtils]: 1: Hoare triple {3405#(= |getWaterLevel_#res| ~waterLevel~0)} assume true; {3405#(= |getWaterLevel_#res| ~waterLevel~0)} is VALID [2020-07-17 21:31:33,957 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {3405#(= |getWaterLevel_#res| ~waterLevel~0)} {3353#(not (= 0 ~waterLevel~0))} #395#return; {3380#(not (= |__utac_acc__Specification4_spec__1_#t~ret70| 0))} is VALID [2020-07-17 21:31:33,958 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:31:33,961 INFO L280 TraceCheckUtils]: 0: Hoare triple {3338#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {3338#true} is VALID [2020-07-17 21:31:33,961 INFO L280 TraceCheckUtils]: 1: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,961 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {3338#true} {3339#false} #397#return; {3339#false} is VALID [2020-07-17 21:31:33,965 INFO L263 TraceCheckUtils]: 0: Hoare triple {3338#true} call ULTIMATE.init(); {3385#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} is VALID [2020-07-17 21:31:33,972 INFO L280 TraceCheckUtils]: 1: Hoare triple {3385#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,973 INFO L280 TraceCheckUtils]: 2: Hoare triple {3343#(= 1 ~waterLevel~0)} assume true; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,974 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {3343#(= 1 ~waterLevel~0)} {3338#true} #479#return; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,975 INFO L263 TraceCheckUtils]: 4: Hoare triple {3343#(= 1 ~waterLevel~0)} call #t~ret72 := main(); {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,976 INFO L280 TraceCheckUtils]: 5: Hoare triple {3343#(= 1 ~waterLevel~0)} havoc ~retValue_acc~3;havoc ~tmp~3; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,976 INFO L263 TraceCheckUtils]: 6: Hoare triple {3343#(= 1 ~waterLevel~0)} call select_helpers(); {3338#true} is VALID [2020-07-17 21:31:33,977 INFO L280 TraceCheckUtils]: 7: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,978 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {3338#true} {3343#(= 1 ~waterLevel~0)} #401#return; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,979 INFO L263 TraceCheckUtils]: 9: Hoare triple {3343#(= 1 ~waterLevel~0)} call select_features(); {3338#true} is VALID [2020-07-17 21:31:33,979 INFO L280 TraceCheckUtils]: 10: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,980 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {3338#true} {3343#(= 1 ~waterLevel~0)} #403#return; {3343#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,980 INFO L263 TraceCheckUtils]: 12: Hoare triple {3343#(= 1 ~waterLevel~0)} call #t~ret35 := valid_product(); {3338#true} is VALID [2020-07-17 21:31:33,981 INFO L280 TraceCheckUtils]: 13: Hoare triple {3338#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {3386#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} is VALID [2020-07-17 21:31:33,982 INFO L280 TraceCheckUtils]: 14: Hoare triple {3386#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} assume true; {3386#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} is VALID [2020-07-17 21:31:33,983 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {3386#(and (<= |valid_product_#res| 1) (< 0 |valid_product_#res|))} {3343#(= 1 ~waterLevel~0)} #405#return; {3351#(= |main_#t~ret35| ~waterLevel~0)} is VALID [2020-07-17 21:31:33,984 INFO L280 TraceCheckUtils]: 16: Hoare triple {3351#(= |main_#t~ret35| ~waterLevel~0)} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {3352#(= main_~tmp~3 ~waterLevel~0)} is VALID [2020-07-17 21:31:33,985 INFO L280 TraceCheckUtils]: 17: Hoare triple {3352#(= main_~tmp~3 ~waterLevel~0)} assume 0 != ~tmp~3; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,985 INFO L263 TraceCheckUtils]: 18: Hoare triple {3353#(not (= 0 ~waterLevel~0))} call setup(); {3338#true} is VALID [2020-07-17 21:31:33,985 INFO L280 TraceCheckUtils]: 19: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:33,986 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {3338#true} {3353#(not (= 0 ~waterLevel~0))} #407#return; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,987 INFO L263 TraceCheckUtils]: 21: Hoare triple {3353#(not (= 0 ~waterLevel~0))} call runTest(); {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,989 INFO L263 TraceCheckUtils]: 22: Hoare triple {3353#(not (= 0 ~waterLevel~0))} call test(); {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,990 INFO L280 TraceCheckUtils]: 23: Hoare triple {3353#(not (= 0 ~waterLevel~0))} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,991 INFO L280 TraceCheckUtils]: 24: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume !false; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,992 INFO L280 TraceCheckUtils]: 25: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume ~splverifierCounter~0 < 4; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,993 INFO L280 TraceCheckUtils]: 26: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,993 INFO L280 TraceCheckUtils]: 27: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume !(0 != ~tmp~4); {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,994 INFO L280 TraceCheckUtils]: 28: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,995 INFO L280 TraceCheckUtils]: 29: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume !(0 != ~tmp___0~0); {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,996 INFO L280 TraceCheckUtils]: 30: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,996 INFO L280 TraceCheckUtils]: 31: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume 0 != ~tmp___2~0; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,997 INFO L263 TraceCheckUtils]: 32: Hoare triple {3353#(not (= 0 ~waterLevel~0))} call timeShift(); {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,998 INFO L280 TraceCheckUtils]: 33: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume !(0 != ~pumpRunning~0); {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:33,999 INFO L280 TraceCheckUtils]: 34: Hoare triple {3353#(not (= 0 ~waterLevel~0))} assume 0 != ~systemActive~0; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:34,000 INFO L263 TraceCheckUtils]: 35: Hoare triple {3353#(not (= 0 ~waterLevel~0))} call processEnvironment(); {3387#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:31:34,000 INFO L280 TraceCheckUtils]: 36: Hoare triple {3387#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {3338#true} is VALID [2020-07-17 21:31:34,001 INFO L280 TraceCheckUtils]: 37: Hoare triple {3338#true} assume 0 == ~pumpRunning~0; {3338#true} is VALID [2020-07-17 21:31:34,001 INFO L263 TraceCheckUtils]: 38: Hoare triple {3338#true} call #t~ret51 := isHighWaterLevel(); {3338#true} is VALID [2020-07-17 21:31:34,001 INFO L280 TraceCheckUtils]: 39: Hoare triple {3338#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {3338#true} is VALID [2020-07-17 21:31:34,002 INFO L263 TraceCheckUtils]: 40: Hoare triple {3338#true} call #t~ret69 := isHighWaterSensorDry(); {3338#true} is VALID [2020-07-17 21:31:34,002 INFO L280 TraceCheckUtils]: 41: Hoare triple {3338#true} havoc ~retValue_acc~8; {3338#true} is VALID [2020-07-17 21:31:34,002 INFO L280 TraceCheckUtils]: 42: Hoare triple {3338#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {3338#true} is VALID [2020-07-17 21:31:34,002 INFO L280 TraceCheckUtils]: 43: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:34,003 INFO L275 TraceCheckUtils]: 44: Hoare quadruple {3338#true} {3338#true} #457#return; {3338#true} is VALID [2020-07-17 21:31:34,003 INFO L280 TraceCheckUtils]: 45: Hoare triple {3338#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {3338#true} is VALID [2020-07-17 21:31:34,003 INFO L280 TraceCheckUtils]: 46: Hoare triple {3338#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {3338#true} is VALID [2020-07-17 21:31:34,003 INFO L280 TraceCheckUtils]: 47: Hoare triple {3338#true} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {3338#true} is VALID [2020-07-17 21:31:34,003 INFO L280 TraceCheckUtils]: 48: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:34,004 INFO L275 TraceCheckUtils]: 49: Hoare quadruple {3338#true} {3338#true} #441#return; {3338#true} is VALID [2020-07-17 21:31:34,004 INFO L280 TraceCheckUtils]: 50: Hoare triple {3338#true} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {3338#true} is VALID [2020-07-17 21:31:34,004 INFO L280 TraceCheckUtils]: 51: Hoare triple {3338#true} assume !(0 != ~tmp~5); {3338#true} is VALID [2020-07-17 21:31:34,004 INFO L263 TraceCheckUtils]: 52: Hoare triple {3338#true} call processEnvironment__wrappee__base(); {3338#true} is VALID [2020-07-17 21:31:34,005 INFO L280 TraceCheckUtils]: 53: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:34,005 INFO L275 TraceCheckUtils]: 54: Hoare quadruple {3338#true} {3338#true} #445#return; {3338#true} is VALID [2020-07-17 21:31:34,005 INFO L280 TraceCheckUtils]: 55: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:34,006 INFO L275 TraceCheckUtils]: 56: Hoare quadruple {3338#true} {3353#(not (= 0 ~waterLevel~0))} #461#return; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:34,007 INFO L263 TraceCheckUtils]: 57: Hoare triple {3353#(not (= 0 ~waterLevel~0))} call __utac_acc__Specification4_spec__1(); {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:34,008 INFO L280 TraceCheckUtils]: 58: Hoare triple {3353#(not (= 0 ~waterLevel~0))} havoc ~tmp~7;havoc ~tmp___0~2; {3353#(not (= 0 ~waterLevel~0))} is VALID [2020-07-17 21:31:34,008 INFO L263 TraceCheckUtils]: 59: Hoare triple {3353#(not (= 0 ~waterLevel~0))} call #t~ret70 := getWaterLevel(); {3338#true} is VALID [2020-07-17 21:31:34,009 INFO L280 TraceCheckUtils]: 60: Hoare triple {3338#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {3405#(= |getWaterLevel_#res| ~waterLevel~0)} is VALID [2020-07-17 21:31:34,010 INFO L280 TraceCheckUtils]: 61: Hoare triple {3405#(= |getWaterLevel_#res| ~waterLevel~0)} assume true; {3405#(= |getWaterLevel_#res| ~waterLevel~0)} is VALID [2020-07-17 21:31:34,011 INFO L275 TraceCheckUtils]: 62: Hoare quadruple {3405#(= |getWaterLevel_#res| ~waterLevel~0)} {3353#(not (= 0 ~waterLevel~0))} #395#return; {3380#(not (= |__utac_acc__Specification4_spec__1_#t~ret70| 0))} is VALID [2020-07-17 21:31:34,011 INFO L280 TraceCheckUtils]: 63: Hoare triple {3380#(not (= |__utac_acc__Specification4_spec__1_#t~ret70| 0))} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {3381#(not (= 0 __utac_acc__Specification4_spec__1_~tmp~7))} is VALID [2020-07-17 21:31:34,012 INFO L280 TraceCheckUtils]: 64: Hoare triple {3381#(not (= 0 __utac_acc__Specification4_spec__1_~tmp~7))} assume 0 == ~tmp~7; {3339#false} is VALID [2020-07-17 21:31:34,012 INFO L263 TraceCheckUtils]: 65: Hoare triple {3339#false} call #t~ret71 := isPumpRunning(); {3338#true} is VALID [2020-07-17 21:31:34,012 INFO L280 TraceCheckUtils]: 66: Hoare triple {3338#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {3338#true} is VALID [2020-07-17 21:31:34,013 INFO L280 TraceCheckUtils]: 67: Hoare triple {3338#true} assume true; {3338#true} is VALID [2020-07-17 21:31:34,013 INFO L275 TraceCheckUtils]: 68: Hoare quadruple {3338#true} {3339#false} #397#return; {3339#false} is VALID [2020-07-17 21:31:34,013 INFO L280 TraceCheckUtils]: 69: Hoare triple {3339#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {3339#false} is VALID [2020-07-17 21:31:34,013 INFO L280 TraceCheckUtils]: 70: Hoare triple {3339#false} assume 0 != ~tmp___0~2; {3339#false} is VALID [2020-07-17 21:31:34,014 INFO L263 TraceCheckUtils]: 71: Hoare triple {3339#false} call __automaton_fail(); {3339#false} is VALID [2020-07-17 21:31:34,014 INFO L280 TraceCheckUtils]: 72: Hoare triple {3339#false} assume !false; {3339#false} is VALID [2020-07-17 21:31:34,029 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2020-07-17 21:31:34,030 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1285093917] [2020-07-17 21:31:34,030 INFO L220 FreeRefinementEngine]: Constructing automaton from 1 perfect and 0 imperfect interpolant sequences. [2020-07-17 21:31:34,030 INFO L233 FreeRefinementEngine]: Number of different interpolants: perfect sequences [12] imperfect sequences [] total 12 [2020-07-17 21:31:34,030 INFO L156 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1367823224] [2020-07-17 21:31:34,032 INFO L78 Accepts]: Start accepts. Automaton has 12 states. Word has length 73 [2020-07-17 21:31:34,033 INFO L84 Accepts]: Finished accepts. word is accepted. [2020-07-17 21:31:34,033 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 12 states. [2020-07-17 21:31:34,140 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 73 edges. 73 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:31:34,140 INFO L459 AbstractCegarLoop]: Interpolant automaton has 12 states [2020-07-17 21:31:34,141 INFO L143 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2020-07-17 21:31:34,141 INFO L142 InterpolantAutomaton]: Constructing interpolant automaton starting with 12 interpolants. [2020-07-17 21:31:34,141 INFO L144 InterpolantAutomaton]: CoverageRelationStatistics Valid=23, Invalid=109, Unknown=0, NotChecked=0, Total=132 [2020-07-17 21:31:34,141 INFO L87 Difference]: Start difference. First operand 161 states and 185 transitions. Second operand 12 states. [2020-07-17 21:31:35,458 WARN L193 SmtUtils]: Spent 227.00 ms on a formula simplification that was a NOOP. DAG size: 186 [2020-07-17 21:31:36,574 WARN L193 SmtUtils]: Spent 233.00 ms on a formula simplification that was a NOOP. DAG size: 190 [2020-07-17 21:31:37,065 WARN L193 SmtUtils]: Spent 229.00 ms on a formula simplification that was a NOOP. DAG size: 188 [2020-07-17 21:31:37,396 WARN L193 SmtUtils]: Spent 216.00 ms on a formula simplification that was a NOOP. DAG size: 188 [2020-07-17 21:31:39,870 WARN L193 SmtUtils]: Spent 225.00 ms on a formula simplification that was a NOOP. DAG size: 187 [2020-07-17 21:31:44,819 WARN L193 SmtUtils]: Spent 236.00 ms on a formula simplification that was a NOOP. DAG size: 188 [2020-07-17 21:31:45,502 WARN L193 SmtUtils]: Spent 236.00 ms on a formula simplification that was a NOOP. DAG size: 190 [2020-07-17 21:31:45,947 WARN L193 SmtUtils]: Spent 232.00 ms on a formula simplification that was a NOOP. DAG size: 190 [2020-07-17 21:31:46,304 WARN L193 SmtUtils]: Spent 250.00 ms on a formula simplification that was a NOOP. DAG size: 189 [2020-07-17 21:31:46,861 WARN L193 SmtUtils]: Spent 233.00 ms on a formula simplification that was a NOOP. DAG size: 190 [2020-07-17 21:31:47,350 WARN L193 SmtUtils]: Spent 231.00 ms on a formula simplification that was a NOOP. DAG size: 190 [2020-07-17 21:31:52,164 WARN L193 SmtUtils]: Spent 214.00 ms on a formula simplification that was a NOOP. DAG size: 186 [2020-07-17 21:31:52,887 WARN L193 SmtUtils]: Spent 213.00 ms on a formula simplification that was a NOOP. DAG size: 188 [2020-07-17 21:31:57,635 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:31:57,635 INFO L93 Difference]: Finished difference Result 568 states and 750 transitions. [2020-07-17 21:31:57,635 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 21 states. [2020-07-17 21:31:57,635 INFO L78 Accepts]: Start accepts. Automaton has 12 states. Word has length 73 [2020-07-17 21:31:57,636 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2020-07-17 21:31:57,636 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 12 states. [2020-07-17 21:31:57,646 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 21 states to 21 states and 490 transitions. [2020-07-17 21:31:57,647 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 12 states. [2020-07-17 21:31:57,657 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 21 states to 21 states and 490 transitions. [2020-07-17 21:31:57,658 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 21 states and 490 transitions. [2020-07-17 21:31:59,361 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 490 edges. 490 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:31:59,383 INFO L225 Difference]: With dead ends: 568 [2020-07-17 21:31:59,384 INFO L226 Difference]: Without dead ends: 431 [2020-07-17 21:31:59,385 INFO L675 BasicCegarLoop]: 0 DeclaredPredicates, 50 GetRequests, 25 SyntacticMatches, 0 SemanticMatches, 25 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 107 ImplicationChecksByTransitivity, 4.2s TimeCoverageRelationStatistics Valid=155, Invalid=547, Unknown=0, NotChecked=0, Total=702 [2020-07-17 21:31:59,386 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 431 states. [2020-07-17 21:32:02,879 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 431 to 373. [2020-07-17 21:32:02,880 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2020-07-17 21:32:02,880 INFO L82 GeneralOperation]: Start isEquivalent. First operand 431 states. Second operand 373 states. [2020-07-17 21:32:02,880 INFO L74 IsIncluded]: Start isIncluded. First operand 431 states. Second operand 373 states. [2020-07-17 21:32:02,880 INFO L87 Difference]: Start difference. First operand 431 states. Second operand 373 states. [2020-07-17 21:32:02,905 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:02,905 INFO L93 Difference]: Finished difference Result 431 states and 544 transitions. [2020-07-17 21:32:02,905 INFO L276 IsEmpty]: Start isEmpty. Operand 431 states and 544 transitions. [2020-07-17 21:32:02,907 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:32:02,908 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:32:02,908 INFO L74 IsIncluded]: Start isIncluded. First operand 373 states. Second operand 431 states. [2020-07-17 21:32:02,908 INFO L87 Difference]: Start difference. First operand 373 states. Second operand 431 states. [2020-07-17 21:32:02,946 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:02,946 INFO L93 Difference]: Finished difference Result 431 states and 544 transitions. [2020-07-17 21:32:02,946 INFO L276 IsEmpty]: Start isEmpty. Operand 431 states and 544 transitions. [2020-07-17 21:32:02,948 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:32:02,948 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:32:02,948 INFO L88 GeneralOperation]: Finished isEquivalent. [2020-07-17 21:32:02,948 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2020-07-17 21:32:02,948 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 373 states. [2020-07-17 21:32:02,967 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 373 states to 373 states and 443 transitions. [2020-07-17 21:32:02,968 INFO L78 Accepts]: Start accepts. Automaton has 373 states and 443 transitions. Word has length 73 [2020-07-17 21:32:02,970 INFO L84 Accepts]: Finished accepts. word is rejected. [2020-07-17 21:32:02,970 INFO L479 AbstractCegarLoop]: Abstraction has 373 states and 443 transitions. [2020-07-17 21:32:02,970 INFO L480 AbstractCegarLoop]: Interpolant automaton has 12 states. [2020-07-17 21:32:02,970 INFO L276 IsEmpty]: Start isEmpty. Operand 373 states and 443 transitions. [2020-07-17 21:32:02,972 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 114 [2020-07-17 21:32:02,972 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:32:02,973 INFO L422 BasicCegarLoop]: trace histogram [2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:32:02,973 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable4 [2020-07-17 21:32:02,973 INFO L427 AbstractCegarLoop]: === Iteration 6 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:32:02,973 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:32:02,974 INFO L82 PathProgramCache]: Analyzing trace with hash 1173114262, now seen corresponding path program 1 times [2020-07-17 21:32:02,974 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:32:02,974 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1298297608] [2020-07-17 21:32:02,974 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:32:03,038 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,413 WARN L193 SmtUtils]: Spent 199.00 ms on a formula simplification that was a NOOP. DAG size: 184 [2020-07-17 21:32:03,461 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,494 INFO L280 TraceCheckUtils]: 0: Hoare triple {5663#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,497 INFO L280 TraceCheckUtils]: 1: Hoare triple {5596#(= 1 ~waterLevel~0)} assume true; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,498 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {5596#(= 1 ~waterLevel~0)} {5591#true} #479#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,499 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,502 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,503 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {5591#true} {5596#(= 1 ~waterLevel~0)} #401#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,504 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,507 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,508 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {5591#true} {5596#(= 1 ~waterLevel~0)} #403#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,509 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,512 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {5591#true} is VALID [2020-07-17 21:32:03,512 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,513 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {5591#true} {5596#(= 1 ~waterLevel~0)} #405#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,514 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,517 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,518 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {5591#true} {5596#(= 1 ~waterLevel~0)} #407#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,534 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,555 INFO L280 TraceCheckUtils]: 0: Hoare triple {5664#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 < 2;~waterLevel~0 := 1 + ~waterLevel~0; {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} is VALID [2020-07-17 21:32:03,556 INFO L280 TraceCheckUtils]: 1: Hoare triple {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} assume true; {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} is VALID [2020-07-17 21:32:03,557 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} {5596#(= 1 ~waterLevel~0)} #449#return; {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,578 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,608 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,652 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,708 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,711 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} havoc ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,711 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,712 INFO L280 TraceCheckUtils]: 2: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,712 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {5591#true} {5591#true} #457#return; {5591#true} is VALID [2020-07-17 21:32:03,712 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {5591#true} is VALID [2020-07-17 21:32:03,713 INFO L263 TraceCheckUtils]: 1: Hoare triple {5591#true} call #t~ret69 := isHighWaterSensorDry(); {5591#true} is VALID [2020-07-17 21:32:03,713 INFO L280 TraceCheckUtils]: 2: Hoare triple {5591#true} havoc ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,713 INFO L280 TraceCheckUtils]: 3: Hoare triple {5591#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,713 INFO L280 TraceCheckUtils]: 4: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,714 INFO L275 TraceCheckUtils]: 5: Hoare quadruple {5591#true} {5591#true} #457#return; {5591#true} is VALID [2020-07-17 21:32:03,714 INFO L280 TraceCheckUtils]: 6: Hoare triple {5591#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {5591#true} is VALID [2020-07-17 21:32:03,715 INFO L280 TraceCheckUtils]: 7: Hoare triple {5591#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {5719#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} is VALID [2020-07-17 21:32:03,716 INFO L280 TraceCheckUtils]: 8: Hoare triple {5719#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:03,716 INFO L280 TraceCheckUtils]: 9: Hoare triple {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} assume true; {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:03,718 INFO L275 TraceCheckUtils]: 10: Hoare quadruple {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} {5591#true} #441#return; {5710#(= 0 |processEnvironment_#t~ret51|)} is VALID [2020-07-17 21:32:03,719 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,722 INFO L280 TraceCheckUtils]: 0: Hoare triple {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {5591#true} is VALID [2020-07-17 21:32:03,722 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,723 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {5591#true} {5592#false} #443#return; {5592#false} is VALID [2020-07-17 21:32:03,723 INFO L280 TraceCheckUtils]: 0: Hoare triple {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {5591#true} is VALID [2020-07-17 21:32:03,723 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume 0 == ~pumpRunning~0; {5591#true} is VALID [2020-07-17 21:32:03,723 INFO L263 TraceCheckUtils]: 2: Hoare triple {5591#true} call #t~ret51 := isHighWaterLevel(); {5591#true} is VALID [2020-07-17 21:32:03,724 INFO L280 TraceCheckUtils]: 3: Hoare triple {5591#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {5591#true} is VALID [2020-07-17 21:32:03,724 INFO L263 TraceCheckUtils]: 4: Hoare triple {5591#true} call #t~ret69 := isHighWaterSensorDry(); {5591#true} is VALID [2020-07-17 21:32:03,724 INFO L280 TraceCheckUtils]: 5: Hoare triple {5591#true} havoc ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,725 INFO L280 TraceCheckUtils]: 6: Hoare triple {5591#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,725 INFO L280 TraceCheckUtils]: 7: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,725 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {5591#true} {5591#true} #457#return; {5591#true} is VALID [2020-07-17 21:32:03,725 INFO L280 TraceCheckUtils]: 9: Hoare triple {5591#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {5591#true} is VALID [2020-07-17 21:32:03,726 INFO L280 TraceCheckUtils]: 10: Hoare triple {5591#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {5719#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} is VALID [2020-07-17 21:32:03,727 INFO L280 TraceCheckUtils]: 11: Hoare triple {5719#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:03,728 INFO L280 TraceCheckUtils]: 12: Hoare triple {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} assume true; {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:03,729 INFO L275 TraceCheckUtils]: 13: Hoare quadruple {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} {5591#true} #441#return; {5710#(= 0 |processEnvironment_#t~ret51|)} is VALID [2020-07-17 21:32:03,730 INFO L280 TraceCheckUtils]: 14: Hoare triple {5710#(= 0 |processEnvironment_#t~ret51|)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {5711#(= 0 processEnvironment_~tmp~5)} is VALID [2020-07-17 21:32:03,731 INFO L280 TraceCheckUtils]: 15: Hoare triple {5711#(= 0 processEnvironment_~tmp~5)} assume 0 != ~tmp~5; {5592#false} is VALID [2020-07-17 21:32:03,731 INFO L263 TraceCheckUtils]: 16: Hoare triple {5592#false} call activatePump(); {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:03,731 INFO L280 TraceCheckUtils]: 17: Hoare triple {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {5591#true} is VALID [2020-07-17 21:32:03,732 INFO L280 TraceCheckUtils]: 18: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,732 INFO L275 TraceCheckUtils]: 19: Hoare quadruple {5591#true} {5592#false} #443#return; {5592#false} is VALID [2020-07-17 21:32:03,732 INFO L280 TraceCheckUtils]: 20: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:03,732 INFO L275 TraceCheckUtils]: 21: Hoare quadruple {5592#false} {5591#true} #461#return; {5592#false} is VALID [2020-07-17 21:32:03,735 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,738 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,741 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {5591#true} is VALID [2020-07-17 21:32:03,741 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,741 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {5591#true} {5591#true} #395#return; {5591#true} is VALID [2020-07-17 21:32:03,742 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} havoc ~tmp~7;havoc ~tmp___0~2; {5591#true} is VALID [2020-07-17 21:32:03,742 INFO L263 TraceCheckUtils]: 1: Hoare triple {5591#true} call #t~ret70 := getWaterLevel(); {5591#true} is VALID [2020-07-17 21:32:03,742 INFO L280 TraceCheckUtils]: 2: Hoare triple {5591#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {5591#true} is VALID [2020-07-17 21:32:03,743 INFO L280 TraceCheckUtils]: 3: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,743 INFO L275 TraceCheckUtils]: 4: Hoare quadruple {5591#true} {5591#true} #395#return; {5591#true} is VALID [2020-07-17 21:32:03,743 INFO L280 TraceCheckUtils]: 5: Hoare triple {5591#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {5591#true} is VALID [2020-07-17 21:32:03,743 INFO L280 TraceCheckUtils]: 6: Hoare triple {5591#true} assume !(0 == ~tmp~7); {5591#true} is VALID [2020-07-17 21:32:03,744 INFO L280 TraceCheckUtils]: 7: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,744 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {5591#true} {5592#false} #463#return; {5592#false} is VALID [2020-07-17 21:32:03,744 INFO L280 TraceCheckUtils]: 0: Hoare triple {5666#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} assume !(0 != ~pumpRunning~0); {5591#true} is VALID [2020-07-17 21:32:03,745 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume 0 != ~systemActive~0; {5591#true} is VALID [2020-07-17 21:32:03,746 INFO L263 TraceCheckUtils]: 2: Hoare triple {5591#true} call processEnvironment(); {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:03,746 INFO L280 TraceCheckUtils]: 3: Hoare triple {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {5591#true} is VALID [2020-07-17 21:32:03,746 INFO L280 TraceCheckUtils]: 4: Hoare triple {5591#true} assume 0 == ~pumpRunning~0; {5591#true} is VALID [2020-07-17 21:32:03,747 INFO L263 TraceCheckUtils]: 5: Hoare triple {5591#true} call #t~ret51 := isHighWaterLevel(); {5591#true} is VALID [2020-07-17 21:32:03,747 INFO L280 TraceCheckUtils]: 6: Hoare triple {5591#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {5591#true} is VALID [2020-07-17 21:32:03,747 INFO L263 TraceCheckUtils]: 7: Hoare triple {5591#true} call #t~ret69 := isHighWaterSensorDry(); {5591#true} is VALID [2020-07-17 21:32:03,747 INFO L280 TraceCheckUtils]: 8: Hoare triple {5591#true} havoc ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,748 INFO L280 TraceCheckUtils]: 9: Hoare triple {5591#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,748 INFO L280 TraceCheckUtils]: 10: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,748 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {5591#true} {5591#true} #457#return; {5591#true} is VALID [2020-07-17 21:32:03,748 INFO L280 TraceCheckUtils]: 12: Hoare triple {5591#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {5591#true} is VALID [2020-07-17 21:32:03,749 INFO L280 TraceCheckUtils]: 13: Hoare triple {5591#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {5719#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} is VALID [2020-07-17 21:32:03,750 INFO L280 TraceCheckUtils]: 14: Hoare triple {5719#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:03,751 INFO L280 TraceCheckUtils]: 15: Hoare triple {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} assume true; {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:03,752 INFO L275 TraceCheckUtils]: 16: Hoare quadruple {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} {5591#true} #441#return; {5710#(= 0 |processEnvironment_#t~ret51|)} is VALID [2020-07-17 21:32:03,753 INFO L280 TraceCheckUtils]: 17: Hoare triple {5710#(= 0 |processEnvironment_#t~ret51|)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {5711#(= 0 processEnvironment_~tmp~5)} is VALID [2020-07-17 21:32:03,753 INFO L280 TraceCheckUtils]: 18: Hoare triple {5711#(= 0 processEnvironment_~tmp~5)} assume 0 != ~tmp~5; {5592#false} is VALID [2020-07-17 21:32:03,754 INFO L263 TraceCheckUtils]: 19: Hoare triple {5592#false} call activatePump(); {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:03,754 INFO L280 TraceCheckUtils]: 20: Hoare triple {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {5591#true} is VALID [2020-07-17 21:32:03,754 INFO L280 TraceCheckUtils]: 21: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,754 INFO L275 TraceCheckUtils]: 22: Hoare quadruple {5591#true} {5592#false} #443#return; {5592#false} is VALID [2020-07-17 21:32:03,755 INFO L280 TraceCheckUtils]: 23: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:03,755 INFO L275 TraceCheckUtils]: 24: Hoare quadruple {5592#false} {5591#true} #461#return; {5592#false} is VALID [2020-07-17 21:32:03,755 INFO L263 TraceCheckUtils]: 25: Hoare triple {5592#false} call __utac_acc__Specification4_spec__1(); {5591#true} is VALID [2020-07-17 21:32:03,755 INFO L280 TraceCheckUtils]: 26: Hoare triple {5591#true} havoc ~tmp~7;havoc ~tmp___0~2; {5591#true} is VALID [2020-07-17 21:32:03,756 INFO L263 TraceCheckUtils]: 27: Hoare triple {5591#true} call #t~ret70 := getWaterLevel(); {5591#true} is VALID [2020-07-17 21:32:03,756 INFO L280 TraceCheckUtils]: 28: Hoare triple {5591#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {5591#true} is VALID [2020-07-17 21:32:03,756 INFO L280 TraceCheckUtils]: 29: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,756 INFO L275 TraceCheckUtils]: 30: Hoare quadruple {5591#true} {5591#true} #395#return; {5591#true} is VALID [2020-07-17 21:32:03,756 INFO L280 TraceCheckUtils]: 31: Hoare triple {5591#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {5591#true} is VALID [2020-07-17 21:32:03,757 INFO L280 TraceCheckUtils]: 32: Hoare triple {5591#true} assume !(0 == ~tmp~7); {5591#true} is VALID [2020-07-17 21:32:03,757 INFO L280 TraceCheckUtils]: 33: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,757 INFO L275 TraceCheckUtils]: 34: Hoare quadruple {5591#true} {5592#false} #463#return; {5592#false} is VALID [2020-07-17 21:32:03,757 INFO L280 TraceCheckUtils]: 35: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:03,758 INFO L275 TraceCheckUtils]: 36: Hoare quadruple {5592#false} {5609#(<= 2 ~waterLevel~0)} #453#return; {5592#false} is VALID [2020-07-17 21:32:03,760 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,762 INFO L280 TraceCheckUtils]: 0: Hoare triple {5664#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {5591#true} is VALID [2020-07-17 21:32:03,763 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,763 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {5591#true} {5592#false} #459#return; {5592#false} is VALID [2020-07-17 21:32:03,764 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,766 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,769 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,769 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {5591#true} {5591#true} #447#return; {5591#true} is VALID [2020-07-17 21:32:03,769 INFO L280 TraceCheckUtils]: 0: Hoare triple {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {5591#true} is VALID [2020-07-17 21:32:03,769 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume !(0 == ~pumpRunning~0); {5591#true} is VALID [2020-07-17 21:32:03,770 INFO L263 TraceCheckUtils]: 2: Hoare triple {5591#true} call processEnvironment__wrappee__base(); {5591#true} is VALID [2020-07-17 21:32:03,770 INFO L280 TraceCheckUtils]: 3: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,770 INFO L275 TraceCheckUtils]: 4: Hoare quadruple {5591#true} {5591#true} #447#return; {5591#true} is VALID [2020-07-17 21:32:03,770 INFO L280 TraceCheckUtils]: 5: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,770 INFO L275 TraceCheckUtils]: 6: Hoare quadruple {5591#true} {5592#false} #461#return; {5592#false} is VALID [2020-07-17 21:32:03,771 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,776 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {5591#true} is VALID [2020-07-17 21:32:03,776 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,776 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {5591#true} {5592#false} #395#return; {5592#false} is VALID [2020-07-17 21:32:03,777 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:03,780 INFO L280 TraceCheckUtils]: 0: Hoare triple {5591#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {5591#true} is VALID [2020-07-17 21:32:03,780 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,780 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {5591#true} {5592#false} #397#return; {5592#false} is VALID [2020-07-17 21:32:03,784 INFO L263 TraceCheckUtils]: 0: Hoare triple {5591#true} call ULTIMATE.init(); {5663#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} is VALID [2020-07-17 21:32:03,790 INFO L280 TraceCheckUtils]: 1: Hoare triple {5663#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,790 INFO L280 TraceCheckUtils]: 2: Hoare triple {5596#(= 1 ~waterLevel~0)} assume true; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,791 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {5596#(= 1 ~waterLevel~0)} {5591#true} #479#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,792 INFO L263 TraceCheckUtils]: 4: Hoare triple {5596#(= 1 ~waterLevel~0)} call #t~ret72 := main(); {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,792 INFO L280 TraceCheckUtils]: 5: Hoare triple {5596#(= 1 ~waterLevel~0)} havoc ~retValue_acc~3;havoc ~tmp~3; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,792 INFO L263 TraceCheckUtils]: 6: Hoare triple {5596#(= 1 ~waterLevel~0)} call select_helpers(); {5591#true} is VALID [2020-07-17 21:32:03,792 INFO L280 TraceCheckUtils]: 7: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,793 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {5591#true} {5596#(= 1 ~waterLevel~0)} #401#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,793 INFO L263 TraceCheckUtils]: 9: Hoare triple {5596#(= 1 ~waterLevel~0)} call select_features(); {5591#true} is VALID [2020-07-17 21:32:03,793 INFO L280 TraceCheckUtils]: 10: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,794 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {5591#true} {5596#(= 1 ~waterLevel~0)} #403#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,794 INFO L263 TraceCheckUtils]: 12: Hoare triple {5596#(= 1 ~waterLevel~0)} call #t~ret35 := valid_product(); {5591#true} is VALID [2020-07-17 21:32:03,794 INFO L280 TraceCheckUtils]: 13: Hoare triple {5591#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {5591#true} is VALID [2020-07-17 21:32:03,795 INFO L280 TraceCheckUtils]: 14: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,795 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {5591#true} {5596#(= 1 ~waterLevel~0)} #405#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,796 INFO L280 TraceCheckUtils]: 16: Hoare triple {5596#(= 1 ~waterLevel~0)} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,796 INFO L280 TraceCheckUtils]: 17: Hoare triple {5596#(= 1 ~waterLevel~0)} assume 0 != ~tmp~3; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,797 INFO L263 TraceCheckUtils]: 18: Hoare triple {5596#(= 1 ~waterLevel~0)} call setup(); {5591#true} is VALID [2020-07-17 21:32:03,797 INFO L280 TraceCheckUtils]: 19: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,797 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {5591#true} {5596#(= 1 ~waterLevel~0)} #407#return; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,798 INFO L263 TraceCheckUtils]: 21: Hoare triple {5596#(= 1 ~waterLevel~0)} call runTest(); {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,798 INFO L263 TraceCheckUtils]: 22: Hoare triple {5596#(= 1 ~waterLevel~0)} call test(); {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,799 INFO L280 TraceCheckUtils]: 23: Hoare triple {5596#(= 1 ~waterLevel~0)} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,799 INFO L280 TraceCheckUtils]: 24: Hoare triple {5596#(= 1 ~waterLevel~0)} assume !false; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,800 INFO L280 TraceCheckUtils]: 25: Hoare triple {5596#(= 1 ~waterLevel~0)} assume ~splverifierCounter~0 < 4; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,801 INFO L280 TraceCheckUtils]: 26: Hoare triple {5596#(= 1 ~waterLevel~0)} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,801 INFO L280 TraceCheckUtils]: 27: Hoare triple {5596#(= 1 ~waterLevel~0)} assume 0 != ~tmp~4; {5596#(= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,802 INFO L263 TraceCheckUtils]: 28: Hoare triple {5596#(= 1 ~waterLevel~0)} call waterRise(); {5664#(= ~waterLevel~0 |old(~waterLevel~0)|)} is VALID [2020-07-17 21:32:03,802 INFO L280 TraceCheckUtils]: 29: Hoare triple {5664#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 < 2;~waterLevel~0 := 1 + ~waterLevel~0; {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} is VALID [2020-07-17 21:32:03,803 INFO L280 TraceCheckUtils]: 30: Hoare triple {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} assume true; {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} is VALID [2020-07-17 21:32:03,804 INFO L275 TraceCheckUtils]: 31: Hoare quadruple {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} {5596#(= 1 ~waterLevel~0)} #449#return; {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,804 INFO L280 TraceCheckUtils]: 32: Hoare triple {5609#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,805 INFO L280 TraceCheckUtils]: 33: Hoare triple {5609#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp___0~0); {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,805 INFO L280 TraceCheckUtils]: 34: Hoare triple {5609#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,806 INFO L280 TraceCheckUtils]: 35: Hoare triple {5609#(<= 2 ~waterLevel~0)} assume 0 != ~tmp___2~0; {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:03,807 INFO L263 TraceCheckUtils]: 36: Hoare triple {5609#(<= 2 ~waterLevel~0)} call timeShift(); {5666#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} is VALID [2020-07-17 21:32:03,807 INFO L280 TraceCheckUtils]: 37: Hoare triple {5666#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} assume !(0 != ~pumpRunning~0); {5591#true} is VALID [2020-07-17 21:32:03,807 INFO L280 TraceCheckUtils]: 38: Hoare triple {5591#true} assume 0 != ~systemActive~0; {5591#true} is VALID [2020-07-17 21:32:03,808 INFO L263 TraceCheckUtils]: 39: Hoare triple {5591#true} call processEnvironment(); {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:03,808 INFO L280 TraceCheckUtils]: 40: Hoare triple {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {5591#true} is VALID [2020-07-17 21:32:03,808 INFO L280 TraceCheckUtils]: 41: Hoare triple {5591#true} assume 0 == ~pumpRunning~0; {5591#true} is VALID [2020-07-17 21:32:03,808 INFO L263 TraceCheckUtils]: 42: Hoare triple {5591#true} call #t~ret51 := isHighWaterLevel(); {5591#true} is VALID [2020-07-17 21:32:03,808 INFO L280 TraceCheckUtils]: 43: Hoare triple {5591#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {5591#true} is VALID [2020-07-17 21:32:03,808 INFO L263 TraceCheckUtils]: 44: Hoare triple {5591#true} call #t~ret69 := isHighWaterSensorDry(); {5591#true} is VALID [2020-07-17 21:32:03,809 INFO L280 TraceCheckUtils]: 45: Hoare triple {5591#true} havoc ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,809 INFO L280 TraceCheckUtils]: 46: Hoare triple {5591#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:03,809 INFO L280 TraceCheckUtils]: 47: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,809 INFO L275 TraceCheckUtils]: 48: Hoare quadruple {5591#true} {5591#true} #457#return; {5591#true} is VALID [2020-07-17 21:32:03,809 INFO L280 TraceCheckUtils]: 49: Hoare triple {5591#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {5591#true} is VALID [2020-07-17 21:32:03,810 INFO L280 TraceCheckUtils]: 50: Hoare triple {5591#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {5719#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} is VALID [2020-07-17 21:32:03,811 INFO L280 TraceCheckUtils]: 51: Hoare triple {5719#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:03,812 INFO L280 TraceCheckUtils]: 52: Hoare triple {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} assume true; {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:03,812 INFO L275 TraceCheckUtils]: 53: Hoare quadruple {5720#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} {5591#true} #441#return; {5710#(= 0 |processEnvironment_#t~ret51|)} is VALID [2020-07-17 21:32:03,813 INFO L280 TraceCheckUtils]: 54: Hoare triple {5710#(= 0 |processEnvironment_#t~ret51|)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {5711#(= 0 processEnvironment_~tmp~5)} is VALID [2020-07-17 21:32:03,814 INFO L280 TraceCheckUtils]: 55: Hoare triple {5711#(= 0 processEnvironment_~tmp~5)} assume 0 != ~tmp~5; {5592#false} is VALID [2020-07-17 21:32:03,814 INFO L263 TraceCheckUtils]: 56: Hoare triple {5592#false} call activatePump(); {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:03,814 INFO L280 TraceCheckUtils]: 57: Hoare triple {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {5591#true} is VALID [2020-07-17 21:32:03,814 INFO L280 TraceCheckUtils]: 58: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,815 INFO L275 TraceCheckUtils]: 59: Hoare quadruple {5591#true} {5592#false} #443#return; {5592#false} is VALID [2020-07-17 21:32:03,815 INFO L280 TraceCheckUtils]: 60: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:03,815 INFO L275 TraceCheckUtils]: 61: Hoare quadruple {5592#false} {5591#true} #461#return; {5592#false} is VALID [2020-07-17 21:32:03,815 INFO L263 TraceCheckUtils]: 62: Hoare triple {5592#false} call __utac_acc__Specification4_spec__1(); {5591#true} is VALID [2020-07-17 21:32:03,815 INFO L280 TraceCheckUtils]: 63: Hoare triple {5591#true} havoc ~tmp~7;havoc ~tmp___0~2; {5591#true} is VALID [2020-07-17 21:32:03,816 INFO L263 TraceCheckUtils]: 64: Hoare triple {5591#true} call #t~ret70 := getWaterLevel(); {5591#true} is VALID [2020-07-17 21:32:03,816 INFO L280 TraceCheckUtils]: 65: Hoare triple {5591#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {5591#true} is VALID [2020-07-17 21:32:03,816 INFO L280 TraceCheckUtils]: 66: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,816 INFO L275 TraceCheckUtils]: 67: Hoare quadruple {5591#true} {5591#true} #395#return; {5591#true} is VALID [2020-07-17 21:32:03,816 INFO L280 TraceCheckUtils]: 68: Hoare triple {5591#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {5591#true} is VALID [2020-07-17 21:32:03,817 INFO L280 TraceCheckUtils]: 69: Hoare triple {5591#true} assume !(0 == ~tmp~7); {5591#true} is VALID [2020-07-17 21:32:03,817 INFO L280 TraceCheckUtils]: 70: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,817 INFO L275 TraceCheckUtils]: 71: Hoare quadruple {5591#true} {5592#false} #463#return; {5592#false} is VALID [2020-07-17 21:32:03,817 INFO L280 TraceCheckUtils]: 72: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:03,817 INFO L275 TraceCheckUtils]: 73: Hoare quadruple {5592#false} {5609#(<= 2 ~waterLevel~0)} #453#return; {5592#false} is VALID [2020-07-17 21:32:03,817 INFO L280 TraceCheckUtils]: 74: Hoare triple {5592#false} assume !false; {5592#false} is VALID [2020-07-17 21:32:03,818 INFO L280 TraceCheckUtils]: 75: Hoare triple {5592#false} assume ~splverifierCounter~0 < 4; {5592#false} is VALID [2020-07-17 21:32:03,818 INFO L280 TraceCheckUtils]: 76: Hoare triple {5592#false} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {5592#false} is VALID [2020-07-17 21:32:03,818 INFO L280 TraceCheckUtils]: 77: Hoare triple {5592#false} assume !(0 != ~tmp~4); {5592#false} is VALID [2020-07-17 21:32:03,818 INFO L280 TraceCheckUtils]: 78: Hoare triple {5592#false} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {5592#false} is VALID [2020-07-17 21:32:03,818 INFO L280 TraceCheckUtils]: 79: Hoare triple {5592#false} assume !(0 != ~tmp___0~0); {5592#false} is VALID [2020-07-17 21:32:03,819 INFO L280 TraceCheckUtils]: 80: Hoare triple {5592#false} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {5592#false} is VALID [2020-07-17 21:32:03,819 INFO L280 TraceCheckUtils]: 81: Hoare triple {5592#false} assume 0 != ~tmp___2~0; {5592#false} is VALID [2020-07-17 21:32:03,819 INFO L263 TraceCheckUtils]: 82: Hoare triple {5592#false} call timeShift(); {5592#false} is VALID [2020-07-17 21:32:03,819 INFO L280 TraceCheckUtils]: 83: Hoare triple {5592#false} assume 0 != ~pumpRunning~0; {5592#false} is VALID [2020-07-17 21:32:03,820 INFO L263 TraceCheckUtils]: 84: Hoare triple {5592#false} call lowerWaterLevel(); {5664#(= ~waterLevel~0 |old(~waterLevel~0)|)} is VALID [2020-07-17 21:32:03,820 INFO L280 TraceCheckUtils]: 85: Hoare triple {5664#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {5591#true} is VALID [2020-07-17 21:32:03,820 INFO L280 TraceCheckUtils]: 86: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,820 INFO L275 TraceCheckUtils]: 87: Hoare quadruple {5591#true} {5592#false} #459#return; {5592#false} is VALID [2020-07-17 21:32:03,820 INFO L280 TraceCheckUtils]: 88: Hoare triple {5592#false} assume 0 != ~systemActive~0; {5592#false} is VALID [2020-07-17 21:32:03,821 INFO L263 TraceCheckUtils]: 89: Hoare triple {5592#false} call processEnvironment(); {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:03,821 INFO L280 TraceCheckUtils]: 90: Hoare triple {5698#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {5591#true} is VALID [2020-07-17 21:32:03,821 INFO L280 TraceCheckUtils]: 91: Hoare triple {5591#true} assume !(0 == ~pumpRunning~0); {5591#true} is VALID [2020-07-17 21:32:03,821 INFO L263 TraceCheckUtils]: 92: Hoare triple {5591#true} call processEnvironment__wrappee__base(); {5591#true} is VALID [2020-07-17 21:32:03,821 INFO L280 TraceCheckUtils]: 93: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,822 INFO L275 TraceCheckUtils]: 94: Hoare quadruple {5591#true} {5591#true} #447#return; {5591#true} is VALID [2020-07-17 21:32:03,822 INFO L280 TraceCheckUtils]: 95: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,822 INFO L275 TraceCheckUtils]: 96: Hoare quadruple {5591#true} {5592#false} #461#return; {5592#false} is VALID [2020-07-17 21:32:03,822 INFO L263 TraceCheckUtils]: 97: Hoare triple {5592#false} call __utac_acc__Specification4_spec__1(); {5592#false} is VALID [2020-07-17 21:32:03,822 INFO L280 TraceCheckUtils]: 98: Hoare triple {5592#false} havoc ~tmp~7;havoc ~tmp___0~2; {5592#false} is VALID [2020-07-17 21:32:03,823 INFO L263 TraceCheckUtils]: 99: Hoare triple {5592#false} call #t~ret70 := getWaterLevel(); {5591#true} is VALID [2020-07-17 21:32:03,823 INFO L280 TraceCheckUtils]: 100: Hoare triple {5591#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {5591#true} is VALID [2020-07-17 21:32:03,823 INFO L280 TraceCheckUtils]: 101: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,823 INFO L275 TraceCheckUtils]: 102: Hoare quadruple {5591#true} {5592#false} #395#return; {5592#false} is VALID [2020-07-17 21:32:03,824 INFO L280 TraceCheckUtils]: 103: Hoare triple {5592#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {5592#false} is VALID [2020-07-17 21:32:03,824 INFO L280 TraceCheckUtils]: 104: Hoare triple {5592#false} assume 0 == ~tmp~7; {5592#false} is VALID [2020-07-17 21:32:03,824 INFO L263 TraceCheckUtils]: 105: Hoare triple {5592#false} call #t~ret71 := isPumpRunning(); {5591#true} is VALID [2020-07-17 21:32:03,824 INFO L280 TraceCheckUtils]: 106: Hoare triple {5591#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {5591#true} is VALID [2020-07-17 21:32:03,824 INFO L280 TraceCheckUtils]: 107: Hoare triple {5591#true} assume true; {5591#true} is VALID [2020-07-17 21:32:03,825 INFO L275 TraceCheckUtils]: 108: Hoare quadruple {5591#true} {5592#false} #397#return; {5592#false} is VALID [2020-07-17 21:32:03,825 INFO L280 TraceCheckUtils]: 109: Hoare triple {5592#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {5592#false} is VALID [2020-07-17 21:32:03,825 INFO L280 TraceCheckUtils]: 110: Hoare triple {5592#false} assume 0 != ~tmp___0~2; {5592#false} is VALID [2020-07-17 21:32:03,825 INFO L263 TraceCheckUtils]: 111: Hoare triple {5592#false} call __automaton_fail(); {5592#false} is VALID [2020-07-17 21:32:03,825 INFO L280 TraceCheckUtils]: 112: Hoare triple {5592#false} assume !false; {5592#false} is VALID [2020-07-17 21:32:03,845 INFO L134 CoverageAnalysis]: Checked inductivity of 24 backedges. 16 proven. 2 refuted. 0 times theorem prover too weak. 6 trivial. 0 not checked. [2020-07-17 21:32:03,845 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1298297608] [2020-07-17 21:32:03,846 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [949025527] [2020-07-17 21:32:03,846 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 Starting monitored process 2 with z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) Waiting until toolchain timeout for monitored process 2 with z3 -smt2 -in SMTLIB2_COMPLIANT=true [2020-07-17 21:32:04,045 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:04,048 INFO L264 TraceCheckSpWp]: Trace formula consists of 784 conjuncts, 13 conjunts are in the unsatisfiable core [2020-07-17 21:32:04,084 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:04,093 INFO L287 TraceCheckSpWp]: Computing forward predicates... [2020-07-17 21:32:04,407 INFO L263 TraceCheckUtils]: 0: Hoare triple {5591#true} call ULTIMATE.init(); {5591#true} is VALID [2020-07-17 21:32:04,412 INFO L280 TraceCheckUtils]: 1: Hoare triple {5591#true} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,413 INFO L280 TraceCheckUtils]: 2: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume true; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,414 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {5732#(<= 1 ~waterLevel~0)} {5591#true} #479#return; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,414 INFO L263 TraceCheckUtils]: 4: Hoare triple {5732#(<= 1 ~waterLevel~0)} call #t~ret72 := main(); {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,415 INFO L280 TraceCheckUtils]: 5: Hoare triple {5732#(<= 1 ~waterLevel~0)} havoc ~retValue_acc~3;havoc ~tmp~3; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,415 INFO L263 TraceCheckUtils]: 6: Hoare triple {5732#(<= 1 ~waterLevel~0)} call select_helpers(); {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,415 INFO L280 TraceCheckUtils]: 7: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume true; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,416 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {5732#(<= 1 ~waterLevel~0)} {5732#(<= 1 ~waterLevel~0)} #401#return; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,416 INFO L263 TraceCheckUtils]: 9: Hoare triple {5732#(<= 1 ~waterLevel~0)} call select_features(); {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,417 INFO L280 TraceCheckUtils]: 10: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume true; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,418 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {5732#(<= 1 ~waterLevel~0)} {5732#(<= 1 ~waterLevel~0)} #403#return; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,418 INFO L263 TraceCheckUtils]: 12: Hoare triple {5732#(<= 1 ~waterLevel~0)} call #t~ret35 := valid_product(); {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,419 INFO L280 TraceCheckUtils]: 13: Hoare triple {5732#(<= 1 ~waterLevel~0)} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,420 INFO L280 TraceCheckUtils]: 14: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume true; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,421 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {5732#(<= 1 ~waterLevel~0)} {5732#(<= 1 ~waterLevel~0)} #405#return; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,421 INFO L280 TraceCheckUtils]: 16: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,422 INFO L280 TraceCheckUtils]: 17: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume 0 != ~tmp~3; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,423 INFO L263 TraceCheckUtils]: 18: Hoare triple {5732#(<= 1 ~waterLevel~0)} call setup(); {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,423 INFO L280 TraceCheckUtils]: 19: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume true; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,424 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {5732#(<= 1 ~waterLevel~0)} {5732#(<= 1 ~waterLevel~0)} #407#return; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,425 INFO L263 TraceCheckUtils]: 21: Hoare triple {5732#(<= 1 ~waterLevel~0)} call runTest(); {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,425 INFO L263 TraceCheckUtils]: 22: Hoare triple {5732#(<= 1 ~waterLevel~0)} call test(); {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,426 INFO L280 TraceCheckUtils]: 23: Hoare triple {5732#(<= 1 ~waterLevel~0)} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,427 INFO L280 TraceCheckUtils]: 24: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume !false; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,428 INFO L280 TraceCheckUtils]: 25: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume ~splverifierCounter~0 < 4; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,429 INFO L280 TraceCheckUtils]: 26: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,429 INFO L280 TraceCheckUtils]: 27: Hoare triple {5732#(<= 1 ~waterLevel~0)} assume 0 != ~tmp~4; {5732#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,429 INFO L263 TraceCheckUtils]: 28: Hoare triple {5732#(<= 1 ~waterLevel~0)} call waterRise(); {5814#(<= |old(~waterLevel~0)| ~waterLevel~0)} is VALID [2020-07-17 21:32:04,430 INFO L280 TraceCheckUtils]: 29: Hoare triple {5814#(<= |old(~waterLevel~0)| ~waterLevel~0)} assume ~waterLevel~0 < 2;~waterLevel~0 := 1 + ~waterLevel~0; {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} is VALID [2020-07-17 21:32:04,431 INFO L280 TraceCheckUtils]: 30: Hoare triple {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} assume true; {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} is VALID [2020-07-17 21:32:04,432 INFO L275 TraceCheckUtils]: 31: Hoare quadruple {5665#(<= (+ |old(~waterLevel~0)| 1) ~waterLevel~0)} {5732#(<= 1 ~waterLevel~0)} #449#return; {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,433 INFO L280 TraceCheckUtils]: 32: Hoare triple {5609#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,433 INFO L280 TraceCheckUtils]: 33: Hoare triple {5609#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp___0~0); {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,434 INFO L280 TraceCheckUtils]: 34: Hoare triple {5609#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,435 INFO L280 TraceCheckUtils]: 35: Hoare triple {5609#(<= 2 ~waterLevel~0)} assume 0 != ~tmp___2~0; {5609#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:04,435 INFO L263 TraceCheckUtils]: 36: Hoare triple {5609#(<= 2 ~waterLevel~0)} call timeShift(); {5814#(<= |old(~waterLevel~0)| ~waterLevel~0)} is VALID [2020-07-17 21:32:04,436 INFO L280 TraceCheckUtils]: 37: Hoare triple {5814#(<= |old(~waterLevel~0)| ~waterLevel~0)} assume !(0 != ~pumpRunning~0); {5814#(<= |old(~waterLevel~0)| ~waterLevel~0)} is VALID [2020-07-17 21:32:04,436 INFO L280 TraceCheckUtils]: 38: Hoare triple {5814#(<= |old(~waterLevel~0)| ~waterLevel~0)} assume 0 != ~systemActive~0; {5814#(<= |old(~waterLevel~0)| ~waterLevel~0)} is VALID [2020-07-17 21:32:04,436 INFO L263 TraceCheckUtils]: 39: Hoare triple {5814#(<= |old(~waterLevel~0)| ~waterLevel~0)} call processEnvironment(); {5591#true} is VALID [2020-07-17 21:32:04,436 INFO L280 TraceCheckUtils]: 40: Hoare triple {5591#true} havoc ~tmp~5; {5591#true} is VALID [2020-07-17 21:32:04,437 INFO L280 TraceCheckUtils]: 41: Hoare triple {5591#true} assume 0 == ~pumpRunning~0; {5591#true} is VALID [2020-07-17 21:32:04,437 INFO L263 TraceCheckUtils]: 42: Hoare triple {5591#true} call #t~ret51 := isHighWaterLevel(); {5591#true} is VALID [2020-07-17 21:32:04,437 INFO L280 TraceCheckUtils]: 43: Hoare triple {5591#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {5591#true} is VALID [2020-07-17 21:32:04,437 INFO L263 TraceCheckUtils]: 44: Hoare triple {5591#true} call #t~ret69 := isHighWaterSensorDry(); {5591#true} is VALID [2020-07-17 21:32:04,437 INFO L280 TraceCheckUtils]: 45: Hoare triple {5591#true} havoc ~retValue_acc~8; {5591#true} is VALID [2020-07-17 21:32:04,438 INFO L280 TraceCheckUtils]: 46: Hoare triple {5591#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,438 INFO L280 TraceCheckUtils]: 47: Hoare triple {5869#(< ~waterLevel~0 2)} assume true; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,439 INFO L275 TraceCheckUtils]: 48: Hoare quadruple {5869#(< ~waterLevel~0 2)} {5591#true} #457#return; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,439 INFO L280 TraceCheckUtils]: 49: Hoare triple {5869#(< ~waterLevel~0 2)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,439 INFO L280 TraceCheckUtils]: 50: Hoare triple {5869#(< ~waterLevel~0 2)} assume 0 != ~tmp~6;~tmp___0~1 := 0; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,440 INFO L280 TraceCheckUtils]: 51: Hoare triple {5869#(< ~waterLevel~0 2)} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,440 INFO L280 TraceCheckUtils]: 52: Hoare triple {5869#(< ~waterLevel~0 2)} assume true; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,441 INFO L275 TraceCheckUtils]: 53: Hoare quadruple {5869#(< ~waterLevel~0 2)} {5591#true} #441#return; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,442 INFO L280 TraceCheckUtils]: 54: Hoare triple {5869#(< ~waterLevel~0 2)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,442 INFO L280 TraceCheckUtils]: 55: Hoare triple {5869#(< ~waterLevel~0 2)} assume 0 != ~tmp~5; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,443 INFO L263 TraceCheckUtils]: 56: Hoare triple {5869#(< ~waterLevel~0 2)} call activatePump(); {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,444 INFO L280 TraceCheckUtils]: 57: Hoare triple {5869#(< ~waterLevel~0 2)} ~pumpRunning~0 := 1; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,451 INFO L280 TraceCheckUtils]: 58: Hoare triple {5869#(< ~waterLevel~0 2)} assume true; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,451 INFO L275 TraceCheckUtils]: 59: Hoare quadruple {5869#(< ~waterLevel~0 2)} {5869#(< ~waterLevel~0 2)} #443#return; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,452 INFO L280 TraceCheckUtils]: 60: Hoare triple {5869#(< ~waterLevel~0 2)} assume true; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,452 INFO L275 TraceCheckUtils]: 61: Hoare quadruple {5869#(< ~waterLevel~0 2)} {5814#(<= |old(~waterLevel~0)| ~waterLevel~0)} #461#return; {5915#(and (< ~waterLevel~0 2) (<= |old(~waterLevel~0)| ~waterLevel~0))} is VALID [2020-07-17 21:32:04,453 INFO L263 TraceCheckUtils]: 62: Hoare triple {5915#(and (< ~waterLevel~0 2) (<= |old(~waterLevel~0)| ~waterLevel~0))} call __utac_acc__Specification4_spec__1(); {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,457 INFO L280 TraceCheckUtils]: 63: Hoare triple {5869#(< ~waterLevel~0 2)} havoc ~tmp~7;havoc ~tmp___0~2; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,460 INFO L263 TraceCheckUtils]: 64: Hoare triple {5869#(< ~waterLevel~0 2)} call #t~ret70 := getWaterLevel(); {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,460 INFO L280 TraceCheckUtils]: 65: Hoare triple {5869#(< ~waterLevel~0 2)} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,461 INFO L280 TraceCheckUtils]: 66: Hoare triple {5869#(< ~waterLevel~0 2)} assume true; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,461 INFO L275 TraceCheckUtils]: 67: Hoare quadruple {5869#(< ~waterLevel~0 2)} {5869#(< ~waterLevel~0 2)} #395#return; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,462 INFO L280 TraceCheckUtils]: 68: Hoare triple {5869#(< ~waterLevel~0 2)} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,463 INFO L280 TraceCheckUtils]: 69: Hoare triple {5869#(< ~waterLevel~0 2)} assume !(0 == ~tmp~7); {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,463 INFO L280 TraceCheckUtils]: 70: Hoare triple {5869#(< ~waterLevel~0 2)} assume true; {5869#(< ~waterLevel~0 2)} is VALID [2020-07-17 21:32:04,464 INFO L275 TraceCheckUtils]: 71: Hoare quadruple {5869#(< ~waterLevel~0 2)} {5915#(and (< ~waterLevel~0 2) (<= |old(~waterLevel~0)| ~waterLevel~0))} #463#return; {5915#(and (< ~waterLevel~0 2) (<= |old(~waterLevel~0)| ~waterLevel~0))} is VALID [2020-07-17 21:32:04,464 INFO L280 TraceCheckUtils]: 72: Hoare triple {5915#(and (< ~waterLevel~0 2) (<= |old(~waterLevel~0)| ~waterLevel~0))} assume true; {5915#(and (< ~waterLevel~0 2) (<= |old(~waterLevel~0)| ~waterLevel~0))} is VALID [2020-07-17 21:32:04,467 INFO L275 TraceCheckUtils]: 73: Hoare quadruple {5915#(and (< ~waterLevel~0 2) (<= |old(~waterLevel~0)| ~waterLevel~0))} {5609#(<= 2 ~waterLevel~0)} #453#return; {5592#false} is VALID [2020-07-17 21:32:04,467 INFO L280 TraceCheckUtils]: 74: Hoare triple {5592#false} assume !false; {5592#false} is VALID [2020-07-17 21:32:04,468 INFO L280 TraceCheckUtils]: 75: Hoare triple {5592#false} assume ~splverifierCounter~0 < 4; {5592#false} is VALID [2020-07-17 21:32:04,468 INFO L280 TraceCheckUtils]: 76: Hoare triple {5592#false} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {5592#false} is VALID [2020-07-17 21:32:04,468 INFO L280 TraceCheckUtils]: 77: Hoare triple {5592#false} assume !(0 != ~tmp~4); {5592#false} is VALID [2020-07-17 21:32:04,468 INFO L280 TraceCheckUtils]: 78: Hoare triple {5592#false} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {5592#false} is VALID [2020-07-17 21:32:04,468 INFO L280 TraceCheckUtils]: 79: Hoare triple {5592#false} assume !(0 != ~tmp___0~0); {5592#false} is VALID [2020-07-17 21:32:04,468 INFO L280 TraceCheckUtils]: 80: Hoare triple {5592#false} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {5592#false} is VALID [2020-07-17 21:32:04,468 INFO L280 TraceCheckUtils]: 81: Hoare triple {5592#false} assume 0 != ~tmp___2~0; {5592#false} is VALID [2020-07-17 21:32:04,468 INFO L263 TraceCheckUtils]: 82: Hoare triple {5592#false} call timeShift(); {5592#false} is VALID [2020-07-17 21:32:04,469 INFO L280 TraceCheckUtils]: 83: Hoare triple {5592#false} assume 0 != ~pumpRunning~0; {5592#false} is VALID [2020-07-17 21:32:04,469 INFO L263 TraceCheckUtils]: 84: Hoare triple {5592#false} call lowerWaterLevel(); {5592#false} is VALID [2020-07-17 21:32:04,469 INFO L280 TraceCheckUtils]: 85: Hoare triple {5592#false} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {5592#false} is VALID [2020-07-17 21:32:04,469 INFO L280 TraceCheckUtils]: 86: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:04,469 INFO L275 TraceCheckUtils]: 87: Hoare quadruple {5592#false} {5592#false} #459#return; {5592#false} is VALID [2020-07-17 21:32:04,469 INFO L280 TraceCheckUtils]: 88: Hoare triple {5592#false} assume 0 != ~systemActive~0; {5592#false} is VALID [2020-07-17 21:32:04,470 INFO L263 TraceCheckUtils]: 89: Hoare triple {5592#false} call processEnvironment(); {5592#false} is VALID [2020-07-17 21:32:04,470 INFO L280 TraceCheckUtils]: 90: Hoare triple {5592#false} havoc ~tmp~5; {5592#false} is VALID [2020-07-17 21:32:04,470 INFO L280 TraceCheckUtils]: 91: Hoare triple {5592#false} assume !(0 == ~pumpRunning~0); {5592#false} is VALID [2020-07-17 21:32:04,470 INFO L263 TraceCheckUtils]: 92: Hoare triple {5592#false} call processEnvironment__wrappee__base(); {5592#false} is VALID [2020-07-17 21:32:04,470 INFO L280 TraceCheckUtils]: 93: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:04,470 INFO L275 TraceCheckUtils]: 94: Hoare quadruple {5592#false} {5592#false} #447#return; {5592#false} is VALID [2020-07-17 21:32:04,471 INFO L280 TraceCheckUtils]: 95: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:04,471 INFO L275 TraceCheckUtils]: 96: Hoare quadruple {5592#false} {5592#false} #461#return; {5592#false} is VALID [2020-07-17 21:32:04,471 INFO L263 TraceCheckUtils]: 97: Hoare triple {5592#false} call __utac_acc__Specification4_spec__1(); {5592#false} is VALID [2020-07-17 21:32:04,471 INFO L280 TraceCheckUtils]: 98: Hoare triple {5592#false} havoc ~tmp~7;havoc ~tmp___0~2; {5592#false} is VALID [2020-07-17 21:32:04,471 INFO L263 TraceCheckUtils]: 99: Hoare triple {5592#false} call #t~ret70 := getWaterLevel(); {5592#false} is VALID [2020-07-17 21:32:04,471 INFO L280 TraceCheckUtils]: 100: Hoare triple {5592#false} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {5592#false} is VALID [2020-07-17 21:32:04,471 INFO L280 TraceCheckUtils]: 101: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:04,471 INFO L275 TraceCheckUtils]: 102: Hoare quadruple {5592#false} {5592#false} #395#return; {5592#false} is VALID [2020-07-17 21:32:04,472 INFO L280 TraceCheckUtils]: 103: Hoare triple {5592#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {5592#false} is VALID [2020-07-17 21:32:04,472 INFO L280 TraceCheckUtils]: 104: Hoare triple {5592#false} assume 0 == ~tmp~7; {5592#false} is VALID [2020-07-17 21:32:04,472 INFO L263 TraceCheckUtils]: 105: Hoare triple {5592#false} call #t~ret71 := isPumpRunning(); {5592#false} is VALID [2020-07-17 21:32:04,472 INFO L280 TraceCheckUtils]: 106: Hoare triple {5592#false} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {5592#false} is VALID [2020-07-17 21:32:04,472 INFO L280 TraceCheckUtils]: 107: Hoare triple {5592#false} assume true; {5592#false} is VALID [2020-07-17 21:32:04,472 INFO L275 TraceCheckUtils]: 108: Hoare quadruple {5592#false} {5592#false} #397#return; {5592#false} is VALID [2020-07-17 21:32:04,472 INFO L280 TraceCheckUtils]: 109: Hoare triple {5592#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {5592#false} is VALID [2020-07-17 21:32:04,473 INFO L280 TraceCheckUtils]: 110: Hoare triple {5592#false} assume 0 != ~tmp___0~2; {5592#false} is VALID [2020-07-17 21:32:04,473 INFO L263 TraceCheckUtils]: 111: Hoare triple {5592#false} call __automaton_fail(); {5592#false} is VALID [2020-07-17 21:32:04,473 INFO L280 TraceCheckUtils]: 112: Hoare triple {5592#false} assume !false; {5592#false} is VALID [2020-07-17 21:32:04,484 INFO L134 CoverageAnalysis]: Checked inductivity of 24 backedges. 24 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2020-07-17 21:32:04,485 INFO L220 FreeRefinementEngine]: Constructing automaton from 1 perfect and 1 imperfect interpolant sequences. [2020-07-17 21:32:04,485 INFO L233 FreeRefinementEngine]: Number of different interpolants: perfect sequences [8] imperfect sequences [13] total 17 [2020-07-17 21:32:04,485 INFO L156 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [191854971] [2020-07-17 21:32:04,486 INFO L78 Accepts]: Start accepts. Automaton has 8 states. Word has length 113 [2020-07-17 21:32:04,486 INFO L84 Accepts]: Finished accepts. word is accepted. [2020-07-17 21:32:04,486 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 8 states. [2020-07-17 21:32:04,615 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 113 edges. 113 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:32:04,615 INFO L459 AbstractCegarLoop]: Interpolant automaton has 8 states [2020-07-17 21:32:04,615 INFO L143 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2020-07-17 21:32:04,616 INFO L142 InterpolantAutomaton]: Constructing interpolant automaton starting with 8 interpolants. [2020-07-17 21:32:04,616 INFO L144 InterpolantAutomaton]: CoverageRelationStatistics Valid=45, Invalid=227, Unknown=0, NotChecked=0, Total=272 [2020-07-17 21:32:04,616 INFO L87 Difference]: Start difference. First operand 373 states and 443 transitions. Second operand 8 states. [2020-07-17 21:32:16,980 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:16,980 INFO L93 Difference]: Finished difference Result 906 states and 1196 transitions. [2020-07-17 21:32:16,980 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 13 states. [2020-07-17 21:32:16,980 INFO L78 Accepts]: Start accepts. Automaton has 8 states. Word has length 113 [2020-07-17 21:32:16,981 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2020-07-17 21:32:16,981 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 8 states. [2020-07-17 21:32:16,998 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 13 states to 13 states and 581 transitions. [2020-07-17 21:32:16,999 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 8 states. [2020-07-17 21:32:17,015 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 13 states to 13 states and 581 transitions. [2020-07-17 21:32:17,016 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 13 states and 581 transitions. [2020-07-17 21:32:18,034 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 581 edges. 581 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:32:18,076 INFO L225 Difference]: With dead ends: 906 [2020-07-17 21:32:18,076 INFO L226 Difference]: Without dead ends: 650 [2020-07-17 21:32:18,079 INFO L675 BasicCegarLoop]: 0 DeclaredPredicates, 168 GetRequests, 148 SyntacticMatches, 1 SemanticMatches, 19 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 51 ImplicationChecksByTransitivity, 0.5s TimeCoverageRelationStatistics Valid=71, Invalid=349, Unknown=0, NotChecked=0, Total=420 [2020-07-17 21:32:18,080 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 650 states. [2020-07-17 21:32:23,662 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 650 to 578. [2020-07-17 21:32:23,662 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2020-07-17 21:32:23,663 INFO L82 GeneralOperation]: Start isEquivalent. First operand 650 states. Second operand 578 states. [2020-07-17 21:32:23,663 INFO L74 IsIncluded]: Start isIncluded. First operand 650 states. Second operand 578 states. [2020-07-17 21:32:23,663 INFO L87 Difference]: Start difference. First operand 650 states. Second operand 578 states. [2020-07-17 21:32:23,695 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:23,696 INFO L93 Difference]: Finished difference Result 650 states and 820 transitions. [2020-07-17 21:32:23,696 INFO L276 IsEmpty]: Start isEmpty. Operand 650 states and 820 transitions. [2020-07-17 21:32:23,698 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:32:23,699 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:32:23,699 INFO L74 IsIncluded]: Start isIncluded. First operand 578 states. Second operand 650 states. [2020-07-17 21:32:23,699 INFO L87 Difference]: Start difference. First operand 578 states. Second operand 650 states. [2020-07-17 21:32:23,734 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:23,734 INFO L93 Difference]: Finished difference Result 650 states and 820 transitions. [2020-07-17 21:32:23,734 INFO L276 IsEmpty]: Start isEmpty. Operand 650 states and 820 transitions. [2020-07-17 21:32:23,737 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:32:23,737 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:32:23,737 INFO L88 GeneralOperation]: Finished isEquivalent. [2020-07-17 21:32:23,737 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2020-07-17 21:32:23,737 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 578 states. [2020-07-17 21:32:23,767 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 578 states to 578 states and 714 transitions. [2020-07-17 21:32:23,768 INFO L78 Accepts]: Start accepts. Automaton has 578 states and 714 transitions. Word has length 113 [2020-07-17 21:32:23,768 INFO L84 Accepts]: Finished accepts. word is rejected. [2020-07-17 21:32:23,768 INFO L479 AbstractCegarLoop]: Abstraction has 578 states and 714 transitions. [2020-07-17 21:32:23,768 INFO L480 AbstractCegarLoop]: Interpolant automaton has 8 states. [2020-07-17 21:32:23,768 INFO L276 IsEmpty]: Start isEmpty. Operand 578 states and 714 transitions. [2020-07-17 21:32:23,770 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 110 [2020-07-17 21:32:23,770 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:32:23,770 INFO L422 BasicCegarLoop]: trace histogram [2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:32:23,983 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 2 z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable5 [2020-07-17 21:32:23,984 INFO L427 AbstractCegarLoop]: === Iteration 7 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:32:23,985 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:32:23,985 INFO L82 PathProgramCache]: Analyzing trace with hash -1648815792, now seen corresponding path program 1 times [2020-07-17 21:32:23,985 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:32:23,986 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [569057903] [2020-07-17 21:32:23,986 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:32:24,031 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,308 WARN L193 SmtUtils]: Spent 200.00 ms on a formula simplification that was a NOOP. DAG size: 184 [2020-07-17 21:32:24,343 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,359 INFO L280 TraceCheckUtils]: 0: Hoare triple {9501#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {9434#true} is VALID [2020-07-17 21:32:24,359 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,360 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {9434#true} {9434#true} #479#return; {9434#true} is VALID [2020-07-17 21:32:24,360 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,364 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,364 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {9434#true} {9434#true} #401#return; {9434#true} is VALID [2020-07-17 21:32:24,365 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,368 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,368 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {9434#true} {9434#true} #403#return; {9434#true} is VALID [2020-07-17 21:32:24,369 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,380 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {9434#true} is VALID [2020-07-17 21:32:24,380 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,380 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {9434#true} {9434#true} #405#return; {9434#true} is VALID [2020-07-17 21:32:24,381 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,383 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,383 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {9434#true} {9434#true} #407#return; {9434#true} is VALID [2020-07-17 21:32:24,400 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,422 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,454 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,505 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,509 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} havoc ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,509 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,509 INFO L280 TraceCheckUtils]: 2: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,509 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {9434#true} {9434#true} #457#return; {9434#true} is VALID [2020-07-17 21:32:24,510 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {9434#true} is VALID [2020-07-17 21:32:24,510 INFO L263 TraceCheckUtils]: 1: Hoare triple {9434#true} call #t~ret69 := isHighWaterSensorDry(); {9434#true} is VALID [2020-07-17 21:32:24,510 INFO L280 TraceCheckUtils]: 2: Hoare triple {9434#true} havoc ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,510 INFO L280 TraceCheckUtils]: 3: Hoare triple {9434#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,510 INFO L280 TraceCheckUtils]: 4: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,511 INFO L275 TraceCheckUtils]: 5: Hoare quadruple {9434#true} {9434#true} #457#return; {9434#true} is VALID [2020-07-17 21:32:24,511 INFO L280 TraceCheckUtils]: 6: Hoare triple {9434#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {9434#true} is VALID [2020-07-17 21:32:24,512 INFO L280 TraceCheckUtils]: 7: Hoare triple {9434#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} is VALID [2020-07-17 21:32:24,512 INFO L280 TraceCheckUtils]: 8: Hoare triple {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:24,513 INFO L280 TraceCheckUtils]: 9: Hoare triple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} assume true; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:24,514 INFO L275 TraceCheckUtils]: 10: Hoare quadruple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} {9434#true} #441#return; {9546#(= 0 |processEnvironment_#t~ret51|)} is VALID [2020-07-17 21:32:24,515 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,521 INFO L280 TraceCheckUtils]: 0: Hoare triple {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {9434#true} is VALID [2020-07-17 21:32:24,522 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,522 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {9434#true} {9435#false} #443#return; {9435#false} is VALID [2020-07-17 21:32:24,522 INFO L280 TraceCheckUtils]: 0: Hoare triple {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {9434#true} is VALID [2020-07-17 21:32:24,522 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume 0 == ~pumpRunning~0; {9434#true} is VALID [2020-07-17 21:32:24,523 INFO L263 TraceCheckUtils]: 2: Hoare triple {9434#true} call #t~ret51 := isHighWaterLevel(); {9434#true} is VALID [2020-07-17 21:32:24,523 INFO L280 TraceCheckUtils]: 3: Hoare triple {9434#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {9434#true} is VALID [2020-07-17 21:32:24,523 INFO L263 TraceCheckUtils]: 4: Hoare triple {9434#true} call #t~ret69 := isHighWaterSensorDry(); {9434#true} is VALID [2020-07-17 21:32:24,523 INFO L280 TraceCheckUtils]: 5: Hoare triple {9434#true} havoc ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,524 INFO L280 TraceCheckUtils]: 6: Hoare triple {9434#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,524 INFO L280 TraceCheckUtils]: 7: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,524 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {9434#true} {9434#true} #457#return; {9434#true} is VALID [2020-07-17 21:32:24,524 INFO L280 TraceCheckUtils]: 9: Hoare triple {9434#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {9434#true} is VALID [2020-07-17 21:32:24,525 INFO L280 TraceCheckUtils]: 10: Hoare triple {9434#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} is VALID [2020-07-17 21:32:24,526 INFO L280 TraceCheckUtils]: 11: Hoare triple {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:24,527 INFO L280 TraceCheckUtils]: 12: Hoare triple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} assume true; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:24,528 INFO L275 TraceCheckUtils]: 13: Hoare quadruple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} {9434#true} #441#return; {9546#(= 0 |processEnvironment_#t~ret51|)} is VALID [2020-07-17 21:32:24,529 INFO L280 TraceCheckUtils]: 14: Hoare triple {9546#(= 0 |processEnvironment_#t~ret51|)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {9547#(= 0 processEnvironment_~tmp~5)} is VALID [2020-07-17 21:32:24,529 INFO L280 TraceCheckUtils]: 15: Hoare triple {9547#(= 0 processEnvironment_~tmp~5)} assume 0 != ~tmp~5; {9435#false} is VALID [2020-07-17 21:32:24,530 INFO L263 TraceCheckUtils]: 16: Hoare triple {9435#false} call activatePump(); {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:24,530 INFO L280 TraceCheckUtils]: 17: Hoare triple {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {9434#true} is VALID [2020-07-17 21:32:24,530 INFO L280 TraceCheckUtils]: 18: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,530 INFO L275 TraceCheckUtils]: 19: Hoare quadruple {9434#true} {9435#false} #443#return; {9435#false} is VALID [2020-07-17 21:32:24,530 INFO L280 TraceCheckUtils]: 20: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:24,531 INFO L275 TraceCheckUtils]: 21: Hoare quadruple {9435#false} {9434#true} #461#return; {9435#false} is VALID [2020-07-17 21:32:24,532 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,535 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,538 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {9434#true} is VALID [2020-07-17 21:32:24,538 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,538 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {9434#true} {9434#true} #395#return; {9434#true} is VALID [2020-07-17 21:32:24,539 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} havoc ~tmp~7;havoc ~tmp___0~2; {9434#true} is VALID [2020-07-17 21:32:24,539 INFO L263 TraceCheckUtils]: 1: Hoare triple {9434#true} call #t~ret70 := getWaterLevel(); {9434#true} is VALID [2020-07-17 21:32:24,539 INFO L280 TraceCheckUtils]: 2: Hoare triple {9434#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {9434#true} is VALID [2020-07-17 21:32:24,539 INFO L280 TraceCheckUtils]: 3: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,539 INFO L275 TraceCheckUtils]: 4: Hoare quadruple {9434#true} {9434#true} #395#return; {9434#true} is VALID [2020-07-17 21:32:24,540 INFO L280 TraceCheckUtils]: 5: Hoare triple {9434#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {9434#true} is VALID [2020-07-17 21:32:24,540 INFO L280 TraceCheckUtils]: 6: Hoare triple {9434#true} assume !(0 == ~tmp~7); {9434#true} is VALID [2020-07-17 21:32:24,540 INFO L280 TraceCheckUtils]: 7: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,540 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {9434#true} {9435#false} #463#return; {9435#false} is VALID [2020-07-17 21:32:24,541 INFO L280 TraceCheckUtils]: 0: Hoare triple {9502#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} assume !(0 != ~pumpRunning~0); {9434#true} is VALID [2020-07-17 21:32:24,541 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume 0 != ~systemActive~0; {9434#true} is VALID [2020-07-17 21:32:24,542 INFO L263 TraceCheckUtils]: 2: Hoare triple {9434#true} call processEnvironment(); {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:24,542 INFO L280 TraceCheckUtils]: 3: Hoare triple {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {9434#true} is VALID [2020-07-17 21:32:24,542 INFO L280 TraceCheckUtils]: 4: Hoare triple {9434#true} assume 0 == ~pumpRunning~0; {9434#true} is VALID [2020-07-17 21:32:24,542 INFO L263 TraceCheckUtils]: 5: Hoare triple {9434#true} call #t~ret51 := isHighWaterLevel(); {9434#true} is VALID [2020-07-17 21:32:24,542 INFO L280 TraceCheckUtils]: 6: Hoare triple {9434#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {9434#true} is VALID [2020-07-17 21:32:24,543 INFO L263 TraceCheckUtils]: 7: Hoare triple {9434#true} call #t~ret69 := isHighWaterSensorDry(); {9434#true} is VALID [2020-07-17 21:32:24,543 INFO L280 TraceCheckUtils]: 8: Hoare triple {9434#true} havoc ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,543 INFO L280 TraceCheckUtils]: 9: Hoare triple {9434#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,543 INFO L280 TraceCheckUtils]: 10: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,543 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {9434#true} {9434#true} #457#return; {9434#true} is VALID [2020-07-17 21:32:24,544 INFO L280 TraceCheckUtils]: 12: Hoare triple {9434#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {9434#true} is VALID [2020-07-17 21:32:24,544 INFO L280 TraceCheckUtils]: 13: Hoare triple {9434#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} is VALID [2020-07-17 21:32:24,545 INFO L280 TraceCheckUtils]: 14: Hoare triple {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:24,546 INFO L280 TraceCheckUtils]: 15: Hoare triple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} assume true; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:24,547 INFO L275 TraceCheckUtils]: 16: Hoare quadruple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} {9434#true} #441#return; {9546#(= 0 |processEnvironment_#t~ret51|)} is VALID [2020-07-17 21:32:24,548 INFO L280 TraceCheckUtils]: 17: Hoare triple {9546#(= 0 |processEnvironment_#t~ret51|)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {9547#(= 0 processEnvironment_~tmp~5)} is VALID [2020-07-17 21:32:24,548 INFO L280 TraceCheckUtils]: 18: Hoare triple {9547#(= 0 processEnvironment_~tmp~5)} assume 0 != ~tmp~5; {9435#false} is VALID [2020-07-17 21:32:24,549 INFO L263 TraceCheckUtils]: 19: Hoare triple {9435#false} call activatePump(); {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:24,549 INFO L280 TraceCheckUtils]: 20: Hoare triple {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {9434#true} is VALID [2020-07-17 21:32:24,549 INFO L280 TraceCheckUtils]: 21: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,549 INFO L275 TraceCheckUtils]: 22: Hoare quadruple {9434#true} {9435#false} #443#return; {9435#false} is VALID [2020-07-17 21:32:24,549 INFO L280 TraceCheckUtils]: 23: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:24,550 INFO L275 TraceCheckUtils]: 24: Hoare quadruple {9435#false} {9434#true} #461#return; {9435#false} is VALID [2020-07-17 21:32:24,550 INFO L263 TraceCheckUtils]: 25: Hoare triple {9435#false} call __utac_acc__Specification4_spec__1(); {9434#true} is VALID [2020-07-17 21:32:24,550 INFO L280 TraceCheckUtils]: 26: Hoare triple {9434#true} havoc ~tmp~7;havoc ~tmp___0~2; {9434#true} is VALID [2020-07-17 21:32:24,550 INFO L263 TraceCheckUtils]: 27: Hoare triple {9434#true} call #t~ret70 := getWaterLevel(); {9434#true} is VALID [2020-07-17 21:32:24,551 INFO L280 TraceCheckUtils]: 28: Hoare triple {9434#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {9434#true} is VALID [2020-07-17 21:32:24,551 INFO L280 TraceCheckUtils]: 29: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,551 INFO L275 TraceCheckUtils]: 30: Hoare quadruple {9434#true} {9434#true} #395#return; {9434#true} is VALID [2020-07-17 21:32:24,551 INFO L280 TraceCheckUtils]: 31: Hoare triple {9434#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {9434#true} is VALID [2020-07-17 21:32:24,552 INFO L280 TraceCheckUtils]: 32: Hoare triple {9434#true} assume !(0 == ~tmp~7); {9434#true} is VALID [2020-07-17 21:32:24,552 INFO L280 TraceCheckUtils]: 33: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,552 INFO L275 TraceCheckUtils]: 34: Hoare quadruple {9434#true} {9435#false} #463#return; {9435#false} is VALID [2020-07-17 21:32:24,552 INFO L280 TraceCheckUtils]: 35: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:24,552 INFO L275 TraceCheckUtils]: 36: Hoare quadruple {9435#false} {9434#true} #453#return; {9435#false} is VALID [2020-07-17 21:32:24,569 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,572 INFO L280 TraceCheckUtils]: 0: Hoare triple {9560#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {9434#true} is VALID [2020-07-17 21:32:24,572 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,573 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {9434#true} {9435#false} #459#return; {9435#false} is VALID [2020-07-17 21:32:24,574 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,576 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,581 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,581 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {9434#true} {9434#true} #447#return; {9434#true} is VALID [2020-07-17 21:32:24,581 INFO L280 TraceCheckUtils]: 0: Hoare triple {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {9434#true} is VALID [2020-07-17 21:32:24,582 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume !(0 == ~pumpRunning~0); {9434#true} is VALID [2020-07-17 21:32:24,582 INFO L263 TraceCheckUtils]: 2: Hoare triple {9434#true} call processEnvironment__wrappee__base(); {9434#true} is VALID [2020-07-17 21:32:24,582 INFO L280 TraceCheckUtils]: 3: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,582 INFO L275 TraceCheckUtils]: 4: Hoare quadruple {9434#true} {9434#true} #447#return; {9434#true} is VALID [2020-07-17 21:32:24,582 INFO L280 TraceCheckUtils]: 5: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,583 INFO L275 TraceCheckUtils]: 6: Hoare quadruple {9434#true} {9435#false} #461#return; {9435#false} is VALID [2020-07-17 21:32:24,583 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,587 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {9434#true} is VALID [2020-07-17 21:32:24,587 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,588 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {9434#true} {9435#false} #395#return; {9435#false} is VALID [2020-07-17 21:32:24,588 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,593 INFO L280 TraceCheckUtils]: 0: Hoare triple {9434#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {9434#true} is VALID [2020-07-17 21:32:24,593 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,593 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {9434#true} {9435#false} #397#return; {9435#false} is VALID [2020-07-17 21:32:24,598 INFO L263 TraceCheckUtils]: 0: Hoare triple {9434#true} call ULTIMATE.init(); {9501#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} is VALID [2020-07-17 21:32:24,598 INFO L280 TraceCheckUtils]: 1: Hoare triple {9501#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {9434#true} is VALID [2020-07-17 21:32:24,598 INFO L280 TraceCheckUtils]: 2: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,599 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {9434#true} {9434#true} #479#return; {9434#true} is VALID [2020-07-17 21:32:24,599 INFO L263 TraceCheckUtils]: 4: Hoare triple {9434#true} call #t~ret72 := main(); {9434#true} is VALID [2020-07-17 21:32:24,599 INFO L280 TraceCheckUtils]: 5: Hoare triple {9434#true} havoc ~retValue_acc~3;havoc ~tmp~3; {9434#true} is VALID [2020-07-17 21:32:24,599 INFO L263 TraceCheckUtils]: 6: Hoare triple {9434#true} call select_helpers(); {9434#true} is VALID [2020-07-17 21:32:24,599 INFO L280 TraceCheckUtils]: 7: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,600 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {9434#true} {9434#true} #401#return; {9434#true} is VALID [2020-07-17 21:32:24,600 INFO L263 TraceCheckUtils]: 9: Hoare triple {9434#true} call select_features(); {9434#true} is VALID [2020-07-17 21:32:24,600 INFO L280 TraceCheckUtils]: 10: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,600 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {9434#true} {9434#true} #403#return; {9434#true} is VALID [2020-07-17 21:32:24,600 INFO L263 TraceCheckUtils]: 12: Hoare triple {9434#true} call #t~ret35 := valid_product(); {9434#true} is VALID [2020-07-17 21:32:24,601 INFO L280 TraceCheckUtils]: 13: Hoare triple {9434#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {9434#true} is VALID [2020-07-17 21:32:24,601 INFO L280 TraceCheckUtils]: 14: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,601 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {9434#true} {9434#true} #405#return; {9434#true} is VALID [2020-07-17 21:32:24,601 INFO L280 TraceCheckUtils]: 16: Hoare triple {9434#true} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {9434#true} is VALID [2020-07-17 21:32:24,601 INFO L280 TraceCheckUtils]: 17: Hoare triple {9434#true} assume 0 != ~tmp~3; {9434#true} is VALID [2020-07-17 21:32:24,601 INFO L263 TraceCheckUtils]: 18: Hoare triple {9434#true} call setup(); {9434#true} is VALID [2020-07-17 21:32:24,602 INFO L280 TraceCheckUtils]: 19: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,602 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {9434#true} {9434#true} #407#return; {9434#true} is VALID [2020-07-17 21:32:24,602 INFO L263 TraceCheckUtils]: 21: Hoare triple {9434#true} call runTest(); {9434#true} is VALID [2020-07-17 21:32:24,602 INFO L263 TraceCheckUtils]: 22: Hoare triple {9434#true} call test(); {9434#true} is VALID [2020-07-17 21:32:24,602 INFO L280 TraceCheckUtils]: 23: Hoare triple {9434#true} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {9434#true} is VALID [2020-07-17 21:32:24,603 INFO L280 TraceCheckUtils]: 24: Hoare triple {9434#true} assume !false; {9434#true} is VALID [2020-07-17 21:32:24,603 INFO L280 TraceCheckUtils]: 25: Hoare triple {9434#true} assume ~splverifierCounter~0 < 4; {9434#true} is VALID [2020-07-17 21:32:24,603 INFO L280 TraceCheckUtils]: 26: Hoare triple {9434#true} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {9434#true} is VALID [2020-07-17 21:32:24,603 INFO L280 TraceCheckUtils]: 27: Hoare triple {9434#true} assume !(0 != ~tmp~4); {9434#true} is VALID [2020-07-17 21:32:24,603 INFO L280 TraceCheckUtils]: 28: Hoare triple {9434#true} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {9434#true} is VALID [2020-07-17 21:32:24,603 INFO L280 TraceCheckUtils]: 29: Hoare triple {9434#true} assume !(0 != ~tmp___0~0); {9434#true} is VALID [2020-07-17 21:32:24,604 INFO L280 TraceCheckUtils]: 30: Hoare triple {9434#true} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {9434#true} is VALID [2020-07-17 21:32:24,604 INFO L280 TraceCheckUtils]: 31: Hoare triple {9434#true} assume 0 != ~tmp___2~0; {9434#true} is VALID [2020-07-17 21:32:24,605 INFO L263 TraceCheckUtils]: 32: Hoare triple {9434#true} call timeShift(); {9502#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} is VALID [2020-07-17 21:32:24,605 INFO L280 TraceCheckUtils]: 33: Hoare triple {9502#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} assume !(0 != ~pumpRunning~0); {9434#true} is VALID [2020-07-17 21:32:24,605 INFO L280 TraceCheckUtils]: 34: Hoare triple {9434#true} assume 0 != ~systemActive~0; {9434#true} is VALID [2020-07-17 21:32:24,606 INFO L263 TraceCheckUtils]: 35: Hoare triple {9434#true} call processEnvironment(); {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:24,606 INFO L280 TraceCheckUtils]: 36: Hoare triple {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {9434#true} is VALID [2020-07-17 21:32:24,606 INFO L280 TraceCheckUtils]: 37: Hoare triple {9434#true} assume 0 == ~pumpRunning~0; {9434#true} is VALID [2020-07-17 21:32:24,606 INFO L263 TraceCheckUtils]: 38: Hoare triple {9434#true} call #t~ret51 := isHighWaterLevel(); {9434#true} is VALID [2020-07-17 21:32:24,607 INFO L280 TraceCheckUtils]: 39: Hoare triple {9434#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {9434#true} is VALID [2020-07-17 21:32:24,607 INFO L263 TraceCheckUtils]: 40: Hoare triple {9434#true} call #t~ret69 := isHighWaterSensorDry(); {9434#true} is VALID [2020-07-17 21:32:24,607 INFO L280 TraceCheckUtils]: 41: Hoare triple {9434#true} havoc ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,607 INFO L280 TraceCheckUtils]: 42: Hoare triple {9434#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:24,607 INFO L280 TraceCheckUtils]: 43: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,607 INFO L275 TraceCheckUtils]: 44: Hoare quadruple {9434#true} {9434#true} #457#return; {9434#true} is VALID [2020-07-17 21:32:24,608 INFO L280 TraceCheckUtils]: 45: Hoare triple {9434#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {9434#true} is VALID [2020-07-17 21:32:24,608 INFO L280 TraceCheckUtils]: 46: Hoare triple {9434#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} is VALID [2020-07-17 21:32:24,609 INFO L280 TraceCheckUtils]: 47: Hoare triple {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:24,610 INFO L280 TraceCheckUtils]: 48: Hoare triple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} assume true; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:24,611 INFO L275 TraceCheckUtils]: 49: Hoare quadruple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} {9434#true} #441#return; {9546#(= 0 |processEnvironment_#t~ret51|)} is VALID [2020-07-17 21:32:24,612 INFO L280 TraceCheckUtils]: 50: Hoare triple {9546#(= 0 |processEnvironment_#t~ret51|)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {9547#(= 0 processEnvironment_~tmp~5)} is VALID [2020-07-17 21:32:24,612 INFO L280 TraceCheckUtils]: 51: Hoare triple {9547#(= 0 processEnvironment_~tmp~5)} assume 0 != ~tmp~5; {9435#false} is VALID [2020-07-17 21:32:24,612 INFO L263 TraceCheckUtils]: 52: Hoare triple {9435#false} call activatePump(); {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:24,613 INFO L280 TraceCheckUtils]: 53: Hoare triple {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {9434#true} is VALID [2020-07-17 21:32:24,613 INFO L280 TraceCheckUtils]: 54: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,613 INFO L275 TraceCheckUtils]: 55: Hoare quadruple {9434#true} {9435#false} #443#return; {9435#false} is VALID [2020-07-17 21:32:24,613 INFO L280 TraceCheckUtils]: 56: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:24,613 INFO L275 TraceCheckUtils]: 57: Hoare quadruple {9435#false} {9434#true} #461#return; {9435#false} is VALID [2020-07-17 21:32:24,614 INFO L263 TraceCheckUtils]: 58: Hoare triple {9435#false} call __utac_acc__Specification4_spec__1(); {9434#true} is VALID [2020-07-17 21:32:24,614 INFO L280 TraceCheckUtils]: 59: Hoare triple {9434#true} havoc ~tmp~7;havoc ~tmp___0~2; {9434#true} is VALID [2020-07-17 21:32:24,614 INFO L263 TraceCheckUtils]: 60: Hoare triple {9434#true} call #t~ret70 := getWaterLevel(); {9434#true} is VALID [2020-07-17 21:32:24,614 INFO L280 TraceCheckUtils]: 61: Hoare triple {9434#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {9434#true} is VALID [2020-07-17 21:32:24,615 INFO L280 TraceCheckUtils]: 62: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,615 INFO L275 TraceCheckUtils]: 63: Hoare quadruple {9434#true} {9434#true} #395#return; {9434#true} is VALID [2020-07-17 21:32:24,615 INFO L280 TraceCheckUtils]: 64: Hoare triple {9434#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {9434#true} is VALID [2020-07-17 21:32:24,615 INFO L280 TraceCheckUtils]: 65: Hoare triple {9434#true} assume !(0 == ~tmp~7); {9434#true} is VALID [2020-07-17 21:32:24,615 INFO L280 TraceCheckUtils]: 66: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,616 INFO L275 TraceCheckUtils]: 67: Hoare quadruple {9434#true} {9435#false} #463#return; {9435#false} is VALID [2020-07-17 21:32:24,616 INFO L280 TraceCheckUtils]: 68: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:24,616 INFO L275 TraceCheckUtils]: 69: Hoare quadruple {9435#false} {9434#true} #453#return; {9435#false} is VALID [2020-07-17 21:32:24,616 INFO L280 TraceCheckUtils]: 70: Hoare triple {9435#false} assume !false; {9435#false} is VALID [2020-07-17 21:32:24,616 INFO L280 TraceCheckUtils]: 71: Hoare triple {9435#false} assume ~splverifierCounter~0 < 4; {9435#false} is VALID [2020-07-17 21:32:24,616 INFO L280 TraceCheckUtils]: 72: Hoare triple {9435#false} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {9435#false} is VALID [2020-07-17 21:32:24,617 INFO L280 TraceCheckUtils]: 73: Hoare triple {9435#false} assume !(0 != ~tmp~4); {9435#false} is VALID [2020-07-17 21:32:24,617 INFO L280 TraceCheckUtils]: 74: Hoare triple {9435#false} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {9435#false} is VALID [2020-07-17 21:32:24,617 INFO L280 TraceCheckUtils]: 75: Hoare triple {9435#false} assume !(0 != ~tmp___0~0); {9435#false} is VALID [2020-07-17 21:32:24,617 INFO L280 TraceCheckUtils]: 76: Hoare triple {9435#false} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {9435#false} is VALID [2020-07-17 21:32:24,617 INFO L280 TraceCheckUtils]: 77: Hoare triple {9435#false} assume 0 != ~tmp___2~0; {9435#false} is VALID [2020-07-17 21:32:24,617 INFO L263 TraceCheckUtils]: 78: Hoare triple {9435#false} call timeShift(); {9435#false} is VALID [2020-07-17 21:32:24,618 INFO L280 TraceCheckUtils]: 79: Hoare triple {9435#false} assume 0 != ~pumpRunning~0; {9435#false} is VALID [2020-07-17 21:32:24,618 INFO L263 TraceCheckUtils]: 80: Hoare triple {9435#false} call lowerWaterLevel(); {9560#(= ~waterLevel~0 |old(~waterLevel~0)|)} is VALID [2020-07-17 21:32:24,618 INFO L280 TraceCheckUtils]: 81: Hoare triple {9560#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {9434#true} is VALID [2020-07-17 21:32:24,618 INFO L280 TraceCheckUtils]: 82: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,618 INFO L275 TraceCheckUtils]: 83: Hoare quadruple {9434#true} {9435#false} #459#return; {9435#false} is VALID [2020-07-17 21:32:24,619 INFO L280 TraceCheckUtils]: 84: Hoare triple {9435#false} assume 0 != ~systemActive~0; {9435#false} is VALID [2020-07-17 21:32:24,619 INFO L263 TraceCheckUtils]: 85: Hoare triple {9435#false} call processEnvironment(); {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:24,619 INFO L280 TraceCheckUtils]: 86: Hoare triple {9534#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {9434#true} is VALID [2020-07-17 21:32:24,619 INFO L280 TraceCheckUtils]: 87: Hoare triple {9434#true} assume !(0 == ~pumpRunning~0); {9434#true} is VALID [2020-07-17 21:32:24,619 INFO L263 TraceCheckUtils]: 88: Hoare triple {9434#true} call processEnvironment__wrappee__base(); {9434#true} is VALID [2020-07-17 21:32:24,620 INFO L280 TraceCheckUtils]: 89: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,620 INFO L275 TraceCheckUtils]: 90: Hoare quadruple {9434#true} {9434#true} #447#return; {9434#true} is VALID [2020-07-17 21:32:24,620 INFO L280 TraceCheckUtils]: 91: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,620 INFO L275 TraceCheckUtils]: 92: Hoare quadruple {9434#true} {9435#false} #461#return; {9435#false} is VALID [2020-07-17 21:32:24,620 INFO L263 TraceCheckUtils]: 93: Hoare triple {9435#false} call __utac_acc__Specification4_spec__1(); {9435#false} is VALID [2020-07-17 21:32:24,621 INFO L280 TraceCheckUtils]: 94: Hoare triple {9435#false} havoc ~tmp~7;havoc ~tmp___0~2; {9435#false} is VALID [2020-07-17 21:32:24,621 INFO L263 TraceCheckUtils]: 95: Hoare triple {9435#false} call #t~ret70 := getWaterLevel(); {9434#true} is VALID [2020-07-17 21:32:24,621 INFO L280 TraceCheckUtils]: 96: Hoare triple {9434#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {9434#true} is VALID [2020-07-17 21:32:24,621 INFO L280 TraceCheckUtils]: 97: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,621 INFO L275 TraceCheckUtils]: 98: Hoare quadruple {9434#true} {9435#false} #395#return; {9435#false} is VALID [2020-07-17 21:32:24,622 INFO L280 TraceCheckUtils]: 99: Hoare triple {9435#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {9435#false} is VALID [2020-07-17 21:32:24,622 INFO L280 TraceCheckUtils]: 100: Hoare triple {9435#false} assume 0 == ~tmp~7; {9435#false} is VALID [2020-07-17 21:32:24,622 INFO L263 TraceCheckUtils]: 101: Hoare triple {9435#false} call #t~ret71 := isPumpRunning(); {9434#true} is VALID [2020-07-17 21:32:24,622 INFO L280 TraceCheckUtils]: 102: Hoare triple {9434#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {9434#true} is VALID [2020-07-17 21:32:24,622 INFO L280 TraceCheckUtils]: 103: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:24,622 INFO L275 TraceCheckUtils]: 104: Hoare quadruple {9434#true} {9435#false} #397#return; {9435#false} is VALID [2020-07-17 21:32:24,623 INFO L280 TraceCheckUtils]: 105: Hoare triple {9435#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {9435#false} is VALID [2020-07-17 21:32:24,623 INFO L280 TraceCheckUtils]: 106: Hoare triple {9435#false} assume 0 != ~tmp___0~2; {9435#false} is VALID [2020-07-17 21:32:24,623 INFO L263 TraceCheckUtils]: 107: Hoare triple {9435#false} call __automaton_fail(); {9435#false} is VALID [2020-07-17 21:32:24,623 INFO L280 TraceCheckUtils]: 108: Hoare triple {9435#false} assume !false; {9435#false} is VALID [2020-07-17 21:32:24,637 INFO L134 CoverageAnalysis]: Checked inductivity of 24 backedges. 16 proven. 2 refuted. 0 times theorem prover too weak. 6 trivial. 0 not checked. [2020-07-17 21:32:24,638 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [569057903] [2020-07-17 21:32:24,638 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [799037563] [2020-07-17 21:32:24,638 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 Starting monitored process 3 with z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) Waiting until toolchain timeout for monitored process 3 with z3 -smt2 -in SMTLIB2_COMPLIANT=true [2020-07-17 21:32:24,907 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,911 INFO L264 TraceCheckSpWp]: Trace formula consists of 775 conjuncts, 11 conjunts are in the unsatisfiable core [2020-07-17 21:32:24,962 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:24,965 INFO L287 TraceCheckSpWp]: Computing forward predicates... [2020-07-17 21:32:25,118 INFO L263 TraceCheckUtils]: 0: Hoare triple {9434#true} call ULTIMATE.init(); {9434#true} is VALID [2020-07-17 21:32:25,119 INFO L280 TraceCheckUtils]: 1: Hoare triple {9434#true} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {9434#true} is VALID [2020-07-17 21:32:25,119 INFO L280 TraceCheckUtils]: 2: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:25,119 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {9434#true} {9434#true} #479#return; {9434#true} is VALID [2020-07-17 21:32:25,120 INFO L263 TraceCheckUtils]: 4: Hoare triple {9434#true} call #t~ret72 := main(); {9434#true} is VALID [2020-07-17 21:32:25,120 INFO L280 TraceCheckUtils]: 5: Hoare triple {9434#true} havoc ~retValue_acc~3;havoc ~tmp~3; {9434#true} is VALID [2020-07-17 21:32:25,120 INFO L263 TraceCheckUtils]: 6: Hoare triple {9434#true} call select_helpers(); {9434#true} is VALID [2020-07-17 21:32:25,120 INFO L280 TraceCheckUtils]: 7: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:25,121 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {9434#true} {9434#true} #401#return; {9434#true} is VALID [2020-07-17 21:32:25,121 INFO L263 TraceCheckUtils]: 9: Hoare triple {9434#true} call select_features(); {9434#true} is VALID [2020-07-17 21:32:25,121 INFO L280 TraceCheckUtils]: 10: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:25,122 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {9434#true} {9434#true} #403#return; {9434#true} is VALID [2020-07-17 21:32:25,122 INFO L263 TraceCheckUtils]: 12: Hoare triple {9434#true} call #t~ret35 := valid_product(); {9434#true} is VALID [2020-07-17 21:32:25,122 INFO L280 TraceCheckUtils]: 13: Hoare triple {9434#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {9434#true} is VALID [2020-07-17 21:32:25,122 INFO L280 TraceCheckUtils]: 14: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:25,123 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {9434#true} {9434#true} #405#return; {9434#true} is VALID [2020-07-17 21:32:25,123 INFO L280 TraceCheckUtils]: 16: Hoare triple {9434#true} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {9434#true} is VALID [2020-07-17 21:32:25,123 INFO L280 TraceCheckUtils]: 17: Hoare triple {9434#true} assume 0 != ~tmp~3; {9434#true} is VALID [2020-07-17 21:32:25,124 INFO L263 TraceCheckUtils]: 18: Hoare triple {9434#true} call setup(); {9434#true} is VALID [2020-07-17 21:32:25,124 INFO L280 TraceCheckUtils]: 19: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:25,124 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {9434#true} {9434#true} #407#return; {9434#true} is VALID [2020-07-17 21:32:25,124 INFO L263 TraceCheckUtils]: 21: Hoare triple {9434#true} call runTest(); {9434#true} is VALID [2020-07-17 21:32:25,124 INFO L263 TraceCheckUtils]: 22: Hoare triple {9434#true} call test(); {9434#true} is VALID [2020-07-17 21:32:25,125 INFO L280 TraceCheckUtils]: 23: Hoare triple {9434#true} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {9434#true} is VALID [2020-07-17 21:32:25,125 INFO L280 TraceCheckUtils]: 24: Hoare triple {9434#true} assume !false; {9434#true} is VALID [2020-07-17 21:32:25,125 INFO L280 TraceCheckUtils]: 25: Hoare triple {9434#true} assume ~splverifierCounter~0 < 4; {9434#true} is VALID [2020-07-17 21:32:25,125 INFO L280 TraceCheckUtils]: 26: Hoare triple {9434#true} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {9434#true} is VALID [2020-07-17 21:32:25,125 INFO L280 TraceCheckUtils]: 27: Hoare triple {9434#true} assume !(0 != ~tmp~4); {9434#true} is VALID [2020-07-17 21:32:25,125 INFO L280 TraceCheckUtils]: 28: Hoare triple {9434#true} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {9434#true} is VALID [2020-07-17 21:32:25,126 INFO L280 TraceCheckUtils]: 29: Hoare triple {9434#true} assume !(0 != ~tmp___0~0); {9434#true} is VALID [2020-07-17 21:32:25,126 INFO L280 TraceCheckUtils]: 30: Hoare triple {9434#true} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {9434#true} is VALID [2020-07-17 21:32:25,126 INFO L280 TraceCheckUtils]: 31: Hoare triple {9434#true} assume 0 != ~tmp___2~0; {9434#true} is VALID [2020-07-17 21:32:25,126 INFO L263 TraceCheckUtils]: 32: Hoare triple {9434#true} call timeShift(); {9434#true} is VALID [2020-07-17 21:32:25,126 INFO L280 TraceCheckUtils]: 33: Hoare triple {9434#true} assume !(0 != ~pumpRunning~0); {9434#true} is VALID [2020-07-17 21:32:25,127 INFO L280 TraceCheckUtils]: 34: Hoare triple {9434#true} assume 0 != ~systemActive~0; {9434#true} is VALID [2020-07-17 21:32:25,127 INFO L263 TraceCheckUtils]: 35: Hoare triple {9434#true} call processEnvironment(); {9434#true} is VALID [2020-07-17 21:32:25,127 INFO L280 TraceCheckUtils]: 36: Hoare triple {9434#true} havoc ~tmp~5; {9434#true} is VALID [2020-07-17 21:32:25,127 INFO L280 TraceCheckUtils]: 37: Hoare triple {9434#true} assume 0 == ~pumpRunning~0; {9434#true} is VALID [2020-07-17 21:32:25,127 INFO L263 TraceCheckUtils]: 38: Hoare triple {9434#true} call #t~ret51 := isHighWaterLevel(); {9434#true} is VALID [2020-07-17 21:32:25,127 INFO L280 TraceCheckUtils]: 39: Hoare triple {9434#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {9434#true} is VALID [2020-07-17 21:32:25,128 INFO L263 TraceCheckUtils]: 40: Hoare triple {9434#true} call #t~ret69 := isHighWaterSensorDry(); {9434#true} is VALID [2020-07-17 21:32:25,128 INFO L280 TraceCheckUtils]: 41: Hoare triple {9434#true} havoc ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:25,128 INFO L280 TraceCheckUtils]: 42: Hoare triple {9434#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {9434#true} is VALID [2020-07-17 21:32:25,128 INFO L280 TraceCheckUtils]: 43: Hoare triple {9434#true} assume true; {9434#true} is VALID [2020-07-17 21:32:25,128 INFO L275 TraceCheckUtils]: 44: Hoare quadruple {9434#true} {9434#true} #457#return; {9434#true} is VALID [2020-07-17 21:32:25,129 INFO L280 TraceCheckUtils]: 45: Hoare triple {9434#true} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {9434#true} is VALID [2020-07-17 21:32:25,130 INFO L280 TraceCheckUtils]: 46: Hoare triple {9434#true} assume 0 != ~tmp~6;~tmp___0~1 := 0; {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} is VALID [2020-07-17 21:32:25,130 INFO L280 TraceCheckUtils]: 47: Hoare triple {9555#(and (<= 0 isHighWaterLevel_~tmp___0~1) (<= isHighWaterLevel_~tmp___0~1 0))} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:25,131 INFO L280 TraceCheckUtils]: 48: Hoare triple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} assume true; {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} is VALID [2020-07-17 21:32:25,132 INFO L275 TraceCheckUtils]: 49: Hoare quadruple {9556#(and (<= |isHighWaterLevel_#res| 0) (<= 0 |isHighWaterLevel_#res|))} {9434#true} #441#return; {9546#(= 0 |processEnvironment_#t~ret51|)} is VALID [2020-07-17 21:32:25,133 INFO L280 TraceCheckUtils]: 50: Hoare triple {9546#(= 0 |processEnvironment_#t~ret51|)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {9547#(= 0 processEnvironment_~tmp~5)} is VALID [2020-07-17 21:32:25,133 INFO L280 TraceCheckUtils]: 51: Hoare triple {9547#(= 0 processEnvironment_~tmp~5)} assume 0 != ~tmp~5; {9435#false} is VALID [2020-07-17 21:32:25,133 INFO L263 TraceCheckUtils]: 52: Hoare triple {9435#false} call activatePump(); {9435#false} is VALID [2020-07-17 21:32:25,134 INFO L280 TraceCheckUtils]: 53: Hoare triple {9435#false} ~pumpRunning~0 := 1; {9435#false} is VALID [2020-07-17 21:32:25,134 INFO L280 TraceCheckUtils]: 54: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,134 INFO L275 TraceCheckUtils]: 55: Hoare quadruple {9435#false} {9435#false} #443#return; {9435#false} is VALID [2020-07-17 21:32:25,134 INFO L280 TraceCheckUtils]: 56: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,134 INFO L275 TraceCheckUtils]: 57: Hoare quadruple {9435#false} {9434#true} #461#return; {9435#false} is VALID [2020-07-17 21:32:25,135 INFO L263 TraceCheckUtils]: 58: Hoare triple {9435#false} call __utac_acc__Specification4_spec__1(); {9435#false} is VALID [2020-07-17 21:32:25,135 INFO L280 TraceCheckUtils]: 59: Hoare triple {9435#false} havoc ~tmp~7;havoc ~tmp___0~2; {9435#false} is VALID [2020-07-17 21:32:25,135 INFO L263 TraceCheckUtils]: 60: Hoare triple {9435#false} call #t~ret70 := getWaterLevel(); {9435#false} is VALID [2020-07-17 21:32:25,135 INFO L280 TraceCheckUtils]: 61: Hoare triple {9435#false} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {9435#false} is VALID [2020-07-17 21:32:25,135 INFO L280 TraceCheckUtils]: 62: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,136 INFO L275 TraceCheckUtils]: 63: Hoare quadruple {9435#false} {9435#false} #395#return; {9435#false} is VALID [2020-07-17 21:32:25,136 INFO L280 TraceCheckUtils]: 64: Hoare triple {9435#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {9435#false} is VALID [2020-07-17 21:32:25,136 INFO L280 TraceCheckUtils]: 65: Hoare triple {9435#false} assume !(0 == ~tmp~7); {9435#false} is VALID [2020-07-17 21:32:25,136 INFO L280 TraceCheckUtils]: 66: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,136 INFO L275 TraceCheckUtils]: 67: Hoare quadruple {9435#false} {9435#false} #463#return; {9435#false} is VALID [2020-07-17 21:32:25,137 INFO L280 TraceCheckUtils]: 68: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,137 INFO L275 TraceCheckUtils]: 69: Hoare quadruple {9435#false} {9434#true} #453#return; {9435#false} is VALID [2020-07-17 21:32:25,137 INFO L280 TraceCheckUtils]: 70: Hoare triple {9435#false} assume !false; {9435#false} is VALID [2020-07-17 21:32:25,137 INFO L280 TraceCheckUtils]: 71: Hoare triple {9435#false} assume ~splverifierCounter~0 < 4; {9435#false} is VALID [2020-07-17 21:32:25,137 INFO L280 TraceCheckUtils]: 72: Hoare triple {9435#false} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {9435#false} is VALID [2020-07-17 21:32:25,138 INFO L280 TraceCheckUtils]: 73: Hoare triple {9435#false} assume !(0 != ~tmp~4); {9435#false} is VALID [2020-07-17 21:32:25,138 INFO L280 TraceCheckUtils]: 74: Hoare triple {9435#false} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {9435#false} is VALID [2020-07-17 21:32:25,138 INFO L280 TraceCheckUtils]: 75: Hoare triple {9435#false} assume !(0 != ~tmp___0~0); {9435#false} is VALID [2020-07-17 21:32:25,138 INFO L280 TraceCheckUtils]: 76: Hoare triple {9435#false} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {9435#false} is VALID [2020-07-17 21:32:25,138 INFO L280 TraceCheckUtils]: 77: Hoare triple {9435#false} assume 0 != ~tmp___2~0; {9435#false} is VALID [2020-07-17 21:32:25,139 INFO L263 TraceCheckUtils]: 78: Hoare triple {9435#false} call timeShift(); {9435#false} is VALID [2020-07-17 21:32:25,139 INFO L280 TraceCheckUtils]: 79: Hoare triple {9435#false} assume 0 != ~pumpRunning~0; {9435#false} is VALID [2020-07-17 21:32:25,139 INFO L263 TraceCheckUtils]: 80: Hoare triple {9435#false} call lowerWaterLevel(); {9435#false} is VALID [2020-07-17 21:32:25,139 INFO L280 TraceCheckUtils]: 81: Hoare triple {9435#false} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {9435#false} is VALID [2020-07-17 21:32:25,139 INFO L280 TraceCheckUtils]: 82: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,139 INFO L275 TraceCheckUtils]: 83: Hoare quadruple {9435#false} {9435#false} #459#return; {9435#false} is VALID [2020-07-17 21:32:25,140 INFO L280 TraceCheckUtils]: 84: Hoare triple {9435#false} assume 0 != ~systemActive~0; {9435#false} is VALID [2020-07-17 21:32:25,140 INFO L263 TraceCheckUtils]: 85: Hoare triple {9435#false} call processEnvironment(); {9435#false} is VALID [2020-07-17 21:32:25,140 INFO L280 TraceCheckUtils]: 86: Hoare triple {9435#false} havoc ~tmp~5; {9435#false} is VALID [2020-07-17 21:32:25,140 INFO L280 TraceCheckUtils]: 87: Hoare triple {9435#false} assume !(0 == ~pumpRunning~0); {9435#false} is VALID [2020-07-17 21:32:25,140 INFO L263 TraceCheckUtils]: 88: Hoare triple {9435#false} call processEnvironment__wrappee__base(); {9435#false} is VALID [2020-07-17 21:32:25,141 INFO L280 TraceCheckUtils]: 89: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,141 INFO L275 TraceCheckUtils]: 90: Hoare quadruple {9435#false} {9435#false} #447#return; {9435#false} is VALID [2020-07-17 21:32:25,141 INFO L280 TraceCheckUtils]: 91: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,141 INFO L275 TraceCheckUtils]: 92: Hoare quadruple {9435#false} {9435#false} #461#return; {9435#false} is VALID [2020-07-17 21:32:25,141 INFO L263 TraceCheckUtils]: 93: Hoare triple {9435#false} call __utac_acc__Specification4_spec__1(); {9435#false} is VALID [2020-07-17 21:32:25,142 INFO L280 TraceCheckUtils]: 94: Hoare triple {9435#false} havoc ~tmp~7;havoc ~tmp___0~2; {9435#false} is VALID [2020-07-17 21:32:25,142 INFO L263 TraceCheckUtils]: 95: Hoare triple {9435#false} call #t~ret70 := getWaterLevel(); {9435#false} is VALID [2020-07-17 21:32:25,142 INFO L280 TraceCheckUtils]: 96: Hoare triple {9435#false} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {9435#false} is VALID [2020-07-17 21:32:25,142 INFO L280 TraceCheckUtils]: 97: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,142 INFO L275 TraceCheckUtils]: 98: Hoare quadruple {9435#false} {9435#false} #395#return; {9435#false} is VALID [2020-07-17 21:32:25,143 INFO L280 TraceCheckUtils]: 99: Hoare triple {9435#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {9435#false} is VALID [2020-07-17 21:32:25,143 INFO L280 TraceCheckUtils]: 100: Hoare triple {9435#false} assume 0 == ~tmp~7; {9435#false} is VALID [2020-07-17 21:32:25,143 INFO L263 TraceCheckUtils]: 101: Hoare triple {9435#false} call #t~ret71 := isPumpRunning(); {9435#false} is VALID [2020-07-17 21:32:25,143 INFO L280 TraceCheckUtils]: 102: Hoare triple {9435#false} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {9435#false} is VALID [2020-07-17 21:32:25,143 INFO L280 TraceCheckUtils]: 103: Hoare triple {9435#false} assume true; {9435#false} is VALID [2020-07-17 21:32:25,144 INFO L275 TraceCheckUtils]: 104: Hoare quadruple {9435#false} {9435#false} #397#return; {9435#false} is VALID [2020-07-17 21:32:25,144 INFO L280 TraceCheckUtils]: 105: Hoare triple {9435#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {9435#false} is VALID [2020-07-17 21:32:25,144 INFO L280 TraceCheckUtils]: 106: Hoare triple {9435#false} assume 0 != ~tmp___0~2; {9435#false} is VALID [2020-07-17 21:32:25,144 INFO L263 TraceCheckUtils]: 107: Hoare triple {9435#false} call __automaton_fail(); {9435#false} is VALID [2020-07-17 21:32:25,144 INFO L280 TraceCheckUtils]: 108: Hoare triple {9435#false} assume !false; {9435#false} is VALID [2020-07-17 21:32:25,153 INFO L134 CoverageAnalysis]: Checked inductivity of 24 backedges. 14 proven. 0 refuted. 0 times theorem prover too weak. 10 trivial. 0 not checked. [2020-07-17 21:32:25,153 INFO L220 FreeRefinementEngine]: Constructing automaton from 1 perfect and 1 imperfect interpolant sequences. [2020-07-17 21:32:25,154 INFO L233 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [10] total 10 [2020-07-17 21:32:25,154 INFO L156 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [2010971995] [2020-07-17 21:32:25,156 INFO L78 Accepts]: Start accepts. Automaton has 6 states. Word has length 109 [2020-07-17 21:32:25,157 INFO L84 Accepts]: Finished accepts. word is accepted. [2020-07-17 21:32:25,157 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 6 states. [2020-07-17 21:32:25,264 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 101 edges. 101 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:32:25,265 INFO L459 AbstractCegarLoop]: Interpolant automaton has 6 states [2020-07-17 21:32:25,265 INFO L143 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2020-07-17 21:32:25,265 INFO L142 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2020-07-17 21:32:25,265 INFO L144 InterpolantAutomaton]: CoverageRelationStatistics Valid=22, Invalid=68, Unknown=0, NotChecked=0, Total=90 [2020-07-17 21:32:25,265 INFO L87 Difference]: Start difference. First operand 578 states and 714 transitions. Second operand 6 states. [2020-07-17 21:32:31,485 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:31,486 INFO L93 Difference]: Finished difference Result 1152 states and 1454 transitions. [2020-07-17 21:32:31,486 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 6 states. [2020-07-17 21:32:31,486 INFO L78 Accepts]: Start accepts. Automaton has 6 states. Word has length 109 [2020-07-17 21:32:31,487 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2020-07-17 21:32:31,487 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 6 states. [2020-07-17 21:32:31,490 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 206 transitions. [2020-07-17 21:32:31,490 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 6 states. [2020-07-17 21:32:31,492 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 206 transitions. [2020-07-17 21:32:31,492 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 6 states and 206 transitions. [2020-07-17 21:32:31,731 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 206 edges. 206 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:32:31,774 INFO L225 Difference]: With dead ends: 1152 [2020-07-17 21:32:31,775 INFO L226 Difference]: Without dead ends: 598 [2020-07-17 21:32:31,778 INFO L675 BasicCegarLoop]: 0 DeclaredPredicates, 151 GetRequests, 140 SyntacticMatches, 2 SemanticMatches, 9 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 14 ImplicationChecksByTransitivity, 0.3s TimeCoverageRelationStatistics Valid=26, Invalid=84, Unknown=0, NotChecked=0, Total=110 [2020-07-17 21:32:31,780 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 598 states. [2020-07-17 21:32:37,231 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 598 to 598. [2020-07-17 21:32:37,231 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2020-07-17 21:32:37,231 INFO L82 GeneralOperation]: Start isEquivalent. First operand 598 states. Second operand 598 states. [2020-07-17 21:32:37,231 INFO L74 IsIncluded]: Start isIncluded. First operand 598 states. Second operand 598 states. [2020-07-17 21:32:37,231 INFO L87 Difference]: Start difference. First operand 598 states. Second operand 598 states. [2020-07-17 21:32:37,262 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:37,262 INFO L93 Difference]: Finished difference Result 598 states and 738 transitions. [2020-07-17 21:32:37,263 INFO L276 IsEmpty]: Start isEmpty. Operand 598 states and 738 transitions. [2020-07-17 21:32:37,265 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:32:37,265 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:32:37,265 INFO L74 IsIncluded]: Start isIncluded. First operand 598 states. Second operand 598 states. [2020-07-17 21:32:37,266 INFO L87 Difference]: Start difference. First operand 598 states. Second operand 598 states. [2020-07-17 21:32:37,293 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:37,293 INFO L93 Difference]: Finished difference Result 598 states and 738 transitions. [2020-07-17 21:32:37,293 INFO L276 IsEmpty]: Start isEmpty. Operand 598 states and 738 transitions. [2020-07-17 21:32:37,295 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:32:37,296 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:32:37,296 INFO L88 GeneralOperation]: Finished isEquivalent. [2020-07-17 21:32:37,296 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2020-07-17 21:32:37,296 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 598 states. [2020-07-17 21:32:37,327 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 598 states to 598 states and 738 transitions. [2020-07-17 21:32:37,328 INFO L78 Accepts]: Start accepts. Automaton has 598 states and 738 transitions. Word has length 109 [2020-07-17 21:32:37,328 INFO L84 Accepts]: Finished accepts. word is rejected. [2020-07-17 21:32:37,328 INFO L479 AbstractCegarLoop]: Abstraction has 598 states and 738 transitions. [2020-07-17 21:32:37,329 INFO L480 AbstractCegarLoop]: Interpolant automaton has 6 states. [2020-07-17 21:32:37,329 INFO L276 IsEmpty]: Start isEmpty. Operand 598 states and 738 transitions. [2020-07-17 21:32:37,331 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 110 [2020-07-17 21:32:37,331 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:32:37,331 INFO L422 BasicCegarLoop]: trace histogram [2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:32:37,545 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable6,3 z3 -smt2 -in SMTLIB2_COMPLIANT=true [2020-07-17 21:32:37,546 INFO L427 AbstractCegarLoop]: === Iteration 8 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:32:37,546 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:32:37,546 INFO L82 PathProgramCache]: Analyzing trace with hash -2066212398, now seen corresponding path program 1 times [2020-07-17 21:32:37,546 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:32:37,547 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1657453452] [2020-07-17 21:32:37,547 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:32:37,585 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:37,864 WARN L193 SmtUtils]: Spent 189.00 ms on a formula simplification that was a NOOP. DAG size: 184 [2020-07-17 21:32:37,891 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:37,910 INFO L280 TraceCheckUtils]: 0: Hoare triple {13560#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {13491#true} is VALID [2020-07-17 21:32:37,911 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:37,911 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {13491#true} {13491#true} #479#return; {13491#true} is VALID [2020-07-17 21:32:37,911 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:37,914 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:37,914 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {13491#true} {13491#true} #401#return; {13491#true} is VALID [2020-07-17 21:32:37,915 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:37,921 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:37,922 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {13491#true} {13491#true} #403#return; {13491#true} is VALID [2020-07-17 21:32:37,923 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:37,943 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {13561#(and (<= 1 |valid_product_#res|) (<= |valid_product_#res| 1))} is VALID [2020-07-17 21:32:37,944 INFO L280 TraceCheckUtils]: 1: Hoare triple {13561#(and (<= 1 |valid_product_#res|) (<= |valid_product_#res| 1))} assume true; {13561#(and (<= 1 |valid_product_#res|) (<= |valid_product_#res| 1))} is VALID [2020-07-17 21:32:37,945 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {13561#(and (<= 1 |valid_product_#res|) (<= |valid_product_#res| 1))} {13491#true} #405#return; {13503#(= |main_#t~ret35| 1)} is VALID [2020-07-17 21:32:37,946 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:37,948 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:37,948 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {13491#true} {13491#true} #407#return; {13491#true} is VALID [2020-07-17 21:32:37,965 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:37,984 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:37,990 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,021 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,039 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} havoc ~retValue_acc~8; {13491#true} is VALID [2020-07-17 21:32:38,040 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,040 INFO L280 TraceCheckUtils]: 2: Hoare triple {13615#(= 1 |isHighWaterSensorDry_#res|)} assume true; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,041 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {13615#(= 1 |isHighWaterSensorDry_#res|)} {13491#true} #457#return; {13613#(= 1 |isHighWaterLevel_#t~ret69|)} is VALID [2020-07-17 21:32:38,042 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {13491#true} is VALID [2020-07-17 21:32:38,042 INFO L263 TraceCheckUtils]: 1: Hoare triple {13491#true} call #t~ret69 := isHighWaterSensorDry(); {13491#true} is VALID [2020-07-17 21:32:38,042 INFO L280 TraceCheckUtils]: 2: Hoare triple {13491#true} havoc ~retValue_acc~8; {13491#true} is VALID [2020-07-17 21:32:38,043 INFO L280 TraceCheckUtils]: 3: Hoare triple {13491#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,043 INFO L280 TraceCheckUtils]: 4: Hoare triple {13615#(= 1 |isHighWaterSensorDry_#res|)} assume true; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,044 INFO L275 TraceCheckUtils]: 5: Hoare quadruple {13615#(= 1 |isHighWaterSensorDry_#res|)} {13491#true} #457#return; {13613#(= 1 |isHighWaterLevel_#t~ret69|)} is VALID [2020-07-17 21:32:38,045 INFO L280 TraceCheckUtils]: 6: Hoare triple {13613#(= 1 |isHighWaterLevel_#t~ret69|)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {13614#(= 1 isHighWaterLevel_~tmp~6)} is VALID [2020-07-17 21:32:38,045 INFO L280 TraceCheckUtils]: 7: Hoare triple {13614#(= 1 isHighWaterLevel_~tmp~6)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {13492#false} is VALID [2020-07-17 21:32:38,046 INFO L280 TraceCheckUtils]: 8: Hoare triple {13492#false} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {13492#false} is VALID [2020-07-17 21:32:38,046 INFO L280 TraceCheckUtils]: 9: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,046 INFO L275 TraceCheckUtils]: 10: Hoare quadruple {13492#false} {13491#true} #441#return; {13492#false} is VALID [2020-07-17 21:32:38,047 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,054 INFO L280 TraceCheckUtils]: 0: Hoare triple {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {13491#true} is VALID [2020-07-17 21:32:38,055 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,055 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {13491#true} {13492#false} #443#return; {13492#false} is VALID [2020-07-17 21:32:38,055 INFO L280 TraceCheckUtils]: 0: Hoare triple {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {13491#true} is VALID [2020-07-17 21:32:38,055 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume 0 == ~pumpRunning~0; {13491#true} is VALID [2020-07-17 21:32:38,055 INFO L263 TraceCheckUtils]: 2: Hoare triple {13491#true} call #t~ret51 := isHighWaterLevel(); {13491#true} is VALID [2020-07-17 21:32:38,056 INFO L280 TraceCheckUtils]: 3: Hoare triple {13491#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {13491#true} is VALID [2020-07-17 21:32:38,056 INFO L263 TraceCheckUtils]: 4: Hoare triple {13491#true} call #t~ret69 := isHighWaterSensorDry(); {13491#true} is VALID [2020-07-17 21:32:38,056 INFO L280 TraceCheckUtils]: 5: Hoare triple {13491#true} havoc ~retValue_acc~8; {13491#true} is VALID [2020-07-17 21:32:38,057 INFO L280 TraceCheckUtils]: 6: Hoare triple {13491#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,057 INFO L280 TraceCheckUtils]: 7: Hoare triple {13615#(= 1 |isHighWaterSensorDry_#res|)} assume true; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,058 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {13615#(= 1 |isHighWaterSensorDry_#res|)} {13491#true} #457#return; {13613#(= 1 |isHighWaterLevel_#t~ret69|)} is VALID [2020-07-17 21:32:38,059 INFO L280 TraceCheckUtils]: 9: Hoare triple {13613#(= 1 |isHighWaterLevel_#t~ret69|)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {13614#(= 1 isHighWaterLevel_~tmp~6)} is VALID [2020-07-17 21:32:38,059 INFO L280 TraceCheckUtils]: 10: Hoare triple {13614#(= 1 isHighWaterLevel_~tmp~6)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {13492#false} is VALID [2020-07-17 21:32:38,060 INFO L280 TraceCheckUtils]: 11: Hoare triple {13492#false} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {13492#false} is VALID [2020-07-17 21:32:38,060 INFO L280 TraceCheckUtils]: 12: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,060 INFO L275 TraceCheckUtils]: 13: Hoare quadruple {13492#false} {13491#true} #441#return; {13492#false} is VALID [2020-07-17 21:32:38,060 INFO L280 TraceCheckUtils]: 14: Hoare triple {13492#false} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {13492#false} is VALID [2020-07-17 21:32:38,060 INFO L280 TraceCheckUtils]: 15: Hoare triple {13492#false} assume 0 != ~tmp~5; {13492#false} is VALID [2020-07-17 21:32:38,061 INFO L263 TraceCheckUtils]: 16: Hoare triple {13492#false} call activatePump(); {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:38,061 INFO L280 TraceCheckUtils]: 17: Hoare triple {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {13491#true} is VALID [2020-07-17 21:32:38,061 INFO L280 TraceCheckUtils]: 18: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,061 INFO L275 TraceCheckUtils]: 19: Hoare quadruple {13491#true} {13492#false} #443#return; {13492#false} is VALID [2020-07-17 21:32:38,061 INFO L280 TraceCheckUtils]: 20: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,062 INFO L275 TraceCheckUtils]: 21: Hoare quadruple {13492#false} {13491#true} #461#return; {13492#false} is VALID [2020-07-17 21:32:38,063 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,066 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,068 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {13491#true} is VALID [2020-07-17 21:32:38,068 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,068 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {13491#true} {13491#true} #395#return; {13491#true} is VALID [2020-07-17 21:32:38,068 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} havoc ~tmp~7;havoc ~tmp___0~2; {13491#true} is VALID [2020-07-17 21:32:38,069 INFO L263 TraceCheckUtils]: 1: Hoare triple {13491#true} call #t~ret70 := getWaterLevel(); {13491#true} is VALID [2020-07-17 21:32:38,069 INFO L280 TraceCheckUtils]: 2: Hoare triple {13491#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {13491#true} is VALID [2020-07-17 21:32:38,069 INFO L280 TraceCheckUtils]: 3: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,069 INFO L275 TraceCheckUtils]: 4: Hoare quadruple {13491#true} {13491#true} #395#return; {13491#true} is VALID [2020-07-17 21:32:38,069 INFO L280 TraceCheckUtils]: 5: Hoare triple {13491#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {13491#true} is VALID [2020-07-17 21:32:38,070 INFO L280 TraceCheckUtils]: 6: Hoare triple {13491#true} assume !(0 == ~tmp~7); {13491#true} is VALID [2020-07-17 21:32:38,070 INFO L280 TraceCheckUtils]: 7: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,070 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {13491#true} {13492#false} #463#return; {13492#false} is VALID [2020-07-17 21:32:38,070 INFO L280 TraceCheckUtils]: 0: Hoare triple {13562#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} assume !(0 != ~pumpRunning~0); {13491#true} is VALID [2020-07-17 21:32:38,071 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume 0 != ~systemActive~0; {13491#true} is VALID [2020-07-17 21:32:38,071 INFO L263 TraceCheckUtils]: 2: Hoare triple {13491#true} call processEnvironment(); {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:38,072 INFO L280 TraceCheckUtils]: 3: Hoare triple {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {13491#true} is VALID [2020-07-17 21:32:38,072 INFO L280 TraceCheckUtils]: 4: Hoare triple {13491#true} assume 0 == ~pumpRunning~0; {13491#true} is VALID [2020-07-17 21:32:38,072 INFO L263 TraceCheckUtils]: 5: Hoare triple {13491#true} call #t~ret51 := isHighWaterLevel(); {13491#true} is VALID [2020-07-17 21:32:38,072 INFO L280 TraceCheckUtils]: 6: Hoare triple {13491#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {13491#true} is VALID [2020-07-17 21:32:38,072 INFO L263 TraceCheckUtils]: 7: Hoare triple {13491#true} call #t~ret69 := isHighWaterSensorDry(); {13491#true} is VALID [2020-07-17 21:32:38,072 INFO L280 TraceCheckUtils]: 8: Hoare triple {13491#true} havoc ~retValue_acc~8; {13491#true} is VALID [2020-07-17 21:32:38,074 INFO L280 TraceCheckUtils]: 9: Hoare triple {13491#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,074 INFO L280 TraceCheckUtils]: 10: Hoare triple {13615#(= 1 |isHighWaterSensorDry_#res|)} assume true; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,075 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {13615#(= 1 |isHighWaterSensorDry_#res|)} {13491#true} #457#return; {13613#(= 1 |isHighWaterLevel_#t~ret69|)} is VALID [2020-07-17 21:32:38,076 INFO L280 TraceCheckUtils]: 12: Hoare triple {13613#(= 1 |isHighWaterLevel_#t~ret69|)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {13614#(= 1 isHighWaterLevel_~tmp~6)} is VALID [2020-07-17 21:32:38,076 INFO L280 TraceCheckUtils]: 13: Hoare triple {13614#(= 1 isHighWaterLevel_~tmp~6)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {13492#false} is VALID [2020-07-17 21:32:38,077 INFO L280 TraceCheckUtils]: 14: Hoare triple {13492#false} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {13492#false} is VALID [2020-07-17 21:32:38,077 INFO L280 TraceCheckUtils]: 15: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,077 INFO L275 TraceCheckUtils]: 16: Hoare quadruple {13492#false} {13491#true} #441#return; {13492#false} is VALID [2020-07-17 21:32:38,077 INFO L280 TraceCheckUtils]: 17: Hoare triple {13492#false} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {13492#false} is VALID [2020-07-17 21:32:38,077 INFO L280 TraceCheckUtils]: 18: Hoare triple {13492#false} assume 0 != ~tmp~5; {13492#false} is VALID [2020-07-17 21:32:38,078 INFO L263 TraceCheckUtils]: 19: Hoare triple {13492#false} call activatePump(); {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:38,078 INFO L280 TraceCheckUtils]: 20: Hoare triple {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {13491#true} is VALID [2020-07-17 21:32:38,078 INFO L280 TraceCheckUtils]: 21: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,078 INFO L275 TraceCheckUtils]: 22: Hoare quadruple {13491#true} {13492#false} #443#return; {13492#false} is VALID [2020-07-17 21:32:38,078 INFO L280 TraceCheckUtils]: 23: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,079 INFO L275 TraceCheckUtils]: 24: Hoare quadruple {13492#false} {13491#true} #461#return; {13492#false} is VALID [2020-07-17 21:32:38,079 INFO L263 TraceCheckUtils]: 25: Hoare triple {13492#false} call __utac_acc__Specification4_spec__1(); {13491#true} is VALID [2020-07-17 21:32:38,079 INFO L280 TraceCheckUtils]: 26: Hoare triple {13491#true} havoc ~tmp~7;havoc ~tmp___0~2; {13491#true} is VALID [2020-07-17 21:32:38,079 INFO L263 TraceCheckUtils]: 27: Hoare triple {13491#true} call #t~ret70 := getWaterLevel(); {13491#true} is VALID [2020-07-17 21:32:38,079 INFO L280 TraceCheckUtils]: 28: Hoare triple {13491#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {13491#true} is VALID [2020-07-17 21:32:38,080 INFO L280 TraceCheckUtils]: 29: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,080 INFO L275 TraceCheckUtils]: 30: Hoare quadruple {13491#true} {13491#true} #395#return; {13491#true} is VALID [2020-07-17 21:32:38,080 INFO L280 TraceCheckUtils]: 31: Hoare triple {13491#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {13491#true} is VALID [2020-07-17 21:32:38,080 INFO L280 TraceCheckUtils]: 32: Hoare triple {13491#true} assume !(0 == ~tmp~7); {13491#true} is VALID [2020-07-17 21:32:38,080 INFO L280 TraceCheckUtils]: 33: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,081 INFO L275 TraceCheckUtils]: 34: Hoare quadruple {13491#true} {13492#false} #463#return; {13492#false} is VALID [2020-07-17 21:32:38,081 INFO L280 TraceCheckUtils]: 35: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,081 INFO L275 TraceCheckUtils]: 36: Hoare quadruple {13492#false} {13491#true} #453#return; {13492#false} is VALID [2020-07-17 21:32:38,100 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,103 INFO L280 TraceCheckUtils]: 0: Hoare triple {13619#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {13491#true} is VALID [2020-07-17 21:32:38,103 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,104 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {13491#true} {13492#false} #459#return; {13492#false} is VALID [2020-07-17 21:32:38,105 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,107 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,109 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,109 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {13491#true} {13491#true} #447#return; {13491#true} is VALID [2020-07-17 21:32:38,109 INFO L280 TraceCheckUtils]: 0: Hoare triple {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {13491#true} is VALID [2020-07-17 21:32:38,110 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume !(0 == ~pumpRunning~0); {13491#true} is VALID [2020-07-17 21:32:38,110 INFO L263 TraceCheckUtils]: 2: Hoare triple {13491#true} call processEnvironment__wrappee__base(); {13491#true} is VALID [2020-07-17 21:32:38,110 INFO L280 TraceCheckUtils]: 3: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,110 INFO L275 TraceCheckUtils]: 4: Hoare quadruple {13491#true} {13491#true} #447#return; {13491#true} is VALID [2020-07-17 21:32:38,110 INFO L280 TraceCheckUtils]: 5: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,111 INFO L275 TraceCheckUtils]: 6: Hoare quadruple {13491#true} {13492#false} #461#return; {13492#false} is VALID [2020-07-17 21:32:38,111 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,114 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {13491#true} is VALID [2020-07-17 21:32:38,114 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,114 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {13491#true} {13492#false} #395#return; {13492#false} is VALID [2020-07-17 21:32:38,115 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,117 INFO L280 TraceCheckUtils]: 0: Hoare triple {13491#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {13491#true} is VALID [2020-07-17 21:32:38,117 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,117 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {13491#true} {13492#false} #397#return; {13492#false} is VALID [2020-07-17 21:32:38,122 INFO L263 TraceCheckUtils]: 0: Hoare triple {13491#true} call ULTIMATE.init(); {13560#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} is VALID [2020-07-17 21:32:38,122 INFO L280 TraceCheckUtils]: 1: Hoare triple {13560#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {13491#true} is VALID [2020-07-17 21:32:38,123 INFO L280 TraceCheckUtils]: 2: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,123 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {13491#true} {13491#true} #479#return; {13491#true} is VALID [2020-07-17 21:32:38,123 INFO L263 TraceCheckUtils]: 4: Hoare triple {13491#true} call #t~ret72 := main(); {13491#true} is VALID [2020-07-17 21:32:38,123 INFO L280 TraceCheckUtils]: 5: Hoare triple {13491#true} havoc ~retValue_acc~3;havoc ~tmp~3; {13491#true} is VALID [2020-07-17 21:32:38,123 INFO L263 TraceCheckUtils]: 6: Hoare triple {13491#true} call select_helpers(); {13491#true} is VALID [2020-07-17 21:32:38,124 INFO L280 TraceCheckUtils]: 7: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,124 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {13491#true} {13491#true} #401#return; {13491#true} is VALID [2020-07-17 21:32:38,124 INFO L263 TraceCheckUtils]: 9: Hoare triple {13491#true} call select_features(); {13491#true} is VALID [2020-07-17 21:32:38,124 INFO L280 TraceCheckUtils]: 10: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,124 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {13491#true} {13491#true} #403#return; {13491#true} is VALID [2020-07-17 21:32:38,125 INFO L263 TraceCheckUtils]: 12: Hoare triple {13491#true} call #t~ret35 := valid_product(); {13491#true} is VALID [2020-07-17 21:32:38,125 INFO L280 TraceCheckUtils]: 13: Hoare triple {13491#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {13561#(and (<= 1 |valid_product_#res|) (<= |valid_product_#res| 1))} is VALID [2020-07-17 21:32:38,126 INFO L280 TraceCheckUtils]: 14: Hoare triple {13561#(and (<= 1 |valid_product_#res|) (<= |valid_product_#res| 1))} assume true; {13561#(and (<= 1 |valid_product_#res|) (<= |valid_product_#res| 1))} is VALID [2020-07-17 21:32:38,127 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {13561#(and (<= 1 |valid_product_#res|) (<= |valid_product_#res| 1))} {13491#true} #405#return; {13503#(= |main_#t~ret35| 1)} is VALID [2020-07-17 21:32:38,128 INFO L280 TraceCheckUtils]: 16: Hoare triple {13503#(= |main_#t~ret35| 1)} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {13504#(= 1 main_~tmp~3)} is VALID [2020-07-17 21:32:38,128 INFO L280 TraceCheckUtils]: 17: Hoare triple {13504#(= 1 main_~tmp~3)} assume 0 != ~tmp~3; {13491#true} is VALID [2020-07-17 21:32:38,128 INFO L263 TraceCheckUtils]: 18: Hoare triple {13491#true} call setup(); {13491#true} is VALID [2020-07-17 21:32:38,128 INFO L280 TraceCheckUtils]: 19: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,129 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {13491#true} {13491#true} #407#return; {13491#true} is VALID [2020-07-17 21:32:38,129 INFO L263 TraceCheckUtils]: 21: Hoare triple {13491#true} call runTest(); {13491#true} is VALID [2020-07-17 21:32:38,129 INFO L263 TraceCheckUtils]: 22: Hoare triple {13491#true} call test(); {13491#true} is VALID [2020-07-17 21:32:38,129 INFO L280 TraceCheckUtils]: 23: Hoare triple {13491#true} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {13491#true} is VALID [2020-07-17 21:32:38,129 INFO L280 TraceCheckUtils]: 24: Hoare triple {13491#true} assume !false; {13491#true} is VALID [2020-07-17 21:32:38,129 INFO L280 TraceCheckUtils]: 25: Hoare triple {13491#true} assume ~splverifierCounter~0 < 4; {13491#true} is VALID [2020-07-17 21:32:38,130 INFO L280 TraceCheckUtils]: 26: Hoare triple {13491#true} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {13491#true} is VALID [2020-07-17 21:32:38,130 INFO L280 TraceCheckUtils]: 27: Hoare triple {13491#true} assume !(0 != ~tmp~4); {13491#true} is VALID [2020-07-17 21:32:38,130 INFO L280 TraceCheckUtils]: 28: Hoare triple {13491#true} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {13491#true} is VALID [2020-07-17 21:32:38,130 INFO L280 TraceCheckUtils]: 29: Hoare triple {13491#true} assume !(0 != ~tmp___0~0); {13491#true} is VALID [2020-07-17 21:32:38,130 INFO L280 TraceCheckUtils]: 30: Hoare triple {13491#true} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {13491#true} is VALID [2020-07-17 21:32:38,131 INFO L280 TraceCheckUtils]: 31: Hoare triple {13491#true} assume 0 != ~tmp___2~0; {13491#true} is VALID [2020-07-17 21:32:38,131 INFO L263 TraceCheckUtils]: 32: Hoare triple {13491#true} call timeShift(); {13562#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} is VALID [2020-07-17 21:32:38,132 INFO L280 TraceCheckUtils]: 33: Hoare triple {13562#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} assume !(0 != ~pumpRunning~0); {13491#true} is VALID [2020-07-17 21:32:38,132 INFO L280 TraceCheckUtils]: 34: Hoare triple {13491#true} assume 0 != ~systemActive~0; {13491#true} is VALID [2020-07-17 21:32:38,133 INFO L263 TraceCheckUtils]: 35: Hoare triple {13491#true} call processEnvironment(); {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:38,134 INFO L280 TraceCheckUtils]: 36: Hoare triple {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {13491#true} is VALID [2020-07-17 21:32:38,134 INFO L280 TraceCheckUtils]: 37: Hoare triple {13491#true} assume 0 == ~pumpRunning~0; {13491#true} is VALID [2020-07-17 21:32:38,134 INFO L263 TraceCheckUtils]: 38: Hoare triple {13491#true} call #t~ret51 := isHighWaterLevel(); {13491#true} is VALID [2020-07-17 21:32:38,134 INFO L280 TraceCheckUtils]: 39: Hoare triple {13491#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {13491#true} is VALID [2020-07-17 21:32:38,134 INFO L263 TraceCheckUtils]: 40: Hoare triple {13491#true} call #t~ret69 := isHighWaterSensorDry(); {13491#true} is VALID [2020-07-17 21:32:38,134 INFO L280 TraceCheckUtils]: 41: Hoare triple {13491#true} havoc ~retValue_acc~8; {13491#true} is VALID [2020-07-17 21:32:38,135 INFO L280 TraceCheckUtils]: 42: Hoare triple {13491#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,136 INFO L280 TraceCheckUtils]: 43: Hoare triple {13615#(= 1 |isHighWaterSensorDry_#res|)} assume true; {13615#(= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,137 INFO L275 TraceCheckUtils]: 44: Hoare quadruple {13615#(= 1 |isHighWaterSensorDry_#res|)} {13491#true} #457#return; {13613#(= 1 |isHighWaterLevel_#t~ret69|)} is VALID [2020-07-17 21:32:38,137 INFO L280 TraceCheckUtils]: 45: Hoare triple {13613#(= 1 |isHighWaterLevel_#t~ret69|)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {13614#(= 1 isHighWaterLevel_~tmp~6)} is VALID [2020-07-17 21:32:38,138 INFO L280 TraceCheckUtils]: 46: Hoare triple {13614#(= 1 isHighWaterLevel_~tmp~6)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {13492#false} is VALID [2020-07-17 21:32:38,138 INFO L280 TraceCheckUtils]: 47: Hoare triple {13492#false} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {13492#false} is VALID [2020-07-17 21:32:38,138 INFO L280 TraceCheckUtils]: 48: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,138 INFO L275 TraceCheckUtils]: 49: Hoare quadruple {13492#false} {13491#true} #441#return; {13492#false} is VALID [2020-07-17 21:32:38,139 INFO L280 TraceCheckUtils]: 50: Hoare triple {13492#false} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {13492#false} is VALID [2020-07-17 21:32:38,139 INFO L280 TraceCheckUtils]: 51: Hoare triple {13492#false} assume 0 != ~tmp~5; {13492#false} is VALID [2020-07-17 21:32:38,139 INFO L263 TraceCheckUtils]: 52: Hoare triple {13492#false} call activatePump(); {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:38,139 INFO L280 TraceCheckUtils]: 53: Hoare triple {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {13491#true} is VALID [2020-07-17 21:32:38,139 INFO L280 TraceCheckUtils]: 54: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,140 INFO L275 TraceCheckUtils]: 55: Hoare quadruple {13491#true} {13492#false} #443#return; {13492#false} is VALID [2020-07-17 21:32:38,140 INFO L280 TraceCheckUtils]: 56: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,140 INFO L275 TraceCheckUtils]: 57: Hoare quadruple {13492#false} {13491#true} #461#return; {13492#false} is VALID [2020-07-17 21:32:38,140 INFO L263 TraceCheckUtils]: 58: Hoare triple {13492#false} call __utac_acc__Specification4_spec__1(); {13491#true} is VALID [2020-07-17 21:32:38,140 INFO L280 TraceCheckUtils]: 59: Hoare triple {13491#true} havoc ~tmp~7;havoc ~tmp___0~2; {13491#true} is VALID [2020-07-17 21:32:38,140 INFO L263 TraceCheckUtils]: 60: Hoare triple {13491#true} call #t~ret70 := getWaterLevel(); {13491#true} is VALID [2020-07-17 21:32:38,141 INFO L280 TraceCheckUtils]: 61: Hoare triple {13491#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {13491#true} is VALID [2020-07-17 21:32:38,141 INFO L280 TraceCheckUtils]: 62: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,141 INFO L275 TraceCheckUtils]: 63: Hoare quadruple {13491#true} {13491#true} #395#return; {13491#true} is VALID [2020-07-17 21:32:38,141 INFO L280 TraceCheckUtils]: 64: Hoare triple {13491#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {13491#true} is VALID [2020-07-17 21:32:38,141 INFO L280 TraceCheckUtils]: 65: Hoare triple {13491#true} assume !(0 == ~tmp~7); {13491#true} is VALID [2020-07-17 21:32:38,142 INFO L280 TraceCheckUtils]: 66: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,142 INFO L275 TraceCheckUtils]: 67: Hoare quadruple {13491#true} {13492#false} #463#return; {13492#false} is VALID [2020-07-17 21:32:38,142 INFO L280 TraceCheckUtils]: 68: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,142 INFO L275 TraceCheckUtils]: 69: Hoare quadruple {13492#false} {13491#true} #453#return; {13492#false} is VALID [2020-07-17 21:32:38,142 INFO L280 TraceCheckUtils]: 70: Hoare triple {13492#false} assume !false; {13492#false} is VALID [2020-07-17 21:32:38,142 INFO L280 TraceCheckUtils]: 71: Hoare triple {13492#false} assume ~splverifierCounter~0 < 4; {13492#false} is VALID [2020-07-17 21:32:38,143 INFO L280 TraceCheckUtils]: 72: Hoare triple {13492#false} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {13492#false} is VALID [2020-07-17 21:32:38,143 INFO L280 TraceCheckUtils]: 73: Hoare triple {13492#false} assume !(0 != ~tmp~4); {13492#false} is VALID [2020-07-17 21:32:38,143 INFO L280 TraceCheckUtils]: 74: Hoare triple {13492#false} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {13492#false} is VALID [2020-07-17 21:32:38,143 INFO L280 TraceCheckUtils]: 75: Hoare triple {13492#false} assume !(0 != ~tmp___0~0); {13492#false} is VALID [2020-07-17 21:32:38,143 INFO L280 TraceCheckUtils]: 76: Hoare triple {13492#false} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {13492#false} is VALID [2020-07-17 21:32:38,144 INFO L280 TraceCheckUtils]: 77: Hoare triple {13492#false} assume 0 != ~tmp___2~0; {13492#false} is VALID [2020-07-17 21:32:38,144 INFO L263 TraceCheckUtils]: 78: Hoare triple {13492#false} call timeShift(); {13492#false} is VALID [2020-07-17 21:32:38,144 INFO L280 TraceCheckUtils]: 79: Hoare triple {13492#false} assume 0 != ~pumpRunning~0; {13492#false} is VALID [2020-07-17 21:32:38,144 INFO L263 TraceCheckUtils]: 80: Hoare triple {13492#false} call lowerWaterLevel(); {13619#(= ~waterLevel~0 |old(~waterLevel~0)|)} is VALID [2020-07-17 21:32:38,144 INFO L280 TraceCheckUtils]: 81: Hoare triple {13619#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {13491#true} is VALID [2020-07-17 21:32:38,145 INFO L280 TraceCheckUtils]: 82: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,145 INFO L275 TraceCheckUtils]: 83: Hoare quadruple {13491#true} {13492#false} #459#return; {13492#false} is VALID [2020-07-17 21:32:38,145 INFO L280 TraceCheckUtils]: 84: Hoare triple {13492#false} assume 0 != ~systemActive~0; {13492#false} is VALID [2020-07-17 21:32:38,145 INFO L263 TraceCheckUtils]: 85: Hoare triple {13492#false} call processEnvironment(); {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:38,145 INFO L280 TraceCheckUtils]: 86: Hoare triple {13594#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {13491#true} is VALID [2020-07-17 21:32:38,146 INFO L280 TraceCheckUtils]: 87: Hoare triple {13491#true} assume !(0 == ~pumpRunning~0); {13491#true} is VALID [2020-07-17 21:32:38,146 INFO L263 TraceCheckUtils]: 88: Hoare triple {13491#true} call processEnvironment__wrappee__base(); {13491#true} is VALID [2020-07-17 21:32:38,146 INFO L280 TraceCheckUtils]: 89: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,146 INFO L275 TraceCheckUtils]: 90: Hoare quadruple {13491#true} {13491#true} #447#return; {13491#true} is VALID [2020-07-17 21:32:38,146 INFO L280 TraceCheckUtils]: 91: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,147 INFO L275 TraceCheckUtils]: 92: Hoare quadruple {13491#true} {13492#false} #461#return; {13492#false} is VALID [2020-07-17 21:32:38,147 INFO L263 TraceCheckUtils]: 93: Hoare triple {13492#false} call __utac_acc__Specification4_spec__1(); {13492#false} is VALID [2020-07-17 21:32:38,147 INFO L280 TraceCheckUtils]: 94: Hoare triple {13492#false} havoc ~tmp~7;havoc ~tmp___0~2; {13492#false} is VALID [2020-07-17 21:32:38,147 INFO L263 TraceCheckUtils]: 95: Hoare triple {13492#false} call #t~ret70 := getWaterLevel(); {13491#true} is VALID [2020-07-17 21:32:38,147 INFO L280 TraceCheckUtils]: 96: Hoare triple {13491#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {13491#true} is VALID [2020-07-17 21:32:38,148 INFO L280 TraceCheckUtils]: 97: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,148 INFO L275 TraceCheckUtils]: 98: Hoare quadruple {13491#true} {13492#false} #395#return; {13492#false} is VALID [2020-07-17 21:32:38,148 INFO L280 TraceCheckUtils]: 99: Hoare triple {13492#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {13492#false} is VALID [2020-07-17 21:32:38,148 INFO L280 TraceCheckUtils]: 100: Hoare triple {13492#false} assume 0 == ~tmp~7; {13492#false} is VALID [2020-07-17 21:32:38,148 INFO L263 TraceCheckUtils]: 101: Hoare triple {13492#false} call #t~ret71 := isPumpRunning(); {13491#true} is VALID [2020-07-17 21:32:38,149 INFO L280 TraceCheckUtils]: 102: Hoare triple {13491#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {13491#true} is VALID [2020-07-17 21:32:38,149 INFO L280 TraceCheckUtils]: 103: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,149 INFO L275 TraceCheckUtils]: 104: Hoare quadruple {13491#true} {13492#false} #397#return; {13492#false} is VALID [2020-07-17 21:32:38,149 INFO L280 TraceCheckUtils]: 105: Hoare triple {13492#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {13492#false} is VALID [2020-07-17 21:32:38,149 INFO L280 TraceCheckUtils]: 106: Hoare triple {13492#false} assume 0 != ~tmp___0~2; {13492#false} is VALID [2020-07-17 21:32:38,149 INFO L263 TraceCheckUtils]: 107: Hoare triple {13492#false} call __automaton_fail(); {13492#false} is VALID [2020-07-17 21:32:38,150 INFO L280 TraceCheckUtils]: 108: Hoare triple {13492#false} assume !false; {13492#false} is VALID [2020-07-17 21:32:38,163 INFO L134 CoverageAnalysis]: Checked inductivity of 24 backedges. 16 proven. 2 refuted. 0 times theorem prover too weak. 6 trivial. 0 not checked. [2020-07-17 21:32:38,164 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1657453452] [2020-07-17 21:32:38,164 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [347865748] [2020-07-17 21:32:38,164 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 Starting monitored process 4 with z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) Waiting until toolchain timeout for monitored process 4 with z3 -smt2 -in SMTLIB2_COMPLIANT=true [2020-07-17 21:32:38,356 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,358 INFO L264 TraceCheckSpWp]: Trace formula consists of 776 conjuncts, 5 conjunts are in the unsatisfiable core [2020-07-17 21:32:38,395 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:38,399 INFO L287 TraceCheckSpWp]: Computing forward predicates... [2020-07-17 21:32:38,549 INFO L263 TraceCheckUtils]: 0: Hoare triple {13491#true} call ULTIMATE.init(); {13491#true} is VALID [2020-07-17 21:32:38,549 INFO L280 TraceCheckUtils]: 1: Hoare triple {13491#true} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {13491#true} is VALID [2020-07-17 21:32:38,549 INFO L280 TraceCheckUtils]: 2: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,549 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {13491#true} {13491#true} #479#return; {13491#true} is VALID [2020-07-17 21:32:38,550 INFO L263 TraceCheckUtils]: 4: Hoare triple {13491#true} call #t~ret72 := main(); {13491#true} is VALID [2020-07-17 21:32:38,550 INFO L280 TraceCheckUtils]: 5: Hoare triple {13491#true} havoc ~retValue_acc~3;havoc ~tmp~3; {13491#true} is VALID [2020-07-17 21:32:38,550 INFO L263 TraceCheckUtils]: 6: Hoare triple {13491#true} call select_helpers(); {13491#true} is VALID [2020-07-17 21:32:38,550 INFO L280 TraceCheckUtils]: 7: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,550 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {13491#true} {13491#true} #401#return; {13491#true} is VALID [2020-07-17 21:32:38,551 INFO L263 TraceCheckUtils]: 9: Hoare triple {13491#true} call select_features(); {13491#true} is VALID [2020-07-17 21:32:38,551 INFO L280 TraceCheckUtils]: 10: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,551 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {13491#true} {13491#true} #403#return; {13491#true} is VALID [2020-07-17 21:32:38,551 INFO L263 TraceCheckUtils]: 12: Hoare triple {13491#true} call #t~ret35 := valid_product(); {13491#true} is VALID [2020-07-17 21:32:38,551 INFO L280 TraceCheckUtils]: 13: Hoare triple {13491#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {13491#true} is VALID [2020-07-17 21:32:38,552 INFO L280 TraceCheckUtils]: 14: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,552 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {13491#true} {13491#true} #405#return; {13491#true} is VALID [2020-07-17 21:32:38,552 INFO L280 TraceCheckUtils]: 16: Hoare triple {13491#true} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {13491#true} is VALID [2020-07-17 21:32:38,552 INFO L280 TraceCheckUtils]: 17: Hoare triple {13491#true} assume 0 != ~tmp~3; {13491#true} is VALID [2020-07-17 21:32:38,552 INFO L263 TraceCheckUtils]: 18: Hoare triple {13491#true} call setup(); {13491#true} is VALID [2020-07-17 21:32:38,552 INFO L280 TraceCheckUtils]: 19: Hoare triple {13491#true} assume true; {13491#true} is VALID [2020-07-17 21:32:38,553 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {13491#true} {13491#true} #407#return; {13491#true} is VALID [2020-07-17 21:32:38,553 INFO L263 TraceCheckUtils]: 21: Hoare triple {13491#true} call runTest(); {13491#true} is VALID [2020-07-17 21:32:38,553 INFO L263 TraceCheckUtils]: 22: Hoare triple {13491#true} call test(); {13491#true} is VALID [2020-07-17 21:32:38,553 INFO L280 TraceCheckUtils]: 23: Hoare triple {13491#true} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {13491#true} is VALID [2020-07-17 21:32:38,553 INFO L280 TraceCheckUtils]: 24: Hoare triple {13491#true} assume !false; {13491#true} is VALID [2020-07-17 21:32:38,553 INFO L280 TraceCheckUtils]: 25: Hoare triple {13491#true} assume ~splverifierCounter~0 < 4; {13491#true} is VALID [2020-07-17 21:32:38,553 INFO L280 TraceCheckUtils]: 26: Hoare triple {13491#true} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {13491#true} is VALID [2020-07-17 21:32:38,553 INFO L280 TraceCheckUtils]: 27: Hoare triple {13491#true} assume !(0 != ~tmp~4); {13491#true} is VALID [2020-07-17 21:32:38,554 INFO L280 TraceCheckUtils]: 28: Hoare triple {13491#true} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {13491#true} is VALID [2020-07-17 21:32:38,554 INFO L280 TraceCheckUtils]: 29: Hoare triple {13491#true} assume !(0 != ~tmp___0~0); {13491#true} is VALID [2020-07-17 21:32:38,554 INFO L280 TraceCheckUtils]: 30: Hoare triple {13491#true} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {13491#true} is VALID [2020-07-17 21:32:38,554 INFO L280 TraceCheckUtils]: 31: Hoare triple {13491#true} assume 0 != ~tmp___2~0; {13491#true} is VALID [2020-07-17 21:32:38,554 INFO L263 TraceCheckUtils]: 32: Hoare triple {13491#true} call timeShift(); {13491#true} is VALID [2020-07-17 21:32:38,554 INFO L280 TraceCheckUtils]: 33: Hoare triple {13491#true} assume !(0 != ~pumpRunning~0); {13491#true} is VALID [2020-07-17 21:32:38,554 INFO L280 TraceCheckUtils]: 34: Hoare triple {13491#true} assume 0 != ~systemActive~0; {13491#true} is VALID [2020-07-17 21:32:38,555 INFO L263 TraceCheckUtils]: 35: Hoare triple {13491#true} call processEnvironment(); {13491#true} is VALID [2020-07-17 21:32:38,555 INFO L280 TraceCheckUtils]: 36: Hoare triple {13491#true} havoc ~tmp~5; {13491#true} is VALID [2020-07-17 21:32:38,555 INFO L280 TraceCheckUtils]: 37: Hoare triple {13491#true} assume 0 == ~pumpRunning~0; {13491#true} is VALID [2020-07-17 21:32:38,555 INFO L263 TraceCheckUtils]: 38: Hoare triple {13491#true} call #t~ret51 := isHighWaterLevel(); {13491#true} is VALID [2020-07-17 21:32:38,555 INFO L280 TraceCheckUtils]: 39: Hoare triple {13491#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {13491#true} is VALID [2020-07-17 21:32:38,555 INFO L263 TraceCheckUtils]: 40: Hoare triple {13491#true} call #t~ret69 := isHighWaterSensorDry(); {13491#true} is VALID [2020-07-17 21:32:38,555 INFO L280 TraceCheckUtils]: 41: Hoare triple {13491#true} havoc ~retValue_acc~8; {13491#true} is VALID [2020-07-17 21:32:38,556 INFO L280 TraceCheckUtils]: 42: Hoare triple {13491#true} assume ~waterLevel~0 < 2;~retValue_acc~8 := 1;#res := ~retValue_acc~8; {13751#(<= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,556 INFO L280 TraceCheckUtils]: 43: Hoare triple {13751#(<= 1 |isHighWaterSensorDry_#res|)} assume true; {13751#(<= 1 |isHighWaterSensorDry_#res|)} is VALID [2020-07-17 21:32:38,557 INFO L275 TraceCheckUtils]: 44: Hoare quadruple {13751#(<= 1 |isHighWaterSensorDry_#res|)} {13491#true} #457#return; {13758#(<= 1 |isHighWaterLevel_#t~ret69|)} is VALID [2020-07-17 21:32:38,557 INFO L280 TraceCheckUtils]: 45: Hoare triple {13758#(<= 1 |isHighWaterLevel_#t~ret69|)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {13762#(<= 1 isHighWaterLevel_~tmp~6)} is VALID [2020-07-17 21:32:38,558 INFO L280 TraceCheckUtils]: 46: Hoare triple {13762#(<= 1 isHighWaterLevel_~tmp~6)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {13492#false} is VALID [2020-07-17 21:32:38,558 INFO L280 TraceCheckUtils]: 47: Hoare triple {13492#false} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {13492#false} is VALID [2020-07-17 21:32:38,558 INFO L280 TraceCheckUtils]: 48: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,558 INFO L275 TraceCheckUtils]: 49: Hoare quadruple {13492#false} {13491#true} #441#return; {13492#false} is VALID [2020-07-17 21:32:38,558 INFO L280 TraceCheckUtils]: 50: Hoare triple {13492#false} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {13492#false} is VALID [2020-07-17 21:32:38,558 INFO L280 TraceCheckUtils]: 51: Hoare triple {13492#false} assume 0 != ~tmp~5; {13492#false} is VALID [2020-07-17 21:32:38,559 INFO L263 TraceCheckUtils]: 52: Hoare triple {13492#false} call activatePump(); {13492#false} is VALID [2020-07-17 21:32:38,559 INFO L280 TraceCheckUtils]: 53: Hoare triple {13492#false} ~pumpRunning~0 := 1; {13492#false} is VALID [2020-07-17 21:32:38,559 INFO L280 TraceCheckUtils]: 54: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,559 INFO L275 TraceCheckUtils]: 55: Hoare quadruple {13492#false} {13492#false} #443#return; {13492#false} is VALID [2020-07-17 21:32:38,559 INFO L280 TraceCheckUtils]: 56: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,559 INFO L275 TraceCheckUtils]: 57: Hoare quadruple {13492#false} {13491#true} #461#return; {13492#false} is VALID [2020-07-17 21:32:38,560 INFO L263 TraceCheckUtils]: 58: Hoare triple {13492#false} call __utac_acc__Specification4_spec__1(); {13492#false} is VALID [2020-07-17 21:32:38,560 INFO L280 TraceCheckUtils]: 59: Hoare triple {13492#false} havoc ~tmp~7;havoc ~tmp___0~2; {13492#false} is VALID [2020-07-17 21:32:38,560 INFO L263 TraceCheckUtils]: 60: Hoare triple {13492#false} call #t~ret70 := getWaterLevel(); {13492#false} is VALID [2020-07-17 21:32:38,560 INFO L280 TraceCheckUtils]: 61: Hoare triple {13492#false} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {13492#false} is VALID [2020-07-17 21:32:38,560 INFO L280 TraceCheckUtils]: 62: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,561 INFO L275 TraceCheckUtils]: 63: Hoare quadruple {13492#false} {13492#false} #395#return; {13492#false} is VALID [2020-07-17 21:32:38,561 INFO L280 TraceCheckUtils]: 64: Hoare triple {13492#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {13492#false} is VALID [2020-07-17 21:32:38,561 INFO L280 TraceCheckUtils]: 65: Hoare triple {13492#false} assume !(0 == ~tmp~7); {13492#false} is VALID [2020-07-17 21:32:38,561 INFO L280 TraceCheckUtils]: 66: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,561 INFO L275 TraceCheckUtils]: 67: Hoare quadruple {13492#false} {13492#false} #463#return; {13492#false} is VALID [2020-07-17 21:32:38,562 INFO L280 TraceCheckUtils]: 68: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,562 INFO L275 TraceCheckUtils]: 69: Hoare quadruple {13492#false} {13491#true} #453#return; {13492#false} is VALID [2020-07-17 21:32:38,562 INFO L280 TraceCheckUtils]: 70: Hoare triple {13492#false} assume !false; {13492#false} is VALID [2020-07-17 21:32:38,562 INFO L280 TraceCheckUtils]: 71: Hoare triple {13492#false} assume ~splverifierCounter~0 < 4; {13492#false} is VALID [2020-07-17 21:32:38,562 INFO L280 TraceCheckUtils]: 72: Hoare triple {13492#false} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {13492#false} is VALID [2020-07-17 21:32:38,562 INFO L280 TraceCheckUtils]: 73: Hoare triple {13492#false} assume !(0 != ~tmp~4); {13492#false} is VALID [2020-07-17 21:32:38,563 INFO L280 TraceCheckUtils]: 74: Hoare triple {13492#false} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {13492#false} is VALID [2020-07-17 21:32:38,563 INFO L280 TraceCheckUtils]: 75: Hoare triple {13492#false} assume !(0 != ~tmp___0~0); {13492#false} is VALID [2020-07-17 21:32:38,563 INFO L280 TraceCheckUtils]: 76: Hoare triple {13492#false} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {13492#false} is VALID [2020-07-17 21:32:38,563 INFO L280 TraceCheckUtils]: 77: Hoare triple {13492#false} assume 0 != ~tmp___2~0; {13492#false} is VALID [2020-07-17 21:32:38,563 INFO L263 TraceCheckUtils]: 78: Hoare triple {13492#false} call timeShift(); {13492#false} is VALID [2020-07-17 21:32:38,563 INFO L280 TraceCheckUtils]: 79: Hoare triple {13492#false} assume 0 != ~pumpRunning~0; {13492#false} is VALID [2020-07-17 21:32:38,564 INFO L263 TraceCheckUtils]: 80: Hoare triple {13492#false} call lowerWaterLevel(); {13492#false} is VALID [2020-07-17 21:32:38,564 INFO L280 TraceCheckUtils]: 81: Hoare triple {13492#false} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {13492#false} is VALID [2020-07-17 21:32:38,564 INFO L280 TraceCheckUtils]: 82: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,564 INFO L275 TraceCheckUtils]: 83: Hoare quadruple {13492#false} {13492#false} #459#return; {13492#false} is VALID [2020-07-17 21:32:38,564 INFO L280 TraceCheckUtils]: 84: Hoare triple {13492#false} assume 0 != ~systemActive~0; {13492#false} is VALID [2020-07-17 21:32:38,565 INFO L263 TraceCheckUtils]: 85: Hoare triple {13492#false} call processEnvironment(); {13492#false} is VALID [2020-07-17 21:32:38,565 INFO L280 TraceCheckUtils]: 86: Hoare triple {13492#false} havoc ~tmp~5; {13492#false} is VALID [2020-07-17 21:32:38,565 INFO L280 TraceCheckUtils]: 87: Hoare triple {13492#false} assume !(0 == ~pumpRunning~0); {13492#false} is VALID [2020-07-17 21:32:38,565 INFO L263 TraceCheckUtils]: 88: Hoare triple {13492#false} call processEnvironment__wrappee__base(); {13492#false} is VALID [2020-07-17 21:32:38,565 INFO L280 TraceCheckUtils]: 89: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,565 INFO L275 TraceCheckUtils]: 90: Hoare quadruple {13492#false} {13492#false} #447#return; {13492#false} is VALID [2020-07-17 21:32:38,566 INFO L280 TraceCheckUtils]: 91: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,566 INFO L275 TraceCheckUtils]: 92: Hoare quadruple {13492#false} {13492#false} #461#return; {13492#false} is VALID [2020-07-17 21:32:38,566 INFO L263 TraceCheckUtils]: 93: Hoare triple {13492#false} call __utac_acc__Specification4_spec__1(); {13492#false} is VALID [2020-07-17 21:32:38,566 INFO L280 TraceCheckUtils]: 94: Hoare triple {13492#false} havoc ~tmp~7;havoc ~tmp___0~2; {13492#false} is VALID [2020-07-17 21:32:38,566 INFO L263 TraceCheckUtils]: 95: Hoare triple {13492#false} call #t~ret70 := getWaterLevel(); {13492#false} is VALID [2020-07-17 21:32:38,567 INFO L280 TraceCheckUtils]: 96: Hoare triple {13492#false} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {13492#false} is VALID [2020-07-17 21:32:38,567 INFO L280 TraceCheckUtils]: 97: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,567 INFO L275 TraceCheckUtils]: 98: Hoare quadruple {13492#false} {13492#false} #395#return; {13492#false} is VALID [2020-07-17 21:32:38,567 INFO L280 TraceCheckUtils]: 99: Hoare triple {13492#false} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {13492#false} is VALID [2020-07-17 21:32:38,567 INFO L280 TraceCheckUtils]: 100: Hoare triple {13492#false} assume 0 == ~tmp~7; {13492#false} is VALID [2020-07-17 21:32:38,568 INFO L263 TraceCheckUtils]: 101: Hoare triple {13492#false} call #t~ret71 := isPumpRunning(); {13492#false} is VALID [2020-07-17 21:32:38,568 INFO L280 TraceCheckUtils]: 102: Hoare triple {13492#false} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {13492#false} is VALID [2020-07-17 21:32:38,568 INFO L280 TraceCheckUtils]: 103: Hoare triple {13492#false} assume true; {13492#false} is VALID [2020-07-17 21:32:38,568 INFO L275 TraceCheckUtils]: 104: Hoare quadruple {13492#false} {13492#false} #397#return; {13492#false} is VALID [2020-07-17 21:32:38,568 INFO L280 TraceCheckUtils]: 105: Hoare triple {13492#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {13492#false} is VALID [2020-07-17 21:32:38,568 INFO L280 TraceCheckUtils]: 106: Hoare triple {13492#false} assume 0 != ~tmp___0~2; {13492#false} is VALID [2020-07-17 21:32:38,569 INFO L263 TraceCheckUtils]: 107: Hoare triple {13492#false} call __automaton_fail(); {13492#false} is VALID [2020-07-17 21:32:38,569 INFO L280 TraceCheckUtils]: 108: Hoare triple {13492#false} assume !false; {13492#false} is VALID [2020-07-17 21:32:38,575 INFO L134 CoverageAnalysis]: Checked inductivity of 24 backedges. 14 proven. 0 refuted. 0 times theorem prover too weak. 10 trivial. 0 not checked. [2020-07-17 21:32:38,575 INFO L220 FreeRefinementEngine]: Constructing automaton from 1 perfect and 1 imperfect interpolant sequences. [2020-07-17 21:32:38,576 INFO L233 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [12] total 15 [2020-07-17 21:32:38,576 INFO L156 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1624913423] [2020-07-17 21:32:38,576 INFO L78 Accepts]: Start accepts. Automaton has 5 states. Word has length 109 [2020-07-17 21:32:38,577 INFO L84 Accepts]: Finished accepts. word is accepted. [2020-07-17 21:32:38,577 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 5 states. [2020-07-17 21:32:38,686 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 101 edges. 101 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:32:38,686 INFO L459 AbstractCegarLoop]: Interpolant automaton has 5 states [2020-07-17 21:32:38,686 INFO L143 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2020-07-17 21:32:38,686 INFO L142 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2020-07-17 21:32:38,687 INFO L144 InterpolantAutomaton]: CoverageRelationStatistics Valid=35, Invalid=175, Unknown=0, NotChecked=0, Total=210 [2020-07-17 21:32:38,687 INFO L87 Difference]: Start difference. First operand 598 states and 738 transitions. Second operand 5 states. [2020-07-17 21:32:43,535 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:43,535 INFO L93 Difference]: Finished difference Result 1053 states and 1327 transitions. [2020-07-17 21:32:43,536 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2020-07-17 21:32:43,536 INFO L78 Accepts]: Start accepts. Automaton has 5 states. Word has length 109 [2020-07-17 21:32:43,536 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2020-07-17 21:32:43,536 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 5 states. [2020-07-17 21:32:43,538 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 207 transitions. [2020-07-17 21:32:43,539 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 5 states. [2020-07-17 21:32:43,540 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 207 transitions. [2020-07-17 21:32:43,541 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 5 states and 207 transitions. [2020-07-17 21:32:43,783 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 207 edges. 207 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:32:43,805 INFO L225 Difference]: With dead ends: 1053 [2020-07-17 21:32:43,805 INFO L226 Difference]: Without dead ends: 479 [2020-07-17 21:32:43,807 INFO L675 BasicCegarLoop]: 0 DeclaredPredicates, 153 GetRequests, 140 SyntacticMatches, 0 SemanticMatches, 13 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 18 ImplicationChecksByTransitivity, 0.4s TimeCoverageRelationStatistics Valid=35, Invalid=175, Unknown=0, NotChecked=0, Total=210 [2020-07-17 21:32:43,808 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 479 states. [2020-07-17 21:32:48,176 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 479 to 479. [2020-07-17 21:32:48,176 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2020-07-17 21:32:48,176 INFO L82 GeneralOperation]: Start isEquivalent. First operand 479 states. Second operand 479 states. [2020-07-17 21:32:48,176 INFO L74 IsIncluded]: Start isIncluded. First operand 479 states. Second operand 479 states. [2020-07-17 21:32:48,176 INFO L87 Difference]: Start difference. First operand 479 states. Second operand 479 states. [2020-07-17 21:32:48,191 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:48,191 INFO L93 Difference]: Finished difference Result 479 states and 581 transitions. [2020-07-17 21:32:48,191 INFO L276 IsEmpty]: Start isEmpty. Operand 479 states and 581 transitions. [2020-07-17 21:32:48,193 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:32:48,193 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:32:48,193 INFO L74 IsIncluded]: Start isIncluded. First operand 479 states. Second operand 479 states. [2020-07-17 21:32:48,193 INFO L87 Difference]: Start difference. First operand 479 states. Second operand 479 states. [2020-07-17 21:32:48,211 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:32:48,211 INFO L93 Difference]: Finished difference Result 479 states and 581 transitions. [2020-07-17 21:32:48,212 INFO L276 IsEmpty]: Start isEmpty. Operand 479 states and 581 transitions. [2020-07-17 21:32:48,213 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:32:48,213 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:32:48,214 INFO L88 GeneralOperation]: Finished isEquivalent. [2020-07-17 21:32:48,214 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2020-07-17 21:32:48,214 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 479 states. [2020-07-17 21:32:48,233 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 479 states to 479 states and 581 transitions. [2020-07-17 21:32:48,234 INFO L78 Accepts]: Start accepts. Automaton has 479 states and 581 transitions. Word has length 109 [2020-07-17 21:32:48,234 INFO L84 Accepts]: Finished accepts. word is rejected. [2020-07-17 21:32:48,234 INFO L479 AbstractCegarLoop]: Abstraction has 479 states and 581 transitions. [2020-07-17 21:32:48,234 INFO L480 AbstractCegarLoop]: Interpolant automaton has 5 states. [2020-07-17 21:32:48,234 INFO L276 IsEmpty]: Start isEmpty. Operand 479 states and 581 transitions. [2020-07-17 21:32:48,236 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 114 [2020-07-17 21:32:48,236 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:32:48,236 INFO L422 BasicCegarLoop]: trace histogram [2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:32:48,449 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable7,4 z3 -smt2 -in SMTLIB2_COMPLIANT=true [2020-07-17 21:32:48,450 INFO L427 AbstractCegarLoop]: === Iteration 9 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:32:48,450 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:32:48,450 INFO L82 PathProgramCache]: Analyzing trace with hash 147640793, now seen corresponding path program 1 times [2020-07-17 21:32:48,450 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:32:48,451 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1686879657] [2020-07-17 21:32:48,451 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:32:48,483 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,786 WARN L193 SmtUtils]: Spent 199.00 ms on a formula simplification that was a NOOP. DAG size: 184 [2020-07-17 21:32:48,814 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,833 INFO L280 TraceCheckUtils]: 0: Hoare triple {17093#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {17019#true} is VALID [2020-07-17 21:32:48,834 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,834 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {17019#true} {17019#true} #479#return; {17019#true} is VALID [2020-07-17 21:32:48,835 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,836 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,837 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {17019#true} {17019#true} #401#return; {17019#true} is VALID [2020-07-17 21:32:48,837 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,839 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,839 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {17019#true} {17019#true} #403#return; {17019#true} is VALID [2020-07-17 21:32:48,840 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,847 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {17019#true} is VALID [2020-07-17 21:32:48,848 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,848 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {17019#true} {17019#true} #405#return; {17019#true} is VALID [2020-07-17 21:32:48,848 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,852 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,853 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {17019#true} {17019#true} #407#return; {17019#true} is VALID [2020-07-17 21:32:48,865 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,867 INFO L280 TraceCheckUtils]: 0: Hoare triple {17094#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 < 2;~waterLevel~0 := 1 + ~waterLevel~0; {17019#true} is VALID [2020-07-17 21:32:48,868 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,868 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {17019#true} {17019#true} #449#return; {17019#true} is VALID [2020-07-17 21:32:48,885 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,910 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,931 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,939 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,956 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} havoc ~retValue_acc~8; {17019#true} is VALID [2020-07-17 21:32:48,956 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume !(~waterLevel~0 < 2);~retValue_acc~8 := 0;#res := ~retValue_acc~8; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,957 INFO L280 TraceCheckUtils]: 2: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,958 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #457#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,958 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {17019#true} is VALID [2020-07-17 21:32:48,958 INFO L263 TraceCheckUtils]: 1: Hoare triple {17019#true} call #t~ret69 := isHighWaterSensorDry(); {17019#true} is VALID [2020-07-17 21:32:48,958 INFO L280 TraceCheckUtils]: 2: Hoare triple {17019#true} havoc ~retValue_acc~8; {17019#true} is VALID [2020-07-17 21:32:48,959 INFO L280 TraceCheckUtils]: 3: Hoare triple {17019#true} assume !(~waterLevel~0 < 2);~retValue_acc~8 := 0;#res := ~retValue_acc~8; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,960 INFO L280 TraceCheckUtils]: 4: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,960 INFO L275 TraceCheckUtils]: 5: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #457#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,961 INFO L280 TraceCheckUtils]: 6: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,961 INFO L280 TraceCheckUtils]: 7: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,962 INFO L280 TraceCheckUtils]: 8: Hoare triple {17073#(<= 2 ~waterLevel~0)} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,962 INFO L280 TraceCheckUtils]: 9: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,963 INFO L275 TraceCheckUtils]: 10: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #441#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,964 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,967 INFO L280 TraceCheckUtils]: 0: Hoare triple {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {17019#true} is VALID [2020-07-17 21:32:48,967 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,967 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {17019#true} {17073#(<= 2 ~waterLevel~0)} #443#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,968 INFO L280 TraceCheckUtils]: 0: Hoare triple {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {17019#true} is VALID [2020-07-17 21:32:48,968 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume 0 == ~pumpRunning~0; {17019#true} is VALID [2020-07-17 21:32:48,968 INFO L263 TraceCheckUtils]: 2: Hoare triple {17019#true} call #t~ret51 := isHighWaterLevel(); {17019#true} is VALID [2020-07-17 21:32:48,968 INFO L280 TraceCheckUtils]: 3: Hoare triple {17019#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {17019#true} is VALID [2020-07-17 21:32:48,969 INFO L263 TraceCheckUtils]: 4: Hoare triple {17019#true} call #t~ret69 := isHighWaterSensorDry(); {17019#true} is VALID [2020-07-17 21:32:48,969 INFO L280 TraceCheckUtils]: 5: Hoare triple {17019#true} havoc ~retValue_acc~8; {17019#true} is VALID [2020-07-17 21:32:48,970 INFO L280 TraceCheckUtils]: 6: Hoare triple {17019#true} assume !(~waterLevel~0 < 2);~retValue_acc~8 := 0;#res := ~retValue_acc~8; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,971 INFO L280 TraceCheckUtils]: 7: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,972 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #457#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,972 INFO L280 TraceCheckUtils]: 9: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,973 INFO L280 TraceCheckUtils]: 10: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,973 INFO L280 TraceCheckUtils]: 11: Hoare triple {17073#(<= 2 ~waterLevel~0)} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,974 INFO L280 TraceCheckUtils]: 12: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,975 INFO L275 TraceCheckUtils]: 13: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #441#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,975 INFO L280 TraceCheckUtils]: 14: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,976 INFO L280 TraceCheckUtils]: 15: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume 0 != ~tmp~5; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,976 INFO L263 TraceCheckUtils]: 16: Hoare triple {17073#(<= 2 ~waterLevel~0)} call activatePump(); {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:48,976 INFO L280 TraceCheckUtils]: 17: Hoare triple {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {17019#true} is VALID [2020-07-17 21:32:48,977 INFO L280 TraceCheckUtils]: 18: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,977 INFO L275 TraceCheckUtils]: 19: Hoare quadruple {17019#true} {17073#(<= 2 ~waterLevel~0)} #443#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,978 INFO L280 TraceCheckUtils]: 20: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,978 INFO L275 TraceCheckUtils]: 21: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #461#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,980 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,983 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:48,986 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {17019#true} is VALID [2020-07-17 21:32:48,986 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,986 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {17019#true} {17019#true} #395#return; {17019#true} is VALID [2020-07-17 21:32:48,986 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} havoc ~tmp~7;havoc ~tmp___0~2; {17019#true} is VALID [2020-07-17 21:32:48,987 INFO L263 TraceCheckUtils]: 1: Hoare triple {17019#true} call #t~ret70 := getWaterLevel(); {17019#true} is VALID [2020-07-17 21:32:48,987 INFO L280 TraceCheckUtils]: 2: Hoare triple {17019#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {17019#true} is VALID [2020-07-17 21:32:48,987 INFO L280 TraceCheckUtils]: 3: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,987 INFO L275 TraceCheckUtils]: 4: Hoare quadruple {17019#true} {17019#true} #395#return; {17019#true} is VALID [2020-07-17 21:32:48,988 INFO L280 TraceCheckUtils]: 5: Hoare triple {17019#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {17019#true} is VALID [2020-07-17 21:32:48,988 INFO L280 TraceCheckUtils]: 6: Hoare triple {17019#true} assume !(0 == ~tmp~7); {17019#true} is VALID [2020-07-17 21:32:48,988 INFO L280 TraceCheckUtils]: 7: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:48,989 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {17019#true} {17073#(<= 2 ~waterLevel~0)} #463#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,989 INFO L280 TraceCheckUtils]: 0: Hoare triple {17095#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} assume !(0 != ~pumpRunning~0); {17019#true} is VALID [2020-07-17 21:32:48,989 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume 0 != ~systemActive~0; {17019#true} is VALID [2020-07-17 21:32:48,990 INFO L263 TraceCheckUtils]: 2: Hoare triple {17019#true} call processEnvironment(); {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:48,990 INFO L280 TraceCheckUtils]: 3: Hoare triple {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {17019#true} is VALID [2020-07-17 21:32:48,990 INFO L280 TraceCheckUtils]: 4: Hoare triple {17019#true} assume 0 == ~pumpRunning~0; {17019#true} is VALID [2020-07-17 21:32:48,991 INFO L263 TraceCheckUtils]: 5: Hoare triple {17019#true} call #t~ret51 := isHighWaterLevel(); {17019#true} is VALID [2020-07-17 21:32:48,991 INFO L280 TraceCheckUtils]: 6: Hoare triple {17019#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {17019#true} is VALID [2020-07-17 21:32:48,991 INFO L263 TraceCheckUtils]: 7: Hoare triple {17019#true} call #t~ret69 := isHighWaterSensorDry(); {17019#true} is VALID [2020-07-17 21:32:48,991 INFO L280 TraceCheckUtils]: 8: Hoare triple {17019#true} havoc ~retValue_acc~8; {17019#true} is VALID [2020-07-17 21:32:48,992 INFO L280 TraceCheckUtils]: 9: Hoare triple {17019#true} assume !(~waterLevel~0 < 2);~retValue_acc~8 := 0;#res := ~retValue_acc~8; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,992 INFO L280 TraceCheckUtils]: 10: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,993 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #457#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,994 INFO L280 TraceCheckUtils]: 12: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,994 INFO L280 TraceCheckUtils]: 13: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,995 INFO L280 TraceCheckUtils]: 14: Hoare triple {17073#(<= 2 ~waterLevel~0)} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,995 INFO L280 TraceCheckUtils]: 15: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,996 INFO L275 TraceCheckUtils]: 16: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #441#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,997 INFO L280 TraceCheckUtils]: 17: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,997 INFO L280 TraceCheckUtils]: 18: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume 0 != ~tmp~5; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:48,998 INFO L263 TraceCheckUtils]: 19: Hoare triple {17073#(<= 2 ~waterLevel~0)} call activatePump(); {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:48,998 INFO L280 TraceCheckUtils]: 20: Hoare triple {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {17019#true} is VALID [2020-07-17 21:32:48,998 INFO L280 TraceCheckUtils]: 21: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,000 INFO L275 TraceCheckUtils]: 22: Hoare quadruple {17019#true} {17073#(<= 2 ~waterLevel~0)} #443#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,000 INFO L280 TraceCheckUtils]: 23: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,001 INFO L275 TraceCheckUtils]: 24: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #461#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,001 INFO L263 TraceCheckUtils]: 25: Hoare triple {17073#(<= 2 ~waterLevel~0)} call __utac_acc__Specification4_spec__1(); {17019#true} is VALID [2020-07-17 21:32:49,001 INFO L280 TraceCheckUtils]: 26: Hoare triple {17019#true} havoc ~tmp~7;havoc ~tmp___0~2; {17019#true} is VALID [2020-07-17 21:32:49,001 INFO L263 TraceCheckUtils]: 27: Hoare triple {17019#true} call #t~ret70 := getWaterLevel(); {17019#true} is VALID [2020-07-17 21:32:49,002 INFO L280 TraceCheckUtils]: 28: Hoare triple {17019#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {17019#true} is VALID [2020-07-17 21:32:49,002 INFO L280 TraceCheckUtils]: 29: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,002 INFO L275 TraceCheckUtils]: 30: Hoare quadruple {17019#true} {17019#true} #395#return; {17019#true} is VALID [2020-07-17 21:32:49,002 INFO L280 TraceCheckUtils]: 31: Hoare triple {17019#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {17019#true} is VALID [2020-07-17 21:32:49,002 INFO L280 TraceCheckUtils]: 32: Hoare triple {17019#true} assume !(0 == ~tmp~7); {17019#true} is VALID [2020-07-17 21:32:49,003 INFO L280 TraceCheckUtils]: 33: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,004 INFO L275 TraceCheckUtils]: 34: Hoare quadruple {17019#true} {17073#(<= 2 ~waterLevel~0)} #463#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,004 INFO L280 TraceCheckUtils]: 35: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,005 INFO L275 TraceCheckUtils]: 36: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #453#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,007 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:49,027 INFO L280 TraceCheckUtils]: 0: Hoare triple {17094#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} is VALID [2020-07-17 21:32:49,028 INFO L280 TraceCheckUtils]: 1: Hoare triple {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} assume true; {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} is VALID [2020-07-17 21:32:49,029 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} {17073#(<= 2 ~waterLevel~0)} #459#return; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,030 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:49,033 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:49,035 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,035 INFO L275 TraceCheckUtils]: 1: Hoare quadruple {17019#true} {17019#true} #447#return; {17019#true} is VALID [2020-07-17 21:32:49,036 INFO L280 TraceCheckUtils]: 0: Hoare triple {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {17019#true} is VALID [2020-07-17 21:32:49,036 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume !(0 == ~pumpRunning~0); {17019#true} is VALID [2020-07-17 21:32:49,036 INFO L263 TraceCheckUtils]: 2: Hoare triple {17019#true} call processEnvironment__wrappee__base(); {17019#true} is VALID [2020-07-17 21:32:49,036 INFO L280 TraceCheckUtils]: 3: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,036 INFO L275 TraceCheckUtils]: 4: Hoare quadruple {17019#true} {17019#true} #447#return; {17019#true} is VALID [2020-07-17 21:32:49,037 INFO L280 TraceCheckUtils]: 5: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,037 INFO L275 TraceCheckUtils]: 6: Hoare quadruple {17019#true} {17077#(<= 1 ~waterLevel~0)} #461#return; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,039 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:49,057 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {17152#(= |getWaterLevel_#res| ~waterLevel~0)} is VALID [2020-07-17 21:32:49,058 INFO L280 TraceCheckUtils]: 1: Hoare triple {17152#(= |getWaterLevel_#res| ~waterLevel~0)} assume true; {17152#(= |getWaterLevel_#res| ~waterLevel~0)} is VALID [2020-07-17 21:32:49,059 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {17152#(= |getWaterLevel_#res| ~waterLevel~0)} {17077#(<= 1 ~waterLevel~0)} #395#return; {17088#(<= 1 |__utac_acc__Specification4_spec__1_#t~ret70|)} is VALID [2020-07-17 21:32:49,059 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:49,062 INFO L280 TraceCheckUtils]: 0: Hoare triple {17019#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {17019#true} is VALID [2020-07-17 21:32:49,062 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,062 INFO L275 TraceCheckUtils]: 2: Hoare quadruple {17019#true} {17020#false} #397#return; {17020#false} is VALID [2020-07-17 21:32:49,066 INFO L263 TraceCheckUtils]: 0: Hoare triple {17019#true} call ULTIMATE.init(); {17093#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} is VALID [2020-07-17 21:32:49,067 INFO L280 TraceCheckUtils]: 1: Hoare triple {17093#(and (= |#t~string23.base| |old(#t~string23.base)|) (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= |#t~string48.base| |old(#t~string48.base)|) (= |#t~string68.offset| |old(#t~string68.offset)|) (= |#t~string48.offset| |old(#t~string48.offset)|) (= ~waterLevel~0 |old(~waterLevel~0)|) (= |#t~string50.base| |old(#t~string50.base)|) (= |#t~string66.offset| |old(#t~string66.offset)|) (= |#t~string44.offset| |old(#t~string44.offset)|) (= |#t~string42.offset| |old(#t~string42.offset)|) (= |#t~string27.offset| |old(#t~string27.offset)|) (= |#t~string28.offset| |old(#t~string28.offset)|) (= |#t~string42.base| |old(#t~string42.base)|) (= ~head~0.offset |old(~head~0.offset)|) (= |#t~string19.offset| |old(#t~string19.offset)|) (= |#t~string58.offset| |old(#t~string58.offset)|) (= |#t~string18.offset| |old(#t~string18.offset)|) (= ~head~0.base |old(~head~0.base)|) (= |#t~string64.base| |old(#t~string64.base)|) (= |#t~string66.base| |old(#t~string66.base)|) (= |#t~string28.base| |old(#t~string28.base)|) (= |#t~string60.base| |old(#t~string60.base)|) (= |#t~string23.offset| |old(#t~string23.offset)|) (= |#t~string62.offset| |old(#t~string62.offset)|) (= |#t~string32.base| |old(#t~string32.base)|) (= |#t~string31.base| |old(#t~string31.base)|) (= |#t~string30.offset| |old(#t~string30.offset)|) (= |#t~string29.offset| |old(#t~string29.offset)|) (= |#t~string46.offset| |old(#t~string46.offset)|) (= |#t~string22.base| |old(#t~string22.base)|) (= |#t~string50.offset| |old(#t~string50.offset)|) (= |#t~string30.base| |old(#t~string30.base)|) (= |#t~string29.base| |old(#t~string29.base)|) (= ~systemActive~0 |old(~systemActive~0)|) (= |#t~string56.offset| |old(#t~string56.offset)|) (= |#t~string60.offset| |old(#t~string60.offset)|) (= |#t~string58.base| |old(#t~string58.base)|) (= |#t~string22.offset| |old(#t~string22.offset)|) (= |#t~string20.offset| |old(#t~string20.offset)|) (= |#NULL.base| |old(#NULL.base)|) (= |#t~string32.offset| |old(#t~string32.offset)|) (= |#t~string56.base| |old(#t~string56.base)|) (= |#t~string18.base| |old(#t~string18.base)|) (= |#NULL.offset| |old(#NULL.offset)|) (= |#t~string54.offset| |old(#t~string54.offset)|) (= |old(#length)| |#length|) (= |#t~string62.base| |old(#t~string62.base)|) (= |#t~string46.base| |old(#t~string46.base)|) (= |#t~string19.base| |old(#t~string19.base)|) (= |#t~string20.base| |old(#t~string20.base)|) (= ~methaneLevelCritical~0 |old(~methaneLevelCritical~0)|) (= |#t~string21.offset| |old(#t~string21.offset)|) (= |#t~string21.base| |old(#t~string21.base)|) (= |#t~string27.base| |old(#t~string27.base)|) (= |#valid| |old(#valid)|) (= |#t~string68.base| |old(#t~string68.base)|) (= |#t~string64.offset| |old(#t~string64.offset)|) (= |#t~string54.base| |old(#t~string54.base)|) (= |#t~string44.base| |old(#t~string44.base)|) (= ~cleanupTimeShifts~0 |old(~cleanupTimeShifts~0)|) (= |#t~string31.offset| |old(#t~string31.offset)|))} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {17019#true} is VALID [2020-07-17 21:32:49,067 INFO L280 TraceCheckUtils]: 2: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,067 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {17019#true} {17019#true} #479#return; {17019#true} is VALID [2020-07-17 21:32:49,067 INFO L263 TraceCheckUtils]: 4: Hoare triple {17019#true} call #t~ret72 := main(); {17019#true} is VALID [2020-07-17 21:32:49,068 INFO L280 TraceCheckUtils]: 5: Hoare triple {17019#true} havoc ~retValue_acc~3;havoc ~tmp~3; {17019#true} is VALID [2020-07-17 21:32:49,068 INFO L263 TraceCheckUtils]: 6: Hoare triple {17019#true} call select_helpers(); {17019#true} is VALID [2020-07-17 21:32:49,068 INFO L280 TraceCheckUtils]: 7: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,068 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {17019#true} {17019#true} #401#return; {17019#true} is VALID [2020-07-17 21:32:49,068 INFO L263 TraceCheckUtils]: 9: Hoare triple {17019#true} call select_features(); {17019#true} is VALID [2020-07-17 21:32:49,069 INFO L280 TraceCheckUtils]: 10: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,069 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {17019#true} {17019#true} #403#return; {17019#true} is VALID [2020-07-17 21:32:49,069 INFO L263 TraceCheckUtils]: 12: Hoare triple {17019#true} call #t~ret35 := valid_product(); {17019#true} is VALID [2020-07-17 21:32:49,069 INFO L280 TraceCheckUtils]: 13: Hoare triple {17019#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {17019#true} is VALID [2020-07-17 21:32:49,069 INFO L280 TraceCheckUtils]: 14: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,070 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {17019#true} {17019#true} #405#return; {17019#true} is VALID [2020-07-17 21:32:49,070 INFO L280 TraceCheckUtils]: 16: Hoare triple {17019#true} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {17019#true} is VALID [2020-07-17 21:32:49,070 INFO L280 TraceCheckUtils]: 17: Hoare triple {17019#true} assume 0 != ~tmp~3; {17019#true} is VALID [2020-07-17 21:32:49,070 INFO L263 TraceCheckUtils]: 18: Hoare triple {17019#true} call setup(); {17019#true} is VALID [2020-07-17 21:32:49,070 INFO L280 TraceCheckUtils]: 19: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,071 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {17019#true} {17019#true} #407#return; {17019#true} is VALID [2020-07-17 21:32:49,071 INFO L263 TraceCheckUtils]: 21: Hoare triple {17019#true} call runTest(); {17019#true} is VALID [2020-07-17 21:32:49,071 INFO L263 TraceCheckUtils]: 22: Hoare triple {17019#true} call test(); {17019#true} is VALID [2020-07-17 21:32:49,071 INFO L280 TraceCheckUtils]: 23: Hoare triple {17019#true} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {17019#true} is VALID [2020-07-17 21:32:49,072 INFO L280 TraceCheckUtils]: 24: Hoare triple {17019#true} assume !false; {17019#true} is VALID [2020-07-17 21:32:49,072 INFO L280 TraceCheckUtils]: 25: Hoare triple {17019#true} assume ~splverifierCounter~0 < 4; {17019#true} is VALID [2020-07-17 21:32:49,072 INFO L280 TraceCheckUtils]: 26: Hoare triple {17019#true} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {17019#true} is VALID [2020-07-17 21:32:49,072 INFO L280 TraceCheckUtils]: 27: Hoare triple {17019#true} assume 0 != ~tmp~4; {17019#true} is VALID [2020-07-17 21:32:49,074 INFO L263 TraceCheckUtils]: 28: Hoare triple {17019#true} call waterRise(); {17094#(= ~waterLevel~0 |old(~waterLevel~0)|)} is VALID [2020-07-17 21:32:49,074 INFO L280 TraceCheckUtils]: 29: Hoare triple {17094#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 < 2;~waterLevel~0 := 1 + ~waterLevel~0; {17019#true} is VALID [2020-07-17 21:32:49,074 INFO L280 TraceCheckUtils]: 30: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,074 INFO L275 TraceCheckUtils]: 31: Hoare quadruple {17019#true} {17019#true} #449#return; {17019#true} is VALID [2020-07-17 21:32:49,074 INFO L280 TraceCheckUtils]: 32: Hoare triple {17019#true} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {17019#true} is VALID [2020-07-17 21:32:49,075 INFO L280 TraceCheckUtils]: 33: Hoare triple {17019#true} assume !(0 != ~tmp___0~0); {17019#true} is VALID [2020-07-17 21:32:49,075 INFO L280 TraceCheckUtils]: 34: Hoare triple {17019#true} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {17019#true} is VALID [2020-07-17 21:32:49,075 INFO L280 TraceCheckUtils]: 35: Hoare triple {17019#true} assume 0 != ~tmp___2~0; {17019#true} is VALID [2020-07-17 21:32:49,076 INFO L263 TraceCheckUtils]: 36: Hoare triple {17019#true} call timeShift(); {17095#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} is VALID [2020-07-17 21:32:49,076 INFO L280 TraceCheckUtils]: 37: Hoare triple {17095#(and (= ~pumpRunning~0 |old(~pumpRunning~0)|) (= ~waterLevel~0 |old(~waterLevel~0)|))} assume !(0 != ~pumpRunning~0); {17019#true} is VALID [2020-07-17 21:32:49,076 INFO L280 TraceCheckUtils]: 38: Hoare triple {17019#true} assume 0 != ~systemActive~0; {17019#true} is VALID [2020-07-17 21:32:49,077 INFO L263 TraceCheckUtils]: 39: Hoare triple {17019#true} call processEnvironment(); {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:49,077 INFO L280 TraceCheckUtils]: 40: Hoare triple {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {17019#true} is VALID [2020-07-17 21:32:49,077 INFO L280 TraceCheckUtils]: 41: Hoare triple {17019#true} assume 0 == ~pumpRunning~0; {17019#true} is VALID [2020-07-17 21:32:49,078 INFO L263 TraceCheckUtils]: 42: Hoare triple {17019#true} call #t~ret51 := isHighWaterLevel(); {17019#true} is VALID [2020-07-17 21:32:49,078 INFO L280 TraceCheckUtils]: 43: Hoare triple {17019#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {17019#true} is VALID [2020-07-17 21:32:49,078 INFO L263 TraceCheckUtils]: 44: Hoare triple {17019#true} call #t~ret69 := isHighWaterSensorDry(); {17019#true} is VALID [2020-07-17 21:32:49,078 INFO L280 TraceCheckUtils]: 45: Hoare triple {17019#true} havoc ~retValue_acc~8; {17019#true} is VALID [2020-07-17 21:32:49,079 INFO L280 TraceCheckUtils]: 46: Hoare triple {17019#true} assume !(~waterLevel~0 < 2);~retValue_acc~8 := 0;#res := ~retValue_acc~8; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,079 INFO L280 TraceCheckUtils]: 47: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,080 INFO L275 TraceCheckUtils]: 48: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #457#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,081 INFO L280 TraceCheckUtils]: 49: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,081 INFO L280 TraceCheckUtils]: 50: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,082 INFO L280 TraceCheckUtils]: 51: Hoare triple {17073#(<= 2 ~waterLevel~0)} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,082 INFO L280 TraceCheckUtils]: 52: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,083 INFO L275 TraceCheckUtils]: 53: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #441#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,084 INFO L280 TraceCheckUtils]: 54: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,084 INFO L280 TraceCheckUtils]: 55: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume 0 != ~tmp~5; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,085 INFO L263 TraceCheckUtils]: 56: Hoare triple {17073#(<= 2 ~waterLevel~0)} call activatePump(); {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:49,085 INFO L280 TraceCheckUtils]: 57: Hoare triple {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} ~pumpRunning~0 := 1; {17019#true} is VALID [2020-07-17 21:32:49,085 INFO L280 TraceCheckUtils]: 58: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,086 INFO L275 TraceCheckUtils]: 59: Hoare quadruple {17019#true} {17073#(<= 2 ~waterLevel~0)} #443#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,086 INFO L280 TraceCheckUtils]: 60: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,087 INFO L275 TraceCheckUtils]: 61: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #461#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,087 INFO L263 TraceCheckUtils]: 62: Hoare triple {17073#(<= 2 ~waterLevel~0)} call __utac_acc__Specification4_spec__1(); {17019#true} is VALID [2020-07-17 21:32:49,087 INFO L280 TraceCheckUtils]: 63: Hoare triple {17019#true} havoc ~tmp~7;havoc ~tmp___0~2; {17019#true} is VALID [2020-07-17 21:32:49,088 INFO L263 TraceCheckUtils]: 64: Hoare triple {17019#true} call #t~ret70 := getWaterLevel(); {17019#true} is VALID [2020-07-17 21:32:49,088 INFO L280 TraceCheckUtils]: 65: Hoare triple {17019#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {17019#true} is VALID [2020-07-17 21:32:49,088 INFO L280 TraceCheckUtils]: 66: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,088 INFO L275 TraceCheckUtils]: 67: Hoare quadruple {17019#true} {17019#true} #395#return; {17019#true} is VALID [2020-07-17 21:32:49,088 INFO L280 TraceCheckUtils]: 68: Hoare triple {17019#true} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {17019#true} is VALID [2020-07-17 21:32:49,089 INFO L280 TraceCheckUtils]: 69: Hoare triple {17019#true} assume !(0 == ~tmp~7); {17019#true} is VALID [2020-07-17 21:32:49,089 INFO L280 TraceCheckUtils]: 70: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,090 INFO L275 TraceCheckUtils]: 71: Hoare quadruple {17019#true} {17073#(<= 2 ~waterLevel~0)} #463#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,090 INFO L280 TraceCheckUtils]: 72: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,091 INFO L275 TraceCheckUtils]: 73: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #453#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,092 INFO L280 TraceCheckUtils]: 74: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !false; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,092 INFO L280 TraceCheckUtils]: 75: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume ~splverifierCounter~0 < 4; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,093 INFO L280 TraceCheckUtils]: 76: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,093 INFO L280 TraceCheckUtils]: 77: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp~4); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,094 INFO L280 TraceCheckUtils]: 78: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,094 INFO L280 TraceCheckUtils]: 79: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp___0~0); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,095 INFO L280 TraceCheckUtils]: 80: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,095 INFO L280 TraceCheckUtils]: 81: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume 0 != ~tmp___2~0; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,096 INFO L263 TraceCheckUtils]: 82: Hoare triple {17073#(<= 2 ~waterLevel~0)} call timeShift(); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,096 INFO L280 TraceCheckUtils]: 83: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume 0 != ~pumpRunning~0; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,097 INFO L263 TraceCheckUtils]: 84: Hoare triple {17073#(<= 2 ~waterLevel~0)} call lowerWaterLevel(); {17094#(= ~waterLevel~0 |old(~waterLevel~0)|)} is VALID [2020-07-17 21:32:49,098 INFO L280 TraceCheckUtils]: 85: Hoare triple {17094#(= ~waterLevel~0 |old(~waterLevel~0)|)} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} is VALID [2020-07-17 21:32:49,098 INFO L280 TraceCheckUtils]: 86: Hoare triple {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} assume true; {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} is VALID [2020-07-17 21:32:49,099 INFO L275 TraceCheckUtils]: 87: Hoare quadruple {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} {17073#(<= 2 ~waterLevel~0)} #459#return; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,100 INFO L280 TraceCheckUtils]: 88: Hoare triple {17077#(<= 1 ~waterLevel~0)} assume 0 != ~systemActive~0; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,101 INFO L263 TraceCheckUtils]: 89: Hoare triple {17077#(<= 1 ~waterLevel~0)} call processEnvironment(); {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} is VALID [2020-07-17 21:32:49,101 INFO L280 TraceCheckUtils]: 90: Hoare triple {17127#(= ~pumpRunning~0 |old(~pumpRunning~0)|)} havoc ~tmp~5; {17019#true} is VALID [2020-07-17 21:32:49,101 INFO L280 TraceCheckUtils]: 91: Hoare triple {17019#true} assume !(0 == ~pumpRunning~0); {17019#true} is VALID [2020-07-17 21:32:49,101 INFO L263 TraceCheckUtils]: 92: Hoare triple {17019#true} call processEnvironment__wrappee__base(); {17019#true} is VALID [2020-07-17 21:32:49,101 INFO L280 TraceCheckUtils]: 93: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,102 INFO L275 TraceCheckUtils]: 94: Hoare quadruple {17019#true} {17019#true} #447#return; {17019#true} is VALID [2020-07-17 21:32:49,102 INFO L280 TraceCheckUtils]: 95: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,102 INFO L275 TraceCheckUtils]: 96: Hoare quadruple {17019#true} {17077#(<= 1 ~waterLevel~0)} #461#return; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,103 INFO L263 TraceCheckUtils]: 97: Hoare triple {17077#(<= 1 ~waterLevel~0)} call __utac_acc__Specification4_spec__1(); {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,104 INFO L280 TraceCheckUtils]: 98: Hoare triple {17077#(<= 1 ~waterLevel~0)} havoc ~tmp~7;havoc ~tmp___0~2; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,104 INFO L263 TraceCheckUtils]: 99: Hoare triple {17077#(<= 1 ~waterLevel~0)} call #t~ret70 := getWaterLevel(); {17019#true} is VALID [2020-07-17 21:32:49,104 INFO L280 TraceCheckUtils]: 100: Hoare triple {17019#true} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {17152#(= |getWaterLevel_#res| ~waterLevel~0)} is VALID [2020-07-17 21:32:49,105 INFO L280 TraceCheckUtils]: 101: Hoare triple {17152#(= |getWaterLevel_#res| ~waterLevel~0)} assume true; {17152#(= |getWaterLevel_#res| ~waterLevel~0)} is VALID [2020-07-17 21:32:49,106 INFO L275 TraceCheckUtils]: 102: Hoare quadruple {17152#(= |getWaterLevel_#res| ~waterLevel~0)} {17077#(<= 1 ~waterLevel~0)} #395#return; {17088#(<= 1 |__utac_acc__Specification4_spec__1_#t~ret70|)} is VALID [2020-07-17 21:32:49,106 INFO L280 TraceCheckUtils]: 103: Hoare triple {17088#(<= 1 |__utac_acc__Specification4_spec__1_#t~ret70|)} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {17089#(<= 1 __utac_acc__Specification4_spec__1_~tmp~7)} is VALID [2020-07-17 21:32:49,107 INFO L280 TraceCheckUtils]: 104: Hoare triple {17089#(<= 1 __utac_acc__Specification4_spec__1_~tmp~7)} assume 0 == ~tmp~7; {17020#false} is VALID [2020-07-17 21:32:49,107 INFO L263 TraceCheckUtils]: 105: Hoare triple {17020#false} call #t~ret71 := isPumpRunning(); {17019#true} is VALID [2020-07-17 21:32:49,107 INFO L280 TraceCheckUtils]: 106: Hoare triple {17019#true} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {17019#true} is VALID [2020-07-17 21:32:49,107 INFO L280 TraceCheckUtils]: 107: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,108 INFO L275 TraceCheckUtils]: 108: Hoare quadruple {17019#true} {17020#false} #397#return; {17020#false} is VALID [2020-07-17 21:32:49,108 INFO L280 TraceCheckUtils]: 109: Hoare triple {17020#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {17020#false} is VALID [2020-07-17 21:32:49,108 INFO L280 TraceCheckUtils]: 110: Hoare triple {17020#false} assume 0 != ~tmp___0~2; {17020#false} is VALID [2020-07-17 21:32:49,108 INFO L263 TraceCheckUtils]: 111: Hoare triple {17020#false} call __automaton_fail(); {17020#false} is VALID [2020-07-17 21:32:49,108 INFO L280 TraceCheckUtils]: 112: Hoare triple {17020#false} assume !false; {17020#false} is VALID [2020-07-17 21:32:49,124 INFO L134 CoverageAnalysis]: Checked inductivity of 24 backedges. 17 proven. 4 refuted. 0 times theorem prover too weak. 3 trivial. 0 not checked. [2020-07-17 21:32:49,125 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1686879657] [2020-07-17 21:32:49,125 INFO L354 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [555611675] [2020-07-17 21:32:49,125 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 Starting monitored process 5 with z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) Waiting until toolchain timeout for monitored process 5 with z3 -smt2 -in SMTLIB2_COMPLIANT=true [2020-07-17 21:32:49,283 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:49,285 INFO L264 TraceCheckSpWp]: Trace formula consists of 785 conjuncts, 11 conjunts are in the unsatisfiable core [2020-07-17 21:32:49,331 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2020-07-17 21:32:49,334 INFO L287 TraceCheckSpWp]: Computing forward predicates... [2020-07-17 21:32:49,613 INFO L263 TraceCheckUtils]: 0: Hoare triple {17019#true} call ULTIMATE.init(); {17019#true} is VALID [2020-07-17 21:32:49,613 INFO L280 TraceCheckUtils]: 1: Hoare triple {17019#true} #NULL.base, #NULL.offset := 0, 0;#valid := #valid[0 := 0];assume 0 < #StackHeapBarrier;call #t~string18.base, #t~string18.offset := #Ultimate.allocOnStack(30);call #t~string19.base, #t~string19.offset := #Ultimate.allocOnStack(9);call #t~string20.base, #t~string20.offset := #Ultimate.allocOnStack(21);call #t~string21.base, #t~string21.offset := #Ultimate.allocOnStack(30);call #t~string22.base, #t~string22.offset := #Ultimate.allocOnStack(9);call #t~string23.base, #t~string23.offset := #Ultimate.allocOnStack(21);call #t~string27.base, #t~string27.offset := #Ultimate.allocOnStack(30);call #t~string28.base, #t~string28.offset := #Ultimate.allocOnStack(9);call #t~string29.base, #t~string29.offset := #Ultimate.allocOnStack(25);call #t~string30.base, #t~string30.offset := #Ultimate.allocOnStack(30);call #t~string31.base, #t~string31.offset := #Ultimate.allocOnStack(9);call #t~string32.base, #t~string32.offset := #Ultimate.allocOnStack(25);call #t~string42.base, #t~string42.offset := #Ultimate.allocOnStack(13);call #t~string44.base, #t~string44.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string44.base, #t~string44.offset, 1);call write~init~int(77, #t~string44.base, 1 + #t~string44.offset, 1);call write~init~int(101, #t~string44.base, 2 + #t~string44.offset, 1);call write~init~int(116, #t~string44.base, 3 + #t~string44.offset, 1);call write~init~int(104, #t~string44.base, 4 + #t~string44.offset, 1);call write~init~int(58, #t~string44.base, 5 + #t~string44.offset, 1);call write~init~int(0, #t~string44.base, 6 + #t~string44.offset, 1);call #t~string46.base, #t~string46.offset := #Ultimate.allocOnStack(5);call write~init~int(67, #t~string46.base, #t~string46.offset, 1);call write~init~int(82, #t~string46.base, 1 + #t~string46.offset, 1);call write~init~int(73, #t~string46.base, 2 + #t~string46.offset, 1);call write~init~int(84, #t~string46.base, 3 + #t~string46.offset, 1);call write~init~int(0, #t~string46.base, 4 + #t~string46.offset, 1);call #t~string48.base, #t~string48.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string48.base, #t~string48.offset, 1);call write~init~int(75, #t~string48.base, 1 + #t~string48.offset, 1);call write~init~int(0, #t~string48.base, 2 + #t~string48.offset, 1);call #t~string50.base, #t~string50.offset := #Ultimate.allocOnStack(2);call write~init~int(41, #t~string50.base, #t~string50.offset, 1);call write~init~int(0, #t~string50.base, 1 + #t~string50.offset, 1);call #t~string54.base, #t~string54.offset := #Ultimate.allocOnStack(13);call #t~string56.base, #t~string56.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string56.base, #t~string56.offset, 1);call write~init~int(110, #t~string56.base, 1 + #t~string56.offset, 1);call write~init~int(0, #t~string56.base, 2 + #t~string56.offset, 1);call #t~string58.base, #t~string58.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string58.base, #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 1 + #t~string58.offset, 1);call write~init~int(102, #t~string58.base, 2 + #t~string58.offset, 1);call write~init~int(0, #t~string58.base, 3 + #t~string58.offset, 1);call #t~string60.base, #t~string60.offset := #Ultimate.allocOnStack(7);call write~init~int(44, #t~string60.base, #t~string60.offset, 1);call write~init~int(80, #t~string60.base, 1 + #t~string60.offset, 1);call write~init~int(117, #t~string60.base, 2 + #t~string60.offset, 1);call write~init~int(109, #t~string60.base, 3 + #t~string60.offset, 1);call write~init~int(112, #t~string60.base, 4 + #t~string60.offset, 1);call write~init~int(58, #t~string60.base, 5 + #t~string60.offset, 1);call write~init~int(0, #t~string60.base, 6 + #t~string60.offset, 1);call #t~string62.base, #t~string62.offset := #Ultimate.allocOnStack(3);call write~init~int(79, #t~string62.base, #t~string62.offset, 1);call write~init~int(110, #t~string62.base, 1 + #t~string62.offset, 1);call write~init~int(0, #t~string62.base, 2 + #t~string62.offset, 1);call #t~string64.base, #t~string64.offset := #Ultimate.allocOnStack(4);call write~init~int(79, #t~string64.base, #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 1 + #t~string64.offset, 1);call write~init~int(102, #t~string64.base, 2 + #t~string64.offset, 1);call write~init~int(0, #t~string64.base, 3 + #t~string64.offset, 1);call #t~string66.base, #t~string66.offset := #Ultimate.allocOnStack(3);call write~init~int(41, #t~string66.base, #t~string66.offset, 1);call write~init~int(32, #t~string66.base, 1 + #t~string66.offset, 1);call write~init~int(0, #t~string66.base, 2 + #t~string66.offset, 1);call #t~string68.base, #t~string68.offset := #Ultimate.allocOnStack(2);call write~init~int(10, #t~string68.base, #t~string68.offset, 1);call write~init~int(0, #t~string68.base, 1 + #t~string68.offset, 1);~head~0.base, ~head~0.offset := 0, 0;~cleanupTimeShifts~0 := 4;~waterLevel~0 := 1;~methaneLevelCritical~0 := 0;~pumpRunning~0 := 0;~systemActive~0 := 1; {17019#true} is VALID [2020-07-17 21:32:49,614 INFO L280 TraceCheckUtils]: 2: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,614 INFO L275 TraceCheckUtils]: 3: Hoare quadruple {17019#true} {17019#true} #479#return; {17019#true} is VALID [2020-07-17 21:32:49,614 INFO L263 TraceCheckUtils]: 4: Hoare triple {17019#true} call #t~ret72 := main(); {17019#true} is VALID [2020-07-17 21:32:49,614 INFO L280 TraceCheckUtils]: 5: Hoare triple {17019#true} havoc ~retValue_acc~3;havoc ~tmp~3; {17019#true} is VALID [2020-07-17 21:32:49,614 INFO L263 TraceCheckUtils]: 6: Hoare triple {17019#true} call select_helpers(); {17019#true} is VALID [2020-07-17 21:32:49,615 INFO L280 TraceCheckUtils]: 7: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,615 INFO L275 TraceCheckUtils]: 8: Hoare quadruple {17019#true} {17019#true} #401#return; {17019#true} is VALID [2020-07-17 21:32:49,615 INFO L263 TraceCheckUtils]: 9: Hoare triple {17019#true} call select_features(); {17019#true} is VALID [2020-07-17 21:32:49,615 INFO L280 TraceCheckUtils]: 10: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,615 INFO L275 TraceCheckUtils]: 11: Hoare quadruple {17019#true} {17019#true} #403#return; {17019#true} is VALID [2020-07-17 21:32:49,615 INFO L263 TraceCheckUtils]: 12: Hoare triple {17019#true} call #t~ret35 := valid_product(); {17019#true} is VALID [2020-07-17 21:32:49,616 INFO L280 TraceCheckUtils]: 13: Hoare triple {17019#true} havoc ~retValue_acc~5;~retValue_acc~5 := 1;#res := ~retValue_acc~5; {17019#true} is VALID [2020-07-17 21:32:49,616 INFO L280 TraceCheckUtils]: 14: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,616 INFO L275 TraceCheckUtils]: 15: Hoare quadruple {17019#true} {17019#true} #405#return; {17019#true} is VALID [2020-07-17 21:32:49,616 INFO L280 TraceCheckUtils]: 16: Hoare triple {17019#true} assume -2147483648 <= #t~ret35 && #t~ret35 <= 2147483647;~tmp~3 := #t~ret35;havoc #t~ret35; {17019#true} is VALID [2020-07-17 21:32:49,616 INFO L280 TraceCheckUtils]: 17: Hoare triple {17019#true} assume 0 != ~tmp~3; {17019#true} is VALID [2020-07-17 21:32:49,617 INFO L263 TraceCheckUtils]: 18: Hoare triple {17019#true} call setup(); {17019#true} is VALID [2020-07-17 21:32:49,617 INFO L280 TraceCheckUtils]: 19: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,617 INFO L275 TraceCheckUtils]: 20: Hoare quadruple {17019#true} {17019#true} #407#return; {17019#true} is VALID [2020-07-17 21:32:49,617 INFO L263 TraceCheckUtils]: 21: Hoare triple {17019#true} call runTest(); {17019#true} is VALID [2020-07-17 21:32:49,617 INFO L263 TraceCheckUtils]: 22: Hoare triple {17019#true} call test(); {17019#true} is VALID [2020-07-17 21:32:49,617 INFO L280 TraceCheckUtils]: 23: Hoare triple {17019#true} havoc ~splverifierCounter~0;havoc ~tmp~4;havoc ~tmp___0~0;havoc ~tmp___1~0;havoc ~tmp___2~0;~splverifierCounter~0 := 0; {17019#true} is VALID [2020-07-17 21:32:49,618 INFO L280 TraceCheckUtils]: 24: Hoare triple {17019#true} assume !false; {17019#true} is VALID [2020-07-17 21:32:49,618 INFO L280 TraceCheckUtils]: 25: Hoare triple {17019#true} assume ~splverifierCounter~0 < 4; {17019#true} is VALID [2020-07-17 21:32:49,618 INFO L280 TraceCheckUtils]: 26: Hoare triple {17019#true} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {17019#true} is VALID [2020-07-17 21:32:49,618 INFO L280 TraceCheckUtils]: 27: Hoare triple {17019#true} assume 0 != ~tmp~4; {17019#true} is VALID [2020-07-17 21:32:49,618 INFO L263 TraceCheckUtils]: 28: Hoare triple {17019#true} call waterRise(); {17019#true} is VALID [2020-07-17 21:32:49,619 INFO L280 TraceCheckUtils]: 29: Hoare triple {17019#true} assume ~waterLevel~0 < 2;~waterLevel~0 := 1 + ~waterLevel~0; {17019#true} is VALID [2020-07-17 21:32:49,619 INFO L280 TraceCheckUtils]: 30: Hoare triple {17019#true} assume true; {17019#true} is VALID [2020-07-17 21:32:49,619 INFO L275 TraceCheckUtils]: 31: Hoare quadruple {17019#true} {17019#true} #449#return; {17019#true} is VALID [2020-07-17 21:32:49,619 INFO L280 TraceCheckUtils]: 32: Hoare triple {17019#true} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {17019#true} is VALID [2020-07-17 21:32:49,619 INFO L280 TraceCheckUtils]: 33: Hoare triple {17019#true} assume !(0 != ~tmp___0~0); {17019#true} is VALID [2020-07-17 21:32:49,619 INFO L280 TraceCheckUtils]: 34: Hoare triple {17019#true} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {17019#true} is VALID [2020-07-17 21:32:49,620 INFO L280 TraceCheckUtils]: 35: Hoare triple {17019#true} assume 0 != ~tmp___2~0; {17019#true} is VALID [2020-07-17 21:32:49,620 INFO L263 TraceCheckUtils]: 36: Hoare triple {17019#true} call timeShift(); {17019#true} is VALID [2020-07-17 21:32:49,620 INFO L280 TraceCheckUtils]: 37: Hoare triple {17019#true} assume !(0 != ~pumpRunning~0); {17019#true} is VALID [2020-07-17 21:32:49,620 INFO L280 TraceCheckUtils]: 38: Hoare triple {17019#true} assume 0 != ~systemActive~0; {17019#true} is VALID [2020-07-17 21:32:49,620 INFO L263 TraceCheckUtils]: 39: Hoare triple {17019#true} call processEnvironment(); {17019#true} is VALID [2020-07-17 21:32:49,620 INFO L280 TraceCheckUtils]: 40: Hoare triple {17019#true} havoc ~tmp~5; {17019#true} is VALID [2020-07-17 21:32:49,621 INFO L280 TraceCheckUtils]: 41: Hoare triple {17019#true} assume 0 == ~pumpRunning~0; {17019#true} is VALID [2020-07-17 21:32:49,621 INFO L263 TraceCheckUtils]: 42: Hoare triple {17019#true} call #t~ret51 := isHighWaterLevel(); {17019#true} is VALID [2020-07-17 21:32:49,621 INFO L280 TraceCheckUtils]: 43: Hoare triple {17019#true} havoc ~retValue_acc~11;havoc ~tmp~6;havoc ~tmp___0~1; {17019#true} is VALID [2020-07-17 21:32:49,621 INFO L263 TraceCheckUtils]: 44: Hoare triple {17019#true} call #t~ret69 := isHighWaterSensorDry(); {17019#true} is VALID [2020-07-17 21:32:49,621 INFO L280 TraceCheckUtils]: 45: Hoare triple {17019#true} havoc ~retValue_acc~8; {17019#true} is VALID [2020-07-17 21:32:49,622 INFO L280 TraceCheckUtils]: 46: Hoare triple {17019#true} assume !(~waterLevel~0 < 2);~retValue_acc~8 := 0;#res := ~retValue_acc~8; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,622 INFO L280 TraceCheckUtils]: 47: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,623 INFO L275 TraceCheckUtils]: 48: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #457#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,624 INFO L280 TraceCheckUtils]: 49: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret69 && #t~ret69 <= 2147483647;~tmp~6 := #t~ret69;havoc #t~ret69; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,624 INFO L280 TraceCheckUtils]: 50: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp~6);~tmp___0~1 := 1; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,625 INFO L280 TraceCheckUtils]: 51: Hoare triple {17073#(<= 2 ~waterLevel~0)} ~retValue_acc~11 := ~tmp___0~1;#res := ~retValue_acc~11; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,625 INFO L280 TraceCheckUtils]: 52: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,626 INFO L275 TraceCheckUtils]: 53: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #441#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,626 INFO L280 TraceCheckUtils]: 54: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret51 && #t~ret51 <= 2147483647;~tmp~5 := #t~ret51;havoc #t~ret51; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,627 INFO L280 TraceCheckUtils]: 55: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume 0 != ~tmp~5; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,627 INFO L263 TraceCheckUtils]: 56: Hoare triple {17073#(<= 2 ~waterLevel~0)} call activatePump(); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,628 INFO L280 TraceCheckUtils]: 57: Hoare triple {17073#(<= 2 ~waterLevel~0)} ~pumpRunning~0 := 1; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,628 INFO L280 TraceCheckUtils]: 58: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,629 INFO L275 TraceCheckUtils]: 59: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17073#(<= 2 ~waterLevel~0)} #443#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,629 INFO L280 TraceCheckUtils]: 60: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,630 INFO L275 TraceCheckUtils]: 61: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #461#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,631 INFO L263 TraceCheckUtils]: 62: Hoare triple {17073#(<= 2 ~waterLevel~0)} call __utac_acc__Specification4_spec__1(); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,631 INFO L280 TraceCheckUtils]: 63: Hoare triple {17073#(<= 2 ~waterLevel~0)} havoc ~tmp~7;havoc ~tmp___0~2; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,632 INFO L263 TraceCheckUtils]: 64: Hoare triple {17073#(<= 2 ~waterLevel~0)} call #t~ret70 := getWaterLevel(); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,632 INFO L280 TraceCheckUtils]: 65: Hoare triple {17073#(<= 2 ~waterLevel~0)} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,632 INFO L280 TraceCheckUtils]: 66: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,633 INFO L275 TraceCheckUtils]: 67: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17073#(<= 2 ~waterLevel~0)} #395#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,633 INFO L280 TraceCheckUtils]: 68: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,634 INFO L280 TraceCheckUtils]: 69: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 == ~tmp~7); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,634 INFO L280 TraceCheckUtils]: 70: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,634 INFO L275 TraceCheckUtils]: 71: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17073#(<= 2 ~waterLevel~0)} #463#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,635 INFO L280 TraceCheckUtils]: 72: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume true; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,635 INFO L275 TraceCheckUtils]: 73: Hoare quadruple {17073#(<= 2 ~waterLevel~0)} {17019#true} #453#return; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,636 INFO L280 TraceCheckUtils]: 74: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !false; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,636 INFO L280 TraceCheckUtils]: 75: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume ~splverifierCounter~0 < 4; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,637 INFO L280 TraceCheckUtils]: 76: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet37 && #t~nondet37 <= 2147483647;~tmp~4 := #t~nondet37;havoc #t~nondet37; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,637 INFO L280 TraceCheckUtils]: 77: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp~4); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,638 INFO L280 TraceCheckUtils]: 78: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet38 && #t~nondet38 <= 2147483647;~tmp___0~0 := #t~nondet38;havoc #t~nondet38; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,639 INFO L280 TraceCheckUtils]: 79: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume !(0 != ~tmp___0~0); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,639 INFO L280 TraceCheckUtils]: 80: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume -2147483648 <= #t~nondet39 && #t~nondet39 <= 2147483647;~tmp___2~0 := #t~nondet39;havoc #t~nondet39; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,639 INFO L280 TraceCheckUtils]: 81: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume 0 != ~tmp___2~0; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,640 INFO L263 TraceCheckUtils]: 82: Hoare triple {17073#(<= 2 ~waterLevel~0)} call timeShift(); {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,640 INFO L280 TraceCheckUtils]: 83: Hoare triple {17073#(<= 2 ~waterLevel~0)} assume 0 != ~pumpRunning~0; {17073#(<= 2 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,641 INFO L263 TraceCheckUtils]: 84: Hoare triple {17073#(<= 2 ~waterLevel~0)} call lowerWaterLevel(); {17408#(<= |old(~waterLevel~0)| ~waterLevel~0)} is VALID [2020-07-17 21:32:49,641 INFO L280 TraceCheckUtils]: 85: Hoare triple {17408#(<= |old(~waterLevel~0)| ~waterLevel~0)} assume ~waterLevel~0 > 0;~waterLevel~0 := ~waterLevel~0 - 1; {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} is VALID [2020-07-17 21:32:49,642 INFO L280 TraceCheckUtils]: 86: Hoare triple {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} assume true; {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} is VALID [2020-07-17 21:32:49,642 INFO L275 TraceCheckUtils]: 87: Hoare quadruple {17149#(<= |old(~waterLevel~0)| (+ ~waterLevel~0 1))} {17073#(<= 2 ~waterLevel~0)} #459#return; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,643 INFO L280 TraceCheckUtils]: 88: Hoare triple {17077#(<= 1 ~waterLevel~0)} assume 0 != ~systemActive~0; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,644 INFO L263 TraceCheckUtils]: 89: Hoare triple {17077#(<= 1 ~waterLevel~0)} call processEnvironment(); {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,644 INFO L280 TraceCheckUtils]: 90: Hoare triple {17077#(<= 1 ~waterLevel~0)} havoc ~tmp~5; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,645 INFO L280 TraceCheckUtils]: 91: Hoare triple {17077#(<= 1 ~waterLevel~0)} assume !(0 == ~pumpRunning~0); {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,645 INFO L263 TraceCheckUtils]: 92: Hoare triple {17077#(<= 1 ~waterLevel~0)} call processEnvironment__wrappee__base(); {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,646 INFO L280 TraceCheckUtils]: 93: Hoare triple {17077#(<= 1 ~waterLevel~0)} assume true; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,647 INFO L275 TraceCheckUtils]: 94: Hoare quadruple {17077#(<= 1 ~waterLevel~0)} {17077#(<= 1 ~waterLevel~0)} #447#return; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,647 INFO L280 TraceCheckUtils]: 95: Hoare triple {17077#(<= 1 ~waterLevel~0)} assume true; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,648 INFO L275 TraceCheckUtils]: 96: Hoare quadruple {17077#(<= 1 ~waterLevel~0)} {17077#(<= 1 ~waterLevel~0)} #461#return; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,649 INFO L263 TraceCheckUtils]: 97: Hoare triple {17077#(<= 1 ~waterLevel~0)} call __utac_acc__Specification4_spec__1(); {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,653 INFO L280 TraceCheckUtils]: 98: Hoare triple {17077#(<= 1 ~waterLevel~0)} havoc ~tmp~7;havoc ~tmp___0~2; {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,656 INFO L263 TraceCheckUtils]: 99: Hoare triple {17077#(<= 1 ~waterLevel~0)} call #t~ret70 := getWaterLevel(); {17077#(<= 1 ~waterLevel~0)} is VALID [2020-07-17 21:32:49,657 INFO L280 TraceCheckUtils]: 100: Hoare triple {17077#(<= 1 ~waterLevel~0)} havoc ~retValue_acc~7;~retValue_acc~7 := ~waterLevel~0;#res := ~retValue_acc~7; {17457#(and (<= ~waterLevel~0 |getWaterLevel_#res|) (<= 1 ~waterLevel~0))} is VALID [2020-07-17 21:32:49,658 INFO L280 TraceCheckUtils]: 101: Hoare triple {17457#(and (<= ~waterLevel~0 |getWaterLevel_#res|) (<= 1 ~waterLevel~0))} assume true; {17457#(and (<= ~waterLevel~0 |getWaterLevel_#res|) (<= 1 ~waterLevel~0))} is VALID [2020-07-17 21:32:49,659 INFO L275 TraceCheckUtils]: 102: Hoare quadruple {17457#(and (<= ~waterLevel~0 |getWaterLevel_#res|) (<= 1 ~waterLevel~0))} {17077#(<= 1 ~waterLevel~0)} #395#return; {17088#(<= 1 |__utac_acc__Specification4_spec__1_#t~ret70|)} is VALID [2020-07-17 21:32:49,660 INFO L280 TraceCheckUtils]: 103: Hoare triple {17088#(<= 1 |__utac_acc__Specification4_spec__1_#t~ret70|)} assume -2147483648 <= #t~ret70 && #t~ret70 <= 2147483647;~tmp~7 := #t~ret70;havoc #t~ret70; {17089#(<= 1 __utac_acc__Specification4_spec__1_~tmp~7)} is VALID [2020-07-17 21:32:49,660 INFO L280 TraceCheckUtils]: 104: Hoare triple {17089#(<= 1 __utac_acc__Specification4_spec__1_~tmp~7)} assume 0 == ~tmp~7; {17020#false} is VALID [2020-07-17 21:32:49,660 INFO L263 TraceCheckUtils]: 105: Hoare triple {17020#false} call #t~ret71 := isPumpRunning(); {17020#false} is VALID [2020-07-17 21:32:49,661 INFO L280 TraceCheckUtils]: 106: Hoare triple {17020#false} havoc ~retValue_acc~10;~retValue_acc~10 := ~pumpRunning~0;#res := ~retValue_acc~10; {17020#false} is VALID [2020-07-17 21:32:49,661 INFO L280 TraceCheckUtils]: 107: Hoare triple {17020#false} assume true; {17020#false} is VALID [2020-07-17 21:32:49,661 INFO L275 TraceCheckUtils]: 108: Hoare quadruple {17020#false} {17020#false} #397#return; {17020#false} is VALID [2020-07-17 21:32:49,661 INFO L280 TraceCheckUtils]: 109: Hoare triple {17020#false} assume -2147483648 <= #t~ret71 && #t~ret71 <= 2147483647;~tmp___0~2 := #t~ret71;havoc #t~ret71; {17020#false} is VALID [2020-07-17 21:32:49,661 INFO L280 TraceCheckUtils]: 110: Hoare triple {17020#false} assume 0 != ~tmp___0~2; {17020#false} is VALID [2020-07-17 21:32:49,661 INFO L263 TraceCheckUtils]: 111: Hoare triple {17020#false} call __automaton_fail(); {17020#false} is VALID [2020-07-17 21:32:49,662 INFO L280 TraceCheckUtils]: 112: Hoare triple {17020#false} assume !false; {17020#false} is VALID [2020-07-17 21:32:49,671 INFO L134 CoverageAnalysis]: Checked inductivity of 24 backedges. 14 proven. 10 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2020-07-17 21:32:49,671 INFO L220 FreeRefinementEngine]: Constructing automaton from 0 perfect and 2 imperfect interpolant sequences. [2020-07-17 21:32:49,671 INFO L233 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [12, 9] total 14 [2020-07-17 21:32:49,672 INFO L156 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [677649720] [2020-07-17 21:32:49,672 INFO L78 Accepts]: Start accepts. Automaton has 14 states. Word has length 113 [2020-07-17 21:32:49,690 INFO L84 Accepts]: Finished accepts. word is accepted. [2020-07-17 21:32:49,690 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 14 states. [2020-07-17 21:32:49,875 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 152 edges. 152 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:32:49,875 INFO L459 AbstractCegarLoop]: Interpolant automaton has 14 states [2020-07-17 21:32:49,875 INFO L143 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2020-07-17 21:32:49,876 INFO L142 InterpolantAutomaton]: Constructing interpolant automaton starting with 14 interpolants. [2020-07-17 21:32:49,876 INFO L144 InterpolantAutomaton]: CoverageRelationStatistics Valid=39, Invalid=143, Unknown=0, NotChecked=0, Total=182 [2020-07-17 21:32:49,876 INFO L87 Difference]: Start difference. First operand 479 states and 581 transitions. Second operand 14 states. [2020-07-17 21:32:50,918 WARN L193 SmtUtils]: Spent 216.00 ms on a formula simplification that was a NOOP. DAG size: 186 [2020-07-17 21:32:54,396 WARN L193 SmtUtils]: Spent 219.00 ms on a formula simplification that was a NOOP. DAG size: 186 [2020-07-17 21:32:58,986 WARN L193 SmtUtils]: Spent 438.00 ms on a formula simplification. DAG size of input: 189 DAG size of output: 188 [2020-07-17 21:32:59,698 WARN L193 SmtUtils]: Spent 239.00 ms on a formula simplification that was a NOOP. DAG size: 188 [2020-07-17 21:33:00,105 WARN L193 SmtUtils]: Spent 222.00 ms on a formula simplification that was a NOOP. DAG size: 188 [2020-07-17 21:33:00,644 WARN L193 SmtUtils]: Spent 439.00 ms on a formula simplification. DAG size of input: 191 DAG size of output: 188 [2020-07-17 21:33:01,137 WARN L193 SmtUtils]: Spent 224.00 ms on a formula simplification that was a NOOP. DAG size: 189 [2020-07-17 21:33:01,630 WARN L193 SmtUtils]: Spent 247.00 ms on a formula simplification that was a NOOP. DAG size: 189 [2020-07-17 21:33:05,789 WARN L193 SmtUtils]: Spent 227.00 ms on a formula simplification that was a NOOP. DAG size: 186 [2020-07-17 21:33:13,668 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:33:13,668 INFO L93 Difference]: Finished difference Result 969 states and 1243 transitions. [2020-07-17 21:33:13,668 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 25 states. [2020-07-17 21:33:13,668 INFO L78 Accepts]: Start accepts. Automaton has 14 states. Word has length 113 [2020-07-17 21:33:13,669 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2020-07-17 21:33:13,669 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 14 states. [2020-07-17 21:33:13,674 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 25 states to 25 states and 496 transitions. [2020-07-17 21:33:13,674 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 14 states. [2020-07-17 21:33:13,680 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 25 states to 25 states and 496 transitions. [2020-07-17 21:33:13,680 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 25 states and 496 transitions. [2020-07-17 21:33:15,353 INFO L119 InductivityCheck]: Floyd-Hoare automaton has 496 edges. 496 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2020-07-17 21:33:15,375 INFO L225 Difference]: With dead ends: 969 [2020-07-17 21:33:15,376 INFO L226 Difference]: Without dead ends: 564 [2020-07-17 21:33:15,377 INFO L675 BasicCegarLoop]: 0 DeclaredPredicates, 188 GetRequests, 153 SyntacticMatches, 4 SemanticMatches, 31 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 238 ImplicationChecksByTransitivity, 3.6s TimeCoverageRelationStatistics Valid=301, Invalid=755, Unknown=0, NotChecked=0, Total=1056 [2020-07-17 21:33:15,378 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 564 states. [2020-07-17 21:33:19,661 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 564 to 467. [2020-07-17 21:33:19,661 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2020-07-17 21:33:19,661 INFO L82 GeneralOperation]: Start isEquivalent. First operand 564 states. Second operand 467 states. [2020-07-17 21:33:19,661 INFO L74 IsIncluded]: Start isIncluded. First operand 564 states. Second operand 467 states. [2020-07-17 21:33:19,662 INFO L87 Difference]: Start difference. First operand 564 states. Second operand 467 states. [2020-07-17 21:33:19,683 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:33:19,683 INFO L93 Difference]: Finished difference Result 564 states and 730 transitions. [2020-07-17 21:33:19,684 INFO L276 IsEmpty]: Start isEmpty. Operand 564 states and 730 transitions. [2020-07-17 21:33:19,686 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:33:19,686 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:33:19,686 INFO L74 IsIncluded]: Start isIncluded. First operand 467 states. Second operand 564 states. [2020-07-17 21:33:19,687 INFO L87 Difference]: Start difference. First operand 467 states. Second operand 564 states. [2020-07-17 21:33:19,709 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2020-07-17 21:33:19,709 INFO L93 Difference]: Finished difference Result 564 states and 730 transitions. [2020-07-17 21:33:19,709 INFO L276 IsEmpty]: Start isEmpty. Operand 564 states and 730 transitions. [2020-07-17 21:33:19,711 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2020-07-17 21:33:19,712 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2020-07-17 21:33:19,712 INFO L88 GeneralOperation]: Finished isEquivalent. [2020-07-17 21:33:19,712 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2020-07-17 21:33:19,712 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 467 states. [2020-07-17 21:33:19,729 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 467 states to 467 states and 565 transitions. [2020-07-17 21:33:19,730 INFO L78 Accepts]: Start accepts. Automaton has 467 states and 565 transitions. Word has length 113 [2020-07-17 21:33:19,730 INFO L84 Accepts]: Finished accepts. word is rejected. [2020-07-17 21:33:19,730 INFO L479 AbstractCegarLoop]: Abstraction has 467 states and 565 transitions. [2020-07-17 21:33:19,730 INFO L480 AbstractCegarLoop]: Interpolant automaton has 14 states. [2020-07-17 21:33:19,731 INFO L276 IsEmpty]: Start isEmpty. Operand 467 states and 565 transitions. [2020-07-17 21:33:19,733 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 149 [2020-07-17 21:33:19,733 INFO L414 BasicCegarLoop]: Found error trace [2020-07-17 21:33:19,733 INFO L422 BasicCegarLoop]: trace histogram [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2020-07-17 21:33:19,943 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable8,5 z3 -smt2 -in SMTLIB2_COMPLIANT=true [2020-07-17 21:33:19,943 INFO L427 AbstractCegarLoop]: === Iteration 10 === [__automaton_failErr0ASSERT_VIOLATIONERROR_FUNCTION]=== [2020-07-17 21:33:19,944 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2020-07-17 21:33:19,944 INFO L82 PathProgramCache]: Analyzing trace with hash 1088865250, now seen corresponding path program 2 times [2020-07-17 21:33:19,944 INFO L163 FreeRefinementEngine]: Executing refinement strategy CAMEL [2020-07-17 21:33:19,945 INFO L354 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1132666815] [2020-07-17 21:33:19,945 INFO L94 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2020-07-17 21:33:20,017 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2020-07-17 21:33:20,110 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2020-07-17 21:33:20,363 INFO L174 FreeRefinementEngine]: Strategy CAMEL found a feasible trace [2020-07-17 21:33:20,364 INFO L520 BasicCegarLoop]: Counterexample might be feasible [2020-07-17 21:33:20,364 WARN L516 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable9 [2020-07-17 21:33:20,756 WARN L170 areAnnotationChecker]: __utac__exception__cf_handler_freeENTRY has no Hoare annotation [2020-07-17 21:33:20,756 WARN L170 areAnnotationChecker]: __utac__exception__cf_handler_resetENTRY has no Hoare annotation [2020-07-17 21:33:20,756 WARN L170 areAnnotationChecker]: select_helpersFINAL has no Hoare annotation [2020-07-17 21:33:20,756 WARN L170 areAnnotationChecker]: valid_productENTRY has no Hoare annotation [2020-07-17 21:33:20,757 WARN L170 areAnnotationChecker]: __utac_acc__Specification4_spec__1ENTRY has no Hoare annotation [2020-07-17 21:33:20,757 WARN L170 areAnnotationChecker]: mainENTRY has no Hoare annotation [2020-07-17 21:33:20,757 WARN L170 areAnnotationChecker]: Specification2ENTRY has no Hoare annotation [2020-07-17 21:33:20,757 WARN L170 areAnnotationChecker]: Specification2ENTRY has no Hoare annotation [2020-07-17 21:33:20,757 WARN L170 areAnnotationChecker]: isPumpRunningENTRY has no Hoare annotation [2020-07-17 21:33:20,757 WARN L170 areAnnotationChecker]: printPumpENTRY has no Hoare annotation [2020-07-17 21:33:20,758 WARN L170 areAnnotationChecker]: select_featuresFINAL has no Hoare annotation [2020-07-17 21:33:20,758 WARN L170 areAnnotationChecker]: __utac__exception__cf_handler_setENTRY has no Hoare annotation [2020-07-17 21:33:20,758 WARN L170 areAnnotationChecker]: __utac__get_this_argtypeENTRY has no Hoare annotation [2020-07-17 21:33:20,758 WARN L170 areAnnotationChecker]: runTestENTRY has no Hoare annotation [2020-07-17 21:33:20,758 WARN L170 areAnnotationChecker]: runTestENTRY has no Hoare annotation [2020-07-17 21:33:20,758 WARN L170 areAnnotationChecker]: isMethaneAlarmENTRY has no Hoare annotation [2020-07-17 21:33:20,759 WARN L170 areAnnotationChecker]: deactivatePumpENTRY has no Hoare annotation [2020-07-17 21:33:20,759 WARN L170 areAnnotationChecker]: isHighWaterSensorDryENTRY has no Hoare annotation [2020-07-17 21:33:20,759 WARN L170 areAnnotationChecker]: processEnvironmentENTRY has no Hoare annotation [2020-07-17 21:33:20,759 WARN L170 areAnnotationChecker]: processEnvironment__wrappee__baseFINAL has no Hoare annotation [2020-07-17 21:33:20,759 WARN L170 areAnnotationChecker]: testENTRY has no Hoare annotation [2020-07-17 21:33:20,759 WARN L170 areAnnotationChecker]: __utac__get_this_argENTRY has no Hoare annotation [2020-07-17 21:33:20,760 WARN L170 areAnnotationChecker]: ULTIMATE.initENTRY has no Hoare annotation [2020-07-17 21:33:20,760 WARN L170 areAnnotationChecker]: __utac__error_stack_mgtENTRY has no Hoare annotation [2020-07-17 21:33:20,760 WARN L170 areAnnotationChecker]: select_oneENTRY has no Hoare annotation [2020-07-17 21:33:20,760 WARN L170 areAnnotationChecker]: printEnvironmentENTRY has no Hoare annotation [2020-07-17 21:33:20,760 WARN L170 areAnnotationChecker]: activatePumpENTRY has no Hoare annotation [2020-07-17 21:33:20,761 WARN L170 areAnnotationChecker]: ##fun~int~X~int~TO~intENTRY has no Hoare annotation [2020-07-17 21:33:20,761 WARN L170 areAnnotationChecker]: changeMethaneLevelENTRY has no Hoare annotation [2020-07-17 21:33:20,761 WARN L170 areAnnotationChecker]: changeMethaneLevelENTRY has no Hoare annotation [2020-07-17 21:33:20,761 WARN L170 areAnnotationChecker]: getWaterLevelENTRY has no Hoare annotation [2020-07-17 21:33:20,761 WARN L170 areAnnotationChecker]: isHighWaterLevelENTRY has no Hoare annotation [2020-07-17 21:33:20,761 WARN L170 areAnnotationChecker]: cleanupENTRY has no Hoare annotation [2020-07-17 21:33:20,762 WARN L170 areAnnotationChecker]: isMethaneLevelCriticalENTRY has no Hoare annotation [2020-07-17 21:33:20,762 WARN L170 areAnnotationChecker]: timeShiftENTRY has no Hoare annotation [2020-07-17 21:33:20,762 WARN L170 areAnnotationChecker]: timeShiftENTRY has no Hoare annotation [2020-07-17 21:33:20,762 WARN L170 areAnnotationChecker]: lowerWaterLevelENTRY has no Hoare annotation [2020-07-17 21:33:20,762 WARN L170 areAnnotationChecker]: lowerWaterLevelENTRY has no Hoare annotation [2020-07-17 21:33:20,762 WARN L170 areAnnotationChecker]: ULTIMATE.startENTRY has no Hoare annotation [2020-07-17 21:33:20,763 WARN L170 areAnnotationChecker]: ULTIMATE.startENTRY has no Hoare annotation [2020-07-17 21:33:20,763 WARN L170 areAnnotationChecker]: setupFINAL has no Hoare annotation [2020-07-17 21:33:20,763 WARN L170 areAnnotationChecker]: waterRiseENTRY has no Hoare annotation [2020-07-17 21:33:20,763 WARN L170 areAnnotationChecker]: waterRiseENTRY has no Hoare annotation [2020-07-17 21:33:20,763 WARN L170 areAnnotationChecker]: __automaton_failENTRY has no Hoare annotation [2020-07-17 21:33:20,763 WARN L170 areAnnotationChecker]: __automaton_failENTRY has no Hoare annotation [2020-07-17 21:33:20,764 WARN L170 areAnnotationChecker]: L117-2 has no Hoare annotation [2020-07-17 21:33:20,764 WARN L170 areAnnotationChecker]: L117-2 has no Hoare annotation [2020-07-17 21:33:20,764 WARN L170 areAnnotationChecker]: L117-2 has no Hoare annotation [2020-07-17 21:33:20,764 WARN L170 areAnnotationChecker]: L174-2 has no Hoare annotation [2020-07-17 21:33:20,764 WARN L170 areAnnotationChecker]: L174-2 has no Hoare annotation [2020-07-17 21:33:20,764 WARN L170 areAnnotationChecker]: L174-2 has no Hoare annotation [2020-07-17 21:33:20,765 WARN L170 areAnnotationChecker]: select_helpersEXIT has no Hoare annotation [2020-07-17 21:33:20,765 WARN L170 areAnnotationChecker]: valid_productFINAL has no Hoare annotation [2020-07-17 21:33:20,765 WARN L170 areAnnotationChecker]: L880 has no Hoare annotation [2020-07-17 21:33:20,765 WARN L170 areAnnotationChecker]: L880 has no Hoare annotation [2020-07-17 21:33:20,765 WARN L170 areAnnotationChecker]: L492 has no Hoare annotation [2020-07-17 21:33:20,765 WARN L170 areAnnotationChecker]: L492 has no Hoare annotation [2020-07-17 21:33:20,766 WARN L170 areAnnotationChecker]: L446 has no Hoare annotation [2020-07-17 21:33:20,766 WARN L170 areAnnotationChecker]: L446 has no Hoare annotation [2020-07-17 21:33:20,766 WARN L170 areAnnotationChecker]: isPumpRunningFINAL has no Hoare annotation [2020-07-17 21:33:20,766 WARN L170 areAnnotationChecker]: L816 has no Hoare annotation [2020-07-17 21:33:20,766 WARN L170 areAnnotationChecker]: L816 has no Hoare annotation [2020-07-17 21:33:20,766 WARN L170 areAnnotationChecker]: select_featuresEXIT has no Hoare annotation [2020-07-17 21:33:20,767 WARN L170 areAnnotationChecker]: __utac__exception__cf_handler_setFINAL has no Hoare annotation [2020-07-17 21:33:20,767 WARN L170 areAnnotationChecker]: L373 has no Hoare annotation [2020-07-17 21:33:20,767 WARN L170 areAnnotationChecker]: L373 has no Hoare annotation [2020-07-17 21:33:20,767 WARN L170 areAnnotationChecker]: runTestFINAL has no Hoare annotation [2020-07-17 21:33:20,767 WARN L170 areAnnotationChecker]: L794 has no Hoare annotation [2020-07-17 21:33:20,767 WARN L170 areAnnotationChecker]: L794 has no Hoare annotation [2020-07-17 21:33:20,768 WARN L170 areAnnotationChecker]: deactivatePumpFINAL has no Hoare annotation [2020-07-17 21:33:20,768 WARN L170 areAnnotationChecker]: L698 has no Hoare annotation [2020-07-17 21:33:20,768 WARN L170 areAnnotationChecker]: L698 has no Hoare annotation [2020-07-17 21:33:20,768 WARN L170 areAnnotationChecker]: L752 has no Hoare annotation [2020-07-17 21:33:20,768 WARN L170 areAnnotationChecker]: L752 has no Hoare annotation [2020-07-17 21:33:20,768 WARN L170 areAnnotationChecker]: processEnvironment__wrappee__baseEXIT has no Hoare annotation [2020-07-17 21:33:20,769 WARN L170 areAnnotationChecker]: processEnvironment__wrappee__baseEXIT has no Hoare annotation [2020-07-17 21:33:20,769 WARN L170 areAnnotationChecker]: L598 has no Hoare annotation [2020-07-17 21:33:20,769 WARN L170 areAnnotationChecker]: L598 has no Hoare annotation [2020-07-17 21:33:20,769 WARN L170 areAnnotationChecker]: L598 has no Hoare annotation [2020-07-17 21:33:20,769 WARN L170 areAnnotationChecker]: L327 has no Hoare annotation [2020-07-17 21:33:20,769 WARN L170 areAnnotationChecker]: L327 has no Hoare annotation [2020-07-17 21:33:20,770 WARN L170 areAnnotationChecker]: ULTIMATE.initFINAL has no Hoare annotation [2020-07-17 21:33:20,770 WARN L170 areAnnotationChecker]: L234 has no Hoare annotation [2020-07-17 21:33:20,770 WARN L170 areAnnotationChecker]: L234 has no Hoare annotation [2020-07-17 21:33:20,770 WARN L170 areAnnotationChecker]: select_oneFINAL has no Hoare annotation [2020-07-17 21:33:20,770 WARN L170 areAnnotationChecker]: L670 has no Hoare annotation [2020-07-17 21:33:20,770 WARN L170 areAnnotationChecker]: L670 has no Hoare annotation [2020-07-17 21:33:20,771 WARN L170 areAnnotationChecker]: activatePumpFINAL has no Hoare annotation [2020-07-17 21:33:20,771 WARN L170 areAnnotationChecker]: ##fun~int~X~int~TO~intFINAL has no Hoare annotation [2020-07-17 21:33:20,771 WARN L170 areAnnotationChecker]: L645-1 has no Hoare annotation [2020-07-17 21:33:20,771 WARN L170 areAnnotationChecker]: getWaterLevelFINAL has no Hoare annotation [2020-07-17 21:33:20,771 WARN L170 areAnnotationChecker]: L852 has no Hoare annotation [2020-07-17 21:33:20,772 WARN L170 areAnnotationChecker]: L852 has no Hoare annotation [2020-07-17 21:33:20,772 WARN L170 areAnnotationChecker]: L414 has no Hoare annotation [2020-07-17 21:33:20,772 WARN L170 areAnnotationChecker]: L414 has no Hoare annotation [2020-07-17 21:33:20,772 WARN L170 areAnnotationChecker]: isMethaneLevelCriticalFINAL has no Hoare annotation [2020-07-17 21:33:20,772 WARN L170 areAnnotationChecker]: L722 has no Hoare annotation [2020-07-17 21:33:20,772 WARN L170 areAnnotationChecker]: L722 has no Hoare annotation [2020-07-17 21:33:20,773 WARN L170 areAnnotationChecker]: L720 has no Hoare annotation [2020-07-17 21:33:20,773 WARN L170 areAnnotationChecker]: L720 has no Hoare annotation [2020-07-17 21:33:20,773 WARN L170 areAnnotationChecker]: L621-1 has no Hoare annotation [2020-07-17 21:33:20,773 WARN L170 areAnnotationChecker]: L-1 has no Hoare annotation [2020-07-17 21:33:20,773 WARN L170 areAnnotationChecker]: L-1 has no Hoare annotation [2020-07-17 21:33:20,773 WARN L170 areAnnotationChecker]: setupEXIT has no Hoare annotation [2020-07-17 21:33:20,774 WARN L170 areAnnotationChecker]: L633-1 has no Hoare annotation [2020-07-17 21:33:20,774 WARN L170 areAnnotationChecker]: __automaton_failFINAL has no Hoare annotation [2020-07-17 21:33:20,774 WARN L170 areAnnotationChecker]: L139 has no Hoare annotation [2020-07-17 21:33:20,774 WARN L170 areAnnotationChecker]: L118 has no Hoare annotation [2020-07-17 21:33:20,774 WARN L170 areAnnotationChecker]: L200 has no Hoare annotation [2020-07-17 21:33:20,774 WARN L170 areAnnotationChecker]: L200 has no Hoare annotation [2020-07-17 21:33:20,774 WARN L170 areAnnotationChecker]: L175 has no Hoare annotation [2020-07-17 21:33:20,775 WARN L170 areAnnotationChecker]: L492-1 has no Hoare annotation [2020-07-17 21:33:20,775 WARN L170 areAnnotationChecker]: L492-1 has no Hoare annotation [2020-07-17 21:33:20,775 WARN L170 areAnnotationChecker]: valid_productEXIT has no Hoare annotation [2020-07-17 21:33:20,775 WARN L170 areAnnotationChecker]: L880-1 has no Hoare annotation [2020-07-17 21:33:20,775 WARN L170 areAnnotationChecker]: L447 has no Hoare annotation [2020-07-17 21:33:20,775 WARN L170 areAnnotationChecker]: L447 has no Hoare annotation [2020-07-17 21:33:20,776 WARN L170 areAnnotationChecker]: isPumpRunningEXIT has no Hoare annotation [2020-07-17 21:33:20,776 WARN L170 areAnnotationChecker]: L816-2 has no Hoare annotation [2020-07-17 21:33:20,776 WARN L170 areAnnotationChecker]: L493 has no Hoare annotation [2020-07-17 21:33:20,776 WARN L170 areAnnotationChecker]: L493 has no Hoare annotation [2020-07-17 21:33:20,776 WARN L170 areAnnotationChecker]: L379 has no Hoare annotation [2020-07-17 21:33:20,776 WARN L170 areAnnotationChecker]: L379 has no Hoare annotation [2020-07-17 21:33:20,777 WARN L170 areAnnotationChecker]: L373-1 has no Hoare annotation [2020-07-17 21:33:20,777 WARN L170 areAnnotationChecker]: runTestEXIT has no Hoare annotation [2020-07-17 21:33:20,777 WARN L170 areAnnotationChecker]: L794-1 has no Hoare annotation [2020-07-17 21:33:20,777 WARN L170 areAnnotationChecker]: isHighWaterSensorDryFINAL has no Hoare annotation [2020-07-17 21:33:20,777 WARN L170 areAnnotationChecker]: L754 has no Hoare annotation [2020-07-17 21:33:20,777 WARN L170 areAnnotationChecker]: L754 has no Hoare annotation [2020-07-17 21:33:20,778 WARN L170 areAnnotationChecker]: L767 has no Hoare annotation [2020-07-17 21:33:20,778 WARN L170 areAnnotationChecker]: L767 has no Hoare annotation [2020-07-17 21:33:20,778 WARN L170 areAnnotationChecker]: L767-1 has no Hoare annotation [2020-07-17 21:33:20,778 WARN L170 areAnnotationChecker]: L601 has no Hoare annotation [2020-07-17 21:33:20,778 WARN L170 areAnnotationChecker]: L601 has no Hoare annotation [2020-07-17 21:33:20,778 WARN L170 areAnnotationChecker]: L556 has no Hoare annotation [2020-07-17 21:33:20,779 WARN L170 areAnnotationChecker]: L556 has no Hoare annotation [2020-07-17 21:33:20,779 WARN L170 areAnnotationChecker]: L333 has no Hoare annotation [2020-07-17 21:33:20,779 WARN L170 areAnnotationChecker]: L333 has no Hoare annotation [2020-07-17 21:33:20,779 WARN L170 areAnnotationChecker]: L327-1 has no Hoare annotation [2020-07-17 21:33:20,779 WARN L170 areAnnotationChecker]: ULTIMATE.initEXIT has no Hoare annotation [2020-07-17 21:33:20,780 WARN L170 areAnnotationChecker]: __utac__error_stack_mgtFINAL has no Hoare annotation [2020-07-17 21:33:20,780 WARN L170 areAnnotationChecker]: L239 has no Hoare annotation [2020-07-17 21:33:20,780 WARN L170 areAnnotationChecker]: L239 has no Hoare annotation [2020-07-17 21:33:20,780 WARN L170 areAnnotationChecker]: L670-2 has no Hoare annotation [2020-07-17 21:33:20,780 WARN L170 areAnnotationChecker]: activatePumpEXIT has no Hoare annotation [2020-07-17 21:33:20,780 WARN L170 areAnnotationChecker]: ##fun~int~X~int~TO~intEXIT has no Hoare annotation [2020-07-17 21:33:20,781 WARN L170 areAnnotationChecker]: changeMethaneLevelEXIT has no Hoare annotation [2020-07-17 21:33:20,781 WARN L170 areAnnotationChecker]: changeMethaneLevelEXIT has no Hoare annotation [2020-07-17 21:33:20,781 WARN L170 areAnnotationChecker]: getWaterLevelEXIT has no Hoare annotation [2020-07-17 21:33:20,781 WARN L170 areAnnotationChecker]: L852-1 has no Hoare annotation [2020-07-17 21:33:20,781 WARN L170 areAnnotationChecker]: L414-1 has no Hoare annotation [2020-07-17 21:33:20,781 WARN L170 areAnnotationChecker]: isMethaneLevelCriticalEXIT has no Hoare annotation [2020-07-17 21:33:20,782 WARN L170 areAnnotationChecker]: L729 has no Hoare annotation [2020-07-17 21:33:20,782 WARN L170 areAnnotationChecker]: L729 has no Hoare annotation [2020-07-17 21:33:20,782 WARN L170 areAnnotationChecker]: L727 has no Hoare annotation [2020-07-17 21:33:20,782 WARN L170 areAnnotationChecker]: L727 has no Hoare annotation [2020-07-17 21:33:20,782 WARN L170 areAnnotationChecker]: lowerWaterLevelEXIT has no Hoare annotation [2020-07-17 21:33:20,782 WARN L170 areAnnotationChecker]: ULTIMATE.startFINAL has no Hoare annotation [2020-07-17 21:33:20,783 WARN L170 areAnnotationChecker]: L498-1 has no Hoare annotation [2020-07-17 21:33:20,783 WARN L170 areAnnotationChecker]: L498-1 has no Hoare annotation [2020-07-17 21:33:20,783 WARN L170 areAnnotationChecker]: waterRiseEXIT has no Hoare annotation [2020-07-17 21:33:20,783 WARN L170 areAnnotationChecker]: waterRiseEXIT has no Hoare annotation [2020-07-17 21:33:20,783 WARN L170 areAnnotationChecker]: __automaton_failEXIT has no Hoare annotation [2020-07-17 21:33:20,783 WARN L170 areAnnotationChecker]: __utac__exception__cf_handler_freeFINAL has no Hoare annotation [2020-07-17 21:33:20,784 WARN L170 areAnnotationChecker]: L123 has no Hoare annotation [2020-07-17 21:33:20,784 WARN L170 areAnnotationChecker]: L123 has no Hoare annotation [2020-07-17 21:33:20,784 WARN L170 areAnnotationChecker]: __utac__exception__cf_handler_resetFINAL has no Hoare annotation [2020-07-17 21:33:20,784 WARN L170 areAnnotationChecker]: L180 has no Hoare annotation [2020-07-17 21:33:20,784 WARN L170 areAnnotationChecker]: L180 has no Hoare annotation [2020-07-17 21:33:20,784 WARN L170 areAnnotationChecker]: L494 has no Hoare annotation [2020-07-17 21:33:20,785 WARN L170 areAnnotationChecker]: L882 has no Hoare annotation [2020-07-17 21:33:20,785 WARN L170 areAnnotationChecker]: L882 has no Hoare annotation [2020-07-17 21:33:20,785 WARN L170 areAnnotationChecker]: L448 has no Hoare annotation [2020-07-17 21:33:20,785 WARN L170 areAnnotationChecker]: L448 has no Hoare annotation [2020-07-17 21:33:20,785 WARN L170 areAnnotationChecker]: L884-1 has no Hoare annotation [2020-07-17 21:33:20,785 WARN L170 areAnnotationChecker]: L828 has no Hoare annotation [2020-07-17 21:33:20,786 WARN L170 areAnnotationChecker]: L828 has no Hoare annotation [2020-07-17 21:33:20,786 WARN L170 areAnnotationChecker]: __utac__get_this_argtypeFINAL has no Hoare annotation [2020-07-17 21:33:20,786 WARN L170 areAnnotationChecker]: L496-1 has no Hoare annotation [2020-07-17 21:33:20,786 WARN L170 areAnnotationChecker]: isMethaneAlarmFINAL has no Hoare annotation [2020-07-17 21:33:20,786 WARN L170 areAnnotationChecker]: isHighWaterSensorDryEXIT has no Hoare annotation [2020-07-17 21:33:20,786 WARN L170 areAnnotationChecker]: L754-1 has no Hoare annotation [2020-07-17 21:33:20,786 WARN L170 areAnnotationChecker]: processEnvironmentEXIT has no Hoare annotation [2020-07-17 21:33:20,787 WARN L170 areAnnotationChecker]: testFINAL has no Hoare annotation [2020-07-17 21:33:20,787 WARN L170 areAnnotationChecker]: L557 has no Hoare annotation [2020-07-17 21:33:20,787 WARN L170 areAnnotationChecker]: __utac__get_this_argFINAL has no Hoare annotation [2020-07-17 21:33:20,787 WARN L170 areAnnotationChecker]: L256 has no Hoare annotation [2020-07-17 21:33:20,787 WARN L170 areAnnotationChecker]: L256 has no Hoare annotation [2020-07-17 21:33:20,787 WARN L170 areAnnotationChecker]: printEnvironmentFINAL has no Hoare annotation [2020-07-17 21:33:20,788 WARN L170 areAnnotationChecker]: L193-1 has no Hoare annotation [2020-07-17 21:33:20,788 WARN L170 areAnnotationChecker]: L456 has no Hoare annotation [2020-07-17 21:33:20,788 WARN L170 areAnnotationChecker]: L456 has no Hoare annotation [2020-07-17 21:33:20,788 WARN L170 areAnnotationChecker]: L575-1 has no Hoare annotation [2020-07-17 21:33:20,788 WARN L170 areAnnotationChecker]: L854 has no Hoare annotation [2020-07-17 21:33:20,788 WARN L170 areAnnotationChecker]: L854 has no Hoare annotation [2020-07-17 21:33:20,789 WARN L170 areAnnotationChecker]: L418-2 has no Hoare annotation [2020-07-17 21:33:20,789 WARN L170 areAnnotationChecker]: L418-2 has no Hoare annotation [2020-07-17 21:33:20,789 WARN L170 areAnnotationChecker]: L418-2 has no Hoare annotation [2020-07-17 21:33:20,789 WARN L170 areAnnotationChecker]: timeShiftFINAL has no Hoare annotation [2020-07-17 21:33:20,789 WARN L170 areAnnotationChecker]: L452 has no Hoare annotation [2020-07-17 21:33:20,789 WARN L170 areAnnotationChecker]: L452 has no Hoare annotation [2020-07-17 21:33:20,789 WARN L170 areAnnotationChecker]: L565-1 has no Hoare annotation [2020-07-17 21:33:20,790 WARN L170 areAnnotationChecker]: L882-1 has no Hoare annotation [2020-07-17 21:33:20,790 WARN L170 areAnnotationChecker]: __utac__exception__cf_handler_freeEXIT has no Hoare annotation [2020-07-17 21:33:20,790 WARN L170 areAnnotationChecker]: L123-1 has no Hoare annotation [2020-07-17 21:33:20,790 WARN L170 areAnnotationChecker]: __utac__exception__cf_handler_resetEXIT has no Hoare annotation [2020-07-17 21:33:20,790 WARN L170 areAnnotationChecker]: __utac__exception__cf_handler_resetEXIT has no Hoare annotation [2020-07-17 21:33:20,790 WARN L170 areAnnotationChecker]: L180-1 has no Hoare annotation [2020-07-17 21:33:20,791 WARN L170 areAnnotationChecker]: L496 has no Hoare annotation [2020-07-17 21:33:20,791 WARN L170 areAnnotationChecker]: L496 has no Hoare annotation [2020-07-17 21:33:20,791 WARN L170 areAnnotationChecker]: L884 has no Hoare annotation [2020-07-17 21:33:20,791 WARN L170 areAnnotationChecker]: L884 has no Hoare annotation [2020-07-17 21:33:20,791 WARN L170 areAnnotationChecker]: L449 has no Hoare annotation [2020-07-17 21:33:20,791 WARN L170 areAnnotationChecker]: L449 has no Hoare annotation [2020-07-17 21:33:20,792 WARN L170 areAnnotationChecker]: L886 has no Hoare annotation [2020-07-17 21:33:20,792 WARN L170 areAnnotationChecker]: L886 has no Hoare annotation [2020-07-17 21:33:20,792 WARN L170 areAnnotationChecker]: L828-2 has no Hoare annotation [2020-07-17 21:33:20,792 WARN L170 areAnnotationChecker]: mainFINAL has no Hoare annotation [2020-07-17 21:33:20,792 WARN L170 areAnnotationChecker]: L756 has no Hoare annotation [2020-07-17 21:33:20,792 WARN L170 areAnnotationChecker]: L756 has no Hoare annotation [2020-07-17 21:33:20,793 WARN L170 areAnnotationChecker]: testEXIT has no Hoare annotation [2020-07-17 21:33:20,793 WARN L170 areAnnotationChecker]: L565 has no Hoare annotation [2020-07-17 21:33:20,793 WARN L170 areAnnotationChecker]: L565 has no Hoare annotation [2020-07-17 21:33:20,793 WARN L170 areAnnotationChecker]: L259-2 has no Hoare annotation [2020-07-17 21:33:20,793 WARN L170 areAnnotationChecker]: L259-2 has no Hoare annotation [2020-07-17 21:33:20,793 WARN L170 areAnnotationChecker]: L259-2 has no Hoare annotation [2020-07-17 21:33:20,793 WARN L170 areAnnotationChecker]: L298 has no Hoare annotation [2020-07-17 21:33:20,794 WARN L170 areAnnotationChecker]: L298 has no Hoare annotation [2020-07-17 21:33:20,794 WARN L170 areAnnotationChecker]: printEnvironmentEXIT has no Hoare annotation [2020-07-17 21:33:20,794 WARN L170 areAnnotationChecker]: L457 has no Hoare annotation [2020-07-17 21:33:20,794 WARN L170 areAnnotationChecker]: L457 has no Hoare annotation [2020-07-17 21:33:20,794 WARN L170 areAnnotationChecker]: L585 has no Hoare annotation [2020-07-17 21:33:20,794 WARN L170 areAnnotationChecker]: L585 has no Hoare annotation [2020-07-17 21:33:20,795 WARN L170 areAnnotationChecker]: L854-2 has no Hoare annotation [2020-07-17 21:33:20,795 WARN L170 areAnnotationChecker]: L433 has no Hoare annotation [2020-07-17 21:33:20,795 WARN L170 areAnnotationChecker]: L419 has no Hoare annotation [2020-07-17 21:33:20,795 WARN L170 areAnnotationChecker]: timeShiftEXIT has no Hoare annotation [2020-07-17 21:33:20,795 WARN L170 areAnnotationChecker]: timeShiftEXIT has no Hoare annotation [2020-07-17 21:33:20,795 WARN L170 areAnnotationChecker]: timeShiftEXIT has no Hoare annotation [2020-07-17 21:33:20,795 WARN L170 areAnnotationChecker]: timeShiftEXIT has no Hoare annotation [2020-07-17 21:33:20,795 WARN L170 areAnnotationChecker]: timeShiftEXIT has no Hoare annotation [2020-07-17 21:33:20,796 WARN L170 areAnnotationChecker]: timeShiftEXIT has no Hoare annotation [2020-07-17 21:33:20,796 WARN L170 areAnnotationChecker]: timeShiftEXIT has no Hoare annotation [2020-07-17 21:33:20,796 WARN L170 areAnnotationChecker]: timeShiftEXIT has no Hoare annotation [2020-07-17 21:33:20,796 WARN L170 areAnnotationChecker]: L453 has no Hoare annotation [2020-07-17 21:33:20,796 WARN L170 areAnnotationChecker]: L453 has no Hoare annotation [2020-07-17 21:33:20,796 WARN L170 areAnnotationChecker]: L575 has no Hoare annotation [2020-07-17 21:33:20,796 WARN L170 areAnnotationChecker]: L575 has no Hoare annotation [2020-07-17 21:33:20,796 WARN L170 areAnnotationChecker]: __utac_acc__Specification4_spec__1EXIT has no Hoare annotation [2020-07-17 21:33:20,796 WARN L170 areAnnotationChecker]: L275-1 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L291-1 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L193 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L193 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L498 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L498 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L450 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L450 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L888 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L888 has no Hoare annotation [2020-07-17 21:33:20,797 WARN L170 areAnnotationChecker]: L839 has no Hoare annotation [2020-07-17 21:33:20,798 WARN L170 areAnnotationChecker]: L839 has no Hoare annotation [2020-07-17 21:33:20,798 WARN L170 areAnnotationChecker]: mainEXIT has no Hoare annotation [2020-07-17 21:33:20,798 WARN L170 areAnnotationChecker]: L758 has no Hoare annotation [2020-07-17 21:33:20,798 WARN L170 areAnnotationChecker]: L758 has no Hoare annotation [2020-07-17 21:33:20,798 WARN L170 areAnnotationChecker]: L762 has no Hoare annotation [2020-07-17 21:33:20,798 WARN L170 areAnnotationChecker]: L762 has no Hoare annotation [2020-07-17 21:33:20,798 WARN L170 areAnnotationChecker]: L567 has no Hoare annotation [2020-07-17 21:33:20,798 WARN L170 areAnnotationChecker]: L567 has no Hoare annotation [2020-07-17 21:33:20,799 WARN L170 areAnnotationChecker]: L280 has no Hoare annotation [2020-07-17 21:33:20,799 WARN L170 areAnnotationChecker]: L260 has no Hoare annotation [2020-07-17 21:33:20,799 WARN L170 areAnnotationChecker]: L260 has no Hoare annotation [2020-07-17 21:33:20,799 WARN L170 areAnnotationChecker]: L299 has no Hoare annotation [2020-07-17 21:33:20,799 WARN L170 areAnnotationChecker]: L299 has no Hoare annotation [2020-07-17 21:33:20,799 WARN L170 areAnnotationChecker]: L839-1 has no Hoare annotation [2020-07-17 21:33:20,799 WARN L170 areAnnotationChecker]: L458 has no Hoare annotation [2020-07-17 21:33:20,799 WARN L170 areAnnotationChecker]: L458 has no Hoare annotation [2020-07-17 21:33:20,799 WARN L170 areAnnotationChecker]: L591-2 has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: L591-2 has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: L591 has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: L591 has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: isHighWaterLevelFINAL has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: cleanupEXIT has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: cleanupEXIT has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: L422 has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: L422 has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: L454 has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: L454 has no Hoare annotation [2020-07-17 21:33:20,800 WARN L170 areAnnotationChecker]: L429 has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: L577 has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: L577 has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: L451 has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: L451 has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: L291 has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: L291 has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: L261 has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: printPumpFINAL has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: L459 has no Hoare annotation [2020-07-17 21:33:20,801 WARN L170 areAnnotationChecker]: L459 has no Hoare annotation [2020-07-17 21:33:20,802 WARN L170 areAnnotationChecker]: isHighWaterLevelEXIT has no Hoare annotation [2020-07-17 21:33:20,802 WARN L170 areAnnotationChecker]: Specification2FINAL has no Hoare annotation [2020-07-17 21:33:20,802 WARN L170 areAnnotationChecker]: L422-1 has no Hoare annotation [2020-07-17 21:33:20,802 WARN L170 areAnnotationChecker]: L422-1 has no Hoare annotation [2020-07-17 21:33:20,802 WARN L170 areAnnotationChecker]: L455 has no Hoare annotation [2020-07-17 21:33:20,802 WARN L170 areAnnotationChecker]: L455 has no Hoare annotation [2020-07-17 21:33:20,802 WARN L170 areAnnotationChecker]: L275 has no Hoare annotation [2020-07-17 21:33:20,802 WARN L170 areAnnotationChecker]: L275 has no Hoare annotation [2020-07-17 21:33:20,803 WARN L170 areAnnotationChecker]: printPumpEXIT has no Hoare annotation [2020-07-17 21:33:20,803 WARN L170 areAnnotationChecker]: printPumpEXIT has no Hoare annotation [2020-07-17 21:33:20,803 WARN L170 areAnnotationChecker]: printPumpEXIT has no Hoare annotation [2020-07-17 21:33:20,803 WARN L170 areAnnotationChecker]: printPumpEXIT has no Hoare annotation [2020-07-17 21:33:20,803 WARN L170 areAnnotationChecker]: printPumpEXIT has no Hoare annotation [2020-07-17 21:33:20,803 WARN L170 areAnnotationChecker]: printPumpEXIT has no Hoare annotation [2020-07-17 21:33:20,804 WARN L170 areAnnotationChecker]: printPumpEXIT has no Hoare annotation [2020-07-17 21:33:20,804 INFO L163 areAnnotationChecker]: CFG has 0 edges. 0 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. 0 times interpolants missing. [2020-07-17 21:33:20,807 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction CFG 17.07 09:33:20 BoogieIcfgContainer [2020-07-17 21:33:20,807 INFO L132 PluginConnector]: ------------------------ END TraceAbstraction---------------------------- [2020-07-17 21:33:20,810 INFO L168 Benchmark]: Toolchain (without parser) took 145836.47 ms. Allocated memory was 137.9 MB in the beginning and 1.0 GB in the end (delta: 874.5 MB). Free memory was 101.5 MB in the beginning and 200.0 MB in the end (delta: -98.5 MB). Peak memory consumption was 776.0 MB. Max. memory is 7.1 GB. [2020-07-17 21:33:20,811 INFO L168 Benchmark]: CDTParser took 0.53 ms. Allocated memory is still 137.9 MB. Free memory is still 120.6 MB. There was no memory consumed. Max. memory is 7.1 GB. [2020-07-17 21:33:20,811 INFO L168 Benchmark]: CACSL2BoogieTranslator took 719.16 ms. Allocated memory was 137.9 MB in the beginning and 201.9 MB in the end (delta: 64.0 MB). Free memory was 101.1 MB in the beginning and 170.1 MB in the end (delta: -69.1 MB). Peak memory consumption was 30.7 MB. Max. memory is 7.1 GB. [2020-07-17 21:33:20,812 INFO L168 Benchmark]: Boogie Preprocessor took 169.65 ms. Allocated memory is still 201.9 MB. Free memory was 170.1 MB in the beginning and 163.2 MB in the end (delta: 6.9 MB). Peak memory consumption was 6.9 MB. Max. memory is 7.1 GB. [2020-07-17 21:33:20,812 INFO L168 Benchmark]: RCFGBuilder took 1921.66 ms. Allocated memory was 201.9 MB in the beginning and 234.4 MB in the end (delta: 32.5 MB). Free memory was 163.2 MB in the beginning and 95.9 MB in the end (delta: 67.3 MB). Peak memory consumption was 99.8 MB. Max. memory is 7.1 GB. [2020-07-17 21:33:20,813 INFO L168 Benchmark]: TraceAbstraction took 143013.33 ms. Allocated memory was 234.4 MB in the beginning and 1.0 GB in the end (delta: 778.0 MB). Free memory was 95.9 MB in the beginning and 200.0 MB in the end (delta: -104.1 MB). Peak memory consumption was 674.0 MB. Max. memory is 7.1 GB. [2020-07-17 21:33:20,815 INFO L336 ainManager$Toolchain]: ####################### End [Toolchain 1] ####################### --- Results --- * Results from de.uni_freiburg.informatik.ultimate.core: - AssertionsEnabledResult: Assertions are enabled Assertions are enabled - StatisticsResult: Toolchain Benchmarks Benchmark results are: * CDTParser took 0.53 ms. Allocated memory is still 137.9 MB. Free memory is still 120.6 MB. There was no memory consumed. Max. memory is 7.1 GB. * CACSL2BoogieTranslator took 719.16 ms. Allocated memory was 137.9 MB in the beginning and 201.9 MB in the end (delta: 64.0 MB). Free memory was 101.1 MB in the beginning and 170.1 MB in the end (delta: -69.1 MB). Peak memory consumption was 30.7 MB. Max. memory is 7.1 GB. * Boogie Preprocessor took 169.65 ms. Allocated memory is still 201.9 MB. Free memory was 170.1 MB in the beginning and 163.2 MB in the end (delta: 6.9 MB). Peak memory consumption was 6.9 MB. Max. memory is 7.1 GB. * RCFGBuilder took 1921.66 ms. Allocated memory was 201.9 MB in the beginning and 234.4 MB in the end (delta: 32.5 MB). Free memory was 163.2 MB in the beginning and 95.9 MB in the end (delta: 67.3 MB). Peak memory consumption was 99.8 MB. Max. memory is 7.1 GB. * TraceAbstraction took 143013.33 ms. Allocated memory was 234.4 MB in the beginning and 1.0 GB in the end (delta: 778.0 MB). Free memory was 95.9 MB in the beginning and 200.0 MB in the end (delta: -104.1 MB). Peak memory consumption was 674.0 MB. Max. memory is 7.1 GB. * Results from de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: - CounterExampleResult [Line: 869]: a call of __VERIFIER_error() is reachable a call of __VERIFIER_error() is reachable We found a FailurePath: [L209] static struct __ACC__ERR *head = (struct __ACC__ERR *)0; [L406] int cleanupTimeShifts = 4; [L615] int waterLevel = 1; [L616] int methaneLevelCritical = 0; [L712] int pumpRunning = 0; [L713] int systemActive = 1; VAL [\old(cleanupTimeShifts)=172, \old(head)=162, \old(head)=176, \old(methaneLevelCritical)=147, \old(pumpRunning)=136, \old(systemActive)=135, \old(waterLevel)=140, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=1] [L487] int retValue_acc ; [L488] int tmp ; VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=1] [L492] FCALL select_helpers() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=1] [L493] FCALL select_features() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=1] [L494] CALL, EXPR valid_product() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=1] [L536] int retValue_acc ; [L539] retValue_acc = 1 [L540] return (retValue_acc); VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, \result=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, retValue_acc=1, systemActive=1, waterLevel=1] [L494] RET, EXPR valid_product() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, valid_product()=1, waterLevel=1] [L494] tmp = valid_product() [L496] COND TRUE \read(tmp) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, tmp=1, waterLevel=1] [L498] FCALL setup() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, tmp=1, waterLevel=1] [L499] CALL runTest() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=1] [L478] CALL test() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=1] [L546] int splverifierCounter ; [L547] int tmp ; [L548] int tmp___0 ; [L549] int tmp___1 ; [L550] int tmp___2 ; [L553] splverifierCounter = 0 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, splverifierCounter=0, systemActive=1, waterLevel=1] [L555] COND TRUE 1 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, splverifierCounter=0, systemActive=1, waterLevel=1] [L557] COND TRUE splverifierCounter < 4 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, splverifierCounter=0, systemActive=1, waterLevel=1] [L563] tmp = __VERIFIER_nondet_int() [L565] COND TRUE \read(tmp) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, splverifierCounter=0, systemActive=1, tmp=-1, waterLevel=1] [L567] CALL waterRise() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=1] [L633] COND TRUE waterLevel < 2 [L634] waterLevel = waterLevel + 1 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L567] RET waterRise() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, splverifierCounter=0, systemActive=1, tmp=-1, waterLevel=2] [L573] tmp___0 = __VERIFIER_nondet_int() [L575] COND FALSE !(\read(tmp___0)) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, splverifierCounter=0, systemActive=1, tmp=-1, tmp___0=0, waterLevel=2] [L583] tmp___2 = __VERIFIER_nondet_int() [L585] COND TRUE \read(tmp___2) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, splverifierCounter=0, systemActive=1, tmp=-1, tmp___0=0, tmp___2=1, waterLevel=2] [L598] CALL timeShift() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L720] COND FALSE !(\read(pumpRunning)) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L727] COND TRUE \read(systemActive) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L729] CALL processEnvironment() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L749] int tmp ; VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L752] COND TRUE ! pumpRunning VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L754] CALL, EXPR isHighWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L846] int retValue_acc ; [L847] int tmp ; [L848] int tmp___0 ; VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L852] CALL, EXPR isHighWaterSensorDry() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L695] int retValue_acc ; VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L698] COND FALSE !(waterLevel < 2) [L702] retValue_acc = 0 [L703] return (retValue_acc); VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, \result=0, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, retValue_acc=0, systemActive=1, waterLevel=2] [L852] RET, EXPR isHighWaterSensorDry() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, isHighWaterSensorDry()=0, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L852] tmp = isHighWaterSensorDry() [L854] COND FALSE !(\read(tmp)) [L857] tmp___0 = 1 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, tmp=0, tmp___0=1, waterLevel=2] [L859] retValue_acc = tmp___0 [L860] return (retValue_acc); VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, \result=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, retValue_acc=1, systemActive=1, tmp=0, tmp___0=1, waterLevel=2] [L754] RET, EXPR isHighWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, isHighWaterLevel()=1, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L754] tmp = isHighWaterLevel() [L756] COND TRUE \read(tmp) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, tmp=1, waterLevel=2] [L758] CALL activatePump() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=0, systemActive=1, waterLevel=2] [L777] pumpRunning = 1 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L758] RET activatePump() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, tmp=1, waterLevel=2] [L729] RET processEnvironment() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L735] CALL __utac_acc__Specification4_spec__1() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L875] int tmp ; [L876] int tmp___0 ; VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L880] CALL, EXPR getWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L686] int retValue_acc ; [L689] retValue_acc = waterLevel [L690] return (retValue_acc); VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, \result=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, retValue_acc=2, systemActive=1, waterLevel=2] [L880] RET, EXPR getWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, getWaterLevel()=2, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L880] tmp = getWaterLevel() [L882] COND FALSE !(tmp == 0) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, tmp=2, waterLevel=2] [L735] RET __utac_acc__Specification4_spec__1() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L598] RET timeShift() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=-1, tmp___0=0, tmp___2=1, waterLevel=2] [L555] COND TRUE 1 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=-1, tmp___0=0, tmp___2=1, waterLevel=2] [L557] COND TRUE splverifierCounter < 4 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=-1, tmp___0=0, tmp___2=1, waterLevel=2] [L563] tmp = __VERIFIER_nondet_int() [L565] COND FALSE !(\read(tmp)) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=0, tmp___0=0, tmp___2=1, waterLevel=2] [L573] tmp___0 = __VERIFIER_nondet_int() [L575] COND FALSE !(\read(tmp___0)) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=0, tmp___0=0, tmp___2=1, waterLevel=2] [L583] tmp___2 = __VERIFIER_nondet_int() [L585] COND TRUE \read(tmp___2) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=0, tmp___0=0, tmp___2=1, waterLevel=2] [L598] CALL timeShift() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L720] COND TRUE \read(pumpRunning) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L722] CALL lowerWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=2] [L621] COND TRUE waterLevel > 0 [L622] waterLevel = waterLevel - 1 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L722] RET lowerWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L727] COND TRUE \read(systemActive) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L729] CALL processEnvironment() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L749] int tmp ; VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L752] COND FALSE !(! pumpRunning) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L767] FCALL processEnvironment__wrappee__base() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L729] RET processEnvironment() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L735] CALL __utac_acc__Specification4_spec__1() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L875] int tmp ; [L876] int tmp___0 ; VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L880] CALL, EXPR getWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L686] int retValue_acc ; [L689] retValue_acc = waterLevel [L690] return (retValue_acc); VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, \result=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, retValue_acc=1, systemActive=1, waterLevel=1] [L880] RET, EXPR getWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, getWaterLevel()=1, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L880] tmp = getWaterLevel() [L882] COND FALSE !(tmp == 0) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, tmp=1, waterLevel=1] [L735] RET __utac_acc__Specification4_spec__1() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=2, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L598] RET timeShift() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=0, tmp___0=0, tmp___2=1, waterLevel=1] [L555] COND TRUE 1 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=0, tmp___0=0, tmp___2=1, waterLevel=1] [L557] COND TRUE splverifierCounter < 4 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=0, tmp___0=0, tmp___2=1, waterLevel=1] [L563] tmp = __VERIFIER_nondet_int() [L565] COND FALSE !(\read(tmp)) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=0, tmp___0=0, tmp___2=1, waterLevel=1] [L573] tmp___0 = __VERIFIER_nondet_int() [L575] COND FALSE !(\read(tmp___0)) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=0, tmp___0=0, tmp___2=1, waterLevel=1] [L583] tmp___2 = __VERIFIER_nondet_int() [L585] COND TRUE \read(tmp___2) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=0, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, splverifierCounter=0, systemActive=1, tmp=0, tmp___0=0, tmp___2=1, waterLevel=1] [L598] CALL timeShift() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L720] COND TRUE \read(pumpRunning) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L722] CALL lowerWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=1] [L621] COND TRUE waterLevel > 0 [L622] waterLevel = waterLevel - 1 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L722] RET lowerWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L727] COND TRUE \read(systemActive) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L729] CALL processEnvironment() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L749] int tmp ; VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L752] COND FALSE !(! pumpRunning) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L767] FCALL processEnvironment__wrappee__base() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L729] RET processEnvironment() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L735] CALL __utac_acc__Specification4_spec__1() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L875] int tmp ; [L876] int tmp___0 ; VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L880] CALL, EXPR getWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L686] int retValue_acc ; [L689] retValue_acc = waterLevel [L690] return (retValue_acc); VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, \result=0, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, retValue_acc=0, systemActive=1, waterLevel=0] [L880] RET, EXPR getWaterLevel() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, getWaterLevel()=0, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L880] tmp = getWaterLevel() [L882] COND TRUE tmp == 0 VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, tmp=0, waterLevel=0] [L884] CALL, EXPR isPumpRunning() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L801] int retValue_acc ; [L804] retValue_acc = pumpRunning [L805] return (retValue_acc); VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, \result=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, retValue_acc=1, systemActive=1, waterLevel=0] [L884] RET, EXPR isPumpRunning() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, isPumpRunning()=1, methaneLevelCritical=0, pumpRunning=1, systemActive=1, tmp=0, waterLevel=0] [L884] tmp___0 = isPumpRunning() [L886] COND TRUE \read(tmp___0) VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, tmp=0, tmp___0=1, waterLevel=0] [L888] CALL __automaton_fail() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] [L869] __VERIFIER_error() VAL [\old(methaneLevelCritical)=0, \old(pumpRunning)=1, \old(waterLevel)=1, cleanupTimeShifts=4, head={0:0}, methaneLevelCritical=0, pumpRunning=1, systemActive=1, waterLevel=0] - StatisticsResult: Ultimate Automizer benchmark data CFG has 37 procedures, 215 locations, 1 error locations. Started 1 CEGAR loops. VerificationResult: UNSAFE, OverallTime: 142.5s, OverallIterations: 10, TraceHistogramMax: 3, AutomataDifference: 103.3s, DeadEndRemovalTime: 0.0s, HoareAnnotationTime: 0.0s, InitialAbstractionConstructionTime: 0.0s, HoareTripleCheckerStatistics: 990 SDtfs, 1764 SDslu, 1549 SDs, 0 SdLazy, 4037 SolverSat, 1117 SolverUnsat, 0 SolverUnknown, 0 SolverNotchecked, 22.5s Time, PredicateUnifierStatistics: 0 DeclaredPredicates, 799 GetRequests, 673 SyntacticMatches, 7 SemanticMatches, 119 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 440 ImplicationChecksByTransitivity, 12.6s Time, 0.0s BasicInterpolantAutomatonTime, BiggestAbstraction: size=598occurred in iteration=7, traceCheckStatistics: No data available, InterpolantConsolidationStatistics: No data available, PathInvariantsStatistics: No data available, 0/0 InterpolantCoveringCapability, TotalInterpolationStatistics: No data available, 0.0s DumpTime, AutomataMinimizationStatistics: 28.5s AutomataMinimizationTime, 9 MinimizatonAttempts, 344 StatesRemovedByMinimization, 7 NontrivialMinimizations, HoareAnnotationStatistics: No data available, RefinementEngineStatistics: TRACE_CHECK: 0.1s SsaConstructionTime, 1.0s SatisfiabilityAnalysisTime, 6.6s InterpolantComputationTime, 1312 NumberOfCodeBlocks, 1312 NumberOfCodeBlocksAsserted, 14 NumberOfCheckSat, 1151 ConstructedInterpolants, 0 QuantifiedInterpolants, 319602 SizeOfPredicates, 12 NumberOfNonLiveVariables, 3120 ConjunctsInSsa, 40 ConjunctsInUnsatCore, 13 InterpolantComputations, 8 PerfectInterpolantSequences, 172/192 InterpolantCoveringCapability, INVARIANT_SYNTHESIS: No data available, INTERPOLANT_CONSOLIDATION: No data available, ABSTRACT_INTERPRETATION: No data available, PDR: No data available, ACCELERATED_INTERPOLATION: No data available, SIFA: No data available, ReuseStatistics: No data available RESULT: Ultimate proved your program to be incorrect! Received shutdown request...