/usr/bin/java -ea -Xmx8000000000 -Xss4m -jar ./plugins/org.eclipse.equinox.launcher_1.5.800.v20200727-1323.jar -data @noDefault -ultimatedata ./data --core.log.level.for.class de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=WARN -tc ../../../trunk/examples/toolchains/AutomizerC.xml -s ../../../trunk/examples/settings/automizer/acceleratedInterpolation/acceleratedInterpolationJordan_32.epf -i ../../../trunk/examples/svcomp/nla-digbench-scaling/egcd2-ll_valuebound5.c -------------------------------------------------------------------------------- This is Ultimate 0.2.2-dev-e106359-m [2022-04-15 08:44:11,293 INFO L177 SettingsManager]: Resetting all preferences to default values... [2022-04-15 08:44:11,295 INFO L181 SettingsManager]: Resetting UltimateCore preferences to default values [2022-04-15 08:44:11,332 INFO L184 SettingsManager]: Ultimate Commandline Interface provides no preferences, ignoring... [2022-04-15 08:44:11,332 INFO L181 SettingsManager]: Resetting Boogie Preprocessor preferences to default values [2022-04-15 08:44:11,334 INFO L181 SettingsManager]: Resetting Boogie Procedure Inliner preferences to default values [2022-04-15 08:44:11,336 INFO L181 SettingsManager]: Resetting Abstract Interpretation preferences to default values [2022-04-15 08:44:11,338 INFO L181 SettingsManager]: Resetting LassoRanker preferences to default values [2022-04-15 08:44:11,339 INFO L181 SettingsManager]: Resetting Reaching Definitions preferences to default values [2022-04-15 08:44:11,344 INFO L181 SettingsManager]: Resetting SyntaxChecker preferences to default values [2022-04-15 08:44:11,344 INFO L181 SettingsManager]: Resetting Sifa preferences to default values [2022-04-15 08:44:11,345 INFO L184 SettingsManager]: Büchi Program Product provides no preferences, ignoring... [2022-04-15 08:44:11,345 INFO L181 SettingsManager]: Resetting LTL2Aut preferences to default values [2022-04-15 08:44:11,347 INFO L181 SettingsManager]: Resetting PEA to Boogie preferences to default values [2022-04-15 08:44:11,348 INFO L181 SettingsManager]: Resetting BlockEncodingV2 preferences to default values [2022-04-15 08:44:11,350 INFO L181 SettingsManager]: Resetting ChcToBoogie preferences to default values [2022-04-15 08:44:11,351 INFO L181 SettingsManager]: Resetting AutomataScriptInterpreter preferences to default values [2022-04-15 08:44:11,351 INFO L181 SettingsManager]: Resetting BuchiAutomizer preferences to default values [2022-04-15 08:44:11,353 INFO L181 SettingsManager]: Resetting CACSL2BoogieTranslator preferences to default values [2022-04-15 08:44:11,357 INFO L181 SettingsManager]: Resetting CodeCheck preferences to default values [2022-04-15 08:44:11,358 INFO L181 SettingsManager]: Resetting HornVerifier preferences to default values [2022-04-15 08:44:11,359 INFO L181 SettingsManager]: Resetting InvariantSynthesis preferences to default values [2022-04-15 08:44:11,359 INFO L181 SettingsManager]: Resetting RCFGBuilder preferences to default values [2022-04-15 08:44:11,360 INFO L181 SettingsManager]: Resetting Referee preferences to default values [2022-04-15 08:44:11,361 INFO L181 SettingsManager]: Resetting TraceAbstraction preferences to default values [2022-04-15 08:44:11,362 INFO L184 SettingsManager]: TraceAbstractionConcurrent provides no preferences, ignoring... [2022-04-15 08:44:11,363 INFO L184 SettingsManager]: TraceAbstractionWithAFAs provides no preferences, ignoring... [2022-04-15 08:44:11,363 INFO L181 SettingsManager]: Resetting TreeAutomizer preferences to default values [2022-04-15 08:44:11,363 INFO L181 SettingsManager]: Resetting IcfgToChc preferences to default values [2022-04-15 08:44:11,363 INFO L181 SettingsManager]: Resetting IcfgTransformer preferences to default values [2022-04-15 08:44:11,364 INFO L184 SettingsManager]: ReqToTest provides no preferences, ignoring... [2022-04-15 08:44:11,364 INFO L181 SettingsManager]: Resetting Boogie Printer preferences to default values [2022-04-15 08:44:11,366 INFO L181 SettingsManager]: Resetting ChcSmtPrinter preferences to default values [2022-04-15 08:44:11,366 INFO L181 SettingsManager]: Resetting ReqPrinter preferences to default values [2022-04-15 08:44:11,366 INFO L181 SettingsManager]: Resetting Witness Printer preferences to default values [2022-04-15 08:44:11,367 INFO L184 SettingsManager]: Boogie PL CUP Parser provides no preferences, ignoring... [2022-04-15 08:44:11,367 INFO L181 SettingsManager]: Resetting CDTParser preferences to default values [2022-04-15 08:44:11,367 INFO L184 SettingsManager]: AutomataScriptParser provides no preferences, ignoring... [2022-04-15 08:44:11,367 INFO L184 SettingsManager]: ReqParser provides no preferences, ignoring... [2022-04-15 08:44:11,368 INFO L181 SettingsManager]: Resetting SmtParser preferences to default values [2022-04-15 08:44:11,368 INFO L181 SettingsManager]: Resetting Witness Parser preferences to default values [2022-04-15 08:44:11,369 INFO L188 SettingsManager]: Finished resetting all preferences to default values... [2022-04-15 08:44:11,370 INFO L101 SettingsManager]: Beginning loading settings from /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/settings/automizer/acceleratedInterpolation/acceleratedInterpolationJordan_32.epf [2022-04-15 08:44:11,377 INFO L113 SettingsManager]: Loading preferences was successful [2022-04-15 08:44:11,377 INFO L115 SettingsManager]: Preferences different from defaults after loading the file: [2022-04-15 08:44:11,378 INFO L136 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2022-04-15 08:44:11,379 INFO L138 SettingsManager]: * sizeof long=4 [2022-04-15 08:44:11,379 INFO L138 SettingsManager]: * Overapproximate operations on floating types=true [2022-04-15 08:44:11,379 INFO L138 SettingsManager]: * sizeof POINTER=4 [2022-04-15 08:44:11,379 INFO L138 SettingsManager]: * Check division by zero=IGNORE [2022-04-15 08:44:11,379 INFO L138 SettingsManager]: * Pointer to allocated memory at dereference=IGNORE [2022-04-15 08:44:11,379 INFO L138 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=IGNORE [2022-04-15 08:44:11,380 INFO L138 SettingsManager]: * Check array bounds for arrays that are off heap=IGNORE [2022-04-15 08:44:11,380 INFO L138 SettingsManager]: * sizeof long double=12 [2022-04-15 08:44:11,380 INFO L138 SettingsManager]: * Check if freed pointer was valid=false [2022-04-15 08:44:11,380 INFO L138 SettingsManager]: * Use constant arrays=true [2022-04-15 08:44:11,380 INFO L138 SettingsManager]: * Pointer base address is valid at dereference=IGNORE [2022-04-15 08:44:11,380 INFO L136 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2022-04-15 08:44:11,380 INFO L138 SettingsManager]: * Size of a code block=SequenceOfStatements [2022-04-15 08:44:11,380 INFO L138 SettingsManager]: * To the following directory=./dump/ [2022-04-15 08:44:11,380 INFO L138 SettingsManager]: * SMT solver=External_DefaultMode [2022-04-15 08:44:11,380 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-04-15 08:44:11,381 INFO L136 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2022-04-15 08:44:11,381 INFO L138 SettingsManager]: * Compute Interpolants along a Counterexample=Craig_NestedInterpolation [2022-04-15 08:44:11,381 INFO L138 SettingsManager]: * Trace refinement strategy=ACCELERATED_INTERPOLATION [2022-04-15 08:44:11,381 INFO L138 SettingsManager]: * Trace refinement strategy used in Accelerated Interpolation=CAMEL [2022-04-15 08:44:11,381 INFO L138 SettingsManager]: * Compute Hoare Annotation of negated interpolant automaton, abstraction and CFG=true [2022-04-15 08:44:11,381 INFO L138 SettingsManager]: * Loop acceleration method that is used by accelerated interpolation=JORDAN [2022-04-15 08:44:11,381 INFO L138 SettingsManager]: * Use separate solver for trace checks=false WARNING: An illegal reflective access operation has occurred WARNING: Illegal reflective access by com.sun.xml.bind.v2.runtime.reflect.opt.Injector$1 (file:/storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/plugins/com.sun.xml.bind_2.2.0.v201505121915.jar) to method java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int) WARNING: Please consider reporting this to the maintainers of com.sun.xml.bind.v2.runtime.reflect.opt.Injector$1 WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations WARNING: All illegal access operations will be denied in a future release Applying setting for plugin de.uni_freiburg.informatik.ultimate.core: Log level for class -> de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=WARN; [2022-04-15 08:44:11,572 INFO L75 nceAwareModelManager]: Repository-Root is: /tmp [2022-04-15 08:44:11,591 INFO L261 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2022-04-15 08:44:11,593 INFO L217 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2022-04-15 08:44:11,594 INFO L271 PluginConnector]: Initializing CDTParser... [2022-04-15 08:44:11,594 INFO L275 PluginConnector]: CDTParser initialized [2022-04-15 08:44:11,595 INFO L432 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/svcomp/nla-digbench-scaling/egcd2-ll_valuebound5.c [2022-04-15 08:44:11,644 INFO L220 CDTParser]: Created temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/e250db135/7e278a7e90ea4c27a6a2434036177c0f/FLAGdd846a1d0 [2022-04-15 08:44:11,988 INFO L306 CDTParser]: Found 1 translation units. [2022-04-15 08:44:11,989 INFO L160 CDTParser]: Scanning /storage/repos/ultimate/trunk/examples/svcomp/nla-digbench-scaling/egcd2-ll_valuebound5.c [2022-04-15 08:44:11,994 INFO L349 CDTParser]: About to delete temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/e250db135/7e278a7e90ea4c27a6a2434036177c0f/FLAGdd846a1d0 [2022-04-15 08:44:12,007 INFO L357 CDTParser]: Successfully deleted /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/e250db135/7e278a7e90ea4c27a6a2434036177c0f [2022-04-15 08:44:12,008 INFO L299 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2022-04-15 08:44:12,009 INFO L131 ToolchainWalker]: Walking toolchain with 4 elements. [2022-04-15 08:44:12,010 INFO L113 PluginConnector]: ------------------------CACSL2BoogieTranslator---------------------------- [2022-04-15 08:44:12,011 INFO L271 PluginConnector]: Initializing CACSL2BoogieTranslator... [2022-04-15 08:44:12,013 INFO L275 PluginConnector]: CACSL2BoogieTranslator initialized [2022-04-15 08:44:12,014 INFO L185 PluginConnector]: Executing the observer ACSLObjectContainerObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,015 INFO L205 PluginConnector]: Invalid model from CACSL2BoogieTranslator for observer de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator.ACSLObjectContainerObserver@48784c78 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12, skipping insertion in model container [2022-04-15 08:44:12,015 INFO L185 PluginConnector]: Executing the observer CACSL2BoogieTranslatorObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,019 INFO L145 MainTranslator]: Starting translation in SV-COMP mode [2022-04-15 08:44:12,032 INFO L178 MainTranslator]: Built tables and reachable declarations [2022-04-15 08:44:12,160 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/trunk/examples/svcomp/nla-digbench-scaling/egcd2-ll_valuebound5.c[490,503] [2022-04-15 08:44:12,187 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-04-15 08:44:12,198 INFO L203 MainTranslator]: Completed pre-run [2022-04-15 08:44:12,208 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/trunk/examples/svcomp/nla-digbench-scaling/egcd2-ll_valuebound5.c[490,503] [2022-04-15 08:44:12,226 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-04-15 08:44:12,234 INFO L208 MainTranslator]: Completed translation [2022-04-15 08:44:12,235 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12 WrapperNode [2022-04-15 08:44:12,235 INFO L132 PluginConnector]: ------------------------ END CACSL2BoogieTranslator---------------------------- [2022-04-15 08:44:12,235 INFO L113 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2022-04-15 08:44:12,236 INFO L271 PluginConnector]: Initializing Boogie Preprocessor... [2022-04-15 08:44:12,236 INFO L275 PluginConnector]: Boogie Preprocessor initialized [2022-04-15 08:44:12,242 INFO L185 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,242 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,246 INFO L185 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,246 INFO L185 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,250 INFO L185 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,253 INFO L185 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,253 INFO L185 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,255 INFO L132 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2022-04-15 08:44:12,255 INFO L113 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2022-04-15 08:44:12,255 INFO L271 PluginConnector]: Initializing RCFGBuilder... [2022-04-15 08:44:12,255 INFO L275 PluginConnector]: RCFGBuilder initialized [2022-04-15 08:44:12,260 INFO L185 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12" (1/1) ... [2022-04-15 08:44:12,265 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-04-15 08:44:12,272 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:44:12,288 INFO L229 MonitoredProcess]: Starting monitored process 1 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (exit command is (exit), workingDir is null) [2022-04-15 08:44:12,305 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1)] Waiting until timeout for monitored process [2022-04-15 08:44:12,314 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.init [2022-04-15 08:44:12,314 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2022-04-15 08:44:12,314 INFO L138 BoogieDeclarations]: Found implementation of procedure reach_error [2022-04-15 08:44:12,314 INFO L138 BoogieDeclarations]: Found implementation of procedure assume_abort_if_not [2022-04-15 08:44:12,314 INFO L138 BoogieDeclarations]: Found implementation of procedure __VERIFIER_assert [2022-04-15 08:44:12,314 INFO L138 BoogieDeclarations]: Found implementation of procedure main [2022-04-15 08:44:12,314 INFO L130 BoogieDeclarations]: Found specification of procedure abort [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure __assert_fail [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure reach_error [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocInit [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure __VERIFIER_nondet_int [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure assume_abort_if_not [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure __VERIFIER_assert [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure main [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.init [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~int [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure write~int [2022-04-15 08:44:12,315 INFO L130 BoogieDeclarations]: Found specification of procedure read~int [2022-04-15 08:44:12,316 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.dealloc [2022-04-15 08:44:12,358 INFO L234 CfgBuilder]: Building ICFG [2022-04-15 08:44:12,359 INFO L260 CfgBuilder]: Building CFG for each procedure with an implementation [2022-04-15 08:44:12,575 INFO L275 CfgBuilder]: Performing block encoding [2022-04-15 08:44:12,580 INFO L294 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2022-04-15 08:44:12,580 INFO L299 CfgBuilder]: Removed 2 assume(true) statements. [2022-04-15 08:44:12,581 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 15.04 08:44:12 BoogieIcfgContainer [2022-04-15 08:44:12,581 INFO L132 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2022-04-15 08:44:12,582 INFO L113 PluginConnector]: ------------------------TraceAbstraction---------------------------- [2022-04-15 08:44:12,582 INFO L271 PluginConnector]: Initializing TraceAbstraction... [2022-04-15 08:44:12,587 INFO L275 PluginConnector]: TraceAbstraction initialized [2022-04-15 08:44:12,587 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "CDTParser AST 15.04 08:44:12" (1/3) ... [2022-04-15 08:44:12,588 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@2200ad10 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 15.04 08:44:12, skipping insertion in model container [2022-04-15 08:44:12,588 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 15.04 08:44:12" (2/3) ... [2022-04-15 08:44:12,588 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@2200ad10 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 15.04 08:44:12, skipping insertion in model container [2022-04-15 08:44:12,588 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 15.04 08:44:12" (3/3) ... [2022-04-15 08:44:12,592 INFO L111 eAbstractionObserver]: Analyzing ICFG egcd2-ll_valuebound5.c [2022-04-15 08:44:12,596 INFO L202 ceAbstractionStarter]: Automizer settings: Hoare:true NWA Interpolation:Craig_NestedInterpolation Determinization: PREDICATE_ABSTRACTION [2022-04-15 08:44:12,596 INFO L161 ceAbstractionStarter]: Applying trace abstraction to program that has 1 error locations. [2022-04-15 08:44:12,630 INFO L339 AbstractCegarLoop]: ======== Iteration 0 == of CEGAR loop == AllErrorsAtOnce ======== [2022-04-15 08:44:12,639 INFO L340 AbstractCegarLoop]: Settings: SEPARATE_VIOLATION_CHECK=true, mInterprocedural=true, mMaxIterations=1000000, mWatchIteration=1000000, mArtifact=RCFG, mInterpolation=Craig_NestedInterpolation, mInterpolantAutomaton=STRAIGHT_LINE, mDumpAutomata=false, mAutomataFormat=ATS_NUMERATE, mDumpPath=., mDeterminiation=PREDICATE_ABSTRACTION, mMinimize=MINIMIZE_SEVPA, mHoare=true, mAutomataTypeConcurrency=FINITE_AUTOMATA, mHoareTripleChecks=INCREMENTAL, mHoareAnnotationPositions=All, mDumpOnlyReuseAutomata=false, mLimitTraceHistogram=0, mErrorLocTimeLimit=0, mLimitPathProgramCount=0, mCollectInterpolantStatistics=true, mHeuristicEmptinessCheck=false, mHeuristicEmptinessCheckAStarHeuristic=ZERO, mHeuristicEmptinessCheckAStarHeuristicRandomSeed=1337, mHeuristicEmptinessCheckSmtFeatureScoringMethod=DAGSIZE, mSMTFeatureExtraction=false, mSMTFeatureExtractionDumpPath=., mOverrideInterpolantAutomaton=false, mMcrInterpolantMethod=WP [2022-04-15 08:44:12,639 INFO L341 AbstractCegarLoop]: Starting to check reachability of 1 error locations. [2022-04-15 08:44:12,660 INFO L276 IsEmpty]: Start isEmpty. Operand has 40 states, 20 states have (on average 1.45) internal successors, (29), 22 states have internal predecessors, (29), 14 states have call successors, (14), 4 states have call predecessors, (14), 4 states have return successors, (14), 14 states have call predecessors, (14), 14 states have call successors, (14) [2022-04-15 08:44:12,665 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 44 [2022-04-15 08:44:12,666 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:44:12,666 INFO L499 BasicCegarLoop]: trace histogram [6, 6, 6, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-15 08:44:12,667 INFO L403 AbstractCegarLoop]: === Iteration 1 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:44:12,670 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:44:12,671 INFO L85 PathProgramCache]: Analyzing trace with hash -587582002, now seen corresponding path program 1 times [2022-04-15 08:44:12,676 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:12,676 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1333971131] [2022-04-15 08:44:12,684 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:44:12,684 INFO L85 PathProgramCache]: Analyzing trace with hash -587582002, now seen corresponding path program 2 times [2022-04-15 08:44:12,686 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:44:12,687 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1006198707] [2022-04-15 08:44:12,687 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:44:12,687 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:44:12,765 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:12,802 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 0 [2022-04-15 08:44:12,805 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:12,815 INFO L290 TraceCheckUtils]: 0: Hoare triple {72#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {43#true} is VALID [2022-04-15 08:44:12,815 INFO L290 TraceCheckUtils]: 1: Hoare triple {43#true} assume true; {43#true} is VALID [2022-04-15 08:44:12,816 INFO L284 TraceCheckUtils]: 2: Hoare quadruple {43#true} {43#true} #103#return; {43#true} is VALID [2022-04-15 08:44:12,816 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 6 [2022-04-15 08:44:12,818 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:12,824 INFO L290 TraceCheckUtils]: 0: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,825 INFO L290 TraceCheckUtils]: 1: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,825 INFO L290 TraceCheckUtils]: 2: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,826 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {44#false} {43#true} #79#return; {44#false} is VALID [2022-04-15 08:44:12,826 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 12 [2022-04-15 08:44:12,831 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:12,840 INFO L290 TraceCheckUtils]: 0: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,841 INFO L290 TraceCheckUtils]: 1: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,841 INFO L290 TraceCheckUtils]: 2: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,841 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {44#false} {44#false} #81#return; {44#false} is VALID [2022-04-15 08:44:12,841 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 17 [2022-04-15 08:44:12,843 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:12,854 INFO L290 TraceCheckUtils]: 0: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,855 INFO L290 TraceCheckUtils]: 1: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,855 INFO L290 TraceCheckUtils]: 2: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,855 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {44#false} {44#false} #83#return; {44#false} is VALID [2022-04-15 08:44:12,855 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 22 [2022-04-15 08:44:12,857 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:12,864 INFO L290 TraceCheckUtils]: 0: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,865 INFO L290 TraceCheckUtils]: 1: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,865 INFO L290 TraceCheckUtils]: 2: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,865 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {44#false} {44#false} #85#return; {44#false} is VALID [2022-04-15 08:44:12,866 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 28 [2022-04-15 08:44:12,867 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:12,872 INFO L290 TraceCheckUtils]: 0: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,873 INFO L290 TraceCheckUtils]: 1: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,873 INFO L290 TraceCheckUtils]: 2: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,874 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {44#false} {44#false} #87#return; {44#false} is VALID [2022-04-15 08:44:12,874 INFO L376 atingTraceCheckCraig]: Compute interpolants for subsequence at non-pending call position 33 [2022-04-15 08:44:12,877 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:12,883 INFO L290 TraceCheckUtils]: 0: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,884 INFO L290 TraceCheckUtils]: 1: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,884 INFO L290 TraceCheckUtils]: 2: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,884 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {44#false} {44#false} #89#return; {44#false} is VALID [2022-04-15 08:44:12,885 INFO L272 TraceCheckUtils]: 0: Hoare triple {43#true} call ULTIMATE.init(); {72#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} is VALID [2022-04-15 08:44:12,885 INFO L290 TraceCheckUtils]: 1: Hoare triple {72#(and (= |#NULL.offset| |old(#NULL.offset)|) (= |old(#NULL.base)| |#NULL.base|))} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {43#true} is VALID [2022-04-15 08:44:12,886 INFO L290 TraceCheckUtils]: 2: Hoare triple {43#true} assume true; {43#true} is VALID [2022-04-15 08:44:12,886 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {43#true} {43#true} #103#return; {43#true} is VALID [2022-04-15 08:44:12,886 INFO L272 TraceCheckUtils]: 4: Hoare triple {43#true} call #t~ret6 := main(); {43#true} is VALID [2022-04-15 08:44:12,886 INFO L290 TraceCheckUtils]: 5: Hoare triple {43#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {43#true} is VALID [2022-04-15 08:44:12,887 INFO L272 TraceCheckUtils]: 6: Hoare triple {43#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {43#true} is VALID [2022-04-15 08:44:12,887 INFO L290 TraceCheckUtils]: 7: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,887 INFO L290 TraceCheckUtils]: 8: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,888 INFO L290 TraceCheckUtils]: 9: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,888 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {44#false} {43#true} #79#return; {44#false} is VALID [2022-04-15 08:44:12,889 INFO L290 TraceCheckUtils]: 11: Hoare triple {44#false} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {44#false} is VALID [2022-04-15 08:44:12,889 INFO L272 TraceCheckUtils]: 12: Hoare triple {44#false} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {43#true} is VALID [2022-04-15 08:44:12,890 INFO L290 TraceCheckUtils]: 13: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,890 INFO L290 TraceCheckUtils]: 14: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,890 INFO L290 TraceCheckUtils]: 15: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,891 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {44#false} {44#false} #81#return; {44#false} is VALID [2022-04-15 08:44:12,892 INFO L272 TraceCheckUtils]: 17: Hoare triple {44#false} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {43#true} is VALID [2022-04-15 08:44:12,892 INFO L290 TraceCheckUtils]: 18: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,892 INFO L290 TraceCheckUtils]: 19: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,892 INFO L290 TraceCheckUtils]: 20: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,899 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {44#false} {44#false} #83#return; {44#false} is VALID [2022-04-15 08:44:12,899 INFO L272 TraceCheckUtils]: 22: Hoare triple {44#false} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {43#true} is VALID [2022-04-15 08:44:12,900 INFO L290 TraceCheckUtils]: 23: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,900 INFO L290 TraceCheckUtils]: 24: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,900 INFO L290 TraceCheckUtils]: 25: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,901 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {44#false} {44#false} #85#return; {44#false} is VALID [2022-04-15 08:44:12,901 INFO L290 TraceCheckUtils]: 27: Hoare triple {44#false} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {44#false} is VALID [2022-04-15 08:44:12,902 INFO L272 TraceCheckUtils]: 28: Hoare triple {44#false} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {43#true} is VALID [2022-04-15 08:44:12,903 INFO L290 TraceCheckUtils]: 29: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,903 INFO L290 TraceCheckUtils]: 30: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,903 INFO L290 TraceCheckUtils]: 31: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,904 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {44#false} {44#false} #87#return; {44#false} is VALID [2022-04-15 08:44:12,904 INFO L272 TraceCheckUtils]: 33: Hoare triple {44#false} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {43#true} is VALID [2022-04-15 08:44:12,904 INFO L290 TraceCheckUtils]: 34: Hoare triple {43#true} ~cond := #in~cond; {43#true} is VALID [2022-04-15 08:44:12,904 INFO L290 TraceCheckUtils]: 35: Hoare triple {43#true} assume 0 == ~cond;assume false; {44#false} is VALID [2022-04-15 08:44:12,905 INFO L290 TraceCheckUtils]: 36: Hoare triple {44#false} assume true; {44#false} is VALID [2022-04-15 08:44:12,905 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {44#false} {44#false} #89#return; {44#false} is VALID [2022-04-15 08:44:12,906 INFO L290 TraceCheckUtils]: 38: Hoare triple {44#false} assume !true; {44#false} is VALID [2022-04-15 08:44:12,906 INFO L272 TraceCheckUtils]: 39: Hoare triple {44#false} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {44#false} is VALID [2022-04-15 08:44:12,909 INFO L290 TraceCheckUtils]: 40: Hoare triple {44#false} ~cond := #in~cond; {44#false} is VALID [2022-04-15 08:44:12,909 INFO L290 TraceCheckUtils]: 41: Hoare triple {44#false} assume 0 == ~cond; {44#false} is VALID [2022-04-15 08:44:12,912 INFO L290 TraceCheckUtils]: 42: Hoare triple {44#false} assume !false; {44#false} is VALID [2022-04-15 08:44:12,913 INFO L134 CoverageAnalysis]: Checked inductivity of 60 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 60 trivial. 0 not checked. [2022-04-15 08:44:12,913 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:44:12,913 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1006198707] [2022-04-15 08:44:12,914 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1006198707] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:44:12,914 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:44:12,914 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [] total 3 [2022-04-15 08:44:12,915 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:44:12,916 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1333971131] [2022-04-15 08:44:12,916 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1333971131] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:44:12,916 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:44:12,916 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [] total 3 [2022-04-15 08:44:12,916 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [344064383] [2022-04-15 08:44:12,916 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:44:12,922 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 4.0) internal successors, (12), 2 states have internal predecessors, (12), 2 states have call successors, (9), 3 states have call predecessors, (9), 2 states have return successors, (7), 2 states have call predecessors, (7), 2 states have call successors, (7) Word has length 43 [2022-04-15 08:44:12,923 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:44:12,926 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 3 states, 3 states have (on average 4.0) internal successors, (12), 2 states have internal predecessors, (12), 2 states have call successors, (9), 3 states have call predecessors, (9), 2 states have return successors, (7), 2 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:12,966 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 28 edges. 28 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:12,966 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 3 states [2022-04-15 08:44:12,966 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:12,981 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 3 interpolants. [2022-04-15 08:44:12,982 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=3, Invalid=3, Unknown=0, NotChecked=0, Total=6 [2022-04-15 08:44:12,984 INFO L87 Difference]: Start difference. First operand has 40 states, 20 states have (on average 1.45) internal successors, (29), 22 states have internal predecessors, (29), 14 states have call successors, (14), 4 states have call predecessors, (14), 4 states have return successors, (14), 14 states have call predecessors, (14), 14 states have call successors, (14) Second operand has 3 states, 3 states have (on average 4.0) internal successors, (12), 2 states have internal predecessors, (12), 2 states have call successors, (9), 3 states have call predecessors, (9), 2 states have return successors, (7), 2 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:13,182 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:13,183 INFO L93 Difference]: Finished difference Result 73 states and 118 transitions. [2022-04-15 08:44:13,183 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 3 states. [2022-04-15 08:44:13,184 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 4.0) internal successors, (12), 2 states have internal predecessors, (12), 2 states have call successors, (9), 3 states have call predecessors, (9), 2 states have return successors, (7), 2 states have call predecessors, (7), 2 states have call successors, (7) Word has length 43 [2022-04-15 08:44:13,184 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:44:13,185 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 4.0) internal successors, (12), 2 states have internal predecessors, (12), 2 states have call successors, (9), 3 states have call predecessors, (9), 2 states have return successors, (7), 2 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:13,200 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 118 transitions. [2022-04-15 08:44:13,200 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 4.0) internal successors, (12), 2 states have internal predecessors, (12), 2 states have call successors, (9), 3 states have call predecessors, (9), 2 states have return successors, (7), 2 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:13,205 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 118 transitions. [2022-04-15 08:44:13,205 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 3 states and 118 transitions. [2022-04-15 08:44:13,330 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 118 edges. 118 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:13,338 INFO L225 Difference]: With dead ends: 73 [2022-04-15 08:44:13,338 INFO L226 Difference]: Without dead ends: 35 [2022-04-15 08:44:13,341 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 22 GetRequests, 21 SyntacticMatches, 0 SemanticMatches, 1 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=3, Invalid=3, Unknown=0, NotChecked=0, Total=6 [2022-04-15 08:44:13,345 INFO L913 BasicCegarLoop]: 39 mSDtfsCounter, 20 mSDsluCounter, 3 mSDsCounter, 0 mSdLazyCounter, 14 mSolverCounterSat, 13 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 32 SdHoareTripleChecker+Valid, 42 SdHoareTripleChecker+Invalid, 27 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 13 IncrementalHoareTripleChecker+Valid, 14 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-04-15 08:44:13,347 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [32 Valid, 42 Invalid, 27 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [13 Valid, 14 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-04-15 08:44:13,356 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 35 states. [2022-04-15 08:44:13,375 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 35 to 35. [2022-04-15 08:44:13,375 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:44:13,376 INFO L82 GeneralOperation]: Start isEquivalent. First operand 35 states. Second operand has 35 states, 17 states have (on average 1.1764705882352942) internal successors, (20), 19 states have internal predecessors, (20), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) [2022-04-15 08:44:13,377 INFO L74 IsIncluded]: Start isIncluded. First operand 35 states. Second operand has 35 states, 17 states have (on average 1.1764705882352942) internal successors, (20), 19 states have internal predecessors, (20), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) [2022-04-15 08:44:13,378 INFO L87 Difference]: Start difference. First operand 35 states. Second operand has 35 states, 17 states have (on average 1.1764705882352942) internal successors, (20), 19 states have internal predecessors, (20), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) [2022-04-15 08:44:13,387 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:13,387 INFO L93 Difference]: Finished difference Result 35 states and 46 transitions. [2022-04-15 08:44:13,387 INFO L276 IsEmpty]: Start isEmpty. Operand 35 states and 46 transitions. [2022-04-15 08:44:13,388 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:13,388 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:13,389 INFO L74 IsIncluded]: Start isIncluded. First operand has 35 states, 17 states have (on average 1.1764705882352942) internal successors, (20), 19 states have internal predecessors, (20), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) Second operand 35 states. [2022-04-15 08:44:13,389 INFO L87 Difference]: Start difference. First operand has 35 states, 17 states have (on average 1.1764705882352942) internal successors, (20), 19 states have internal predecessors, (20), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) Second operand 35 states. [2022-04-15 08:44:13,400 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:13,400 INFO L93 Difference]: Finished difference Result 35 states and 46 transitions. [2022-04-15 08:44:13,400 INFO L276 IsEmpty]: Start isEmpty. Operand 35 states and 46 transitions. [2022-04-15 08:44:13,401 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:13,401 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:13,401 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:44:13,401 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:44:13,401 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 35 states, 17 states have (on average 1.1764705882352942) internal successors, (20), 19 states have internal predecessors, (20), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) [2022-04-15 08:44:13,403 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 35 states to 35 states and 46 transitions. [2022-04-15 08:44:13,404 INFO L78 Accepts]: Start accepts. Automaton has 35 states and 46 transitions. Word has length 43 [2022-04-15 08:44:13,404 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:44:13,404 INFO L478 AbstractCegarLoop]: Abstraction has 35 states and 46 transitions. [2022-04-15 08:44:13,404 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 3 states, 3 states have (on average 4.0) internal successors, (12), 2 states have internal predecessors, (12), 2 states have call successors, (9), 3 states have call predecessors, (9), 2 states have return successors, (7), 2 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:13,404 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 35 states and 46 transitions. [2022-04-15 08:44:13,448 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 46 edges. 46 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:13,449 INFO L276 IsEmpty]: Start isEmpty. Operand 35 states and 46 transitions. [2022-04-15 08:44:13,455 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 45 [2022-04-15 08:44:13,456 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:44:13,456 INFO L499 BasicCegarLoop]: trace histogram [6, 6, 6, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-15 08:44:13,456 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable0 [2022-04-15 08:44:13,456 INFO L403 AbstractCegarLoop]: === Iteration 2 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:44:13,457 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:44:13,457 INFO L85 PathProgramCache]: Analyzing trace with hash 987777007, now seen corresponding path program 1 times [2022-04-15 08:44:13,457 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:13,457 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [2037303990] [2022-04-15 08:44:13,460 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:44:13,460 INFO L85 PathProgramCache]: Analyzing trace with hash 987777007, now seen corresponding path program 2 times [2022-04-15 08:44:13,460 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:44:13,460 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [353032235] [2022-04-15 08:44:13,460 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:44:13,461 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:44:13,515 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:44:13,515 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1183111839] [2022-04-15 08:44:13,515 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:44:13,515 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:44:13,515 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:44:13,517 INFO L229 MonitoredProcess]: Starting monitored process 2 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:44:13,522 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (2)] Waiting until timeout for monitored process [2022-04-15 08:44:13,564 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:44:13,564 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:44:13,565 INFO L263 TraceCheckSpWp]: Trace formula consists of 133 conjuncts, 7 conjunts are in the unsatisfiable core [2022-04-15 08:44:13,593 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:13,597 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:44:13,797 INFO L272 TraceCheckUtils]: 0: Hoare triple {361#true} call ULTIMATE.init(); {361#true} is VALID [2022-04-15 08:44:13,797 INFO L290 TraceCheckUtils]: 1: Hoare triple {361#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {361#true} is VALID [2022-04-15 08:44:13,797 INFO L290 TraceCheckUtils]: 2: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:13,798 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {361#true} {361#true} #103#return; {361#true} is VALID [2022-04-15 08:44:13,798 INFO L272 TraceCheckUtils]: 4: Hoare triple {361#true} call #t~ret6 := main(); {361#true} is VALID [2022-04-15 08:44:13,798 INFO L290 TraceCheckUtils]: 5: Hoare triple {361#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {361#true} is VALID [2022-04-15 08:44:13,798 INFO L272 TraceCheckUtils]: 6: Hoare triple {361#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:13,798 INFO L290 TraceCheckUtils]: 7: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:13,798 INFO L290 TraceCheckUtils]: 8: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:13,798 INFO L290 TraceCheckUtils]: 9: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:13,798 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {361#true} {361#true} #79#return; {361#true} is VALID [2022-04-15 08:44:13,799 INFO L290 TraceCheckUtils]: 11: Hoare triple {361#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {361#true} is VALID [2022-04-15 08:44:13,799 INFO L272 TraceCheckUtils]: 12: Hoare triple {361#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:13,799 INFO L290 TraceCheckUtils]: 13: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:13,799 INFO L290 TraceCheckUtils]: 14: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:13,799 INFO L290 TraceCheckUtils]: 15: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:13,799 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {361#true} {361#true} #81#return; {361#true} is VALID [2022-04-15 08:44:13,799 INFO L272 TraceCheckUtils]: 17: Hoare triple {361#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:13,799 INFO L290 TraceCheckUtils]: 18: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:13,800 INFO L290 TraceCheckUtils]: 19: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:13,800 INFO L290 TraceCheckUtils]: 20: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:13,800 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {361#true} {361#true} #83#return; {361#true} is VALID [2022-04-15 08:44:13,800 INFO L272 TraceCheckUtils]: 22: Hoare triple {361#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:13,800 INFO L290 TraceCheckUtils]: 23: Hoare triple {361#true} ~cond := #in~cond; {435#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-04-15 08:44:13,801 INFO L290 TraceCheckUtils]: 24: Hoare triple {435#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond); {439#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:44:13,801 INFO L290 TraceCheckUtils]: 25: Hoare triple {439#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {439#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:44:13,802 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {439#(not (= |assume_abort_if_not_#in~cond| 0))} {361#true} #85#return; {446#(<= 1 main_~y~0)} is VALID [2022-04-15 08:44:13,802 INFO L290 TraceCheckUtils]: 27: Hoare triple {446#(<= 1 main_~y~0)} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {450#(<= 1 main_~b~0)} is VALID [2022-04-15 08:44:13,802 INFO L272 TraceCheckUtils]: 28: Hoare triple {450#(<= 1 main_~b~0)} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:13,803 INFO L290 TraceCheckUtils]: 29: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:13,803 INFO L290 TraceCheckUtils]: 30: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:13,803 INFO L290 TraceCheckUtils]: 31: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:13,803 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {361#true} {450#(<= 1 main_~b~0)} #87#return; {450#(<= 1 main_~b~0)} is VALID [2022-04-15 08:44:13,803 INFO L272 TraceCheckUtils]: 33: Hoare triple {450#(<= 1 main_~b~0)} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:13,804 INFO L290 TraceCheckUtils]: 34: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:13,804 INFO L290 TraceCheckUtils]: 35: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:13,804 INFO L290 TraceCheckUtils]: 36: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:13,804 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {361#true} {450#(<= 1 main_~b~0)} #89#return; {450#(<= 1 main_~b~0)} is VALID [2022-04-15 08:44:13,805 INFO L290 TraceCheckUtils]: 38: Hoare triple {450#(<= 1 main_~b~0)} assume !false; {450#(<= 1 main_~b~0)} is VALID [2022-04-15 08:44:13,805 INFO L290 TraceCheckUtils]: 39: Hoare triple {450#(<= 1 main_~b~0)} assume !(0 != ~b~0); {362#false} is VALID [2022-04-15 08:44:13,805 INFO L272 TraceCheckUtils]: 40: Hoare triple {362#false} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {362#false} is VALID [2022-04-15 08:44:13,805 INFO L290 TraceCheckUtils]: 41: Hoare triple {362#false} ~cond := #in~cond; {362#false} is VALID [2022-04-15 08:44:13,805 INFO L290 TraceCheckUtils]: 42: Hoare triple {362#false} assume 0 == ~cond; {362#false} is VALID [2022-04-15 08:44:13,805 INFO L290 TraceCheckUtils]: 43: Hoare triple {362#false} assume !false; {362#false} is VALID [2022-04-15 08:44:13,806 INFO L134 CoverageAnalysis]: Checked inductivity of 60 backedges. 9 proven. 6 refuted. 0 times theorem prover too weak. 45 trivial. 0 not checked. [2022-04-15 08:44:13,806 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:44:14,049 INFO L290 TraceCheckUtils]: 43: Hoare triple {362#false} assume !false; {362#false} is VALID [2022-04-15 08:44:14,049 INFO L290 TraceCheckUtils]: 42: Hoare triple {362#false} assume 0 == ~cond; {362#false} is VALID [2022-04-15 08:44:14,049 INFO L290 TraceCheckUtils]: 41: Hoare triple {362#false} ~cond := #in~cond; {362#false} is VALID [2022-04-15 08:44:14,050 INFO L272 TraceCheckUtils]: 40: Hoare triple {362#false} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {362#false} is VALID [2022-04-15 08:44:14,051 INFO L290 TraceCheckUtils]: 39: Hoare triple {450#(<= 1 main_~b~0)} assume !(0 != ~b~0); {362#false} is VALID [2022-04-15 08:44:14,051 INFO L290 TraceCheckUtils]: 38: Hoare triple {450#(<= 1 main_~b~0)} assume !false; {450#(<= 1 main_~b~0)} is VALID [2022-04-15 08:44:14,057 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {361#true} {450#(<= 1 main_~b~0)} #89#return; {450#(<= 1 main_~b~0)} is VALID [2022-04-15 08:44:14,060 INFO L290 TraceCheckUtils]: 36: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:14,061 INFO L290 TraceCheckUtils]: 35: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:14,061 INFO L290 TraceCheckUtils]: 34: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:14,061 INFO L272 TraceCheckUtils]: 33: Hoare triple {450#(<= 1 main_~b~0)} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:14,062 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {361#true} {450#(<= 1 main_~b~0)} #87#return; {450#(<= 1 main_~b~0)} is VALID [2022-04-15 08:44:14,062 INFO L290 TraceCheckUtils]: 31: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:14,062 INFO L290 TraceCheckUtils]: 30: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:14,062 INFO L290 TraceCheckUtils]: 29: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:14,062 INFO L272 TraceCheckUtils]: 28: Hoare triple {450#(<= 1 main_~b~0)} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:14,062 INFO L290 TraceCheckUtils]: 27: Hoare triple {446#(<= 1 main_~y~0)} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {450#(<= 1 main_~b~0)} is VALID [2022-04-15 08:44:14,063 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {439#(not (= |assume_abort_if_not_#in~cond| 0))} {361#true} #85#return; {446#(<= 1 main_~y~0)} is VALID [2022-04-15 08:44:14,063 INFO L290 TraceCheckUtils]: 25: Hoare triple {439#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {439#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:44:14,064 INFO L290 TraceCheckUtils]: 24: Hoare triple {559#(or (not (= |assume_abort_if_not_#in~cond| 0)) (= assume_abort_if_not_~cond 0))} assume !(0 == ~cond); {439#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:44:14,064 INFO L290 TraceCheckUtils]: 23: Hoare triple {361#true} ~cond := #in~cond; {559#(or (not (= |assume_abort_if_not_#in~cond| 0)) (= assume_abort_if_not_~cond 0))} is VALID [2022-04-15 08:44:14,064 INFO L272 TraceCheckUtils]: 22: Hoare triple {361#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:14,064 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {361#true} {361#true} #83#return; {361#true} is VALID [2022-04-15 08:44:14,064 INFO L290 TraceCheckUtils]: 20: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:14,064 INFO L290 TraceCheckUtils]: 19: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:14,065 INFO L290 TraceCheckUtils]: 18: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:14,065 INFO L272 TraceCheckUtils]: 17: Hoare triple {361#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:14,065 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {361#true} {361#true} #81#return; {361#true} is VALID [2022-04-15 08:44:14,065 INFO L290 TraceCheckUtils]: 15: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:14,065 INFO L290 TraceCheckUtils]: 14: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:14,065 INFO L290 TraceCheckUtils]: 13: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:14,065 INFO L272 TraceCheckUtils]: 12: Hoare triple {361#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:14,065 INFO L290 TraceCheckUtils]: 11: Hoare triple {361#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {361#true} is VALID [2022-04-15 08:44:14,065 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {361#true} {361#true} #79#return; {361#true} is VALID [2022-04-15 08:44:14,065 INFO L290 TraceCheckUtils]: 9: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:14,066 INFO L290 TraceCheckUtils]: 8: Hoare triple {361#true} assume !(0 == ~cond); {361#true} is VALID [2022-04-15 08:44:14,066 INFO L290 TraceCheckUtils]: 7: Hoare triple {361#true} ~cond := #in~cond; {361#true} is VALID [2022-04-15 08:44:14,066 INFO L272 TraceCheckUtils]: 6: Hoare triple {361#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {361#true} is VALID [2022-04-15 08:44:14,066 INFO L290 TraceCheckUtils]: 5: Hoare triple {361#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {361#true} is VALID [2022-04-15 08:44:14,066 INFO L272 TraceCheckUtils]: 4: Hoare triple {361#true} call #t~ret6 := main(); {361#true} is VALID [2022-04-15 08:44:14,067 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {361#true} {361#true} #103#return; {361#true} is VALID [2022-04-15 08:44:14,067 INFO L290 TraceCheckUtils]: 2: Hoare triple {361#true} assume true; {361#true} is VALID [2022-04-15 08:44:14,067 INFO L290 TraceCheckUtils]: 1: Hoare triple {361#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {361#true} is VALID [2022-04-15 08:44:14,067 INFO L272 TraceCheckUtils]: 0: Hoare triple {361#true} call ULTIMATE.init(); {361#true} is VALID [2022-04-15 08:44:14,067 INFO L134 CoverageAnalysis]: Checked inductivity of 60 backedges. 9 proven. 6 refuted. 0 times theorem prover too weak. 45 trivial. 0 not checked. [2022-04-15 08:44:14,067 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:44:14,067 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [353032235] [2022-04-15 08:44:14,068 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:44:14,068 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1183111839] [2022-04-15 08:44:14,068 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1183111839] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:44:14,068 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:44:14,068 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [6, 6] total 7 [2022-04-15 08:44:14,069 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:44:14,069 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [2037303990] [2022-04-15 08:44:14,069 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [2037303990] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:44:14,070 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:44:14,070 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [6] imperfect sequences [] total 6 [2022-04-15 08:44:14,070 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1582819002] [2022-04-15 08:44:14,070 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:44:14,070 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 2.6666666666666665) internal successors, (16), 5 states have internal predecessors, (16), 3 states have call successors, (9), 2 states have call predecessors, (9), 2 states have return successors, (7), 3 states have call predecessors, (7), 2 states have call successors, (7) Word has length 44 [2022-04-15 08:44:14,071 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:44:14,071 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 2.6666666666666665) internal successors, (16), 5 states have internal predecessors, (16), 3 states have call successors, (9), 2 states have call predecessors, (9), 2 states have return successors, (7), 3 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:14,090 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 32 edges. 32 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:14,090 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-04-15 08:44:14,090 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:14,091 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-04-15 08:44:14,091 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=13, Invalid=29, Unknown=0, NotChecked=0, Total=42 [2022-04-15 08:44:14,091 INFO L87 Difference]: Start difference. First operand 35 states and 46 transitions. Second operand has 6 states, 6 states have (on average 2.6666666666666665) internal successors, (16), 5 states have internal predecessors, (16), 3 states have call successors, (9), 2 states have call predecessors, (9), 2 states have return successors, (7), 3 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:14,368 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:14,368 INFO L93 Difference]: Finished difference Result 52 states and 69 transitions. [2022-04-15 08:44:14,369 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 6 states. [2022-04-15 08:44:14,369 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 2.6666666666666665) internal successors, (16), 5 states have internal predecessors, (16), 3 states have call successors, (9), 2 states have call predecessors, (9), 2 states have return successors, (7), 3 states have call predecessors, (7), 2 states have call successors, (7) Word has length 44 [2022-04-15 08:44:14,369 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:44:14,369 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 2.6666666666666665) internal successors, (16), 5 states have internal predecessors, (16), 3 states have call successors, (9), 2 states have call predecessors, (9), 2 states have return successors, (7), 3 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:14,372 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 69 transitions. [2022-04-15 08:44:14,372 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 2.6666666666666665) internal successors, (16), 5 states have internal predecessors, (16), 3 states have call successors, (9), 2 states have call predecessors, (9), 2 states have return successors, (7), 3 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:14,374 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 69 transitions. [2022-04-15 08:44:14,374 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 6 states and 69 transitions. [2022-04-15 08:44:14,431 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 69 edges. 69 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:14,433 INFO L225 Difference]: With dead ends: 52 [2022-04-15 08:44:14,433 INFO L226 Difference]: Without dead ends: 44 [2022-04-15 08:44:14,434 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 89 GetRequests, 81 SyntacticMatches, 1 SemanticMatches, 7 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 1 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=22, Invalid=50, Unknown=0, NotChecked=0, Total=72 [2022-04-15 08:44:14,434 INFO L913 BasicCegarLoop]: 38 mSDtfsCounter, 19 mSDsluCounter, 90 mSDsCounter, 0 mSdLazyCounter, 90 mSolverCounterSat, 11 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 24 SdHoareTripleChecker+Valid, 128 SdHoareTripleChecker+Invalid, 101 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 11 IncrementalHoareTripleChecker+Valid, 90 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-15 08:44:14,435 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [24 Valid, 128 Invalid, 101 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [11 Valid, 90 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-15 08:44:14,435 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 44 states. [2022-04-15 08:44:14,452 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 44 to 37. [2022-04-15 08:44:14,453 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:44:14,453 INFO L82 GeneralOperation]: Start isEquivalent. First operand 44 states. Second operand has 37 states, 19 states have (on average 1.1578947368421053) internal successors, (22), 20 states have internal predecessors, (22), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) [2022-04-15 08:44:14,453 INFO L74 IsIncluded]: Start isIncluded. First operand 44 states. Second operand has 37 states, 19 states have (on average 1.1578947368421053) internal successors, (22), 20 states have internal predecessors, (22), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) [2022-04-15 08:44:14,454 INFO L87 Difference]: Start difference. First operand 44 states. Second operand has 37 states, 19 states have (on average 1.1578947368421053) internal successors, (22), 20 states have internal predecessors, (22), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) [2022-04-15 08:44:14,456 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:14,456 INFO L93 Difference]: Finished difference Result 44 states and 60 transitions. [2022-04-15 08:44:14,456 INFO L276 IsEmpty]: Start isEmpty. Operand 44 states and 60 transitions. [2022-04-15 08:44:14,457 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:14,457 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:14,457 INFO L74 IsIncluded]: Start isIncluded. First operand has 37 states, 19 states have (on average 1.1578947368421053) internal successors, (22), 20 states have internal predecessors, (22), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) Second operand 44 states. [2022-04-15 08:44:14,458 INFO L87 Difference]: Start difference. First operand has 37 states, 19 states have (on average 1.1578947368421053) internal successors, (22), 20 states have internal predecessors, (22), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) Second operand 44 states. [2022-04-15 08:44:14,460 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:14,460 INFO L93 Difference]: Finished difference Result 44 states and 60 transitions. [2022-04-15 08:44:14,460 INFO L276 IsEmpty]: Start isEmpty. Operand 44 states and 60 transitions. [2022-04-15 08:44:14,460 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:14,460 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:14,460 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:44:14,460 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:44:14,461 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 37 states, 19 states have (on average 1.1578947368421053) internal successors, (22), 20 states have internal predecessors, (22), 14 states have call successors, (14), 4 states have call predecessors, (14), 3 states have return successors, (12), 12 states have call predecessors, (12), 12 states have call successors, (12) [2022-04-15 08:44:14,462 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 37 states to 37 states and 48 transitions. [2022-04-15 08:44:14,462 INFO L78 Accepts]: Start accepts. Automaton has 37 states and 48 transitions. Word has length 44 [2022-04-15 08:44:14,462 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:44:14,462 INFO L478 AbstractCegarLoop]: Abstraction has 37 states and 48 transitions. [2022-04-15 08:44:14,462 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 2.6666666666666665) internal successors, (16), 5 states have internal predecessors, (16), 3 states have call successors, (9), 2 states have call predecessors, (9), 2 states have return successors, (7), 3 states have call predecessors, (7), 2 states have call successors, (7) [2022-04-15 08:44:14,463 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 37 states and 48 transitions. [2022-04-15 08:44:14,503 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 48 edges. 48 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:14,503 INFO L276 IsEmpty]: Start isEmpty. Operand 37 states and 48 transitions. [2022-04-15 08:44:14,504 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 46 [2022-04-15 08:44:14,504 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:44:14,504 INFO L499 BasicCegarLoop]: trace histogram [6, 6, 6, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-15 08:44:14,524 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (2)] Forceful destruction successful, exit code 0 [2022-04-15 08:44:14,726 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable1,2 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:44:14,726 INFO L403 AbstractCegarLoop]: === Iteration 3 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:44:14,726 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:44:14,726 INFO L85 PathProgramCache]: Analyzing trace with hash 561616070, now seen corresponding path program 1 times [2022-04-15 08:44:14,727 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:14,727 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1819466101] [2022-04-15 08:44:14,727 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:44:14,727 INFO L85 PathProgramCache]: Analyzing trace with hash 561616070, now seen corresponding path program 2 times [2022-04-15 08:44:14,727 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:44:14,727 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [2043262537] [2022-04-15 08:44:14,727 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:44:14,727 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:44:14,750 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:44:14,751 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1097274491] [2022-04-15 08:44:14,751 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:44:14,751 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:44:14,751 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:44:14,752 INFO L229 MonitoredProcess]: Starting monitored process 3 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:44:14,755 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Waiting until timeout for monitored process [2022-04-15 08:44:14,795 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 1 check-sat command(s) [2022-04-15 08:44:14,795 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:44:14,795 INFO L263 TraceCheckSpWp]: Trace formula consists of 68 conjuncts, 8 conjunts are in the unsatisfiable core [2022-04-15 08:44:14,804 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:14,805 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:44:14,908 INFO L272 TraceCheckUtils]: 0: Hoare triple {901#true} call ULTIMATE.init(); {901#true} is VALID [2022-04-15 08:44:14,909 INFO L290 TraceCheckUtils]: 1: Hoare triple {901#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {901#true} is VALID [2022-04-15 08:44:14,909 INFO L290 TraceCheckUtils]: 2: Hoare triple {901#true} assume true; {901#true} is VALID [2022-04-15 08:44:14,909 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {901#true} {901#true} #103#return; {901#true} is VALID [2022-04-15 08:44:14,909 INFO L272 TraceCheckUtils]: 4: Hoare triple {901#true} call #t~ret6 := main(); {901#true} is VALID [2022-04-15 08:44:14,909 INFO L290 TraceCheckUtils]: 5: Hoare triple {901#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {901#true} is VALID [2022-04-15 08:44:14,909 INFO L272 TraceCheckUtils]: 6: Hoare triple {901#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {901#true} is VALID [2022-04-15 08:44:14,909 INFO L290 TraceCheckUtils]: 7: Hoare triple {901#true} ~cond := #in~cond; {901#true} is VALID [2022-04-15 08:44:14,909 INFO L290 TraceCheckUtils]: 8: Hoare triple {901#true} assume !(0 == ~cond); {901#true} is VALID [2022-04-15 08:44:14,909 INFO L290 TraceCheckUtils]: 9: Hoare triple {901#true} assume true; {901#true} is VALID [2022-04-15 08:44:14,910 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {901#true} {901#true} #79#return; {901#true} is VALID [2022-04-15 08:44:14,910 INFO L290 TraceCheckUtils]: 11: Hoare triple {901#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {901#true} is VALID [2022-04-15 08:44:14,910 INFO L272 TraceCheckUtils]: 12: Hoare triple {901#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {901#true} is VALID [2022-04-15 08:44:14,910 INFO L290 TraceCheckUtils]: 13: Hoare triple {901#true} ~cond := #in~cond; {901#true} is VALID [2022-04-15 08:44:14,910 INFO L290 TraceCheckUtils]: 14: Hoare triple {901#true} assume !(0 == ~cond); {901#true} is VALID [2022-04-15 08:44:14,910 INFO L290 TraceCheckUtils]: 15: Hoare triple {901#true} assume true; {901#true} is VALID [2022-04-15 08:44:14,910 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {901#true} {901#true} #81#return; {901#true} is VALID [2022-04-15 08:44:14,910 INFO L272 TraceCheckUtils]: 17: Hoare triple {901#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {901#true} is VALID [2022-04-15 08:44:14,910 INFO L290 TraceCheckUtils]: 18: Hoare triple {901#true} ~cond := #in~cond; {901#true} is VALID [2022-04-15 08:44:14,911 INFO L290 TraceCheckUtils]: 19: Hoare triple {901#true} assume !(0 == ~cond); {901#true} is VALID [2022-04-15 08:44:14,911 INFO L290 TraceCheckUtils]: 20: Hoare triple {901#true} assume true; {901#true} is VALID [2022-04-15 08:44:14,911 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {901#true} {901#true} #83#return; {901#true} is VALID [2022-04-15 08:44:14,911 INFO L272 TraceCheckUtils]: 22: Hoare triple {901#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {901#true} is VALID [2022-04-15 08:44:14,911 INFO L290 TraceCheckUtils]: 23: Hoare triple {901#true} ~cond := #in~cond; {901#true} is VALID [2022-04-15 08:44:14,911 INFO L290 TraceCheckUtils]: 24: Hoare triple {901#true} assume !(0 == ~cond); {901#true} is VALID [2022-04-15 08:44:14,911 INFO L290 TraceCheckUtils]: 25: Hoare triple {901#true} assume true; {901#true} is VALID [2022-04-15 08:44:14,911 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {901#true} {901#true} #85#return; {901#true} is VALID [2022-04-15 08:44:14,911 INFO L290 TraceCheckUtils]: 27: Hoare triple {901#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {901#true} is VALID [2022-04-15 08:44:14,911 INFO L272 TraceCheckUtils]: 28: Hoare triple {901#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {901#true} is VALID [2022-04-15 08:44:14,912 INFO L290 TraceCheckUtils]: 29: Hoare triple {901#true} ~cond := #in~cond; {901#true} is VALID [2022-04-15 08:44:14,912 INFO L290 TraceCheckUtils]: 30: Hoare triple {901#true} assume !(0 == ~cond); {901#true} is VALID [2022-04-15 08:44:14,912 INFO L290 TraceCheckUtils]: 31: Hoare triple {901#true} assume true; {901#true} is VALID [2022-04-15 08:44:14,912 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {901#true} {901#true} #87#return; {901#true} is VALID [2022-04-15 08:44:14,912 INFO L272 TraceCheckUtils]: 33: Hoare triple {901#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {901#true} is VALID [2022-04-15 08:44:14,912 INFO L290 TraceCheckUtils]: 34: Hoare triple {901#true} ~cond := #in~cond; {901#true} is VALID [2022-04-15 08:44:14,912 INFO L290 TraceCheckUtils]: 35: Hoare triple {901#true} assume !(0 == ~cond); {901#true} is VALID [2022-04-15 08:44:14,912 INFO L290 TraceCheckUtils]: 36: Hoare triple {901#true} assume true; {901#true} is VALID [2022-04-15 08:44:14,912 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {901#true} {901#true} #89#return; {901#true} is VALID [2022-04-15 08:44:14,912 INFO L290 TraceCheckUtils]: 38: Hoare triple {901#true} assume !false; {901#true} is VALID [2022-04-15 08:44:14,913 INFO L290 TraceCheckUtils]: 39: Hoare triple {901#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {1023#(and (= main_~c~0 main_~a~0) (= main_~k~0 0) (not (= main_~b~0 0)))} is VALID [2022-04-15 08:44:14,913 INFO L290 TraceCheckUtils]: 40: Hoare triple {1023#(and (= main_~c~0 main_~a~0) (= main_~k~0 0) (not (= main_~b~0 0)))} assume !false; {1023#(and (= main_~c~0 main_~a~0) (= main_~k~0 0) (not (= main_~b~0 0)))} is VALID [2022-04-15 08:44:14,914 INFO L272 TraceCheckUtils]: 41: Hoare triple {1023#(and (= main_~c~0 main_~a~0) (= main_~k~0 0) (not (= main_~b~0 0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {1030#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:44:14,914 INFO L290 TraceCheckUtils]: 42: Hoare triple {1030#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {1034#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:44:14,915 INFO L290 TraceCheckUtils]: 43: Hoare triple {1034#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {902#false} is VALID [2022-04-15 08:44:14,915 INFO L290 TraceCheckUtils]: 44: Hoare triple {902#false} assume !false; {902#false} is VALID [2022-04-15 08:44:14,915 INFO L134 CoverageAnalysis]: Checked inductivity of 60 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 60 trivial. 0 not checked. [2022-04-15 08:44:14,915 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-04-15 08:44:14,915 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:44:14,915 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [2043262537] [2022-04-15 08:44:14,915 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:44:14,915 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1097274491] [2022-04-15 08:44:14,915 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1097274491] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:44:14,916 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:44:14,916 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-15 08:44:14,916 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:44:14,916 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1819466101] [2022-04-15 08:44:14,916 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1819466101] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:44:14,916 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:44:14,916 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-15 08:44:14,916 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [563520700] [2022-04-15 08:44:14,916 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:44:14,917 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (9), 2 states have call predecessors, (9), 1 states have return successors, (7), 1 states have call predecessors, (7), 1 states have call successors, (7) Word has length 45 [2022-04-15 08:44:14,917 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:44:14,917 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (9), 2 states have call predecessors, (9), 1 states have return successors, (7), 1 states have call predecessors, (7), 1 states have call successors, (7) [2022-04-15 08:44:14,935 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 30 edges. 30 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:14,935 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-04-15 08:44:14,936 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:14,936 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-04-15 08:44:14,936 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=7, Invalid=13, Unknown=0, NotChecked=0, Total=20 [2022-04-15 08:44:14,936 INFO L87 Difference]: Start difference. First operand 37 states and 48 transitions. Second operand has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (9), 2 states have call predecessors, (9), 1 states have return successors, (7), 1 states have call predecessors, (7), 1 states have call successors, (7) [2022-04-15 08:44:15,133 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:15,133 INFO L93 Difference]: Finished difference Result 50 states and 65 transitions. [2022-04-15 08:44:15,133 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2022-04-15 08:44:15,133 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (9), 2 states have call predecessors, (9), 1 states have return successors, (7), 1 states have call predecessors, (7), 1 states have call successors, (7) Word has length 45 [2022-04-15 08:44:15,134 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:44:15,134 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (9), 2 states have call predecessors, (9), 1 states have return successors, (7), 1 states have call predecessors, (7), 1 states have call successors, (7) [2022-04-15 08:44:15,135 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 63 transitions. [2022-04-15 08:44:15,136 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (9), 2 states have call predecessors, (9), 1 states have return successors, (7), 1 states have call predecessors, (7), 1 states have call successors, (7) [2022-04-15 08:44:15,137 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 63 transitions. [2022-04-15 08:44:15,137 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 5 states and 63 transitions. [2022-04-15 08:44:15,187 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 63 edges. 63 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:15,189 INFO L225 Difference]: With dead ends: 50 [2022-04-15 08:44:15,189 INFO L226 Difference]: Without dead ends: 48 [2022-04-15 08:44:15,189 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 45 GetRequests, 41 SyntacticMatches, 0 SemanticMatches, 4 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=11, Invalid=19, Unknown=0, NotChecked=0, Total=30 [2022-04-15 08:44:15,190 INFO L913 BasicCegarLoop]: 44 mSDtfsCounter, 6 mSDsluCounter, 110 mSDsCounter, 0 mSdLazyCounter, 41 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 10 SdHoareTripleChecker+Valid, 154 SdHoareTripleChecker+Invalid, 41 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 41 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-04-15 08:44:15,190 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [10 Valid, 154 Invalid, 41 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 41 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-04-15 08:44:15,191 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 48 states. [2022-04-15 08:44:15,216 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 48 to 43. [2022-04-15 08:44:15,217 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:44:15,218 INFO L82 GeneralOperation]: Start isEquivalent. First operand 48 states. Second operand has 43 states, 23 states have (on average 1.1304347826086956) internal successors, (26), 25 states have internal predecessors, (26), 15 states have call successors, (15), 5 states have call predecessors, (15), 4 states have return successors, (13), 12 states have call predecessors, (13), 13 states have call successors, (13) [2022-04-15 08:44:15,220 INFO L74 IsIncluded]: Start isIncluded. First operand 48 states. Second operand has 43 states, 23 states have (on average 1.1304347826086956) internal successors, (26), 25 states have internal predecessors, (26), 15 states have call successors, (15), 5 states have call predecessors, (15), 4 states have return successors, (13), 12 states have call predecessors, (13), 13 states have call successors, (13) [2022-04-15 08:44:15,220 INFO L87 Difference]: Start difference. First operand 48 states. Second operand has 43 states, 23 states have (on average 1.1304347826086956) internal successors, (26), 25 states have internal predecessors, (26), 15 states have call successors, (15), 5 states have call predecessors, (15), 4 states have return successors, (13), 12 states have call predecessors, (13), 13 states have call successors, (13) [2022-04-15 08:44:15,224 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:15,224 INFO L93 Difference]: Finished difference Result 48 states and 63 transitions. [2022-04-15 08:44:15,224 INFO L276 IsEmpty]: Start isEmpty. Operand 48 states and 63 transitions. [2022-04-15 08:44:15,225 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:15,225 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:15,226 INFO L74 IsIncluded]: Start isIncluded. First operand has 43 states, 23 states have (on average 1.1304347826086956) internal successors, (26), 25 states have internal predecessors, (26), 15 states have call successors, (15), 5 states have call predecessors, (15), 4 states have return successors, (13), 12 states have call predecessors, (13), 13 states have call successors, (13) Second operand 48 states. [2022-04-15 08:44:15,226 INFO L87 Difference]: Start difference. First operand has 43 states, 23 states have (on average 1.1304347826086956) internal successors, (26), 25 states have internal predecessors, (26), 15 states have call successors, (15), 5 states have call predecessors, (15), 4 states have return successors, (13), 12 states have call predecessors, (13), 13 states have call successors, (13) Second operand 48 states. [2022-04-15 08:44:15,230 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:15,230 INFO L93 Difference]: Finished difference Result 48 states and 63 transitions. [2022-04-15 08:44:15,230 INFO L276 IsEmpty]: Start isEmpty. Operand 48 states and 63 transitions. [2022-04-15 08:44:15,230 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:15,230 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:15,230 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:44:15,231 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:44:15,232 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 43 states, 23 states have (on average 1.1304347826086956) internal successors, (26), 25 states have internal predecessors, (26), 15 states have call successors, (15), 5 states have call predecessors, (15), 4 states have return successors, (13), 12 states have call predecessors, (13), 13 states have call successors, (13) [2022-04-15 08:44:15,235 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 43 states to 43 states and 54 transitions. [2022-04-15 08:44:15,235 INFO L78 Accepts]: Start accepts. Automaton has 43 states and 54 transitions. Word has length 45 [2022-04-15 08:44:15,235 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:44:15,235 INFO L478 AbstractCegarLoop]: Abstraction has 43 states and 54 transitions. [2022-04-15 08:44:15,236 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 2.8) internal successors, (14), 4 states have internal predecessors, (14), 2 states have call successors, (9), 2 states have call predecessors, (9), 1 states have return successors, (7), 1 states have call predecessors, (7), 1 states have call successors, (7) [2022-04-15 08:44:15,236 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 43 states and 54 transitions. [2022-04-15 08:44:15,285 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 54 edges. 54 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:15,285 INFO L276 IsEmpty]: Start isEmpty. Operand 43 states and 54 transitions. [2022-04-15 08:44:15,286 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 51 [2022-04-15 08:44:15,286 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:44:15,286 INFO L499 BasicCegarLoop]: trace histogram [6, 6, 6, 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] [2022-04-15 08:44:15,310 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Forceful destruction successful, exit code 0 [2022-04-15 08:44:15,503 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 3 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable2 [2022-04-15 08:44:15,503 INFO L403 AbstractCegarLoop]: === Iteration 4 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:44:15,504 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:44:15,504 INFO L85 PathProgramCache]: Analyzing trace with hash -680064098, now seen corresponding path program 1 times [2022-04-15 08:44:15,504 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:15,504 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [64397330] [2022-04-15 08:44:15,504 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:44:15,504 INFO L85 PathProgramCache]: Analyzing trace with hash -680064098, now seen corresponding path program 2 times [2022-04-15 08:44:15,504 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:44:15,505 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1617981014] [2022-04-15 08:44:15,505 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:44:15,505 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:44:15,529 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:44:15,529 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [951117629] [2022-04-15 08:44:15,529 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:44:15,529 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:44:15,529 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:44:15,530 INFO L229 MonitoredProcess]: Starting monitored process 4 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:44:15,532 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Waiting until timeout for monitored process [2022-04-15 08:44:15,568 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:44:15,568 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:44:15,569 INFO L263 TraceCheckSpWp]: Trace formula consists of 146 conjuncts, 9 conjunts are in the unsatisfiable core [2022-04-15 08:44:15,578 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:15,579 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:44:15,731 INFO L272 TraceCheckUtils]: 0: Hoare triple {1324#true} call ULTIMATE.init(); {1324#true} is VALID [2022-04-15 08:44:15,731 INFO L290 TraceCheckUtils]: 1: Hoare triple {1324#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {1324#true} is VALID [2022-04-15 08:44:15,731 INFO L290 TraceCheckUtils]: 2: Hoare triple {1324#true} assume true; {1324#true} is VALID [2022-04-15 08:44:15,731 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {1324#true} {1324#true} #103#return; {1324#true} is VALID [2022-04-15 08:44:15,731 INFO L272 TraceCheckUtils]: 4: Hoare triple {1324#true} call #t~ret6 := main(); {1324#true} is VALID [2022-04-15 08:44:15,731 INFO L290 TraceCheckUtils]: 5: Hoare triple {1324#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {1324#true} is VALID [2022-04-15 08:44:15,731 INFO L272 TraceCheckUtils]: 6: Hoare triple {1324#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L290 TraceCheckUtils]: 7: Hoare triple {1324#true} ~cond := #in~cond; {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L290 TraceCheckUtils]: 8: Hoare triple {1324#true} assume !(0 == ~cond); {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L290 TraceCheckUtils]: 9: Hoare triple {1324#true} assume true; {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {1324#true} {1324#true} #79#return; {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L290 TraceCheckUtils]: 11: Hoare triple {1324#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L272 TraceCheckUtils]: 12: Hoare triple {1324#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L290 TraceCheckUtils]: 13: Hoare triple {1324#true} ~cond := #in~cond; {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L290 TraceCheckUtils]: 14: Hoare triple {1324#true} assume !(0 == ~cond); {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L290 TraceCheckUtils]: 15: Hoare triple {1324#true} assume true; {1324#true} is VALID [2022-04-15 08:44:15,732 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {1324#true} {1324#true} #81#return; {1324#true} is VALID [2022-04-15 08:44:15,733 INFO L272 TraceCheckUtils]: 17: Hoare triple {1324#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {1324#true} is VALID [2022-04-15 08:44:15,733 INFO L290 TraceCheckUtils]: 18: Hoare triple {1324#true} ~cond := #in~cond; {1324#true} is VALID [2022-04-15 08:44:15,733 INFO L290 TraceCheckUtils]: 19: Hoare triple {1324#true} assume !(0 == ~cond); {1324#true} is VALID [2022-04-15 08:44:15,733 INFO L290 TraceCheckUtils]: 20: Hoare triple {1324#true} assume true; {1324#true} is VALID [2022-04-15 08:44:15,733 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {1324#true} {1324#true} #83#return; {1324#true} is VALID [2022-04-15 08:44:15,733 INFO L272 TraceCheckUtils]: 22: Hoare triple {1324#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {1324#true} is VALID [2022-04-15 08:44:15,733 INFO L290 TraceCheckUtils]: 23: Hoare triple {1324#true} ~cond := #in~cond; {1324#true} is VALID [2022-04-15 08:44:15,733 INFO L290 TraceCheckUtils]: 24: Hoare triple {1324#true} assume !(0 == ~cond); {1324#true} is VALID [2022-04-15 08:44:15,733 INFO L290 TraceCheckUtils]: 25: Hoare triple {1324#true} assume true; {1324#true} is VALID [2022-04-15 08:44:15,734 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {1324#true} {1324#true} #85#return; {1324#true} is VALID [2022-04-15 08:44:15,735 INFO L290 TraceCheckUtils]: 27: Hoare triple {1324#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:44:15,735 INFO L272 TraceCheckUtils]: 28: Hoare triple {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {1324#true} is VALID [2022-04-15 08:44:15,736 INFO L290 TraceCheckUtils]: 29: Hoare triple {1324#true} ~cond := #in~cond; {1324#true} is VALID [2022-04-15 08:44:15,736 INFO L290 TraceCheckUtils]: 30: Hoare triple {1324#true} assume !(0 == ~cond); {1324#true} is VALID [2022-04-15 08:44:15,736 INFO L290 TraceCheckUtils]: 31: Hoare triple {1324#true} assume true; {1324#true} is VALID [2022-04-15 08:44:15,736 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {1324#true} {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #87#return; {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:44:15,736 INFO L272 TraceCheckUtils]: 33: Hoare triple {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {1324#true} is VALID [2022-04-15 08:44:15,737 INFO L290 TraceCheckUtils]: 34: Hoare triple {1324#true} ~cond := #in~cond; {1324#true} is VALID [2022-04-15 08:44:15,737 INFO L290 TraceCheckUtils]: 35: Hoare triple {1324#true} assume !(0 == ~cond); {1324#true} is VALID [2022-04-15 08:44:15,737 INFO L290 TraceCheckUtils]: 36: Hoare triple {1324#true} assume true; {1324#true} is VALID [2022-04-15 08:44:15,738 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {1324#true} {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #89#return; {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:44:15,738 INFO L290 TraceCheckUtils]: 38: Hoare triple {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:44:15,739 INFO L290 TraceCheckUtils]: 39: Hoare triple {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:44:15,739 INFO L290 TraceCheckUtils]: 40: Hoare triple {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:44:15,739 INFO L272 TraceCheckUtils]: 41: Hoare triple {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {1324#true} is VALID [2022-04-15 08:44:15,740 INFO L290 TraceCheckUtils]: 42: Hoare triple {1324#true} ~cond := #in~cond; {1324#true} is VALID [2022-04-15 08:44:15,740 INFO L290 TraceCheckUtils]: 43: Hoare triple {1324#true} assume !(0 == ~cond); {1324#true} is VALID [2022-04-15 08:44:15,740 INFO L290 TraceCheckUtils]: 44: Hoare triple {1324#true} assume true; {1324#true} is VALID [2022-04-15 08:44:15,744 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {1324#true} {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:44:15,745 INFO L272 TraceCheckUtils]: 46: Hoare triple {1410#(and (= main_~r~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {1468#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:44:15,745 INFO L290 TraceCheckUtils]: 47: Hoare triple {1468#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {1472#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:44:15,745 INFO L290 TraceCheckUtils]: 48: Hoare triple {1472#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {1325#false} is VALID [2022-04-15 08:44:15,746 INFO L290 TraceCheckUtils]: 49: Hoare triple {1325#false} assume !false; {1325#false} is VALID [2022-04-15 08:44:15,746 INFO L134 CoverageAnalysis]: Checked inductivity of 62 backedges. 2 proven. 0 refuted. 0 times theorem prover too weak. 60 trivial. 0 not checked. [2022-04-15 08:44:15,746 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-04-15 08:44:15,746 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:44:15,746 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1617981014] [2022-04-15 08:44:15,746 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:44:15,746 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [951117629] [2022-04-15 08:44:15,746 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [951117629] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:44:15,746 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:44:15,747 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-15 08:44:15,747 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:44:15,747 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [64397330] [2022-04-15 08:44:15,747 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [64397330] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:44:15,747 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:44:15,747 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-15 08:44:15,747 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [631332971] [2022-04-15 08:44:15,747 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:44:15,747 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (10), 2 states have call predecessors, (10), 1 states have return successors, (8), 2 states have call predecessors, (8), 2 states have call successors, (8) Word has length 50 [2022-04-15 08:44:15,748 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:44:15,748 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (10), 2 states have call predecessors, (10), 1 states have return successors, (8), 2 states have call predecessors, (8), 2 states have call successors, (8) [2022-04-15 08:44:15,772 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 35 edges. 35 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:15,772 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-04-15 08:44:15,773 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:15,773 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-04-15 08:44:15,773 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=7, Invalid=13, Unknown=0, NotChecked=0, Total=20 [2022-04-15 08:44:15,774 INFO L87 Difference]: Start difference. First operand 43 states and 54 transitions. Second operand has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (10), 2 states have call predecessors, (10), 1 states have return successors, (8), 2 states have call predecessors, (8), 2 states have call successors, (8) [2022-04-15 08:44:15,955 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:15,955 INFO L93 Difference]: Finished difference Result 58 states and 74 transitions. [2022-04-15 08:44:15,955 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2022-04-15 08:44:15,956 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (10), 2 states have call predecessors, (10), 1 states have return successors, (8), 2 states have call predecessors, (8), 2 states have call successors, (8) Word has length 50 [2022-04-15 08:44:15,956 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:44:15,956 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (10), 2 states have call predecessors, (10), 1 states have return successors, (8), 2 states have call predecessors, (8), 2 states have call successors, (8) [2022-04-15 08:44:15,957 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 65 transitions. [2022-04-15 08:44:15,957 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (10), 2 states have call predecessors, (10), 1 states have return successors, (8), 2 states have call predecessors, (8), 2 states have call successors, (8) [2022-04-15 08:44:15,959 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 65 transitions. [2022-04-15 08:44:15,959 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 5 states and 65 transitions. [2022-04-15 08:44:16,009 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 65 edges. 65 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:16,010 INFO L225 Difference]: With dead ends: 58 [2022-04-15 08:44:16,010 INFO L226 Difference]: Without dead ends: 56 [2022-04-15 08:44:16,010 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 50 GetRequests, 46 SyntacticMatches, 0 SemanticMatches, 4 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=11, Invalid=19, Unknown=0, NotChecked=0, Total=30 [2022-04-15 08:44:16,011 INFO L913 BasicCegarLoop]: 48 mSDtfsCounter, 7 mSDsluCounter, 113 mSDsCounter, 0 mSdLazyCounter, 38 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 10 SdHoareTripleChecker+Valid, 161 SdHoareTripleChecker+Invalid, 38 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 38 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-04-15 08:44:16,011 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [10 Valid, 161 Invalid, 38 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 38 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-04-15 08:44:16,012 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 56 states. [2022-04-15 08:44:16,043 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 56 to 55. [2022-04-15 08:44:16,043 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:44:16,043 INFO L82 GeneralOperation]: Start isEquivalent. First operand 56 states. Second operand has 55 states, 29 states have (on average 1.1379310344827587) internal successors, (33), 32 states have internal predecessors, (33), 20 states have call successors, (20), 6 states have call predecessors, (20), 5 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:44:16,044 INFO L74 IsIncluded]: Start isIncluded. First operand 56 states. Second operand has 55 states, 29 states have (on average 1.1379310344827587) internal successors, (33), 32 states have internal predecessors, (33), 20 states have call successors, (20), 6 states have call predecessors, (20), 5 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:44:16,044 INFO L87 Difference]: Start difference. First operand 56 states. Second operand has 55 states, 29 states have (on average 1.1379310344827587) internal successors, (33), 32 states have internal predecessors, (33), 20 states have call successors, (20), 6 states have call predecessors, (20), 5 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:44:16,046 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:16,046 INFO L93 Difference]: Finished difference Result 56 states and 72 transitions. [2022-04-15 08:44:16,046 INFO L276 IsEmpty]: Start isEmpty. Operand 56 states and 72 transitions. [2022-04-15 08:44:16,046 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:16,046 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:16,047 INFO L74 IsIncluded]: Start isIncluded. First operand has 55 states, 29 states have (on average 1.1379310344827587) internal successors, (33), 32 states have internal predecessors, (33), 20 states have call successors, (20), 6 states have call predecessors, (20), 5 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) Second operand 56 states. [2022-04-15 08:44:16,047 INFO L87 Difference]: Start difference. First operand has 55 states, 29 states have (on average 1.1379310344827587) internal successors, (33), 32 states have internal predecessors, (33), 20 states have call successors, (20), 6 states have call predecessors, (20), 5 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) Second operand 56 states. [2022-04-15 08:44:16,049 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:16,049 INFO L93 Difference]: Finished difference Result 56 states and 72 transitions. [2022-04-15 08:44:16,049 INFO L276 IsEmpty]: Start isEmpty. Operand 56 states and 72 transitions. [2022-04-15 08:44:16,049 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:16,049 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:16,049 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:44:16,049 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:44:16,050 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 55 states, 29 states have (on average 1.1379310344827587) internal successors, (33), 32 states have internal predecessors, (33), 20 states have call successors, (20), 6 states have call predecessors, (20), 5 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:44:16,051 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 55 states to 55 states and 71 transitions. [2022-04-15 08:44:16,052 INFO L78 Accepts]: Start accepts. Automaton has 55 states and 71 transitions. Word has length 50 [2022-04-15 08:44:16,052 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:44:16,052 INFO L478 AbstractCegarLoop]: Abstraction has 55 states and 71 transitions. [2022-04-15 08:44:16,052 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (10), 2 states have call predecessors, (10), 1 states have return successors, (8), 2 states have call predecessors, (8), 2 states have call successors, (8) [2022-04-15 08:44:16,052 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 55 states and 71 transitions. [2022-04-15 08:44:16,117 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 71 edges. 71 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:16,117 INFO L276 IsEmpty]: Start isEmpty. Operand 55 states and 71 transitions. [2022-04-15 08:44:16,118 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 56 [2022-04-15 08:44:16,118 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:44:16,118 INFO L499 BasicCegarLoop]: trace histogram [6, 6, 6, 3, 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] [2022-04-15 08:44:16,136 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Forceful destruction successful, exit code 0 [2022-04-15 08:44:16,334 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable3,4 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:44:16,335 INFO L403 AbstractCegarLoop]: === Iteration 5 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:44:16,335 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:44:16,335 INFO L85 PathProgramCache]: Analyzing trace with hash 606548870, now seen corresponding path program 1 times [2022-04-15 08:44:16,335 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:16,335 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [2076913512] [2022-04-15 08:44:16,336 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:44:16,336 INFO L85 PathProgramCache]: Analyzing trace with hash 606548870, now seen corresponding path program 2 times [2022-04-15 08:44:16,336 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:44:16,336 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [645215129] [2022-04-15 08:44:16,336 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:44:16,336 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:44:16,348 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:44:16,349 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [540856911] [2022-04-15 08:44:16,349 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:44:16,349 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:44:16,349 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:44:16,350 INFO L229 MonitoredProcess]: Starting monitored process 5 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:44:16,353 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (5)] Waiting until timeout for monitored process [2022-04-15 08:44:16,390 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:44:16,391 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:44:16,391 INFO L263 TraceCheckSpWp]: Trace formula consists of 155 conjuncts, 9 conjunts are in the unsatisfiable core [2022-04-15 08:44:16,403 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:16,404 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:44:16,589 INFO L272 TraceCheckUtils]: 0: Hoare triple {1818#true} call ULTIMATE.init(); {1818#true} is VALID [2022-04-15 08:44:16,590 INFO L290 TraceCheckUtils]: 1: Hoare triple {1818#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {1818#true} is VALID [2022-04-15 08:44:16,592 INFO L290 TraceCheckUtils]: 2: Hoare triple {1818#true} assume true; {1818#true} is VALID [2022-04-15 08:44:16,592 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {1818#true} {1818#true} #103#return; {1818#true} is VALID [2022-04-15 08:44:16,592 INFO L272 TraceCheckUtils]: 4: Hoare triple {1818#true} call #t~ret6 := main(); {1818#true} is VALID [2022-04-15 08:44:16,592 INFO L290 TraceCheckUtils]: 5: Hoare triple {1818#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {1818#true} is VALID [2022-04-15 08:44:16,592 INFO L272 TraceCheckUtils]: 6: Hoare triple {1818#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {1818#true} is VALID [2022-04-15 08:44:16,592 INFO L290 TraceCheckUtils]: 7: Hoare triple {1818#true} ~cond := #in~cond; {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L290 TraceCheckUtils]: 8: Hoare triple {1818#true} assume !(0 == ~cond); {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L290 TraceCheckUtils]: 9: Hoare triple {1818#true} assume true; {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {1818#true} {1818#true} #79#return; {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L290 TraceCheckUtils]: 11: Hoare triple {1818#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L272 TraceCheckUtils]: 12: Hoare triple {1818#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L290 TraceCheckUtils]: 13: Hoare triple {1818#true} ~cond := #in~cond; {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L290 TraceCheckUtils]: 14: Hoare triple {1818#true} assume !(0 == ~cond); {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L290 TraceCheckUtils]: 15: Hoare triple {1818#true} assume true; {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {1818#true} {1818#true} #81#return; {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L272 TraceCheckUtils]: 17: Hoare triple {1818#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {1818#true} is VALID [2022-04-15 08:44:16,593 INFO L290 TraceCheckUtils]: 18: Hoare triple {1818#true} ~cond := #in~cond; {1818#true} is VALID [2022-04-15 08:44:16,594 INFO L290 TraceCheckUtils]: 19: Hoare triple {1818#true} assume !(0 == ~cond); {1818#true} is VALID [2022-04-15 08:44:16,594 INFO L290 TraceCheckUtils]: 20: Hoare triple {1818#true} assume true; {1818#true} is VALID [2022-04-15 08:44:16,594 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {1818#true} {1818#true} #83#return; {1818#true} is VALID [2022-04-15 08:44:16,594 INFO L272 TraceCheckUtils]: 22: Hoare triple {1818#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {1818#true} is VALID [2022-04-15 08:44:16,594 INFO L290 TraceCheckUtils]: 23: Hoare triple {1818#true} ~cond := #in~cond; {1818#true} is VALID [2022-04-15 08:44:16,594 INFO L290 TraceCheckUtils]: 24: Hoare triple {1818#true} assume !(0 == ~cond); {1818#true} is VALID [2022-04-15 08:44:16,594 INFO L290 TraceCheckUtils]: 25: Hoare triple {1818#true} assume true; {1818#true} is VALID [2022-04-15 08:44:16,594 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {1818#true} {1818#true} #85#return; {1818#true} is VALID [2022-04-15 08:44:16,595 INFO L290 TraceCheckUtils]: 27: Hoare triple {1818#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} is VALID [2022-04-15 08:44:16,595 INFO L272 TraceCheckUtils]: 28: Hoare triple {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {1818#true} is VALID [2022-04-15 08:44:16,595 INFO L290 TraceCheckUtils]: 29: Hoare triple {1818#true} ~cond := #in~cond; {1818#true} is VALID [2022-04-15 08:44:16,595 INFO L290 TraceCheckUtils]: 30: Hoare triple {1818#true} assume !(0 == ~cond); {1818#true} is VALID [2022-04-15 08:44:16,595 INFO L290 TraceCheckUtils]: 31: Hoare triple {1818#true} assume true; {1818#true} is VALID [2022-04-15 08:44:16,596 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {1818#true} {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} #87#return; {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} is VALID [2022-04-15 08:44:16,596 INFO L272 TraceCheckUtils]: 33: Hoare triple {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {1818#true} is VALID [2022-04-15 08:44:16,596 INFO L290 TraceCheckUtils]: 34: Hoare triple {1818#true} ~cond := #in~cond; {1818#true} is VALID [2022-04-15 08:44:16,596 INFO L290 TraceCheckUtils]: 35: Hoare triple {1818#true} assume !(0 == ~cond); {1818#true} is VALID [2022-04-15 08:44:16,596 INFO L290 TraceCheckUtils]: 36: Hoare triple {1818#true} assume true; {1818#true} is VALID [2022-04-15 08:44:16,597 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {1818#true} {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} #89#return; {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} is VALID [2022-04-15 08:44:16,597 INFO L290 TraceCheckUtils]: 38: Hoare triple {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} assume !false; {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} is VALID [2022-04-15 08:44:16,597 INFO L290 TraceCheckUtils]: 39: Hoare triple {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} is VALID [2022-04-15 08:44:16,598 INFO L290 TraceCheckUtils]: 40: Hoare triple {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} assume !false; {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} is VALID [2022-04-15 08:44:16,598 INFO L272 TraceCheckUtils]: 41: Hoare triple {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {1818#true} is VALID [2022-04-15 08:44:16,598 INFO L290 TraceCheckUtils]: 42: Hoare triple {1818#true} ~cond := #in~cond; {1818#true} is VALID [2022-04-15 08:44:16,598 INFO L290 TraceCheckUtils]: 43: Hoare triple {1818#true} assume !(0 == ~cond); {1818#true} is VALID [2022-04-15 08:44:16,598 INFO L290 TraceCheckUtils]: 44: Hoare triple {1818#true} assume true; {1818#true} is VALID [2022-04-15 08:44:16,599 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {1818#true} {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} #91#return; {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} is VALID [2022-04-15 08:44:16,599 INFO L272 TraceCheckUtils]: 46: Hoare triple {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {1818#true} is VALID [2022-04-15 08:44:16,599 INFO L290 TraceCheckUtils]: 47: Hoare triple {1818#true} ~cond := #in~cond; {1818#true} is VALID [2022-04-15 08:44:16,599 INFO L290 TraceCheckUtils]: 48: Hoare triple {1818#true} assume !(0 == ~cond); {1818#true} is VALID [2022-04-15 08:44:16,599 INFO L290 TraceCheckUtils]: 49: Hoare triple {1818#true} assume true; {1818#true} is VALID [2022-04-15 08:44:16,601 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {1818#true} {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} #93#return; {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} is VALID [2022-04-15 08:44:16,601 INFO L272 TraceCheckUtils]: 51: Hoare triple {1904#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {1977#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:44:16,602 INFO L290 TraceCheckUtils]: 52: Hoare triple {1977#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {1981#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:44:16,602 INFO L290 TraceCheckUtils]: 53: Hoare triple {1981#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {1819#false} is VALID [2022-04-15 08:44:16,602 INFO L290 TraceCheckUtils]: 54: Hoare triple {1819#false} assume !false; {1819#false} is VALID [2022-04-15 08:44:16,604 INFO L134 CoverageAnalysis]: Checked inductivity of 68 backedges. 4 proven. 0 refuted. 0 times theorem prover too weak. 64 trivial. 0 not checked. [2022-04-15 08:44:16,604 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-04-15 08:44:16,604 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:44:16,606 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [645215129] [2022-04-15 08:44:16,606 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:44:16,606 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [540856911] [2022-04-15 08:44:16,606 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [540856911] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:44:16,607 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:44:16,607 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-15 08:44:16,607 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:44:16,607 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [2076913512] [2022-04-15 08:44:16,607 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [2076913512] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:44:16,607 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:44:16,607 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-15 08:44:16,607 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [133946886] [2022-04-15 08:44:16,608 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:44:16,608 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (11), 2 states have call predecessors, (11), 1 states have return successors, (9), 2 states have call predecessors, (9), 2 states have call successors, (9) Word has length 55 [2022-04-15 08:44:16,608 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:44:16,608 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (11), 2 states have call predecessors, (11), 1 states have return successors, (9), 2 states have call predecessors, (9), 2 states have call successors, (9) [2022-04-15 08:44:16,644 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 37 edges. 37 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:16,644 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-04-15 08:44:16,644 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:16,645 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-04-15 08:44:16,645 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=7, Invalid=13, Unknown=0, NotChecked=0, Total=20 [2022-04-15 08:44:16,645 INFO L87 Difference]: Start difference. First operand 55 states and 71 transitions. Second operand has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (11), 2 states have call predecessors, (11), 1 states have return successors, (9), 2 states have call predecessors, (9), 2 states have call successors, (9) [2022-04-15 08:44:16,861 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:16,861 INFO L93 Difference]: Finished difference Result 62 states and 77 transitions. [2022-04-15 08:44:16,861 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2022-04-15 08:44:16,861 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (11), 2 states have call predecessors, (11), 1 states have return successors, (9), 2 states have call predecessors, (9), 2 states have call successors, (9) Word has length 55 [2022-04-15 08:44:16,862 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:44:16,862 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (11), 2 states have call predecessors, (11), 1 states have return successors, (9), 2 states have call predecessors, (9), 2 states have call successors, (9) [2022-04-15 08:44:16,863 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 65 transitions. [2022-04-15 08:44:16,863 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (11), 2 states have call predecessors, (11), 1 states have return successors, (9), 2 states have call predecessors, (9), 2 states have call successors, (9) [2022-04-15 08:44:16,864 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 65 transitions. [2022-04-15 08:44:16,864 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 5 states and 65 transitions. [2022-04-15 08:44:16,907 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 65 edges. 65 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:16,908 INFO L225 Difference]: With dead ends: 62 [2022-04-15 08:44:16,908 INFO L226 Difference]: Without dead ends: 60 [2022-04-15 08:44:16,909 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 55 GetRequests, 51 SyntacticMatches, 0 SemanticMatches, 4 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=11, Invalid=19, Unknown=0, NotChecked=0, Total=30 [2022-04-15 08:44:16,909 INFO L913 BasicCegarLoop]: 46 mSDtfsCounter, 7 mSDsluCounter, 105 mSDsCounter, 0 mSdLazyCounter, 48 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 9 SdHoareTripleChecker+Valid, 151 SdHoareTripleChecker+Invalid, 48 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 48 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-04-15 08:44:16,909 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [9 Valid, 151 Invalid, 48 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 48 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-04-15 08:44:16,910 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 60 states. [2022-04-15 08:44:16,946 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 60 to 59. [2022-04-15 08:44:16,946 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:44:16,946 INFO L82 GeneralOperation]: Start isEquivalent. First operand 60 states. Second operand has 59 states, 32 states have (on average 1.125) internal successors, (36), 35 states have internal predecessors, (36), 20 states have call successors, (20), 7 states have call predecessors, (20), 6 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:44:16,946 INFO L74 IsIncluded]: Start isIncluded. First operand 60 states. Second operand has 59 states, 32 states have (on average 1.125) internal successors, (36), 35 states have internal predecessors, (36), 20 states have call successors, (20), 7 states have call predecessors, (20), 6 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:44:16,947 INFO L87 Difference]: Start difference. First operand 60 states. Second operand has 59 states, 32 states have (on average 1.125) internal successors, (36), 35 states have internal predecessors, (36), 20 states have call successors, (20), 7 states have call predecessors, (20), 6 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:44:16,948 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:16,948 INFO L93 Difference]: Finished difference Result 60 states and 75 transitions. [2022-04-15 08:44:16,949 INFO L276 IsEmpty]: Start isEmpty. Operand 60 states and 75 transitions. [2022-04-15 08:44:16,949 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:16,949 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:16,949 INFO L74 IsIncluded]: Start isIncluded. First operand has 59 states, 32 states have (on average 1.125) internal successors, (36), 35 states have internal predecessors, (36), 20 states have call successors, (20), 7 states have call predecessors, (20), 6 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) Second operand 60 states. [2022-04-15 08:44:16,949 INFO L87 Difference]: Start difference. First operand has 59 states, 32 states have (on average 1.125) internal successors, (36), 35 states have internal predecessors, (36), 20 states have call successors, (20), 7 states have call predecessors, (20), 6 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) Second operand 60 states. [2022-04-15 08:44:16,951 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:44:16,951 INFO L93 Difference]: Finished difference Result 60 states and 75 transitions. [2022-04-15 08:44:16,951 INFO L276 IsEmpty]: Start isEmpty. Operand 60 states and 75 transitions. [2022-04-15 08:44:16,951 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:44:16,951 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:44:16,951 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:44:16,952 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:44:16,952 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 59 states, 32 states have (on average 1.125) internal successors, (36), 35 states have internal predecessors, (36), 20 states have call successors, (20), 7 states have call predecessors, (20), 6 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:44:16,953 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 59 states to 59 states and 74 transitions. [2022-04-15 08:44:16,953 INFO L78 Accepts]: Start accepts. Automaton has 59 states and 74 transitions. Word has length 55 [2022-04-15 08:44:16,954 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:44:16,954 INFO L478 AbstractCegarLoop]: Abstraction has 59 states and 74 transitions. [2022-04-15 08:44:16,954 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 2 states have call successors, (11), 2 states have call predecessors, (11), 1 states have return successors, (9), 2 states have call predecessors, (9), 2 states have call successors, (9) [2022-04-15 08:44:16,954 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 59 states and 74 transitions. [2022-04-15 08:44:17,028 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 74 edges. 74 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:44:17,028 INFO L276 IsEmpty]: Start isEmpty. Operand 59 states and 74 transitions. [2022-04-15 08:44:17,029 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 61 [2022-04-15 08:44:17,029 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:44:17,029 INFO L499 BasicCegarLoop]: trace histogram [6, 6, 6, 4, 3, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-04-15 08:44:17,047 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (5)] Forceful destruction successful, exit code 0 [2022-04-15 08:44:17,229 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable4,5 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:44:17,230 INFO L403 AbstractCegarLoop]: === Iteration 6 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:44:17,230 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:44:17,230 INFO L85 PathProgramCache]: Analyzing trace with hash 1584976990, now seen corresponding path program 1 times [2022-04-15 08:44:17,230 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:44:17,230 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [408352954] [2022-04-15 08:44:17,230 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:44:17,231 INFO L85 PathProgramCache]: Analyzing trace with hash 1584976990, now seen corresponding path program 2 times [2022-04-15 08:44:17,231 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:44:17,231 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [2123425040] [2022-04-15 08:44:17,231 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:44:17,231 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:44:17,243 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:44:17,243 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1970702856] [2022-04-15 08:44:17,243 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:44:17,243 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:44:17,243 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:44:17,244 INFO L229 MonitoredProcess]: Starting monitored process 6 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:44:17,245 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (6)] Waiting until timeout for monitored process [2022-04-15 08:44:17,285 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:44:17,285 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:44:17,286 INFO L263 TraceCheckSpWp]: Trace formula consists of 164 conjuncts, 23 conjunts are in the unsatisfiable core [2022-04-15 08:44:17,297 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:44:17,298 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:44:17,555 INFO L272 TraceCheckUtils]: 0: Hoare triple {2351#true} call ULTIMATE.init(); {2351#true} is VALID [2022-04-15 08:44:17,555 INFO L290 TraceCheckUtils]: 1: Hoare triple {2351#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {2351#true} is VALID [2022-04-15 08:44:17,555 INFO L290 TraceCheckUtils]: 2: Hoare triple {2351#true} assume true; {2351#true} is VALID [2022-04-15 08:44:17,555 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2351#true} {2351#true} #103#return; {2351#true} is VALID [2022-04-15 08:44:17,555 INFO L272 TraceCheckUtils]: 4: Hoare triple {2351#true} call #t~ret6 := main(); {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L290 TraceCheckUtils]: 5: Hoare triple {2351#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L272 TraceCheckUtils]: 6: Hoare triple {2351#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L290 TraceCheckUtils]: 7: Hoare triple {2351#true} ~cond := #in~cond; {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L290 TraceCheckUtils]: 8: Hoare triple {2351#true} assume !(0 == ~cond); {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L290 TraceCheckUtils]: 9: Hoare triple {2351#true} assume true; {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {2351#true} {2351#true} #79#return; {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L290 TraceCheckUtils]: 11: Hoare triple {2351#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L272 TraceCheckUtils]: 12: Hoare triple {2351#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L290 TraceCheckUtils]: 13: Hoare triple {2351#true} ~cond := #in~cond; {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L290 TraceCheckUtils]: 14: Hoare triple {2351#true} assume !(0 == ~cond); {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L290 TraceCheckUtils]: 15: Hoare triple {2351#true} assume true; {2351#true} is VALID [2022-04-15 08:44:17,556 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {2351#true} {2351#true} #81#return; {2351#true} is VALID [2022-04-15 08:44:17,557 INFO L272 TraceCheckUtils]: 17: Hoare triple {2351#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {2351#true} is VALID [2022-04-15 08:44:17,561 INFO L290 TraceCheckUtils]: 18: Hoare triple {2351#true} ~cond := #in~cond; {2351#true} is VALID [2022-04-15 08:44:17,561 INFO L290 TraceCheckUtils]: 19: Hoare triple {2351#true} assume !(0 == ~cond); {2351#true} is VALID [2022-04-15 08:44:17,561 INFO L290 TraceCheckUtils]: 20: Hoare triple {2351#true} assume true; {2351#true} is VALID [2022-04-15 08:44:17,561 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {2351#true} {2351#true} #83#return; {2351#true} is VALID [2022-04-15 08:44:17,561 INFO L272 TraceCheckUtils]: 22: Hoare triple {2351#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {2351#true} is VALID [2022-04-15 08:44:17,561 INFO L290 TraceCheckUtils]: 23: Hoare triple {2351#true} ~cond := #in~cond; {2351#true} is VALID [2022-04-15 08:44:17,561 INFO L290 TraceCheckUtils]: 24: Hoare triple {2351#true} assume !(0 == ~cond); {2351#true} is VALID [2022-04-15 08:44:17,561 INFO L290 TraceCheckUtils]: 25: Hoare triple {2351#true} assume true; {2351#true} is VALID [2022-04-15 08:44:17,561 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {2351#true} {2351#true} #85#return; {2351#true} is VALID [2022-04-15 08:44:17,562 INFO L290 TraceCheckUtils]: 27: Hoare triple {2351#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} is VALID [2022-04-15 08:44:17,562 INFO L272 TraceCheckUtils]: 28: Hoare triple {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {2351#true} is VALID [2022-04-15 08:44:17,562 INFO L290 TraceCheckUtils]: 29: Hoare triple {2351#true} ~cond := #in~cond; {2351#true} is VALID [2022-04-15 08:44:17,562 INFO L290 TraceCheckUtils]: 30: Hoare triple {2351#true} assume !(0 == ~cond); {2351#true} is VALID [2022-04-15 08:44:17,562 INFO L290 TraceCheckUtils]: 31: Hoare triple {2351#true} assume true; {2351#true} is VALID [2022-04-15 08:44:17,563 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {2351#true} {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} #87#return; {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} is VALID [2022-04-15 08:44:17,563 INFO L272 TraceCheckUtils]: 33: Hoare triple {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {2351#true} is VALID [2022-04-15 08:44:17,563 INFO L290 TraceCheckUtils]: 34: Hoare triple {2351#true} ~cond := #in~cond; {2351#true} is VALID [2022-04-15 08:44:17,563 INFO L290 TraceCheckUtils]: 35: Hoare triple {2351#true} assume !(0 == ~cond); {2351#true} is VALID [2022-04-15 08:44:17,563 INFO L290 TraceCheckUtils]: 36: Hoare triple {2351#true} assume true; {2351#true} is VALID [2022-04-15 08:44:17,564 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {2351#true} {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} #89#return; {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} is VALID [2022-04-15 08:44:17,564 INFO L290 TraceCheckUtils]: 38: Hoare triple {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} assume !false; {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} is VALID [2022-04-15 08:44:17,564 INFO L290 TraceCheckUtils]: 39: Hoare triple {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} is VALID [2022-04-15 08:44:17,565 INFO L290 TraceCheckUtils]: 40: Hoare triple {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} assume !false; {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} is VALID [2022-04-15 08:44:17,565 INFO L272 TraceCheckUtils]: 41: Hoare triple {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {2351#true} is VALID [2022-04-15 08:44:17,565 INFO L290 TraceCheckUtils]: 42: Hoare triple {2351#true} ~cond := #in~cond; {2351#true} is VALID [2022-04-15 08:44:17,565 INFO L290 TraceCheckUtils]: 43: Hoare triple {2351#true} assume !(0 == ~cond); {2351#true} is VALID [2022-04-15 08:44:17,565 INFO L290 TraceCheckUtils]: 44: Hoare triple {2351#true} assume true; {2351#true} is VALID [2022-04-15 08:44:17,566 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {2351#true} {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} #91#return; {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} is VALID [2022-04-15 08:44:17,566 INFO L272 TraceCheckUtils]: 46: Hoare triple {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {2351#true} is VALID [2022-04-15 08:44:17,566 INFO L290 TraceCheckUtils]: 47: Hoare triple {2351#true} ~cond := #in~cond; {2498#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:44:17,566 INFO L290 TraceCheckUtils]: 48: Hoare triple {2498#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {2502#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:44:17,567 INFO L290 TraceCheckUtils]: 49: Hoare triple {2502#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {2502#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:44:17,567 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {2502#(not (= |__VERIFIER_assert_#in~cond| 0))} {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} #93#return; {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} is VALID [2022-04-15 08:44:17,567 INFO L272 TraceCheckUtils]: 51: Hoare triple {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {2351#true} is VALID [2022-04-15 08:44:17,568 INFO L290 TraceCheckUtils]: 52: Hoare triple {2351#true} ~cond := #in~cond; {2498#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:44:17,568 INFO L290 TraceCheckUtils]: 53: Hoare triple {2498#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {2502#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:44:17,568 INFO L290 TraceCheckUtils]: 54: Hoare triple {2502#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {2502#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:44:17,569 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {2502#(not (= |__VERIFIER_assert_#in~cond| 0))} {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} #95#return; {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} is VALID [2022-04-15 08:44:17,569 INFO L272 TraceCheckUtils]: 56: Hoare triple {2437#(and (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {2527#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:44:17,570 INFO L290 TraceCheckUtils]: 57: Hoare triple {2527#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {2531#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:44:17,570 INFO L290 TraceCheckUtils]: 58: Hoare triple {2531#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {2352#false} is VALID [2022-04-15 08:44:17,570 INFO L290 TraceCheckUtils]: 59: Hoare triple {2352#false} assume !false; {2352#false} is VALID [2022-04-15 08:44:17,571 INFO L134 CoverageAnalysis]: Checked inductivity of 78 backedges. 10 proven. 2 refuted. 0 times theorem prover too weak. 66 trivial. 0 not checked. [2022-04-15 08:44:17,571 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:45:10,334 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:45:10,334 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [2123425040] [2022-04-15 08:45:10,334 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:45:10,334 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1970702856] [2022-04-15 08:45:10,334 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1970702856] provided 0 perfect and 1 imperfect interpolant sequences [2022-04-15 08:45:10,334 INFO L184 FreeRefinementEngine]: Found 0 perfect and 1 imperfect interpolant sequences. [2022-04-15 08:45:10,334 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [7] total 7 [2022-04-15 08:45:10,334 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:45:10,335 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [408352954] [2022-04-15 08:45:10,335 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [408352954] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:45:10,335 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:45:10,335 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [7] imperfect sequences [] total 7 [2022-04-15 08:45:10,335 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [437311907] [2022-04-15 08:45:10,335 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:45:10,335 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 2.857142857142857) internal successors, (20), 6 states have internal predecessors, (20), 2 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 2 states have call predecessors, (10), 2 states have call successors, (10) Word has length 60 [2022-04-15 08:45:10,335 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:45:10,336 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 7 states, 7 states have (on average 2.857142857142857) internal successors, (20), 6 states have internal predecessors, (20), 2 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 2 states have call predecessors, (10), 2 states have call successors, (10) [2022-04-15 08:45:10,387 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 42 edges. 42 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:10,388 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 7 states [2022-04-15 08:45:10,388 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:45:10,388 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 7 interpolants. [2022-04-15 08:45:10,388 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=19, Invalid=53, Unknown=0, NotChecked=0, Total=72 [2022-04-15 08:45:10,389 INFO L87 Difference]: Start difference. First operand 59 states and 74 transitions. Second operand has 7 states, 7 states have (on average 2.857142857142857) internal successors, (20), 6 states have internal predecessors, (20), 2 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 2 states have call predecessors, (10), 2 states have call successors, (10) [2022-04-15 08:45:10,771 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:10,771 INFO L93 Difference]: Finished difference Result 66 states and 80 transitions. [2022-04-15 08:45:10,771 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2022-04-15 08:45:10,772 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 2.857142857142857) internal successors, (20), 6 states have internal predecessors, (20), 2 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 2 states have call predecessors, (10), 2 states have call successors, (10) Word has length 60 [2022-04-15 08:45:10,772 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:45:10,773 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 2.857142857142857) internal successors, (20), 6 states have internal predecessors, (20), 2 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 2 states have call predecessors, (10), 2 states have call successors, (10) [2022-04-15 08:45:10,774 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 65 transitions. [2022-04-15 08:45:10,774 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 2.857142857142857) internal successors, (20), 6 states have internal predecessors, (20), 2 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 2 states have call predecessors, (10), 2 states have call successors, (10) [2022-04-15 08:45:10,775 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 65 transitions. [2022-04-15 08:45:10,776 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 7 states and 65 transitions. [2022-04-15 08:45:10,825 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 65 edges. 65 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:10,830 INFO L225 Difference]: With dead ends: 66 [2022-04-15 08:45:10,830 INFO L226 Difference]: Without dead ends: 64 [2022-04-15 08:45:10,831 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 66 GetRequests, 56 SyntacticMatches, 1 SemanticMatches, 9 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 4 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=30, Invalid=80, Unknown=0, NotChecked=0, Total=110 [2022-04-15 08:45:10,831 INFO L913 BasicCegarLoop]: 36 mSDtfsCounter, 11 mSDsluCounter, 128 mSDsCounter, 0 mSdLazyCounter, 128 mSolverCounterSat, 2 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 12 SdHoareTripleChecker+Valid, 164 SdHoareTripleChecker+Invalid, 130 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 2 IncrementalHoareTripleChecker+Valid, 128 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-15 08:45:10,831 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [12 Valid, 164 Invalid, 130 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [2 Valid, 128 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-15 08:45:10,832 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 64 states. [2022-04-15 08:45:10,873 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 64 to 63. [2022-04-15 08:45:10,874 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:45:10,875 INFO L82 GeneralOperation]: Start isEquivalent. First operand 64 states. Second operand has 63 states, 35 states have (on average 1.1142857142857143) internal successors, (39), 38 states have internal predecessors, (39), 20 states have call successors, (20), 8 states have call predecessors, (20), 7 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:45:10,875 INFO L74 IsIncluded]: Start isIncluded. First operand 64 states. Second operand has 63 states, 35 states have (on average 1.1142857142857143) internal successors, (39), 38 states have internal predecessors, (39), 20 states have call successors, (20), 8 states have call predecessors, (20), 7 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:45:10,875 INFO L87 Difference]: Start difference. First operand 64 states. Second operand has 63 states, 35 states have (on average 1.1142857142857143) internal successors, (39), 38 states have internal predecessors, (39), 20 states have call successors, (20), 8 states have call predecessors, (20), 7 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:45:10,877 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:10,877 INFO L93 Difference]: Finished difference Result 64 states and 78 transitions. [2022-04-15 08:45:10,877 INFO L276 IsEmpty]: Start isEmpty. Operand 64 states and 78 transitions. [2022-04-15 08:45:10,877 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:45:10,877 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:45:10,878 INFO L74 IsIncluded]: Start isIncluded. First operand has 63 states, 35 states have (on average 1.1142857142857143) internal successors, (39), 38 states have internal predecessors, (39), 20 states have call successors, (20), 8 states have call predecessors, (20), 7 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) Second operand 64 states. [2022-04-15 08:45:10,878 INFO L87 Difference]: Start difference. First operand has 63 states, 35 states have (on average 1.1142857142857143) internal successors, (39), 38 states have internal predecessors, (39), 20 states have call successors, (20), 8 states have call predecessors, (20), 7 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) Second operand 64 states. [2022-04-15 08:45:10,880 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:10,880 INFO L93 Difference]: Finished difference Result 64 states and 78 transitions. [2022-04-15 08:45:10,880 INFO L276 IsEmpty]: Start isEmpty. Operand 64 states and 78 transitions. [2022-04-15 08:45:10,881 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:45:10,881 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:45:10,881 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:45:10,881 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:45:10,881 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 63 states, 35 states have (on average 1.1142857142857143) internal successors, (39), 38 states have internal predecessors, (39), 20 states have call successors, (20), 8 states have call predecessors, (20), 7 states have return successors, (18), 16 states have call predecessors, (18), 18 states have call successors, (18) [2022-04-15 08:45:10,883 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 63 states to 63 states and 77 transitions. [2022-04-15 08:45:10,883 INFO L78 Accepts]: Start accepts. Automaton has 63 states and 77 transitions. Word has length 60 [2022-04-15 08:45:10,883 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:45:10,883 INFO L478 AbstractCegarLoop]: Abstraction has 63 states and 77 transitions. [2022-04-15 08:45:10,883 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 7 states, 7 states have (on average 2.857142857142857) internal successors, (20), 6 states have internal predecessors, (20), 2 states have call successors, (12), 2 states have call predecessors, (12), 2 states have return successors, (10), 2 states have call predecessors, (10), 2 states have call successors, (10) [2022-04-15 08:45:10,884 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 63 states and 77 transitions. [2022-04-15 08:45:10,967 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 77 edges. 77 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:10,967 INFO L276 IsEmpty]: Start isEmpty. Operand 63 states and 77 transitions. [2022-04-15 08:45:10,967 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 68 [2022-04-15 08:45:10,968 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:45:10,968 INFO L499 BasicCegarLoop]: trace histogram [6, 6, 6, 5, 4, 4, 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] [2022-04-15 08:45:10,984 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (6)] Ended with exit code 0 [2022-04-15 08:45:11,185 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable5,6 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:45:11,185 INFO L403 AbstractCegarLoop]: === Iteration 7 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:45:11,186 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:45:11,186 INFO L85 PathProgramCache]: Analyzing trace with hash -669670075, now seen corresponding path program 1 times [2022-04-15 08:45:11,186 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:45:11,186 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [664172334] [2022-04-15 08:45:11,186 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:45:11,187 INFO L85 PathProgramCache]: Analyzing trace with hash -669670075, now seen corresponding path program 2 times [2022-04-15 08:45:11,187 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:45:11,187 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [633024830] [2022-04-15 08:45:11,187 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:45:11,187 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:45:11,198 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:45:11,199 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [555996122] [2022-04-15 08:45:11,199 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:45:11,199 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:45:11,199 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:45:11,200 INFO L229 MonitoredProcess]: Starting monitored process 7 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:45:11,200 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (7)] Waiting until timeout for monitored process [2022-04-15 08:45:11,245 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:45:11,245 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:45:11,246 INFO L263 TraceCheckSpWp]: Trace formula consists of 179 conjuncts, 15 conjunts are in the unsatisfiable core [2022-04-15 08:45:11,256 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:45:11,260 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:45:11,451 INFO L272 TraceCheckUtils]: 0: Hoare triple {2944#true} call ULTIMATE.init(); {2944#true} is VALID [2022-04-15 08:45:11,454 INFO L290 TraceCheckUtils]: 1: Hoare triple {2944#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {2944#true} is VALID [2022-04-15 08:45:11,454 INFO L290 TraceCheckUtils]: 2: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,455 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2944#true} {2944#true} #103#return; {2944#true} is VALID [2022-04-15 08:45:11,455 INFO L272 TraceCheckUtils]: 4: Hoare triple {2944#true} call #t~ret6 := main(); {2944#true} is VALID [2022-04-15 08:45:11,456 INFO L290 TraceCheckUtils]: 5: Hoare triple {2944#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {2944#true} is VALID [2022-04-15 08:45:11,458 INFO L272 TraceCheckUtils]: 6: Hoare triple {2944#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,458 INFO L290 TraceCheckUtils]: 7: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,458 INFO L290 TraceCheckUtils]: 8: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,458 INFO L290 TraceCheckUtils]: 9: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,458 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {2944#true} {2944#true} #79#return; {2944#true} is VALID [2022-04-15 08:45:11,458 INFO L290 TraceCheckUtils]: 11: Hoare triple {2944#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L272 TraceCheckUtils]: 12: Hoare triple {2944#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L290 TraceCheckUtils]: 13: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L290 TraceCheckUtils]: 14: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L290 TraceCheckUtils]: 15: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {2944#true} {2944#true} #81#return; {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L272 TraceCheckUtils]: 17: Hoare triple {2944#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L290 TraceCheckUtils]: 18: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L290 TraceCheckUtils]: 19: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L290 TraceCheckUtils]: 20: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {2944#true} {2944#true} #83#return; {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L272 TraceCheckUtils]: 22: Hoare triple {2944#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,459 INFO L290 TraceCheckUtils]: 23: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L290 TraceCheckUtils]: 24: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L290 TraceCheckUtils]: 25: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {2944#true} {2944#true} #85#return; {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L290 TraceCheckUtils]: 27: Hoare triple {2944#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L272 TraceCheckUtils]: 28: Hoare triple {2944#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L290 TraceCheckUtils]: 29: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L290 TraceCheckUtils]: 30: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L290 TraceCheckUtils]: 31: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {2944#true} {2944#true} #87#return; {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L272 TraceCheckUtils]: 33: Hoare triple {2944#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L290 TraceCheckUtils]: 34: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L290 TraceCheckUtils]: 35: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,460 INFO L290 TraceCheckUtils]: 36: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,461 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {2944#true} {2944#true} #89#return; {2944#true} is VALID [2022-04-15 08:45:11,461 INFO L290 TraceCheckUtils]: 38: Hoare triple {2944#true} assume !false; {2944#true} is VALID [2022-04-15 08:45:11,463 INFO L290 TraceCheckUtils]: 39: Hoare triple {2944#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} is VALID [2022-04-15 08:45:11,464 INFO L290 TraceCheckUtils]: 40: Hoare triple {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} assume !false; {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} is VALID [2022-04-15 08:45:11,464 INFO L272 TraceCheckUtils]: 41: Hoare triple {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,464 INFO L290 TraceCheckUtils]: 42: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,464 INFO L290 TraceCheckUtils]: 43: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,464 INFO L290 TraceCheckUtils]: 44: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,465 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {2944#true} {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} #91#return; {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} is VALID [2022-04-15 08:45:11,465 INFO L272 TraceCheckUtils]: 46: Hoare triple {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,465 INFO L290 TraceCheckUtils]: 47: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,465 INFO L290 TraceCheckUtils]: 48: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,465 INFO L290 TraceCheckUtils]: 49: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,466 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {2944#true} {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} #93#return; {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} is VALID [2022-04-15 08:45:11,466 INFO L272 TraceCheckUtils]: 51: Hoare triple {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,466 INFO L290 TraceCheckUtils]: 52: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,466 INFO L290 TraceCheckUtils]: 53: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,466 INFO L290 TraceCheckUtils]: 54: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,467 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {2944#true} {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} #95#return; {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} is VALID [2022-04-15 08:45:11,467 INFO L272 TraceCheckUtils]: 56: Hoare triple {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,467 INFO L290 TraceCheckUtils]: 57: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,467 INFO L290 TraceCheckUtils]: 58: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,467 INFO L290 TraceCheckUtils]: 59: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,468 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {2944#true} {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} #97#return; {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} is VALID [2022-04-15 08:45:11,469 INFO L290 TraceCheckUtils]: 61: Hoare triple {3066#(and (= main_~c~0 main_~a~0) (= main_~k~0 0))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {3133#(and (= main_~a~0 (+ main_~c~0 main_~b~0)) (= (+ (- 1) main_~k~0) 0))} is VALID [2022-04-15 08:45:11,469 INFO L290 TraceCheckUtils]: 62: Hoare triple {3133#(and (= main_~a~0 (+ main_~c~0 main_~b~0)) (= (+ (- 1) main_~k~0) 0))} assume !false; {3133#(and (= main_~a~0 (+ main_~c~0 main_~b~0)) (= (+ (- 1) main_~k~0) 0))} is VALID [2022-04-15 08:45:11,470 INFO L272 TraceCheckUtils]: 63: Hoare triple {3133#(and (= main_~a~0 (+ main_~c~0 main_~b~0)) (= (+ (- 1) main_~k~0) 0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {3140#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:45:11,470 INFO L290 TraceCheckUtils]: 64: Hoare triple {3140#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {3144#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:45:11,471 INFO L290 TraceCheckUtils]: 65: Hoare triple {3144#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {2945#false} is VALID [2022-04-15 08:45:11,471 INFO L290 TraceCheckUtils]: 66: Hoare triple {2945#false} assume !false; {2945#false} is VALID [2022-04-15 08:45:11,471 INFO L134 CoverageAnalysis]: Checked inductivity of 94 backedges. 8 proven. 2 refuted. 0 times theorem prover too weak. 84 trivial. 0 not checked. [2022-04-15 08:45:11,471 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:45:11,697 INFO L290 TraceCheckUtils]: 66: Hoare triple {2945#false} assume !false; {2945#false} is VALID [2022-04-15 08:45:11,697 INFO L290 TraceCheckUtils]: 65: Hoare triple {3144#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {2945#false} is VALID [2022-04-15 08:45:11,697 INFO L290 TraceCheckUtils]: 64: Hoare triple {3140#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {3144#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:45:11,698 INFO L272 TraceCheckUtils]: 63: Hoare triple {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {3140#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:45:11,699 INFO L290 TraceCheckUtils]: 62: Hoare triple {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} assume !false; {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} is VALID [2022-04-15 08:45:11,700 INFO L290 TraceCheckUtils]: 61: Hoare triple {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} is VALID [2022-04-15 08:45:11,701 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {2944#true} {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} #97#return; {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} is VALID [2022-04-15 08:45:11,701 INFO L290 TraceCheckUtils]: 59: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,701 INFO L290 TraceCheckUtils]: 58: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,701 INFO L290 TraceCheckUtils]: 57: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,701 INFO L272 TraceCheckUtils]: 56: Hoare triple {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,701 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {2944#true} {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} #95#return; {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} is VALID [2022-04-15 08:45:11,702 INFO L290 TraceCheckUtils]: 54: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,702 INFO L290 TraceCheckUtils]: 53: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,702 INFO L290 TraceCheckUtils]: 52: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,702 INFO L272 TraceCheckUtils]: 51: Hoare triple {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,702 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {2944#true} {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} #93#return; {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} is VALID [2022-04-15 08:45:11,702 INFO L290 TraceCheckUtils]: 49: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,703 INFO L290 TraceCheckUtils]: 48: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,703 INFO L290 TraceCheckUtils]: 47: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,703 INFO L272 TraceCheckUtils]: 46: Hoare triple {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,703 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {2944#true} {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} #91#return; {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} is VALID [2022-04-15 08:45:11,703 INFO L290 TraceCheckUtils]: 44: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,703 INFO L290 TraceCheckUtils]: 43: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,703 INFO L290 TraceCheckUtils]: 42: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,703 INFO L272 TraceCheckUtils]: 41: Hoare triple {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,704 INFO L290 TraceCheckUtils]: 40: Hoare triple {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} assume !false; {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} is VALID [2022-04-15 08:45:11,704 INFO L290 TraceCheckUtils]: 39: Hoare triple {2944#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {3160#(= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))} is VALID [2022-04-15 08:45:11,704 INFO L290 TraceCheckUtils]: 38: Hoare triple {2944#true} assume !false; {2944#true} is VALID [2022-04-15 08:45:11,704 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {2944#true} {2944#true} #89#return; {2944#true} is VALID [2022-04-15 08:45:11,704 INFO L290 TraceCheckUtils]: 36: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L290 TraceCheckUtils]: 35: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L290 TraceCheckUtils]: 34: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L272 TraceCheckUtils]: 33: Hoare triple {2944#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {2944#true} {2944#true} #87#return; {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L290 TraceCheckUtils]: 31: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L290 TraceCheckUtils]: 30: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L290 TraceCheckUtils]: 29: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L272 TraceCheckUtils]: 28: Hoare triple {2944#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L290 TraceCheckUtils]: 27: Hoare triple {2944#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {2944#true} {2944#true} #85#return; {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L290 TraceCheckUtils]: 25: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,705 INFO L290 TraceCheckUtils]: 24: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L290 TraceCheckUtils]: 23: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L272 TraceCheckUtils]: 22: Hoare triple {2944#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {2944#true} {2944#true} #83#return; {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L290 TraceCheckUtils]: 20: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L290 TraceCheckUtils]: 19: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L290 TraceCheckUtils]: 18: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L272 TraceCheckUtils]: 17: Hoare triple {2944#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {2944#true} {2944#true} #81#return; {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L290 TraceCheckUtils]: 15: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L290 TraceCheckUtils]: 14: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L290 TraceCheckUtils]: 13: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L272 TraceCheckUtils]: 12: Hoare triple {2944#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,706 INFO L290 TraceCheckUtils]: 11: Hoare triple {2944#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {2944#true} {2944#true} #79#return; {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L290 TraceCheckUtils]: 9: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L290 TraceCheckUtils]: 8: Hoare triple {2944#true} assume !(0 == ~cond); {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L290 TraceCheckUtils]: 7: Hoare triple {2944#true} ~cond := #in~cond; {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L272 TraceCheckUtils]: 6: Hoare triple {2944#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L290 TraceCheckUtils]: 5: Hoare triple {2944#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L272 TraceCheckUtils]: 4: Hoare triple {2944#true} call #t~ret6 := main(); {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {2944#true} {2944#true} #103#return; {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L290 TraceCheckUtils]: 2: Hoare triple {2944#true} assume true; {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L290 TraceCheckUtils]: 1: Hoare triple {2944#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {2944#true} is VALID [2022-04-15 08:45:11,707 INFO L272 TraceCheckUtils]: 0: Hoare triple {2944#true} call ULTIMATE.init(); {2944#true} is VALID [2022-04-15 08:45:11,708 INFO L134 CoverageAnalysis]: Checked inductivity of 94 backedges. 8 proven. 0 refuted. 0 times theorem prover too weak. 86 trivial. 0 not checked. [2022-04-15 08:45:11,708 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:45:11,708 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [633024830] [2022-04-15 08:45:11,708 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:45:11,708 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [555996122] [2022-04-15 08:45:11,708 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [555996122] provided 1 perfect and 1 imperfect interpolant sequences [2022-04-15 08:45:11,708 INFO L184 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-04-15 08:45:11,708 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [6] total 7 [2022-04-15 08:45:11,708 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:45:11,708 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [664172334] [2022-04-15 08:45:11,708 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [664172334] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:45:11,708 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:45:11,709 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-15 08:45:11,709 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1091484821] [2022-04-15 08:45:11,709 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:45:11,709 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.6) internal successors, (18), 4 states have internal predecessors, (18), 2 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 2 states have call predecessors, (11), 2 states have call successors, (11) Word has length 67 [2022-04-15 08:45:11,709 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:45:11,709 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 3.6) internal successors, (18), 4 states have internal predecessors, (18), 2 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 2 states have call predecessors, (11), 2 states have call successors, (11) [2022-04-15 08:45:11,741 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 42 edges. 42 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:11,741 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-04-15 08:45:11,741 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:45:11,741 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-04-15 08:45:11,741 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=13, Invalid=29, Unknown=0, NotChecked=0, Total=42 [2022-04-15 08:45:11,742 INFO L87 Difference]: Start difference. First operand 63 states and 77 transitions. Second operand has 5 states, 5 states have (on average 3.6) internal successors, (18), 4 states have internal predecessors, (18), 2 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 2 states have call predecessors, (11), 2 states have call successors, (11) [2022-04-15 08:45:11,927 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:11,927 INFO L93 Difference]: Finished difference Result 69 states and 82 transitions. [2022-04-15 08:45:11,927 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2022-04-15 08:45:11,927 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 3.6) internal successors, (18), 4 states have internal predecessors, (18), 2 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 2 states have call predecessors, (11), 2 states have call successors, (11) Word has length 67 [2022-04-15 08:45:11,928 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:45:11,929 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.6) internal successors, (18), 4 states have internal predecessors, (18), 2 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 2 states have call predecessors, (11), 2 states have call successors, (11) [2022-04-15 08:45:11,929 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 51 transitions. [2022-04-15 08:45:11,930 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 3.6) internal successors, (18), 4 states have internal predecessors, (18), 2 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 2 states have call predecessors, (11), 2 states have call successors, (11) [2022-04-15 08:45:11,930 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 51 transitions. [2022-04-15 08:45:11,931 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 5 states and 51 transitions. [2022-04-15 08:45:11,971 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 51 edges. 51 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:11,972 INFO L225 Difference]: With dead ends: 69 [2022-04-15 08:45:11,972 INFO L226 Difference]: Without dead ends: 67 [2022-04-15 08:45:11,972 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 134 GetRequests, 126 SyntacticMatches, 2 SemanticMatches, 6 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=17, Invalid=39, Unknown=0, NotChecked=0, Total=56 [2022-04-15 08:45:11,974 INFO L913 BasicCegarLoop]: 40 mSDtfsCounter, 6 mSDsluCounter, 97 mSDsCounter, 0 mSdLazyCounter, 38 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 6 SdHoareTripleChecker+Valid, 137 SdHoareTripleChecker+Invalid, 38 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 38 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-04-15 08:45:11,975 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [6 Valid, 137 Invalid, 38 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 38 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-04-15 08:45:11,975 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 67 states. [2022-04-15 08:45:12,006 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 67 to 59. [2022-04-15 08:45:12,008 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:45:12,008 INFO L82 GeneralOperation]: Start isEquivalent. First operand 67 states. Second operand has 59 states, 33 states have (on average 1.121212121212121) internal successors, (37), 34 states have internal predecessors, (37), 18 states have call successors, (18), 8 states have call predecessors, (18), 7 states have return successors, (16), 16 states have call predecessors, (16), 16 states have call successors, (16) [2022-04-15 08:45:12,008 INFO L74 IsIncluded]: Start isIncluded. First operand 67 states. Second operand has 59 states, 33 states have (on average 1.121212121212121) internal successors, (37), 34 states have internal predecessors, (37), 18 states have call successors, (18), 8 states have call predecessors, (18), 7 states have return successors, (16), 16 states have call predecessors, (16), 16 states have call successors, (16) [2022-04-15 08:45:12,008 INFO L87 Difference]: Start difference. First operand 67 states. Second operand has 59 states, 33 states have (on average 1.121212121212121) internal successors, (37), 34 states have internal predecessors, (37), 18 states have call successors, (18), 8 states have call predecessors, (18), 7 states have return successors, (16), 16 states have call predecessors, (16), 16 states have call successors, (16) [2022-04-15 08:45:12,010 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:12,010 INFO L93 Difference]: Finished difference Result 67 states and 80 transitions. [2022-04-15 08:45:12,010 INFO L276 IsEmpty]: Start isEmpty. Operand 67 states and 80 transitions. [2022-04-15 08:45:12,011 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:45:12,011 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:45:12,011 INFO L74 IsIncluded]: Start isIncluded. First operand has 59 states, 33 states have (on average 1.121212121212121) internal successors, (37), 34 states have internal predecessors, (37), 18 states have call successors, (18), 8 states have call predecessors, (18), 7 states have return successors, (16), 16 states have call predecessors, (16), 16 states have call successors, (16) Second operand 67 states. [2022-04-15 08:45:12,011 INFO L87 Difference]: Start difference. First operand has 59 states, 33 states have (on average 1.121212121212121) internal successors, (37), 34 states have internal predecessors, (37), 18 states have call successors, (18), 8 states have call predecessors, (18), 7 states have return successors, (16), 16 states have call predecessors, (16), 16 states have call successors, (16) Second operand 67 states. [2022-04-15 08:45:12,014 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:12,014 INFO L93 Difference]: Finished difference Result 67 states and 80 transitions. [2022-04-15 08:45:12,014 INFO L276 IsEmpty]: Start isEmpty. Operand 67 states and 80 transitions. [2022-04-15 08:45:12,014 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:45:12,014 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:45:12,014 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:45:12,014 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:45:12,014 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 59 states, 33 states have (on average 1.121212121212121) internal successors, (37), 34 states have internal predecessors, (37), 18 states have call successors, (18), 8 states have call predecessors, (18), 7 states have return successors, (16), 16 states have call predecessors, (16), 16 states have call successors, (16) [2022-04-15 08:45:12,016 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 59 states to 59 states and 71 transitions. [2022-04-15 08:45:12,016 INFO L78 Accepts]: Start accepts. Automaton has 59 states and 71 transitions. Word has length 67 [2022-04-15 08:45:12,017 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:45:12,017 INFO L478 AbstractCegarLoop]: Abstraction has 59 states and 71 transitions. [2022-04-15 08:45:12,017 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 3.6) internal successors, (18), 4 states have internal predecessors, (18), 2 states have call successors, (13), 2 states have call predecessors, (13), 1 states have return successors, (11), 2 states have call predecessors, (11), 2 states have call successors, (11) [2022-04-15 08:45:12,017 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 59 states and 71 transitions. [2022-04-15 08:45:12,112 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 71 edges. 71 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:12,112 INFO L276 IsEmpty]: Start isEmpty. Operand 59 states and 71 transitions. [2022-04-15 08:45:12,112 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 70 [2022-04-15 08:45:12,112 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:45:12,113 INFO L499 BasicCegarLoop]: trace histogram [6, 6, 6, 5, 4, 4, 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] [2022-04-15 08:45:12,133 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (7)] Forceful destruction successful, exit code 0 [2022-04-15 08:45:12,313 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable6,7 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:45:12,313 INFO L403 AbstractCegarLoop]: === Iteration 8 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:45:12,314 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:45:12,314 INFO L85 PathProgramCache]: Analyzing trace with hash -1682830289, now seen corresponding path program 1 times [2022-04-15 08:45:12,314 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:45:12,314 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1150663857] [2022-04-15 08:45:12,314 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:45:12,314 INFO L85 PathProgramCache]: Analyzing trace with hash -1682830289, now seen corresponding path program 2 times [2022-04-15 08:45:12,314 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:45:12,314 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1572668645] [2022-04-15 08:45:12,314 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:45:12,315 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:45:12,331 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:45:12,331 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1681249601] [2022-04-15 08:45:12,331 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:45:12,331 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:45:12,331 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:45:12,339 INFO L229 MonitoredProcess]: Starting monitored process 8 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:45:12,340 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (8)] Waiting until timeout for monitored process [2022-04-15 08:45:12,395 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:45:12,395 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:45:12,396 INFO L263 TraceCheckSpWp]: Trace formula consists of 191 conjuncts, 9 conjunts are in the unsatisfiable core [2022-04-15 08:45:12,408 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:45:12,410 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:45:12,636 INFO L272 TraceCheckUtils]: 0: Hoare triple {3744#true} call ULTIMATE.init(); {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L290 TraceCheckUtils]: 1: Hoare triple {3744#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L290 TraceCheckUtils]: 2: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3744#true} {3744#true} #103#return; {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L272 TraceCheckUtils]: 4: Hoare triple {3744#true} call #t~ret6 := main(); {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L290 TraceCheckUtils]: 5: Hoare triple {3744#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L272 TraceCheckUtils]: 6: Hoare triple {3744#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L290 TraceCheckUtils]: 7: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L290 TraceCheckUtils]: 8: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L290 TraceCheckUtils]: 9: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,637 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {3744#true} {3744#true} #79#return; {3744#true} is VALID [2022-04-15 08:45:12,638 INFO L290 TraceCheckUtils]: 11: Hoare triple {3744#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {3744#true} is VALID [2022-04-15 08:45:12,638 INFO L272 TraceCheckUtils]: 12: Hoare triple {3744#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,638 INFO L290 TraceCheckUtils]: 13: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,638 INFO L290 TraceCheckUtils]: 14: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,638 INFO L290 TraceCheckUtils]: 15: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,638 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {3744#true} {3744#true} #81#return; {3744#true} is VALID [2022-04-15 08:45:12,638 INFO L272 TraceCheckUtils]: 17: Hoare triple {3744#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,639 INFO L290 TraceCheckUtils]: 18: Hoare triple {3744#true} ~cond := #in~cond; {3803#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-04-15 08:45:12,640 INFO L290 TraceCheckUtils]: 19: Hoare triple {3803#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond); {3807#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:45:12,640 INFO L290 TraceCheckUtils]: 20: Hoare triple {3807#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {3807#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:45:12,640 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {3807#(not (= |assume_abort_if_not_#in~cond| 0))} {3744#true} #83#return; {3814#(<= 1 main_~x~0)} is VALID [2022-04-15 08:45:12,641 INFO L272 TraceCheckUtils]: 22: Hoare triple {3814#(<= 1 main_~x~0)} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,641 INFO L290 TraceCheckUtils]: 23: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,641 INFO L290 TraceCheckUtils]: 24: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,641 INFO L290 TraceCheckUtils]: 25: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,641 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {3744#true} {3814#(<= 1 main_~x~0)} #85#return; {3814#(<= 1 main_~x~0)} is VALID [2022-04-15 08:45:12,642 INFO L290 TraceCheckUtils]: 27: Hoare triple {3814#(<= 1 main_~x~0)} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {3833#(<= 1 main_~a~0)} is VALID [2022-04-15 08:45:12,642 INFO L272 TraceCheckUtils]: 28: Hoare triple {3833#(<= 1 main_~a~0)} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,642 INFO L290 TraceCheckUtils]: 29: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,642 INFO L290 TraceCheckUtils]: 30: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,642 INFO L290 TraceCheckUtils]: 31: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,642 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {3744#true} {3833#(<= 1 main_~a~0)} #87#return; {3833#(<= 1 main_~a~0)} is VALID [2022-04-15 08:45:12,643 INFO L272 TraceCheckUtils]: 33: Hoare triple {3833#(<= 1 main_~a~0)} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,643 INFO L290 TraceCheckUtils]: 34: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,643 INFO L290 TraceCheckUtils]: 35: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,643 INFO L290 TraceCheckUtils]: 36: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,643 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {3744#true} {3833#(<= 1 main_~a~0)} #89#return; {3833#(<= 1 main_~a~0)} is VALID [2022-04-15 08:45:12,643 INFO L290 TraceCheckUtils]: 38: Hoare triple {3833#(<= 1 main_~a~0)} assume !false; {3833#(<= 1 main_~a~0)} is VALID [2022-04-15 08:45:12,644 INFO L290 TraceCheckUtils]: 39: Hoare triple {3833#(<= 1 main_~a~0)} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,644 INFO L290 TraceCheckUtils]: 40: Hoare triple {3870#(<= 1 main_~c~0)} assume !false; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,644 INFO L272 TraceCheckUtils]: 41: Hoare triple {3870#(<= 1 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,644 INFO L290 TraceCheckUtils]: 42: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,644 INFO L290 TraceCheckUtils]: 43: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,645 INFO L290 TraceCheckUtils]: 44: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,645 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {3744#true} {3870#(<= 1 main_~c~0)} #91#return; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,645 INFO L272 TraceCheckUtils]: 46: Hoare triple {3870#(<= 1 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,645 INFO L290 TraceCheckUtils]: 47: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,645 INFO L290 TraceCheckUtils]: 48: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,645 INFO L290 TraceCheckUtils]: 49: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,646 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {3744#true} {3870#(<= 1 main_~c~0)} #93#return; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,646 INFO L272 TraceCheckUtils]: 51: Hoare triple {3870#(<= 1 main_~c~0)} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,646 INFO L290 TraceCheckUtils]: 52: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,646 INFO L290 TraceCheckUtils]: 53: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,646 INFO L290 TraceCheckUtils]: 54: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,647 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {3744#true} {3870#(<= 1 main_~c~0)} #95#return; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,647 INFO L272 TraceCheckUtils]: 56: Hoare triple {3870#(<= 1 main_~c~0)} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,647 INFO L290 TraceCheckUtils]: 57: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,647 INFO L290 TraceCheckUtils]: 58: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,647 INFO L290 TraceCheckUtils]: 59: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,648 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {3744#true} {3870#(<= 1 main_~c~0)} #97#return; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,648 INFO L290 TraceCheckUtils]: 61: Hoare triple {3870#(<= 1 main_~c~0)} assume !(~c~0 >= ~b~0); {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,648 INFO L290 TraceCheckUtils]: 62: Hoare triple {3870#(<= 1 main_~c~0)} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {3940#(<= 1 main_~b~0)} is VALID [2022-04-15 08:45:12,649 INFO L290 TraceCheckUtils]: 63: Hoare triple {3940#(<= 1 main_~b~0)} assume !false; {3940#(<= 1 main_~b~0)} is VALID [2022-04-15 08:45:12,649 INFO L290 TraceCheckUtils]: 64: Hoare triple {3940#(<= 1 main_~b~0)} assume !(0 != ~b~0); {3745#false} is VALID [2022-04-15 08:45:12,649 INFO L272 TraceCheckUtils]: 65: Hoare triple {3745#false} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {3745#false} is VALID [2022-04-15 08:45:12,649 INFO L290 TraceCheckUtils]: 66: Hoare triple {3745#false} ~cond := #in~cond; {3745#false} is VALID [2022-04-15 08:45:12,649 INFO L290 TraceCheckUtils]: 67: Hoare triple {3745#false} assume 0 == ~cond; {3745#false} is VALID [2022-04-15 08:45:12,649 INFO L290 TraceCheckUtils]: 68: Hoare triple {3745#false} assume !false; {3745#false} is VALID [2022-04-15 08:45:12,649 INFO L134 CoverageAnalysis]: Checked inductivity of 94 backedges. 14 proven. 11 refuted. 0 times theorem prover too weak. 69 trivial. 0 not checked. [2022-04-15 08:45:12,649 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:45:12,927 INFO L290 TraceCheckUtils]: 68: Hoare triple {3745#false} assume !false; {3745#false} is VALID [2022-04-15 08:45:12,927 INFO L290 TraceCheckUtils]: 67: Hoare triple {3745#false} assume 0 == ~cond; {3745#false} is VALID [2022-04-15 08:45:12,927 INFO L290 TraceCheckUtils]: 66: Hoare triple {3745#false} ~cond := #in~cond; {3745#false} is VALID [2022-04-15 08:45:12,927 INFO L272 TraceCheckUtils]: 65: Hoare triple {3745#false} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {3745#false} is VALID [2022-04-15 08:45:12,928 INFO L290 TraceCheckUtils]: 64: Hoare triple {3940#(<= 1 main_~b~0)} assume !(0 != ~b~0); {3745#false} is VALID [2022-04-15 08:45:12,928 INFO L290 TraceCheckUtils]: 63: Hoare triple {3940#(<= 1 main_~b~0)} assume !false; {3940#(<= 1 main_~b~0)} is VALID [2022-04-15 08:45:12,928 INFO L290 TraceCheckUtils]: 62: Hoare triple {3870#(<= 1 main_~c~0)} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {3940#(<= 1 main_~b~0)} is VALID [2022-04-15 08:45:12,929 INFO L290 TraceCheckUtils]: 61: Hoare triple {3870#(<= 1 main_~c~0)} assume !(~c~0 >= ~b~0); {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,929 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {3744#true} {3870#(<= 1 main_~c~0)} #97#return; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,929 INFO L290 TraceCheckUtils]: 59: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,929 INFO L290 TraceCheckUtils]: 58: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,930 INFO L290 TraceCheckUtils]: 57: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,930 INFO L272 TraceCheckUtils]: 56: Hoare triple {3870#(<= 1 main_~c~0)} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,930 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {3744#true} {3870#(<= 1 main_~c~0)} #95#return; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,930 INFO L290 TraceCheckUtils]: 54: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,930 INFO L290 TraceCheckUtils]: 53: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,930 INFO L290 TraceCheckUtils]: 52: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,930 INFO L272 TraceCheckUtils]: 51: Hoare triple {3870#(<= 1 main_~c~0)} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,931 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {3744#true} {3870#(<= 1 main_~c~0)} #93#return; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,931 INFO L290 TraceCheckUtils]: 49: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,931 INFO L290 TraceCheckUtils]: 48: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,931 INFO L290 TraceCheckUtils]: 47: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,931 INFO L272 TraceCheckUtils]: 46: Hoare triple {3870#(<= 1 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,932 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {3744#true} {3870#(<= 1 main_~c~0)} #91#return; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,933 INFO L290 TraceCheckUtils]: 44: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,933 INFO L290 TraceCheckUtils]: 43: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,933 INFO L290 TraceCheckUtils]: 42: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,933 INFO L272 TraceCheckUtils]: 41: Hoare triple {3870#(<= 1 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,933 INFO L290 TraceCheckUtils]: 40: Hoare triple {3870#(<= 1 main_~c~0)} assume !false; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,933 INFO L290 TraceCheckUtils]: 39: Hoare triple {3833#(<= 1 main_~a~0)} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {3870#(<= 1 main_~c~0)} is VALID [2022-04-15 08:45:12,934 INFO L290 TraceCheckUtils]: 38: Hoare triple {3833#(<= 1 main_~a~0)} assume !false; {3833#(<= 1 main_~a~0)} is VALID [2022-04-15 08:45:12,934 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {3744#true} {3833#(<= 1 main_~a~0)} #89#return; {3833#(<= 1 main_~a~0)} is VALID [2022-04-15 08:45:12,934 INFO L290 TraceCheckUtils]: 36: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,934 INFO L290 TraceCheckUtils]: 35: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,934 INFO L290 TraceCheckUtils]: 34: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,934 INFO L272 TraceCheckUtils]: 33: Hoare triple {3833#(<= 1 main_~a~0)} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,935 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {3744#true} {3833#(<= 1 main_~a~0)} #87#return; {3833#(<= 1 main_~a~0)} is VALID [2022-04-15 08:45:12,935 INFO L290 TraceCheckUtils]: 31: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,935 INFO L290 TraceCheckUtils]: 30: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,935 INFO L290 TraceCheckUtils]: 29: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,935 INFO L272 TraceCheckUtils]: 28: Hoare triple {3833#(<= 1 main_~a~0)} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,935 INFO L290 TraceCheckUtils]: 27: Hoare triple {3814#(<= 1 main_~x~0)} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {3833#(<= 1 main_~a~0)} is VALID [2022-04-15 08:45:12,936 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {3744#true} {3814#(<= 1 main_~x~0)} #85#return; {3814#(<= 1 main_~x~0)} is VALID [2022-04-15 08:45:12,936 INFO L290 TraceCheckUtils]: 25: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,936 INFO L290 TraceCheckUtils]: 24: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,936 INFO L290 TraceCheckUtils]: 23: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,936 INFO L272 TraceCheckUtils]: 22: Hoare triple {3814#(<= 1 main_~x~0)} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,937 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {3807#(not (= |assume_abort_if_not_#in~cond| 0))} {3744#true} #83#return; {3814#(<= 1 main_~x~0)} is VALID [2022-04-15 08:45:12,937 INFO L290 TraceCheckUtils]: 20: Hoare triple {3807#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {3807#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:45:12,937 INFO L290 TraceCheckUtils]: 19: Hoare triple {4109#(or (not (= |assume_abort_if_not_#in~cond| 0)) (= assume_abort_if_not_~cond 0))} assume !(0 == ~cond); {3807#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:45:12,937 INFO L290 TraceCheckUtils]: 18: Hoare triple {3744#true} ~cond := #in~cond; {4109#(or (not (= |assume_abort_if_not_#in~cond| 0)) (= assume_abort_if_not_~cond 0))} is VALID [2022-04-15 08:45:12,938 INFO L272 TraceCheckUtils]: 17: Hoare triple {3744#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {3744#true} {3744#true} #81#return; {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L290 TraceCheckUtils]: 15: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L290 TraceCheckUtils]: 14: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L290 TraceCheckUtils]: 13: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L272 TraceCheckUtils]: 12: Hoare triple {3744#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L290 TraceCheckUtils]: 11: Hoare triple {3744#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {3744#true} {3744#true} #79#return; {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L290 TraceCheckUtils]: 9: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L290 TraceCheckUtils]: 8: Hoare triple {3744#true} assume !(0 == ~cond); {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L290 TraceCheckUtils]: 7: Hoare triple {3744#true} ~cond := #in~cond; {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L272 TraceCheckUtils]: 6: Hoare triple {3744#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {3744#true} is VALID [2022-04-15 08:45:12,938 INFO L290 TraceCheckUtils]: 5: Hoare triple {3744#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {3744#true} is VALID [2022-04-15 08:45:12,939 INFO L272 TraceCheckUtils]: 4: Hoare triple {3744#true} call #t~ret6 := main(); {3744#true} is VALID [2022-04-15 08:45:12,939 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {3744#true} {3744#true} #103#return; {3744#true} is VALID [2022-04-15 08:45:12,939 INFO L290 TraceCheckUtils]: 2: Hoare triple {3744#true} assume true; {3744#true} is VALID [2022-04-15 08:45:12,939 INFO L290 TraceCheckUtils]: 1: Hoare triple {3744#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {3744#true} is VALID [2022-04-15 08:45:12,939 INFO L272 TraceCheckUtils]: 0: Hoare triple {3744#true} call ULTIMATE.init(); {3744#true} is VALID [2022-04-15 08:45:12,939 INFO L134 CoverageAnalysis]: Checked inductivity of 94 backedges. 14 proven. 11 refuted. 0 times theorem prover too weak. 69 trivial. 0 not checked. [2022-04-15 08:45:12,939 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:45:12,939 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1572668645] [2022-04-15 08:45:12,939 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:45:12,939 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1681249601] [2022-04-15 08:45:12,939 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1681249601] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:45:12,940 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:45:12,940 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [8, 8] total 9 [2022-04-15 08:45:12,940 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:45:12,940 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1150663857] [2022-04-15 08:45:12,940 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1150663857] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:45:12,940 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:45:12,940 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [8] imperfect sequences [] total 8 [2022-04-15 08:45:12,940 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1719881000] [2022-04-15 08:45:12,940 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:45:12,941 INFO L78 Accepts]: Start accepts. Automaton has has 8 states, 8 states have (on average 3.0) internal successors, (24), 7 states have internal predecessors, (24), 5 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (11), 4 states have call predecessors, (11), 4 states have call successors, (11) Word has length 69 [2022-04-15 08:45:12,941 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:45:12,941 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 8 states, 8 states have (on average 3.0) internal successors, (24), 7 states have internal predecessors, (24), 5 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (11), 4 states have call predecessors, (11), 4 states have call successors, (11) [2022-04-15 08:45:12,972 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 48 edges. 48 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:12,972 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 8 states [2022-04-15 08:45:12,972 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:45:12,972 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 8 interpolants. [2022-04-15 08:45:12,972 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=17, Invalid=55, Unknown=0, NotChecked=0, Total=72 [2022-04-15 08:45:12,973 INFO L87 Difference]: Start difference. First operand 59 states and 71 transitions. Second operand has 8 states, 8 states have (on average 3.0) internal successors, (24), 7 states have internal predecessors, (24), 5 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (11), 4 states have call predecessors, (11), 4 states have call successors, (11) [2022-04-15 08:45:13,691 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:13,691 INFO L93 Difference]: Finished difference Result 106 states and 146 transitions. [2022-04-15 08:45:13,691 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 9 states. [2022-04-15 08:45:13,691 INFO L78 Accepts]: Start accepts. Automaton has has 8 states, 8 states have (on average 3.0) internal successors, (24), 7 states have internal predecessors, (24), 5 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (11), 4 states have call predecessors, (11), 4 states have call successors, (11) Word has length 69 [2022-04-15 08:45:13,691 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:45:13,691 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 8 states, 8 states have (on average 3.0) internal successors, (24), 7 states have internal predecessors, (24), 5 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (11), 4 states have call predecessors, (11), 4 states have call successors, (11) [2022-04-15 08:45:13,693 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 110 transitions. [2022-04-15 08:45:13,693 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 8 states, 8 states have (on average 3.0) internal successors, (24), 7 states have internal predecessors, (24), 5 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (11), 4 states have call predecessors, (11), 4 states have call successors, (11) [2022-04-15 08:45:13,695 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 110 transitions. [2022-04-15 08:45:13,695 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 9 states and 110 transitions. [2022-04-15 08:45:13,774 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 110 edges. 110 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:13,779 INFO L225 Difference]: With dead ends: 106 [2022-04-15 08:45:13,779 INFO L226 Difference]: Without dead ends: 98 [2022-04-15 08:45:13,779 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 142 GetRequests, 129 SyntacticMatches, 1 SemanticMatches, 12 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 6 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=47, Invalid=135, Unknown=0, NotChecked=0, Total=182 [2022-04-15 08:45:13,780 INFO L913 BasicCegarLoop]: 60 mSDtfsCounter, 30 mSDsluCounter, 199 mSDsCounter, 0 mSdLazyCounter, 174 mSolverCounterSat, 53 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.2s Time, 0 mProtectedPredicate, 0 mProtectedAction, 35 SdHoareTripleChecker+Valid, 259 SdHoareTripleChecker+Invalid, 227 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 53 IncrementalHoareTripleChecker+Valid, 174 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.2s IncrementalHoareTripleChecker+Time [2022-04-15 08:45:13,780 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [35 Valid, 259 Invalid, 227 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [53 Valid, 174 Invalid, 0 Unknown, 0 Unchecked, 0.2s Time] [2022-04-15 08:45:13,780 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 98 states. [2022-04-15 08:45:13,900 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 98 to 89. [2022-04-15 08:45:13,900 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:45:13,901 INFO L82 GeneralOperation]: Start isEquivalent. First operand 98 states. Second operand has 89 states, 47 states have (on average 1.1914893617021276) internal successors, (56), 48 states have internal predecessors, (56), 34 states have call successors, (34), 8 states have call predecessors, (34), 7 states have return successors, (32), 32 states have call predecessors, (32), 32 states have call successors, (32) [2022-04-15 08:45:13,901 INFO L74 IsIncluded]: Start isIncluded. First operand 98 states. Second operand has 89 states, 47 states have (on average 1.1914893617021276) internal successors, (56), 48 states have internal predecessors, (56), 34 states have call successors, (34), 8 states have call predecessors, (34), 7 states have return successors, (32), 32 states have call predecessors, (32), 32 states have call successors, (32) [2022-04-15 08:45:13,901 INFO L87 Difference]: Start difference. First operand 98 states. Second operand has 89 states, 47 states have (on average 1.1914893617021276) internal successors, (56), 48 states have internal predecessors, (56), 34 states have call successors, (34), 8 states have call predecessors, (34), 7 states have return successors, (32), 32 states have call predecessors, (32), 32 states have call successors, (32) [2022-04-15 08:45:13,904 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:13,904 INFO L93 Difference]: Finished difference Result 98 states and 137 transitions. [2022-04-15 08:45:13,904 INFO L276 IsEmpty]: Start isEmpty. Operand 98 states and 137 transitions. [2022-04-15 08:45:13,905 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:45:13,905 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:45:13,905 INFO L74 IsIncluded]: Start isIncluded. First operand has 89 states, 47 states have (on average 1.1914893617021276) internal successors, (56), 48 states have internal predecessors, (56), 34 states have call successors, (34), 8 states have call predecessors, (34), 7 states have return successors, (32), 32 states have call predecessors, (32), 32 states have call successors, (32) Second operand 98 states. [2022-04-15 08:45:13,905 INFO L87 Difference]: Start difference. First operand has 89 states, 47 states have (on average 1.1914893617021276) internal successors, (56), 48 states have internal predecessors, (56), 34 states have call successors, (34), 8 states have call predecessors, (34), 7 states have return successors, (32), 32 states have call predecessors, (32), 32 states have call successors, (32) Second operand 98 states. [2022-04-15 08:45:13,908 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:13,908 INFO L93 Difference]: Finished difference Result 98 states and 137 transitions. [2022-04-15 08:45:13,908 INFO L276 IsEmpty]: Start isEmpty. Operand 98 states and 137 transitions. [2022-04-15 08:45:13,908 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:45:13,908 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:45:13,908 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:45:13,908 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:45:13,909 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 89 states, 47 states have (on average 1.1914893617021276) internal successors, (56), 48 states have internal predecessors, (56), 34 states have call successors, (34), 8 states have call predecessors, (34), 7 states have return successors, (32), 32 states have call predecessors, (32), 32 states have call successors, (32) [2022-04-15 08:45:13,911 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 89 states to 89 states and 122 transitions. [2022-04-15 08:45:13,911 INFO L78 Accepts]: Start accepts. Automaton has 89 states and 122 transitions. Word has length 69 [2022-04-15 08:45:13,911 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:45:13,911 INFO L478 AbstractCegarLoop]: Abstraction has 89 states and 122 transitions. [2022-04-15 08:45:13,911 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 8 states, 8 states have (on average 3.0) internal successors, (24), 7 states have internal predecessors, (24), 5 states have call successors, (13), 2 states have call predecessors, (13), 2 states have return successors, (11), 4 states have call predecessors, (11), 4 states have call successors, (11) [2022-04-15 08:45:13,911 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 89 states and 122 transitions. [2022-04-15 08:45:14,074 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 122 edges. 122 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:14,074 INFO L276 IsEmpty]: Start isEmpty. Operand 89 states and 122 transitions. [2022-04-15 08:45:14,074 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 76 [2022-04-15 08:45:14,074 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:45:14,074 INFO L499 BasicCegarLoop]: trace histogram [6, 6, 6, 6, 5, 5, 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] [2022-04-15 08:45:14,090 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (8)] Forceful destruction successful, exit code 0 [2022-04-15 08:45:14,280 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable7,8 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:45:14,280 INFO L403 AbstractCegarLoop]: === Iteration 9 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:45:14,283 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:45:14,283 INFO L85 PathProgramCache]: Analyzing trace with hash 376741854, now seen corresponding path program 1 times [2022-04-15 08:45:14,283 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:45:14,283 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [2066345642] [2022-04-15 08:45:14,284 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:45:14,284 INFO L85 PathProgramCache]: Analyzing trace with hash 376741854, now seen corresponding path program 2 times [2022-04-15 08:45:14,284 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:45:14,284 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1090609430] [2022-04-15 08:45:14,284 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:45:14,284 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:45:14,306 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:45:14,306 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [42927639] [2022-04-15 08:45:14,306 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:45:14,306 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:45:14,306 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:45:14,311 INFO L229 MonitoredProcess]: Starting monitored process 9 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:45:14,312 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (9)] Waiting until timeout for monitored process [2022-04-15 08:45:14,352 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:45:14,353 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:45:14,353 INFO L263 TraceCheckSpWp]: Trace formula consists of 204 conjuncts, 22 conjunts are in the unsatisfiable core [2022-04-15 08:45:14,365 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:45:14,366 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:45:14,660 INFO L272 TraceCheckUtils]: 0: Hoare triple {4762#true} call ULTIMATE.init(); {4762#true} is VALID [2022-04-15 08:45:14,660 INFO L290 TraceCheckUtils]: 1: Hoare triple {4762#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {4762#true} is VALID [2022-04-15 08:45:14,660 INFO L290 TraceCheckUtils]: 2: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,660 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4762#true} {4762#true} #103#return; {4762#true} is VALID [2022-04-15 08:45:14,660 INFO L272 TraceCheckUtils]: 4: Hoare triple {4762#true} call #t~ret6 := main(); {4762#true} is VALID [2022-04-15 08:45:14,660 INFO L290 TraceCheckUtils]: 5: Hoare triple {4762#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {4762#true} is VALID [2022-04-15 08:45:14,660 INFO L272 TraceCheckUtils]: 6: Hoare triple {4762#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,660 INFO L290 TraceCheckUtils]: 7: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,660 INFO L290 TraceCheckUtils]: 8: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,660 INFO L290 TraceCheckUtils]: 9: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {4762#true} {4762#true} #79#return; {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L290 TraceCheckUtils]: 11: Hoare triple {4762#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L272 TraceCheckUtils]: 12: Hoare triple {4762#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L290 TraceCheckUtils]: 13: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L290 TraceCheckUtils]: 14: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L290 TraceCheckUtils]: 15: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {4762#true} {4762#true} #81#return; {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L272 TraceCheckUtils]: 17: Hoare triple {4762#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L290 TraceCheckUtils]: 18: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L290 TraceCheckUtils]: 19: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L290 TraceCheckUtils]: 20: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {4762#true} {4762#true} #83#return; {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L272 TraceCheckUtils]: 22: Hoare triple {4762#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,661 INFO L290 TraceCheckUtils]: 23: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,662 INFO L290 TraceCheckUtils]: 24: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,662 INFO L290 TraceCheckUtils]: 25: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,662 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {4762#true} {4762#true} #85#return; {4762#true} is VALID [2022-04-15 08:45:14,662 INFO L290 TraceCheckUtils]: 27: Hoare triple {4762#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} is VALID [2022-04-15 08:45:14,662 INFO L272 TraceCheckUtils]: 28: Hoare triple {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,662 INFO L290 TraceCheckUtils]: 29: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,662 INFO L290 TraceCheckUtils]: 30: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,662 INFO L290 TraceCheckUtils]: 31: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,663 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {4762#true} {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} #87#return; {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} is VALID [2022-04-15 08:45:14,663 INFO L272 TraceCheckUtils]: 33: Hoare triple {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,663 INFO L290 TraceCheckUtils]: 34: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,663 INFO L290 TraceCheckUtils]: 35: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,663 INFO L290 TraceCheckUtils]: 36: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,664 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {4762#true} {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} #89#return; {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} is VALID [2022-04-15 08:45:14,664 INFO L290 TraceCheckUtils]: 38: Hoare triple {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} assume !false; {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} is VALID [2022-04-15 08:45:14,664 INFO L290 TraceCheckUtils]: 39: Hoare triple {4848#(and (= main_~q~0 0) (= main_~a~0 main_~x~0))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {4885#(= main_~q~0 0)} is VALID [2022-04-15 08:45:14,665 INFO L290 TraceCheckUtils]: 40: Hoare triple {4885#(= main_~q~0 0)} assume !false; {4885#(= main_~q~0 0)} is VALID [2022-04-15 08:45:14,665 INFO L272 TraceCheckUtils]: 41: Hoare triple {4885#(= main_~q~0 0)} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,665 INFO L290 TraceCheckUtils]: 42: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,665 INFO L290 TraceCheckUtils]: 43: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,665 INFO L290 TraceCheckUtils]: 44: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,665 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {4762#true} {4885#(= main_~q~0 0)} #91#return; {4885#(= main_~q~0 0)} is VALID [2022-04-15 08:45:14,666 INFO L272 TraceCheckUtils]: 46: Hoare triple {4885#(= main_~q~0 0)} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,666 INFO L290 TraceCheckUtils]: 47: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,666 INFO L290 TraceCheckUtils]: 48: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,666 INFO L290 TraceCheckUtils]: 49: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,666 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {4762#true} {4885#(= main_~q~0 0)} #93#return; {4885#(= main_~q~0 0)} is VALID [2022-04-15 08:45:14,666 INFO L272 TraceCheckUtils]: 51: Hoare triple {4885#(= main_~q~0 0)} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,667 INFO L290 TraceCheckUtils]: 52: Hoare triple {4762#true} ~cond := #in~cond; {4925#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:45:14,667 INFO L290 TraceCheckUtils]: 53: Hoare triple {4925#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {4929#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:45:14,667 INFO L290 TraceCheckUtils]: 54: Hoare triple {4929#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {4929#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:45:14,668 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {4929#(not (= |__VERIFIER_assert_#in~cond| 0))} {4885#(= main_~q~0 0)} #95#return; {4936#(and (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~q~0 0))} is VALID [2022-04-15 08:45:14,668 INFO L272 TraceCheckUtils]: 56: Hoare triple {4936#(and (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~q~0 0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,668 INFO L290 TraceCheckUtils]: 57: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,668 INFO L290 TraceCheckUtils]: 58: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,668 INFO L290 TraceCheckUtils]: 59: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,669 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {4762#true} {4936#(and (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~q~0 0))} #97#return; {4936#(and (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~q~0 0))} is VALID [2022-04-15 08:45:14,669 INFO L290 TraceCheckUtils]: 61: Hoare triple {4936#(and (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~q~0 0))} assume !(~c~0 >= ~b~0); {4936#(and (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~q~0 0))} is VALID [2022-04-15 08:45:14,669 INFO L290 TraceCheckUtils]: 62: Hoare triple {4936#(and (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~q~0 0))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:45:14,670 INFO L290 TraceCheckUtils]: 63: Hoare triple {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} assume !false; {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:45:14,681 INFO L290 TraceCheckUtils]: 64: Hoare triple {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:45:14,682 INFO L290 TraceCheckUtils]: 65: Hoare triple {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} assume !false; {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:45:14,682 INFO L272 TraceCheckUtils]: 66: Hoare triple {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:14,682 INFO L290 TraceCheckUtils]: 67: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:14,682 INFO L290 TraceCheckUtils]: 68: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:14,682 INFO L290 TraceCheckUtils]: 69: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:14,683 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {4762#true} {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} #91#return; {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:45:14,683 INFO L272 TraceCheckUtils]: 71: Hoare triple {4958#(and (= main_~p~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {4986#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:45:14,684 INFO L290 TraceCheckUtils]: 72: Hoare triple {4986#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {4990#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:45:14,684 INFO L290 TraceCheckUtils]: 73: Hoare triple {4990#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {4763#false} is VALID [2022-04-15 08:45:14,684 INFO L290 TraceCheckUtils]: 74: Hoare triple {4763#false} assume !false; {4763#false} is VALID [2022-04-15 08:45:14,684 INFO L134 CoverageAnalysis]: Checked inductivity of 115 backedges. 15 proven. 12 refuted. 0 times theorem prover too weak. 88 trivial. 0 not checked. [2022-04-15 08:45:14,684 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:45:27,426 INFO L290 TraceCheckUtils]: 74: Hoare triple {4763#false} assume !false; {4763#false} is VALID [2022-04-15 08:45:27,426 INFO L290 TraceCheckUtils]: 73: Hoare triple {4990#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {4763#false} is VALID [2022-04-15 08:45:27,427 INFO L290 TraceCheckUtils]: 72: Hoare triple {4986#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {4990#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:45:27,427 INFO L272 TraceCheckUtils]: 71: Hoare triple {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {4986#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:45:27,428 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {4762#true} {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} #91#return; {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:45:27,428 INFO L290 TraceCheckUtils]: 69: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,428 INFO L290 TraceCheckUtils]: 68: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,428 INFO L290 TraceCheckUtils]: 67: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,428 INFO L272 TraceCheckUtils]: 66: Hoare triple {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,432 INFO L290 TraceCheckUtils]: 65: Hoare triple {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} assume !false; {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:45:27,432 INFO L290 TraceCheckUtils]: 64: Hoare triple {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:45:27,433 INFO L290 TraceCheckUtils]: 63: Hoare triple {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} assume !false; {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:45:27,433 INFO L290 TraceCheckUtils]: 62: Hoare triple {5034#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {5006#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:45:27,433 INFO L290 TraceCheckUtils]: 61: Hoare triple {5034#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} assume !(~c~0 >= ~b~0); {5034#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:45:27,434 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {4762#true} {5034#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} #97#return; {5034#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:45:27,434 INFO L290 TraceCheckUtils]: 59: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,434 INFO L290 TraceCheckUtils]: 58: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,434 INFO L290 TraceCheckUtils]: 57: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,434 INFO L272 TraceCheckUtils]: 56: Hoare triple {5034#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,435 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {4929#(not (= |__VERIFIER_assert_#in~cond| 0))} {4762#true} #95#return; {5034#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:45:27,435 INFO L290 TraceCheckUtils]: 54: Hoare triple {4929#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {4929#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:45:27,436 INFO L290 TraceCheckUtils]: 53: Hoare triple {5065#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {4929#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:45:27,436 INFO L290 TraceCheckUtils]: 52: Hoare triple {4762#true} ~cond := #in~cond; {5065#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:45:27,436 INFO L272 TraceCheckUtils]: 51: Hoare triple {4762#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,436 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {4762#true} {4762#true} #93#return; {4762#true} is VALID [2022-04-15 08:45:27,436 INFO L290 TraceCheckUtils]: 49: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,436 INFO L290 TraceCheckUtils]: 48: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,436 INFO L290 TraceCheckUtils]: 47: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,436 INFO L272 TraceCheckUtils]: 46: Hoare triple {4762#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {4762#true} {4762#true} #91#return; {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L290 TraceCheckUtils]: 44: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L290 TraceCheckUtils]: 43: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L290 TraceCheckUtils]: 42: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L272 TraceCheckUtils]: 41: Hoare triple {4762#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L290 TraceCheckUtils]: 40: Hoare triple {4762#true} assume !false; {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L290 TraceCheckUtils]: 39: Hoare triple {4762#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L290 TraceCheckUtils]: 38: Hoare triple {4762#true} assume !false; {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {4762#true} {4762#true} #89#return; {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L290 TraceCheckUtils]: 36: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L290 TraceCheckUtils]: 35: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L290 TraceCheckUtils]: 34: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L272 TraceCheckUtils]: 33: Hoare triple {4762#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,437 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {4762#true} {4762#true} #87#return; {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L290 TraceCheckUtils]: 31: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L290 TraceCheckUtils]: 30: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L290 TraceCheckUtils]: 29: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L272 TraceCheckUtils]: 28: Hoare triple {4762#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L290 TraceCheckUtils]: 27: Hoare triple {4762#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {4762#true} {4762#true} #85#return; {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L290 TraceCheckUtils]: 25: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L290 TraceCheckUtils]: 24: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L290 TraceCheckUtils]: 23: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L272 TraceCheckUtils]: 22: Hoare triple {4762#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {4762#true} {4762#true} #83#return; {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L290 TraceCheckUtils]: 20: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,438 INFO L290 TraceCheckUtils]: 19: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L290 TraceCheckUtils]: 18: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L272 TraceCheckUtils]: 17: Hoare triple {4762#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {4762#true} {4762#true} #81#return; {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L290 TraceCheckUtils]: 15: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L290 TraceCheckUtils]: 14: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L290 TraceCheckUtils]: 13: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L272 TraceCheckUtils]: 12: Hoare triple {4762#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L290 TraceCheckUtils]: 11: Hoare triple {4762#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {4762#true} {4762#true} #79#return; {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L290 TraceCheckUtils]: 9: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L290 TraceCheckUtils]: 8: Hoare triple {4762#true} assume !(0 == ~cond); {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L290 TraceCheckUtils]: 7: Hoare triple {4762#true} ~cond := #in~cond; {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L272 TraceCheckUtils]: 6: Hoare triple {4762#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {4762#true} is VALID [2022-04-15 08:45:27,439 INFO L290 TraceCheckUtils]: 5: Hoare triple {4762#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {4762#true} is VALID [2022-04-15 08:45:27,440 INFO L272 TraceCheckUtils]: 4: Hoare triple {4762#true} call #t~ret6 := main(); {4762#true} is VALID [2022-04-15 08:45:27,440 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {4762#true} {4762#true} #103#return; {4762#true} is VALID [2022-04-15 08:45:27,440 INFO L290 TraceCheckUtils]: 2: Hoare triple {4762#true} assume true; {4762#true} is VALID [2022-04-15 08:45:27,440 INFO L290 TraceCheckUtils]: 1: Hoare triple {4762#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {4762#true} is VALID [2022-04-15 08:45:27,440 INFO L272 TraceCheckUtils]: 0: Hoare triple {4762#true} call ULTIMATE.init(); {4762#true} is VALID [2022-04-15 08:45:27,440 INFO L134 CoverageAnalysis]: Checked inductivity of 115 backedges. 20 proven. 7 refuted. 0 times theorem prover too weak. 88 trivial. 0 not checked. [2022-04-15 08:45:27,440 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:45:27,441 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1090609430] [2022-04-15 08:45:27,441 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:45:27,441 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [42927639] [2022-04-15 08:45:27,441 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [42927639] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:45:27,441 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:45:27,441 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [10, 8] total 13 [2022-04-15 08:45:27,443 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:45:27,443 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [2066345642] [2022-04-15 08:45:27,443 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [2066345642] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:45:27,443 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:45:27,443 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [10] imperfect sequences [] total 10 [2022-04-15 08:45:27,443 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1918516889] [2022-04-15 08:45:27,443 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:45:27,444 INFO L78 Accepts]: Start accepts. Automaton has has 10 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 5 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) Word has length 75 [2022-04-15 08:45:27,444 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:45:27,444 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 10 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 5 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-15 08:45:27,482 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 51 edges. 51 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:27,483 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 10 states [2022-04-15 08:45:27,483 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:45:27,483 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 10 interpolants. [2022-04-15 08:45:27,483 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=31, Invalid=125, Unknown=0, NotChecked=0, Total=156 [2022-04-15 08:45:27,483 INFO L87 Difference]: Start difference. First operand 89 states and 122 transitions. Second operand has 10 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 5 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-15 08:45:28,394 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:28,394 INFO L93 Difference]: Finished difference Result 124 states and 173 transitions. [2022-04-15 08:45:28,394 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 8 states. [2022-04-15 08:45:28,394 INFO L78 Accepts]: Start accepts. Automaton has has 10 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 5 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) Word has length 75 [2022-04-15 08:45:28,395 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:45:28,395 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 10 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 5 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-15 08:45:28,396 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 83 transitions. [2022-04-15 08:45:28,396 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 10 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 5 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-15 08:45:28,397 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 83 transitions. [2022-04-15 08:45:28,397 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 8 states and 83 transitions. [2022-04-15 08:45:28,479 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 83 edges. 83 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:28,482 INFO L225 Difference]: With dead ends: 124 [2022-04-15 08:45:28,482 INFO L226 Difference]: Without dead ends: 121 [2022-04-15 08:45:28,482 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 152 GetRequests, 137 SyntacticMatches, 1 SemanticMatches, 14 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 31 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=50, Invalid=190, Unknown=0, NotChecked=0, Total=240 [2022-04-15 08:45:28,483 INFO L913 BasicCegarLoop]: 44 mSDtfsCounter, 23 mSDsluCounter, 174 mSDsCounter, 0 mSdLazyCounter, 212 mSolverCounterSat, 17 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.3s Time, 0 mProtectedPredicate, 0 mProtectedAction, 27 SdHoareTripleChecker+Valid, 218 SdHoareTripleChecker+Invalid, 229 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 17 IncrementalHoareTripleChecker+Valid, 212 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.3s IncrementalHoareTripleChecker+Time [2022-04-15 08:45:28,483 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [27 Valid, 218 Invalid, 229 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [17 Valid, 212 Invalid, 0 Unknown, 0 Unchecked, 0.3s Time] [2022-04-15 08:45:28,483 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 121 states. [2022-04-15 08:45:28,667 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 121 to 118. [2022-04-15 08:45:28,667 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:45:28,668 INFO L82 GeneralOperation]: Start isEquivalent. First operand 121 states. Second operand has 118 states, 62 states have (on average 1.2096774193548387) internal successors, (75), 64 states have internal predecessors, (75), 47 states have call successors, (47), 9 states have call predecessors, (47), 8 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:45:28,668 INFO L74 IsIncluded]: Start isIncluded. First operand 121 states. Second operand has 118 states, 62 states have (on average 1.2096774193548387) internal successors, (75), 64 states have internal predecessors, (75), 47 states have call successors, (47), 9 states have call predecessors, (47), 8 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:45:28,668 INFO L87 Difference]: Start difference. First operand 121 states. Second operand has 118 states, 62 states have (on average 1.2096774193548387) internal successors, (75), 64 states have internal predecessors, (75), 47 states have call successors, (47), 9 states have call predecessors, (47), 8 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:45:28,672 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:28,672 INFO L93 Difference]: Finished difference Result 121 states and 169 transitions. [2022-04-15 08:45:28,672 INFO L276 IsEmpty]: Start isEmpty. Operand 121 states and 169 transitions. [2022-04-15 08:45:28,672 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:45:28,672 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:45:28,673 INFO L74 IsIncluded]: Start isIncluded. First operand has 118 states, 62 states have (on average 1.2096774193548387) internal successors, (75), 64 states have internal predecessors, (75), 47 states have call successors, (47), 9 states have call predecessors, (47), 8 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) Second operand 121 states. [2022-04-15 08:45:28,674 INFO L87 Difference]: Start difference. First operand has 118 states, 62 states have (on average 1.2096774193548387) internal successors, (75), 64 states have internal predecessors, (75), 47 states have call successors, (47), 9 states have call predecessors, (47), 8 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) Second operand 121 states. [2022-04-15 08:45:28,677 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:45:28,677 INFO L93 Difference]: Finished difference Result 121 states and 169 transitions. [2022-04-15 08:45:28,677 INFO L276 IsEmpty]: Start isEmpty. Operand 121 states and 169 transitions. [2022-04-15 08:45:28,678 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:45:28,678 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:45:28,678 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:45:28,678 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:45:28,678 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 118 states, 62 states have (on average 1.2096774193548387) internal successors, (75), 64 states have internal predecessors, (75), 47 states have call successors, (47), 9 states have call predecessors, (47), 8 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:45:28,681 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 118 states to 118 states and 166 transitions. [2022-04-15 08:45:28,681 INFO L78 Accepts]: Start accepts. Automaton has 118 states and 166 transitions. Word has length 75 [2022-04-15 08:45:28,682 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:45:28,682 INFO L478 AbstractCegarLoop]: Abstraction has 118 states and 166 transitions. [2022-04-15 08:45:28,682 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 10 states, 10 states have (on average 2.5) internal successors, (25), 9 states have internal predecessors, (25), 5 states have call successors, (14), 2 states have call predecessors, (14), 2 states have return successors, (12), 5 states have call predecessors, (12), 5 states have call successors, (12) [2022-04-15 08:45:28,682 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 118 states and 166 transitions. [2022-04-15 08:45:28,913 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 166 edges. 166 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:45:28,913 INFO L276 IsEmpty]: Start isEmpty. Operand 118 states and 166 transitions. [2022-04-15 08:45:28,914 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 81 [2022-04-15 08:45:28,914 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:45:28,914 INFO L499 BasicCegarLoop]: trace histogram [7, 6, 6, 6, 6, 6, 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] [2022-04-15 08:45:28,930 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (9)] Forceful destruction successful, exit code 0 [2022-04-15 08:45:29,130 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 9 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable8 [2022-04-15 08:45:29,130 INFO L403 AbstractCegarLoop]: === Iteration 10 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:45:29,130 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:45:29,130 INFO L85 PathProgramCache]: Analyzing trace with hash -1245952186, now seen corresponding path program 3 times [2022-04-15 08:45:29,131 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:45:29,131 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [769043004] [2022-04-15 08:45:29,131 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:45:29,131 INFO L85 PathProgramCache]: Analyzing trace with hash -1245952186, now seen corresponding path program 4 times [2022-04-15 08:45:29,131 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:45:29,131 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1182045930] [2022-04-15 08:45:29,131 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:45:29,131 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:45:29,142 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:45:29,142 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [83458734] [2022-04-15 08:45:29,142 INFO L93 rtionOrderModulation]: Changing assertion order to TERMS_WITH_SMALL_CONSTANTS_FIRST [2022-04-15 08:45:29,142 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:45:29,142 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:45:29,143 INFO L229 MonitoredProcess]: Starting monitored process 10 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:45:29,144 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (10)] Waiting until timeout for monitored process [2022-04-15 08:45:29,190 INFO L228 tOrderPrioritization]: Assert order TERMS_WITH_SMALL_CONSTANTS_FIRST issued 0 check-sat command(s) [2022-04-15 08:45:29,190 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:45:29,191 INFO L263 TraceCheckSpWp]: Trace formula consists of 174 conjuncts, 56 conjunts are in the unsatisfiable core [2022-04-15 08:45:29,205 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:45:29,206 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:45:30,363 INFO L272 TraceCheckUtils]: 0: Hoare triple {5956#true} call ULTIMATE.init(); {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L290 TraceCheckUtils]: 1: Hoare triple {5956#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L290 TraceCheckUtils]: 2: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5956#true} {5956#true} #103#return; {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L272 TraceCheckUtils]: 4: Hoare triple {5956#true} call #t~ret6 := main(); {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L290 TraceCheckUtils]: 5: Hoare triple {5956#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L272 TraceCheckUtils]: 6: Hoare triple {5956#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L290 TraceCheckUtils]: 7: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L290 TraceCheckUtils]: 8: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L290 TraceCheckUtils]: 9: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:45:30,364 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {5956#true} {5956#true} #79#return; {5956#true} is VALID [2022-04-15 08:45:30,365 INFO L290 TraceCheckUtils]: 11: Hoare triple {5956#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {5956#true} is VALID [2022-04-15 08:45:30,365 INFO L272 TraceCheckUtils]: 12: Hoare triple {5956#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,365 INFO L290 TraceCheckUtils]: 13: Hoare triple {5956#true} ~cond := #in~cond; {6000#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-04-15 08:45:30,365 INFO L290 TraceCheckUtils]: 14: Hoare triple {6000#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond); {6004#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:45:30,365 INFO L290 TraceCheckUtils]: 15: Hoare triple {6004#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {6004#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:45:30,366 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {6004#(not (= |assume_abort_if_not_#in~cond| 0))} {5956#true} #81#return; {6011#(and (<= 0 main_~y~0) (<= main_~y~0 5))} is VALID [2022-04-15 08:45:30,366 INFO L272 TraceCheckUtils]: 17: Hoare triple {6011#(and (<= 0 main_~y~0) (<= main_~y~0 5))} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,366 INFO L290 TraceCheckUtils]: 18: Hoare triple {5956#true} ~cond := #in~cond; {6000#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-04-15 08:45:30,366 INFO L290 TraceCheckUtils]: 19: Hoare triple {6000#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond); {6004#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:45:30,367 INFO L290 TraceCheckUtils]: 20: Hoare triple {6004#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {6004#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:45:30,367 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {6004#(not (= |assume_abort_if_not_#in~cond| 0))} {6011#(and (<= 0 main_~y~0) (<= main_~y~0 5))} #83#return; {6027#(and (<= 0 main_~y~0) (<= 1 main_~x~0) (<= main_~y~0 5))} is VALID [2022-04-15 08:45:30,367 INFO L272 TraceCheckUtils]: 22: Hoare triple {6027#(and (<= 0 main_~y~0) (<= 1 main_~x~0) (<= main_~y~0 5))} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,367 INFO L290 TraceCheckUtils]: 23: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:45:30,367 INFO L290 TraceCheckUtils]: 24: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:45:30,368 INFO L290 TraceCheckUtils]: 25: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:45:30,368 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {5956#true} {6027#(and (<= 0 main_~y~0) (<= 1 main_~x~0) (<= main_~y~0 5))} #85#return; {6027#(and (<= 0 main_~y~0) (<= 1 main_~x~0) (<= main_~y~0 5))} is VALID [2022-04-15 08:45:30,368 INFO L290 TraceCheckUtils]: 27: Hoare triple {6027#(and (<= 0 main_~y~0) (<= 1 main_~x~0) (<= main_~y~0 5))} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,368 INFO L272 TraceCheckUtils]: 28: Hoare triple {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,369 INFO L290 TraceCheckUtils]: 29: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:45:30,369 INFO L290 TraceCheckUtils]: 30: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:45:30,369 INFO L290 TraceCheckUtils]: 31: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:45:30,369 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {5956#true} {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} #87#return; {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,369 INFO L272 TraceCheckUtils]: 33: Hoare triple {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,369 INFO L290 TraceCheckUtils]: 34: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:45:30,369 INFO L290 TraceCheckUtils]: 35: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:45:30,370 INFO L290 TraceCheckUtils]: 36: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:45:30,370 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {5956#true} {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} #89#return; {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,371 INFO L290 TraceCheckUtils]: 38: Hoare triple {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} assume !false; {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,371 INFO L290 TraceCheckUtils]: 39: Hoare triple {6046#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (<= main_~y~0 5) (= main_~p~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,371 INFO L290 TraceCheckUtils]: 40: Hoare triple {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} assume !false; {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,371 INFO L272 TraceCheckUtils]: 41: Hoare triple {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,372 INFO L290 TraceCheckUtils]: 42: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:45:30,372 INFO L290 TraceCheckUtils]: 43: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:45:30,372 INFO L290 TraceCheckUtils]: 44: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:45:30,372 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {5956#true} {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #91#return; {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,372 INFO L272 TraceCheckUtils]: 46: Hoare triple {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,372 INFO L290 TraceCheckUtils]: 47: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:45:30,372 INFO L290 TraceCheckUtils]: 48: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:45:30,373 INFO L290 TraceCheckUtils]: 49: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:45:30,374 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {5956#true} {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #93#return; {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,374 INFO L272 TraceCheckUtils]: 51: Hoare triple {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,374 INFO L290 TraceCheckUtils]: 52: Hoare triple {5956#true} ~cond := #in~cond; {6123#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:45:30,375 INFO L290 TraceCheckUtils]: 53: Hoare triple {6123#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:45:30,375 INFO L290 TraceCheckUtils]: 54: Hoare triple {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:45:30,376 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} {6083#(and (<= 0 main_~y~0) (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (<= main_~b~0 main_~y~0) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #95#return; {6134#(and (<= 0 main_~y~0) (= main_~r~0 0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,376 INFO L272 TraceCheckUtils]: 56: Hoare triple {6134#(and (<= 0 main_~y~0) (= main_~r~0 0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,376 INFO L290 TraceCheckUtils]: 57: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:45:30,376 INFO L290 TraceCheckUtils]: 58: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:45:30,376 INFO L290 TraceCheckUtils]: 59: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:45:30,377 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {5956#true} {6134#(and (<= 0 main_~y~0) (= main_~r~0 0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #97#return; {6134#(and (<= 0 main_~y~0) (= main_~r~0 0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,377 INFO L290 TraceCheckUtils]: 61: Hoare triple {6134#(and (<= 0 main_~y~0) (= main_~r~0 0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} assume !(~c~0 >= ~b~0); {6153#(and (= main_~r~0 0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (< main_~c~0 main_~b~0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:45:30,378 INFO L290 TraceCheckUtils]: 62: Hoare triple {6153#(and (= main_~r~0 0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (< main_~c~0 main_~b~0) (<= main_~y~0 5) (= main_~c~0 main_~x~0) (= main_~p~0 1))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} is VALID [2022-04-15 08:45:30,378 INFO L290 TraceCheckUtils]: 63: Hoare triple {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} assume !false; {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} is VALID [2022-04-15 08:45:30,379 INFO L290 TraceCheckUtils]: 64: Hoare triple {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} is VALID [2022-04-15 08:45:30,379 INFO L290 TraceCheckUtils]: 65: Hoare triple {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} assume !false; {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} is VALID [2022-04-15 08:45:30,379 INFO L272 TraceCheckUtils]: 66: Hoare triple {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,379 INFO L290 TraceCheckUtils]: 67: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:45:30,379 INFO L290 TraceCheckUtils]: 68: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:45:30,379 INFO L290 TraceCheckUtils]: 69: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:45:30,380 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {5956#true} {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} #91#return; {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} is VALID [2022-04-15 08:45:30,380 INFO L272 TraceCheckUtils]: 71: Hoare triple {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:45:30,380 INFO L290 TraceCheckUtils]: 72: Hoare triple {5956#true} ~cond := #in~cond; {6123#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:45:30,381 INFO L290 TraceCheckUtils]: 73: Hoare triple {6123#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:45:30,381 INFO L290 TraceCheckUtils]: 74: Hoare triple {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:45:30,382 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} {6157#(and (= (+ main_~y~0 (* main_~p~0 main_~x~0)) main_~a~0) (= main_~s~0 0) (<= 1 main_~x~0) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (< main_~x~0 main_~a~0) (= main_~q~0 1) (<= main_~y~0 5))} #93#return; {6197#(and (= main_~s~0 0) (<= 1 main_~x~0) (< main_~x~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~q~0 1) (<= main_~y~0 5))} is VALID [2022-04-15 08:45:30,382 INFO L272 TraceCheckUtils]: 76: Hoare triple {6197#(and (= main_~s~0 0) (<= 1 main_~x~0) (< main_~x~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~q~0 1) (<= main_~y~0 5))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {6201#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:45:30,383 INFO L290 TraceCheckUtils]: 77: Hoare triple {6201#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {6205#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:45:30,383 INFO L290 TraceCheckUtils]: 78: Hoare triple {6205#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {5957#false} is VALID [2022-04-15 08:45:30,383 INFO L290 TraceCheckUtils]: 79: Hoare triple {5957#false} assume !false; {5957#false} is VALID [2022-04-15 08:45:30,383 INFO L134 CoverageAnalysis]: Checked inductivity of 138 backedges. 34 proven. 32 refuted. 0 times theorem prover too weak. 72 trivial. 0 not checked. [2022-04-15 08:45:30,383 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:46:03,372 INFO L290 TraceCheckUtils]: 79: Hoare triple {5957#false} assume !false; {5957#false} is VALID [2022-04-15 08:46:03,372 INFO L290 TraceCheckUtils]: 78: Hoare triple {6205#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {5957#false} is VALID [2022-04-15 08:46:03,373 INFO L290 TraceCheckUtils]: 77: Hoare triple {6201#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {6205#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:46:03,373 INFO L272 TraceCheckUtils]: 76: Hoare triple {6221#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {6201#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:46:03,374 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} {6225#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} #93#return; {6221#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:46:03,374 INFO L290 TraceCheckUtils]: 74: Hoare triple {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:46:03,374 INFO L290 TraceCheckUtils]: 73: Hoare triple {6235#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {6127#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:46:03,375 INFO L290 TraceCheckUtils]: 72: Hoare triple {5956#true} ~cond := #in~cond; {6235#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:46:03,375 INFO L272 TraceCheckUtils]: 71: Hoare triple {6225#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,375 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {5956#true} {6225#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} #91#return; {6225#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} is VALID [2022-04-15 08:46:03,376 INFO L290 TraceCheckUtils]: 69: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,376 INFO L290 TraceCheckUtils]: 68: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,376 INFO L290 TraceCheckUtils]: 67: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,376 INFO L272 TraceCheckUtils]: 66: Hoare triple {6225#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,376 INFO L290 TraceCheckUtils]: 65: Hoare triple {6225#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} assume !false; {6225#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} is VALID [2022-04-15 08:46:03,377 INFO L290 TraceCheckUtils]: 64: Hoare triple {6260#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~b~0 0) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {6225#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} is VALID [2022-04-15 08:46:03,377 INFO L290 TraceCheckUtils]: 63: Hoare triple {6260#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~b~0 0) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} assume !false; {6260#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~b~0 0) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} is VALID [2022-04-15 08:46:03,502 INFO L290 TraceCheckUtils]: 62: Hoare triple {6267#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= main_~c~0 0))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {6260#(or (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~b~0 0) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))))} is VALID [2022-04-15 08:46:03,502 INFO L290 TraceCheckUtils]: 61: Hoare triple {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} assume !(~c~0 >= ~b~0); {6267#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= main_~c~0 0))} is VALID [2022-04-15 08:46:03,503 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {5956#true} {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} #97#return; {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} is VALID [2022-04-15 08:46:03,503 INFO L290 TraceCheckUtils]: 59: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,503 INFO L290 TraceCheckUtils]: 58: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,503 INFO L290 TraceCheckUtils]: 57: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,503 INFO L272 TraceCheckUtils]: 56: Hoare triple {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,504 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {5956#true} {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} #95#return; {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} is VALID [2022-04-15 08:46:03,504 INFO L290 TraceCheckUtils]: 54: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,504 INFO L290 TraceCheckUtils]: 53: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,504 INFO L290 TraceCheckUtils]: 52: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,505 INFO L272 TraceCheckUtils]: 51: Hoare triple {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,505 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {5956#true} {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} #93#return; {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} is VALID [2022-04-15 08:46:03,505 INFO L290 TraceCheckUtils]: 49: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,505 INFO L290 TraceCheckUtils]: 48: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,505 INFO L290 TraceCheckUtils]: 47: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,506 INFO L272 TraceCheckUtils]: 46: Hoare triple {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,506 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {5956#true} {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} #91#return; {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} is VALID [2022-04-15 08:46:03,506 INFO L290 TraceCheckUtils]: 44: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,506 INFO L290 TraceCheckUtils]: 43: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,506 INFO L290 TraceCheckUtils]: 42: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,507 INFO L272 TraceCheckUtils]: 41: Hoare triple {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,507 INFO L290 TraceCheckUtils]: 40: Hoare triple {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} assume !false; {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} is VALID [2022-04-15 08:46:03,508 INFO L290 TraceCheckUtils]: 39: Hoare triple {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {6271#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (= main_~c~0 0))} is VALID [2022-04-15 08:46:03,508 INFO L290 TraceCheckUtils]: 38: Hoare triple {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} assume !false; {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} is VALID [2022-04-15 08:46:03,509 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {5956#true} {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} #89#return; {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} is VALID [2022-04-15 08:46:03,509 INFO L290 TraceCheckUtils]: 36: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,509 INFO L290 TraceCheckUtils]: 35: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,509 INFO L290 TraceCheckUtils]: 34: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,509 INFO L272 TraceCheckUtils]: 33: Hoare triple {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,510 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {5956#true} {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} #87#return; {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} is VALID [2022-04-15 08:46:03,510 INFO L290 TraceCheckUtils]: 31: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,510 INFO L290 TraceCheckUtils]: 30: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,510 INFO L290 TraceCheckUtils]: 29: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,510 INFO L272 TraceCheckUtils]: 28: Hoare triple {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,510 INFO L290 TraceCheckUtils]: 27: Hoare triple {5956#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {6338#(or (= main_~a~0 0) (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~a~0))} is VALID [2022-04-15 08:46:03,511 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {5956#true} {5956#true} #85#return; {5956#true} is VALID [2022-04-15 08:46:03,511 INFO L290 TraceCheckUtils]: 25: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,511 INFO L290 TraceCheckUtils]: 24: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,511 INFO L290 TraceCheckUtils]: 23: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,511 INFO L272 TraceCheckUtils]: 22: Hoare triple {5956#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,511 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {5956#true} {5956#true} #83#return; {5956#true} is VALID [2022-04-15 08:46:03,511 INFO L290 TraceCheckUtils]: 20: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,511 INFO L290 TraceCheckUtils]: 19: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,511 INFO L290 TraceCheckUtils]: 18: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,511 INFO L272 TraceCheckUtils]: 17: Hoare triple {5956#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {5956#true} {5956#true} #81#return; {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L290 TraceCheckUtils]: 15: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L290 TraceCheckUtils]: 14: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L290 TraceCheckUtils]: 13: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L272 TraceCheckUtils]: 12: Hoare triple {5956#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L290 TraceCheckUtils]: 11: Hoare triple {5956#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {5956#true} {5956#true} #79#return; {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L290 TraceCheckUtils]: 9: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L290 TraceCheckUtils]: 8: Hoare triple {5956#true} assume !(0 == ~cond); {5956#true} is VALID [2022-04-15 08:46:03,512 INFO L290 TraceCheckUtils]: 7: Hoare triple {5956#true} ~cond := #in~cond; {5956#true} is VALID [2022-04-15 08:46:03,513 INFO L272 TraceCheckUtils]: 6: Hoare triple {5956#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {5956#true} is VALID [2022-04-15 08:46:03,513 INFO L290 TraceCheckUtils]: 5: Hoare triple {5956#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {5956#true} is VALID [2022-04-15 08:46:03,513 INFO L272 TraceCheckUtils]: 4: Hoare triple {5956#true} call #t~ret6 := main(); {5956#true} is VALID [2022-04-15 08:46:03,513 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {5956#true} {5956#true} #103#return; {5956#true} is VALID [2022-04-15 08:46:03,513 INFO L290 TraceCheckUtils]: 2: Hoare triple {5956#true} assume true; {5956#true} is VALID [2022-04-15 08:46:03,513 INFO L290 TraceCheckUtils]: 1: Hoare triple {5956#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {5956#true} is VALID [2022-04-15 08:46:03,513 INFO L272 TraceCheckUtils]: 0: Hoare triple {5956#true} call ULTIMATE.init(); {5956#true} is VALID [2022-04-15 08:46:03,514 INFO L134 CoverageAnalysis]: Checked inductivity of 138 backedges. 26 proven. 7 refuted. 0 times theorem prover too weak. 105 trivial. 0 not checked. [2022-04-15 08:46:03,514 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:46:03,514 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1182045930] [2022-04-15 08:46:03,514 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:46:03,514 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [83458734] [2022-04-15 08:46:03,514 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [83458734] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:46:03,514 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:46:03,514 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [16, 12] total 23 [2022-04-15 08:46:03,514 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:46:03,515 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [769043004] [2022-04-15 08:46:03,515 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [769043004] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:46:03,515 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:46:03,515 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [16] imperfect sequences [] total 16 [2022-04-15 08:46:03,515 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1110191743] [2022-04-15 08:46:03,515 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:46:03,515 INFO L78 Accepts]: Start accepts. Automaton has has 16 states, 14 states have (on average 2.0) internal successors, (28), 11 states have internal predecessors, (28), 8 states have call successors, (15), 2 states have call predecessors, (15), 3 states have return successors, (13), 8 states have call predecessors, (13), 7 states have call successors, (13) Word has length 80 [2022-04-15 08:46:03,516 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:46:03,516 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 16 states, 14 states have (on average 2.0) internal successors, (28), 11 states have internal predecessors, (28), 8 states have call successors, (15), 2 states have call predecessors, (15), 3 states have return successors, (13), 8 states have call predecessors, (13), 7 states have call successors, (13) [2022-04-15 08:46:03,561 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 56 edges. 56 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:46:03,561 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 16 states [2022-04-15 08:46:03,561 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:46:03,561 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 16 interpolants. [2022-04-15 08:46:03,561 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=88, Invalid=418, Unknown=0, NotChecked=0, Total=506 [2022-04-15 08:46:03,562 INFO L87 Difference]: Start difference. First operand 118 states and 166 transitions. Second operand has 16 states, 14 states have (on average 2.0) internal successors, (28), 11 states have internal predecessors, (28), 8 states have call successors, (15), 2 states have call predecessors, (15), 3 states have return successors, (13), 8 states have call predecessors, (13), 7 states have call successors, (13) [2022-04-15 08:46:05,161 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:46:05,161 INFO L93 Difference]: Finished difference Result 134 states and 179 transitions. [2022-04-15 08:46:05,162 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 15 states. [2022-04-15 08:46:05,163 INFO L78 Accepts]: Start accepts. Automaton has has 16 states, 14 states have (on average 2.0) internal successors, (28), 11 states have internal predecessors, (28), 8 states have call successors, (15), 2 states have call predecessors, (15), 3 states have return successors, (13), 8 states have call predecessors, (13), 7 states have call successors, (13) Word has length 80 [2022-04-15 08:46:05,163 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:46:05,164 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 16 states, 14 states have (on average 2.0) internal successors, (28), 11 states have internal predecessors, (28), 8 states have call successors, (15), 2 states have call predecessors, (15), 3 states have return successors, (13), 8 states have call predecessors, (13), 7 states have call successors, (13) [2022-04-15 08:46:05,166 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 15 states to 15 states and 91 transitions. [2022-04-15 08:46:05,166 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 16 states, 14 states have (on average 2.0) internal successors, (28), 11 states have internal predecessors, (28), 8 states have call successors, (15), 2 states have call predecessors, (15), 3 states have return successors, (13), 8 states have call predecessors, (13), 7 states have call successors, (13) [2022-04-15 08:46:05,169 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 15 states to 15 states and 91 transitions. [2022-04-15 08:46:05,169 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 15 states and 91 transitions. [2022-04-15 08:46:05,254 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 91 edges. 91 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:46:05,272 INFO L225 Difference]: With dead ends: 134 [2022-04-15 08:46:05,272 INFO L226 Difference]: Without dead ends: 132 [2022-04-15 08:46:05,272 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 165 GetRequests, 136 SyntacticMatches, 2 SemanticMatches, 27 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 173 ImplicationChecksByTransitivity, 0.7s TimeCoverageRelationStatistics Valid=144, Invalid=668, Unknown=0, NotChecked=0, Total=812 [2022-04-15 08:46:05,273 INFO L913 BasicCegarLoop]: 32 mSDtfsCounter, 66 mSDsluCounter, 125 mSDsCounter, 0 mSdLazyCounter, 415 mSolverCounterSat, 62 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.5s Time, 0 mProtectedPredicate, 0 mProtectedAction, 79 SdHoareTripleChecker+Valid, 157 SdHoareTripleChecker+Invalid, 477 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 62 IncrementalHoareTripleChecker+Valid, 415 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.6s IncrementalHoareTripleChecker+Time [2022-04-15 08:46:05,273 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [79 Valid, 157 Invalid, 477 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [62 Valid, 415 Invalid, 0 Unknown, 0 Unchecked, 0.6s Time] [2022-04-15 08:46:05,273 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 132 states. [2022-04-15 08:46:05,486 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 132 to 130. [2022-04-15 08:46:05,486 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:46:05,487 INFO L82 GeneralOperation]: Start isEquivalent. First operand 132 states. Second operand has 130 states, 71 states have (on average 1.1830985915492958) internal successors, (84), 73 states have internal predecessors, (84), 47 states have call successors, (47), 12 states have call predecessors, (47), 11 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:46:05,487 INFO L74 IsIncluded]: Start isIncluded. First operand 132 states. Second operand has 130 states, 71 states have (on average 1.1830985915492958) internal successors, (84), 73 states have internal predecessors, (84), 47 states have call successors, (47), 12 states have call predecessors, (47), 11 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:46:05,487 INFO L87 Difference]: Start difference. First operand 132 states. Second operand has 130 states, 71 states have (on average 1.1830985915492958) internal successors, (84), 73 states have internal predecessors, (84), 47 states have call successors, (47), 12 states have call predecessors, (47), 11 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:46:05,490 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:46:05,490 INFO L93 Difference]: Finished difference Result 132 states and 177 transitions. [2022-04-15 08:46:05,490 INFO L276 IsEmpty]: Start isEmpty. Operand 132 states and 177 transitions. [2022-04-15 08:46:05,491 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:46:05,491 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:46:05,491 INFO L74 IsIncluded]: Start isIncluded. First operand has 130 states, 71 states have (on average 1.1830985915492958) internal successors, (84), 73 states have internal predecessors, (84), 47 states have call successors, (47), 12 states have call predecessors, (47), 11 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) Second operand 132 states. [2022-04-15 08:46:05,491 INFO L87 Difference]: Start difference. First operand has 130 states, 71 states have (on average 1.1830985915492958) internal successors, (84), 73 states have internal predecessors, (84), 47 states have call successors, (47), 12 states have call predecessors, (47), 11 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) Second operand 132 states. [2022-04-15 08:46:05,494 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:46:05,494 INFO L93 Difference]: Finished difference Result 132 states and 177 transitions. [2022-04-15 08:46:05,494 INFO L276 IsEmpty]: Start isEmpty. Operand 132 states and 177 transitions. [2022-04-15 08:46:05,494 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:46:05,494 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:46:05,494 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:46:05,494 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:46:05,494 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 130 states, 71 states have (on average 1.1830985915492958) internal successors, (84), 73 states have internal predecessors, (84), 47 states have call successors, (47), 12 states have call predecessors, (47), 11 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:46:05,497 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 130 states to 130 states and 175 transitions. [2022-04-15 08:46:05,497 INFO L78 Accepts]: Start accepts. Automaton has 130 states and 175 transitions. Word has length 80 [2022-04-15 08:46:05,497 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:46:05,497 INFO L478 AbstractCegarLoop]: Abstraction has 130 states and 175 transitions. [2022-04-15 08:46:05,497 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 16 states, 14 states have (on average 2.0) internal successors, (28), 11 states have internal predecessors, (28), 8 states have call successors, (15), 2 states have call predecessors, (15), 3 states have return successors, (13), 8 states have call predecessors, (13), 7 states have call successors, (13) [2022-04-15 08:46:05,497 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 130 states and 175 transitions. [2022-04-15 08:46:05,730 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 175 edges. 175 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:46:05,730 INFO L276 IsEmpty]: Start isEmpty. Operand 130 states and 175 transitions. [2022-04-15 08:46:05,731 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 86 [2022-04-15 08:46:05,731 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:46:05,731 INFO L499 BasicCegarLoop]: trace histogram [8, 7, 7, 6, 6, 6, 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] [2022-04-15 08:46:05,747 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (10)] Forceful destruction successful, exit code 0 [2022-04-15 08:46:05,931 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 10 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable9 [2022-04-15 08:46:05,932 INFO L403 AbstractCegarLoop]: === Iteration 11 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:46:05,933 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:46:05,933 INFO L85 PathProgramCache]: Analyzing trace with hash 901388446, now seen corresponding path program 5 times [2022-04-15 08:46:05,933 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:46:05,933 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [462332515] [2022-04-15 08:46:05,933 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:46:05,933 INFO L85 PathProgramCache]: Analyzing trace with hash 901388446, now seen corresponding path program 6 times [2022-04-15 08:46:05,933 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:46:05,934 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [411512825] [2022-04-15 08:46:05,934 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:46:05,934 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:46:05,944 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:46:05,944 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1700978463] [2022-04-15 08:46:05,944 INFO L93 rtionOrderModulation]: Changing assertion order to MIX_INSIDE_OUTSIDE [2022-04-15 08:46:05,944 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:46:05,944 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:46:05,945 INFO L229 MonitoredProcess]: Starting monitored process 11 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:46:05,959 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (11)] Waiting until timeout for monitored process [2022-04-15 08:46:06,011 INFO L228 tOrderPrioritization]: Assert order MIX_INSIDE_OUTSIDE issued 5 check-sat command(s) [2022-04-15 08:46:06,011 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:46:06,012 INFO L263 TraceCheckSpWp]: Trace formula consists of 195 conjuncts, 32 conjunts are in the unsatisfiable core [2022-04-15 08:46:06,028 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:46:06,029 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:46:06,546 INFO L272 TraceCheckUtils]: 0: Hoare triple {7262#true} call ULTIMATE.init(); {7262#true} is VALID [2022-04-15 08:46:06,546 INFO L290 TraceCheckUtils]: 1: Hoare triple {7262#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L290 TraceCheckUtils]: 2: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {7262#true} {7262#true} #103#return; {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L272 TraceCheckUtils]: 4: Hoare triple {7262#true} call #t~ret6 := main(); {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L290 TraceCheckUtils]: 5: Hoare triple {7262#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L272 TraceCheckUtils]: 6: Hoare triple {7262#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L290 TraceCheckUtils]: 7: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L290 TraceCheckUtils]: 8: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L290 TraceCheckUtils]: 9: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {7262#true} {7262#true} #79#return; {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L290 TraceCheckUtils]: 11: Hoare triple {7262#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L272 TraceCheckUtils]: 12: Hoare triple {7262#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L290 TraceCheckUtils]: 13: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L290 TraceCheckUtils]: 14: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,547 INFO L290 TraceCheckUtils]: 15: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {7262#true} {7262#true} #81#return; {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L272 TraceCheckUtils]: 17: Hoare triple {7262#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L290 TraceCheckUtils]: 18: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L290 TraceCheckUtils]: 19: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L290 TraceCheckUtils]: 20: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {7262#true} {7262#true} #83#return; {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L272 TraceCheckUtils]: 22: Hoare triple {7262#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L290 TraceCheckUtils]: 23: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L290 TraceCheckUtils]: 24: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L290 TraceCheckUtils]: 25: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,548 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {7262#true} {7262#true} #85#return; {7262#true} is VALID [2022-04-15 08:46:06,549 INFO L290 TraceCheckUtils]: 27: Hoare triple {7262#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} is VALID [2022-04-15 08:46:06,549 INFO L272 TraceCheckUtils]: 28: Hoare triple {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,549 INFO L290 TraceCheckUtils]: 29: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,549 INFO L290 TraceCheckUtils]: 30: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,549 INFO L290 TraceCheckUtils]: 31: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,549 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {7262#true} {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} #87#return; {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} is VALID [2022-04-15 08:46:06,550 INFO L272 TraceCheckUtils]: 33: Hoare triple {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,550 INFO L290 TraceCheckUtils]: 34: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,550 INFO L290 TraceCheckUtils]: 35: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,550 INFO L290 TraceCheckUtils]: 36: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,550 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {7262#true} {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} #89#return; {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} is VALID [2022-04-15 08:46:06,551 INFO L290 TraceCheckUtils]: 38: Hoare triple {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} assume !false; {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} is VALID [2022-04-15 08:46:06,551 INFO L290 TraceCheckUtils]: 39: Hoare triple {7348#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} is VALID [2022-04-15 08:46:06,551 INFO L290 TraceCheckUtils]: 40: Hoare triple {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} assume !false; {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} is VALID [2022-04-15 08:46:06,552 INFO L272 TraceCheckUtils]: 41: Hoare triple {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,552 INFO L290 TraceCheckUtils]: 42: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,552 INFO L290 TraceCheckUtils]: 43: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,552 INFO L290 TraceCheckUtils]: 44: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,552 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {7262#true} {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} #91#return; {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} is VALID [2022-04-15 08:46:06,552 INFO L272 TraceCheckUtils]: 46: Hoare triple {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,553 INFO L290 TraceCheckUtils]: 47: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,553 INFO L290 TraceCheckUtils]: 48: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,553 INFO L290 TraceCheckUtils]: 49: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,553 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {7262#true} {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} #93#return; {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} is VALID [2022-04-15 08:46:06,553 INFO L272 TraceCheckUtils]: 51: Hoare triple {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,553 INFO L290 TraceCheckUtils]: 52: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,553 INFO L290 TraceCheckUtils]: 53: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,554 INFO L290 TraceCheckUtils]: 54: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,554 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {7262#true} {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} #95#return; {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} is VALID [2022-04-15 08:46:06,554 INFO L272 TraceCheckUtils]: 56: Hoare triple {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,554 INFO L290 TraceCheckUtils]: 57: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,554 INFO L290 TraceCheckUtils]: 58: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,554 INFO L290 TraceCheckUtils]: 59: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,555 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {7262#true} {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} #97#return; {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} is VALID [2022-04-15 08:46:06,556 INFO L290 TraceCheckUtils]: 61: Hoare triple {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} assume !(~c~0 >= ~b~0); {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} is VALID [2022-04-15 08:46:06,556 INFO L290 TraceCheckUtils]: 62: Hoare triple {7385#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:46:06,556 INFO L290 TraceCheckUtils]: 63: Hoare triple {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !false; {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:46:06,558 INFO L290 TraceCheckUtils]: 64: Hoare triple {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:46:06,558 INFO L290 TraceCheckUtils]: 65: Hoare triple {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !false; {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:46:06,558 INFO L272 TraceCheckUtils]: 66: Hoare triple {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,559 INFO L290 TraceCheckUtils]: 67: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,559 INFO L290 TraceCheckUtils]: 68: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,559 INFO L290 TraceCheckUtils]: 69: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,561 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {7262#true} {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #91#return; {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:46:06,561 INFO L272 TraceCheckUtils]: 71: Hoare triple {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,561 INFO L290 TraceCheckUtils]: 72: Hoare triple {7262#true} ~cond := #in~cond; {7262#true} is VALID [2022-04-15 08:46:06,561 INFO L290 TraceCheckUtils]: 73: Hoare triple {7262#true} assume !(0 == ~cond); {7262#true} is VALID [2022-04-15 08:46:06,561 INFO L290 TraceCheckUtils]: 74: Hoare triple {7262#true} assume true; {7262#true} is VALID [2022-04-15 08:46:06,562 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {7262#true} {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #93#return; {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:46:06,562 INFO L272 TraceCheckUtils]: 76: Hoare triple {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {7262#true} is VALID [2022-04-15 08:46:06,562 INFO L290 TraceCheckUtils]: 77: Hoare triple {7262#true} ~cond := #in~cond; {7501#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:46:06,563 INFO L290 TraceCheckUtils]: 78: Hoare triple {7501#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {7505#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:46:06,563 INFO L290 TraceCheckUtils]: 79: Hoare triple {7505#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {7505#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:46:06,563 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {7505#(not (= |__VERIFIER_assert_#in~cond| 0))} {7455#(and (= main_~s~0 0) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #95#return; {7512#(and (= main_~s~0 0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:46:06,566 INFO L272 TraceCheckUtils]: 81: Hoare triple {7512#(and (= main_~s~0 0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (= main_~b~0 main_~x~0) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {7516#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:46:06,566 INFO L290 TraceCheckUtils]: 82: Hoare triple {7516#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {7520#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:46:06,566 INFO L290 TraceCheckUtils]: 83: Hoare triple {7520#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {7263#false} is VALID [2022-04-15 08:46:06,566 INFO L290 TraceCheckUtils]: 84: Hoare triple {7263#false} assume !false; {7263#false} is VALID [2022-04-15 08:46:06,567 INFO L134 CoverageAnalysis]: Checked inductivity of 165 backedges. 31 proven. 8 refuted. 0 times theorem prover too weak. 126 trivial. 0 not checked. [2022-04-15 08:46:06,567 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:46:53,044 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:46:53,045 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [411512825] [2022-04-15 08:46:53,045 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:46:53,045 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1700978463] [2022-04-15 08:46:53,045 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1700978463] provided 0 perfect and 1 imperfect interpolant sequences [2022-04-15 08:46:53,045 INFO L184 FreeRefinementEngine]: Found 0 perfect and 1 imperfect interpolant sequences. [2022-04-15 08:46:53,045 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [10] total 10 [2022-04-15 08:46:53,045 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:46:53,045 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [462332515] [2022-04-15 08:46:53,045 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [462332515] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:46:53,045 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:46:53,045 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [10] imperfect sequences [] total 10 [2022-04-15 08:46:53,045 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [128602453] [2022-04-15 08:46:53,045 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:46:53,046 INFO L78 Accepts]: Start accepts. Automaton has has 10 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 5 states have call successors, (16), 2 states have call predecessors, (16), 2 states have return successors, (14), 5 states have call predecessors, (14), 4 states have call successors, (14) Word has length 85 [2022-04-15 08:46:53,046 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:46:53,046 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 10 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 5 states have call successors, (16), 2 states have call predecessors, (16), 2 states have return successors, (14), 5 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-15 08:46:53,089 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 55 edges. 55 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:46:53,089 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 10 states [2022-04-15 08:46:53,089 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:46:53,090 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 10 interpolants. [2022-04-15 08:46:53,090 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=27, Invalid=105, Unknown=0, NotChecked=0, Total=132 [2022-04-15 08:46:53,090 INFO L87 Difference]: Start difference. First operand 130 states and 175 transitions. Second operand has 10 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 5 states have call successors, (16), 2 states have call predecessors, (16), 2 states have return successors, (14), 5 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-15 08:46:54,250 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:46:54,250 INFO L93 Difference]: Finished difference Result 142 states and 185 transitions. [2022-04-15 08:46:54,250 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 10 states. [2022-04-15 08:46:54,251 INFO L78 Accepts]: Start accepts. Automaton has has 10 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 5 states have call successors, (16), 2 states have call predecessors, (16), 2 states have return successors, (14), 5 states have call predecessors, (14), 4 states have call successors, (14) Word has length 85 [2022-04-15 08:46:54,251 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:46:54,251 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 10 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 5 states have call successors, (16), 2 states have call predecessors, (16), 2 states have return successors, (14), 5 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-15 08:46:54,252 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 10 states to 10 states and 98 transitions. [2022-04-15 08:46:54,252 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 10 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 5 states have call successors, (16), 2 states have call predecessors, (16), 2 states have return successors, (14), 5 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-15 08:46:54,255 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 10 states to 10 states and 98 transitions. [2022-04-15 08:46:54,255 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 10 states and 98 transitions. [2022-04-15 08:46:54,344 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 98 edges. 98 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:46:54,346 INFO L225 Difference]: With dead ends: 142 [2022-04-15 08:46:54,347 INFO L226 Difference]: Without dead ends: 140 [2022-04-15 08:46:54,347 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 92 GetRequests, 78 SyntacticMatches, 1 SemanticMatches, 13 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 17 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=42, Invalid=168, Unknown=0, NotChecked=0, Total=210 [2022-04-15 08:46:54,347 INFO L913 BasicCegarLoop]: 44 mSDtfsCounter, 22 mSDsluCounter, 178 mSDsCounter, 0 mSdLazyCounter, 339 mSolverCounterSat, 10 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.4s Time, 0 mProtectedPredicate, 0 mProtectedAction, 30 SdHoareTripleChecker+Valid, 222 SdHoareTripleChecker+Invalid, 349 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 10 IncrementalHoareTripleChecker+Valid, 339 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.4s IncrementalHoareTripleChecker+Time [2022-04-15 08:46:54,347 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [30 Valid, 222 Invalid, 349 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [10 Valid, 339 Invalid, 0 Unknown, 0 Unchecked, 0.4s Time] [2022-04-15 08:46:54,348 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 140 states. [2022-04-15 08:46:54,566 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 140 to 138. [2022-04-15 08:46:54,566 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:46:54,567 INFO L82 GeneralOperation]: Start isEquivalent. First operand 140 states. Second operand has 138 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 79 states have internal predecessors, (90), 47 states have call successors, (47), 14 states have call predecessors, (47), 13 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:46:54,568 INFO L74 IsIncluded]: Start isIncluded. First operand 140 states. Second operand has 138 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 79 states have internal predecessors, (90), 47 states have call successors, (47), 14 states have call predecessors, (47), 13 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:46:54,569 INFO L87 Difference]: Start difference. First operand 140 states. Second operand has 138 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 79 states have internal predecessors, (90), 47 states have call successors, (47), 14 states have call predecessors, (47), 13 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:46:54,574 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:46:54,574 INFO L93 Difference]: Finished difference Result 140 states and 183 transitions. [2022-04-15 08:46:54,574 INFO L276 IsEmpty]: Start isEmpty. Operand 140 states and 183 transitions. [2022-04-15 08:46:54,574 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:46:54,574 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:46:54,575 INFO L74 IsIncluded]: Start isIncluded. First operand has 138 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 79 states have internal predecessors, (90), 47 states have call successors, (47), 14 states have call predecessors, (47), 13 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) Second operand 140 states. [2022-04-15 08:46:54,575 INFO L87 Difference]: Start difference. First operand has 138 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 79 states have internal predecessors, (90), 47 states have call successors, (47), 14 states have call predecessors, (47), 13 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) Second operand 140 states. [2022-04-15 08:46:54,579 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:46:54,579 INFO L93 Difference]: Finished difference Result 140 states and 183 transitions. [2022-04-15 08:46:54,579 INFO L276 IsEmpty]: Start isEmpty. Operand 140 states and 183 transitions. [2022-04-15 08:46:54,580 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:46:54,580 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:46:54,580 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:46:54,580 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:46:54,580 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 138 states, 77 states have (on average 1.1688311688311688) internal successors, (90), 79 states have internal predecessors, (90), 47 states have call successors, (47), 14 states have call predecessors, (47), 13 states have return successors, (44), 44 states have call predecessors, (44), 44 states have call successors, (44) [2022-04-15 08:46:54,582 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 138 states to 138 states and 181 transitions. [2022-04-15 08:46:54,583 INFO L78 Accepts]: Start accepts. Automaton has 138 states and 181 transitions. Word has length 85 [2022-04-15 08:46:54,583 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:46:54,583 INFO L478 AbstractCegarLoop]: Abstraction has 138 states and 181 transitions. [2022-04-15 08:46:54,583 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 10 states, 9 states have (on average 2.7777777777777777) internal successors, (25), 8 states have internal predecessors, (25), 5 states have call successors, (16), 2 states have call predecessors, (16), 2 states have return successors, (14), 5 states have call predecessors, (14), 4 states have call successors, (14) [2022-04-15 08:46:54,583 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 138 states and 181 transitions. [2022-04-15 08:46:54,824 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 181 edges. 181 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:46:54,824 INFO L276 IsEmpty]: Start isEmpty. Operand 138 states and 181 transitions. [2022-04-15 08:46:54,824 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 92 [2022-04-15 08:46:54,824 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:46:54,824 INFO L499 BasicCegarLoop]: trace histogram [9, 8, 8, 6, 6, 6, 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] [2022-04-15 08:46:54,840 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (11)] Ended with exit code 0 [2022-04-15 08:46:55,037 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 11 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable10 [2022-04-15 08:46:55,038 INFO L403 AbstractCegarLoop]: === Iteration 12 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:46:55,038 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:46:55,038 INFO L85 PathProgramCache]: Analyzing trace with hash -686534738, now seen corresponding path program 1 times [2022-04-15 08:46:55,038 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:46:55,038 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [579188483] [2022-04-15 08:46:55,039 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:46:55,039 INFO L85 PathProgramCache]: Analyzing trace with hash -686534738, now seen corresponding path program 2 times [2022-04-15 08:46:55,039 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:46:55,039 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [178685770] [2022-04-15 08:46:55,039 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:46:55,039 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:46:55,058 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:46:55,059 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1830238747] [2022-04-15 08:46:55,059 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:46:55,059 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:46:55,059 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:46:55,060 INFO L229 MonitoredProcess]: Starting monitored process 12 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:46:55,060 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (12)] Waiting until timeout for monitored process [2022-04-15 08:46:55,108 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:46:55,108 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:46:55,109 INFO L263 TraceCheckSpWp]: Trace formula consists of 233 conjuncts, 39 conjunts are in the unsatisfiable core [2022-04-15 08:46:55,126 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:46:55,127 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:46:55,683 INFO L272 TraceCheckUtils]: 0: Hoare triple {8389#true} call ULTIMATE.init(); {8389#true} is VALID [2022-04-15 08:46:55,683 INFO L290 TraceCheckUtils]: 1: Hoare triple {8389#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {8389#true} is VALID [2022-04-15 08:46:55,683 INFO L290 TraceCheckUtils]: 2: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,683 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8389#true} {8389#true} #103#return; {8389#true} is VALID [2022-04-15 08:46:55,683 INFO L272 TraceCheckUtils]: 4: Hoare triple {8389#true} call #t~ret6 := main(); {8389#true} is VALID [2022-04-15 08:46:55,683 INFO L290 TraceCheckUtils]: 5: Hoare triple {8389#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L272 TraceCheckUtils]: 6: Hoare triple {8389#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L290 TraceCheckUtils]: 7: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L290 TraceCheckUtils]: 8: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L290 TraceCheckUtils]: 9: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {8389#true} {8389#true} #79#return; {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L290 TraceCheckUtils]: 11: Hoare triple {8389#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L272 TraceCheckUtils]: 12: Hoare triple {8389#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L290 TraceCheckUtils]: 13: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L290 TraceCheckUtils]: 14: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L290 TraceCheckUtils]: 15: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {8389#true} {8389#true} #81#return; {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L272 TraceCheckUtils]: 17: Hoare triple {8389#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,684 INFO L290 TraceCheckUtils]: 18: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,685 INFO L290 TraceCheckUtils]: 19: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,685 INFO L290 TraceCheckUtils]: 20: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,685 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {8389#true} {8389#true} #83#return; {8389#true} is VALID [2022-04-15 08:46:55,685 INFO L272 TraceCheckUtils]: 22: Hoare triple {8389#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,685 INFO L290 TraceCheckUtils]: 23: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,685 INFO L290 TraceCheckUtils]: 24: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,685 INFO L290 TraceCheckUtils]: 25: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,685 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {8389#true} {8389#true} #85#return; {8389#true} is VALID [2022-04-15 08:46:55,686 INFO L290 TraceCheckUtils]: 27: Hoare triple {8389#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,686 INFO L272 TraceCheckUtils]: 28: Hoare triple {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,686 INFO L290 TraceCheckUtils]: 29: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,686 INFO L290 TraceCheckUtils]: 30: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,686 INFO L290 TraceCheckUtils]: 31: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,686 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {8389#true} {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #87#return; {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,687 INFO L272 TraceCheckUtils]: 33: Hoare triple {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,687 INFO L290 TraceCheckUtils]: 34: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,687 INFO L290 TraceCheckUtils]: 35: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,687 INFO L290 TraceCheckUtils]: 36: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,687 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {8389#true} {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #89#return; {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,688 INFO L290 TraceCheckUtils]: 38: Hoare triple {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,688 INFO L290 TraceCheckUtils]: 39: Hoare triple {8475#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,688 INFO L290 TraceCheckUtils]: 40: Hoare triple {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} assume !false; {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,689 INFO L272 TraceCheckUtils]: 41: Hoare triple {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,689 INFO L290 TraceCheckUtils]: 42: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,689 INFO L290 TraceCheckUtils]: 43: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,689 INFO L290 TraceCheckUtils]: 44: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,689 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {8389#true} {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #91#return; {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,689 INFO L272 TraceCheckUtils]: 46: Hoare triple {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,690 INFO L290 TraceCheckUtils]: 47: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,690 INFO L290 TraceCheckUtils]: 48: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,690 INFO L290 TraceCheckUtils]: 49: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,690 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {8389#true} {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #93#return; {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,690 INFO L272 TraceCheckUtils]: 51: Hoare triple {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,690 INFO L290 TraceCheckUtils]: 52: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,691 INFO L290 TraceCheckUtils]: 53: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,691 INFO L290 TraceCheckUtils]: 54: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,691 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {8389#true} {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #95#return; {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,691 INFO L272 TraceCheckUtils]: 56: Hoare triple {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,691 INFO L290 TraceCheckUtils]: 57: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,691 INFO L290 TraceCheckUtils]: 58: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,692 INFO L290 TraceCheckUtils]: 59: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,692 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {8389#true} {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #97#return; {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,693 INFO L290 TraceCheckUtils]: 61: Hoare triple {8512#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,693 INFO L290 TraceCheckUtils]: 62: Hoare triple {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} assume !false; {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,693 INFO L272 TraceCheckUtils]: 63: Hoare triple {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,693 INFO L290 TraceCheckUtils]: 64: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,693 INFO L290 TraceCheckUtils]: 65: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,693 INFO L290 TraceCheckUtils]: 66: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,694 INFO L284 TraceCheckUtils]: 67: Hoare quadruple {8389#true} {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} #91#return; {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,694 INFO L272 TraceCheckUtils]: 68: Hoare triple {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,694 INFO L290 TraceCheckUtils]: 69: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,694 INFO L290 TraceCheckUtils]: 70: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,694 INFO L290 TraceCheckUtils]: 71: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,695 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {8389#true} {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} #93#return; {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,695 INFO L272 TraceCheckUtils]: 73: Hoare triple {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,695 INFO L290 TraceCheckUtils]: 74: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,695 INFO L290 TraceCheckUtils]: 75: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,695 INFO L290 TraceCheckUtils]: 76: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,696 INFO L284 TraceCheckUtils]: 77: Hoare quadruple {8389#true} {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} #95#return; {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,696 INFO L272 TraceCheckUtils]: 78: Hoare triple {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:55,696 INFO L290 TraceCheckUtils]: 79: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:55,696 INFO L290 TraceCheckUtils]: 80: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:55,696 INFO L290 TraceCheckUtils]: 81: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:55,697 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {8389#true} {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} #97#return; {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,697 INFO L290 TraceCheckUtils]: 83: Hoare triple {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} assume !(~c~0 >= ~b~0); {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:46:55,698 INFO L290 TraceCheckUtils]: 84: Hoare triple {8579#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~x~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~p~0 1))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {8649#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (= main_~q~0 1) (= (+ main_~s~0 1) 0))} is VALID [2022-04-15 08:46:55,698 INFO L290 TraceCheckUtils]: 85: Hoare triple {8649#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (= main_~q~0 1) (= (+ main_~s~0 1) 0))} assume !false; {8649#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (= main_~q~0 1) (= (+ main_~s~0 1) 0))} is VALID [2022-04-15 08:46:55,698 INFO L290 TraceCheckUtils]: 86: Hoare triple {8649#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (= main_~q~0 1) (= (+ main_~s~0 1) 0))} assume !(0 != ~b~0); {8656#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) 0) (= main_~q~0 1) (= (+ main_~s~0 1) 0))} is VALID [2022-04-15 08:46:55,699 INFO L272 TraceCheckUtils]: 87: Hoare triple {8656#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) 0) (= main_~q~0 1) (= (+ main_~s~0 1) 0))} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {8660#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:46:55,699 INFO L290 TraceCheckUtils]: 88: Hoare triple {8660#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {8664#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:46:55,700 INFO L290 TraceCheckUtils]: 89: Hoare triple {8664#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {8390#false} is VALID [2022-04-15 08:46:55,700 INFO L290 TraceCheckUtils]: 90: Hoare triple {8390#false} assume !false; {8390#false} is VALID [2022-04-15 08:46:55,700 INFO L134 CoverageAnalysis]: Checked inductivity of 196 backedges. 16 proven. 8 refuted. 0 times theorem prover too weak. 172 trivial. 0 not checked. [2022-04-15 08:46:55,700 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:46:56,143 INFO L290 TraceCheckUtils]: 90: Hoare triple {8390#false} assume !false; {8390#false} is VALID [2022-04-15 08:46:56,144 INFO L290 TraceCheckUtils]: 89: Hoare triple {8664#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {8390#false} is VALID [2022-04-15 08:46:56,144 INFO L290 TraceCheckUtils]: 88: Hoare triple {8660#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {8664#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:46:56,145 INFO L272 TraceCheckUtils]: 87: Hoare triple {8680#(= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0)} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {8660#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:46:56,145 INFO L290 TraceCheckUtils]: 86: Hoare triple {8684#(or (not (= main_~b~0 0)) (= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0))} assume !(0 != ~b~0); {8680#(= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0)} is VALID [2022-04-15 08:46:56,145 INFO L290 TraceCheckUtils]: 85: Hoare triple {8684#(or (not (= main_~b~0 0)) (= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0))} assume !false; {8684#(or (not (= main_~b~0 0)) (= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0))} is VALID [2022-04-15 08:46:57,416 INFO L290 TraceCheckUtils]: 84: Hoare triple {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {8684#(or (not (= main_~b~0 0)) (= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0))} is VALID [2022-04-15 08:46:57,417 INFO L290 TraceCheckUtils]: 83: Hoare triple {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} assume !(~c~0 >= ~b~0); {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:46:57,418 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {8389#true} {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} #97#return; {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:46:57,418 INFO L290 TraceCheckUtils]: 81: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,418 INFO L290 TraceCheckUtils]: 80: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,418 INFO L290 TraceCheckUtils]: 79: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,418 INFO L272 TraceCheckUtils]: 78: Hoare triple {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,419 INFO L284 TraceCheckUtils]: 77: Hoare quadruple {8389#true} {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} #95#return; {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:46:57,419 INFO L290 TraceCheckUtils]: 76: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,419 INFO L290 TraceCheckUtils]: 75: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,419 INFO L290 TraceCheckUtils]: 74: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,419 INFO L272 TraceCheckUtils]: 73: Hoare triple {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,428 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {8389#true} {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} #93#return; {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:46:57,428 INFO L290 TraceCheckUtils]: 71: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,428 INFO L290 TraceCheckUtils]: 70: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,428 INFO L290 TraceCheckUtils]: 69: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,429 INFO L272 TraceCheckUtils]: 68: Hoare triple {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,429 INFO L284 TraceCheckUtils]: 67: Hoare quadruple {8389#true} {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} #91#return; {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:46:57,429 INFO L290 TraceCheckUtils]: 66: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,429 INFO L290 TraceCheckUtils]: 65: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,429 INFO L290 TraceCheckUtils]: 64: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,429 INFO L272 TraceCheckUtils]: 63: Hoare triple {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,430 INFO L290 TraceCheckUtils]: 62: Hoare triple {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} assume !false; {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:46:57,608 INFO L290 TraceCheckUtils]: 61: Hoare triple {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {8691#(or (not (= main_~c~0 0)) (= (+ (* main_~k~0 main_~y~0 main_~s~0) (* main_~q~0 main_~k~0 main_~x~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))))} is VALID [2022-04-15 08:46:57,609 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {8389#true} {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} #97#return; {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,610 INFO L290 TraceCheckUtils]: 59: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,610 INFO L290 TraceCheckUtils]: 58: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,610 INFO L290 TraceCheckUtils]: 57: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,610 INFO L272 TraceCheckUtils]: 56: Hoare triple {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,610 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {8389#true} {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} #95#return; {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,610 INFO L290 TraceCheckUtils]: 54: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,611 INFO L290 TraceCheckUtils]: 53: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,611 INFO L290 TraceCheckUtils]: 52: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,611 INFO L272 TraceCheckUtils]: 51: Hoare triple {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,611 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {8389#true} {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} #93#return; {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,611 INFO L290 TraceCheckUtils]: 49: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,611 INFO L290 TraceCheckUtils]: 48: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,612 INFO L290 TraceCheckUtils]: 47: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,612 INFO L272 TraceCheckUtils]: 46: Hoare triple {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,612 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {8389#true} {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} #91#return; {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,612 INFO L290 TraceCheckUtils]: 44: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,612 INFO L290 TraceCheckUtils]: 43: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,612 INFO L290 TraceCheckUtils]: 42: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,613 INFO L272 TraceCheckUtils]: 41: Hoare triple {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,613 INFO L290 TraceCheckUtils]: 40: Hoare triple {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} assume !false; {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,613 INFO L290 TraceCheckUtils]: 39: Hoare triple {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {8761#(or (= (+ (* (+ main_~k~0 1) main_~q~0 main_~x~0) (* (+ main_~k~0 1) main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~c~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,614 INFO L290 TraceCheckUtils]: 38: Hoare triple {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} assume !false; {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,614 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {8389#true} {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} #89#return; {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,615 INFO L290 TraceCheckUtils]: 36: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,615 INFO L290 TraceCheckUtils]: 35: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,615 INFO L290 TraceCheckUtils]: 34: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,615 INFO L272 TraceCheckUtils]: 33: Hoare triple {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,615 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {8389#true} {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} #87#return; {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,615 INFO L290 TraceCheckUtils]: 31: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,616 INFO L290 TraceCheckUtils]: 30: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,616 INFO L290 TraceCheckUtils]: 29: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,616 INFO L272 TraceCheckUtils]: 28: Hoare triple {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,616 INFO L290 TraceCheckUtils]: 27: Hoare triple {8389#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {8828#(or (= (+ (* main_~q~0 main_~x~0 1) (* main_~y~0 main_~s~0 1)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) 0)))} is VALID [2022-04-15 08:46:57,616 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {8389#true} {8389#true} #85#return; {8389#true} is VALID [2022-04-15 08:46:57,616 INFO L290 TraceCheckUtils]: 25: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,616 INFO L290 TraceCheckUtils]: 24: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,616 INFO L290 TraceCheckUtils]: 23: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,616 INFO L272 TraceCheckUtils]: 22: Hoare triple {8389#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {8389#true} {8389#true} #83#return; {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L290 TraceCheckUtils]: 20: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L290 TraceCheckUtils]: 19: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L290 TraceCheckUtils]: 18: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L272 TraceCheckUtils]: 17: Hoare triple {8389#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {8389#true} {8389#true} #81#return; {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L290 TraceCheckUtils]: 15: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L290 TraceCheckUtils]: 14: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L290 TraceCheckUtils]: 13: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L272 TraceCheckUtils]: 12: Hoare triple {8389#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L290 TraceCheckUtils]: 11: Hoare triple {8389#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {8389#true} {8389#true} #79#return; {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L290 TraceCheckUtils]: 9: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,617 INFO L290 TraceCheckUtils]: 8: Hoare triple {8389#true} assume !(0 == ~cond); {8389#true} is VALID [2022-04-15 08:46:57,618 INFO L290 TraceCheckUtils]: 7: Hoare triple {8389#true} ~cond := #in~cond; {8389#true} is VALID [2022-04-15 08:46:57,618 INFO L272 TraceCheckUtils]: 6: Hoare triple {8389#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {8389#true} is VALID [2022-04-15 08:46:57,618 INFO L290 TraceCheckUtils]: 5: Hoare triple {8389#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {8389#true} is VALID [2022-04-15 08:46:57,618 INFO L272 TraceCheckUtils]: 4: Hoare triple {8389#true} call #t~ret6 := main(); {8389#true} is VALID [2022-04-15 08:46:57,618 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {8389#true} {8389#true} #103#return; {8389#true} is VALID [2022-04-15 08:46:57,618 INFO L290 TraceCheckUtils]: 2: Hoare triple {8389#true} assume true; {8389#true} is VALID [2022-04-15 08:46:57,618 INFO L290 TraceCheckUtils]: 1: Hoare triple {8389#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {8389#true} is VALID [2022-04-15 08:46:57,618 INFO L272 TraceCheckUtils]: 0: Hoare triple {8389#true} call ULTIMATE.init(); {8389#true} is VALID [2022-04-15 08:46:57,618 INFO L134 CoverageAnalysis]: Checked inductivity of 196 backedges. 16 proven. 8 refuted. 0 times theorem prover too weak. 172 trivial. 0 not checked. [2022-04-15 08:46:57,618 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:46:57,619 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [178685770] [2022-04-15 08:46:57,619 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:46:57,619 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1830238747] [2022-04-15 08:46:57,619 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1830238747] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:46:57,619 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:46:57,619 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [9, 9] total 14 [2022-04-15 08:46:57,619 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:46:57,619 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [579188483] [2022-04-15 08:46:57,619 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [579188483] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:46:57,619 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:46:57,619 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [9] imperfect sequences [] total 9 [2022-04-15 08:46:57,619 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [341096131] [2022-04-15 08:46:57,619 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:46:57,620 INFO L78 Accepts]: Start accepts. Automaton has has 9 states, 8 states have (on average 2.875) internal successors, (23), 8 states have internal predecessors, (23), 5 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) Word has length 91 [2022-04-15 08:46:57,620 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:46:57,620 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 9 states, 8 states have (on average 2.875) internal successors, (23), 8 states have internal predecessors, (23), 5 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-04-15 08:46:57,662 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 55 edges. 55 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:46:57,663 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 9 states [2022-04-15 08:46:57,663 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:46:57,663 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 9 interpolants. [2022-04-15 08:46:57,663 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=37, Invalid=145, Unknown=0, NotChecked=0, Total=182 [2022-04-15 08:46:57,663 INFO L87 Difference]: Start difference. First operand 138 states and 181 transitions. Second operand has 9 states, 8 states have (on average 2.875) internal successors, (23), 8 states have internal predecessors, (23), 5 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-04-15 08:46:58,901 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:46:58,901 INFO L93 Difference]: Finished difference Result 165 states and 217 transitions. [2022-04-15 08:46:58,901 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 9 states. [2022-04-15 08:46:58,901 INFO L78 Accepts]: Start accepts. Automaton has has 9 states, 8 states have (on average 2.875) internal successors, (23), 8 states have internal predecessors, (23), 5 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) Word has length 91 [2022-04-15 08:46:58,901 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:46:58,901 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 9 states, 8 states have (on average 2.875) internal successors, (23), 8 states have internal predecessors, (23), 5 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-04-15 08:46:58,902 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 105 transitions. [2022-04-15 08:46:58,903 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 9 states, 8 states have (on average 2.875) internal successors, (23), 8 states have internal predecessors, (23), 5 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-04-15 08:46:58,904 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 105 transitions. [2022-04-15 08:46:58,904 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 9 states and 105 transitions. [2022-04-15 08:46:58,992 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 105 edges. 105 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:46:58,995 INFO L225 Difference]: With dead ends: 165 [2022-04-15 08:46:58,995 INFO L226 Difference]: Without dead ends: 162 [2022-04-15 08:46:58,995 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 185 GetRequests, 168 SyntacticMatches, 1 SemanticMatches, 16 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 14 ImplicationChecksByTransitivity, 0.2s TimeCoverageRelationStatistics Valid=63, Invalid=243, Unknown=0, NotChecked=0, Total=306 [2022-04-15 08:46:58,996 INFO L913 BasicCegarLoop]: 57 mSDtfsCounter, 19 mSDsluCounter, 218 mSDsCounter, 0 mSdLazyCounter, 323 mSolverCounterSat, 19 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.3s Time, 0 mProtectedPredicate, 0 mProtectedAction, 27 SdHoareTripleChecker+Valid, 275 SdHoareTripleChecker+Invalid, 342 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 19 IncrementalHoareTripleChecker+Valid, 323 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.3s IncrementalHoareTripleChecker+Time [2022-04-15 08:46:58,996 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [27 Valid, 275 Invalid, 342 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [19 Valid, 323 Invalid, 0 Unknown, 0 Unchecked, 0.3s Time] [2022-04-15 08:46:58,996 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 162 states. [2022-04-15 08:46:59,251 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 162 to 161. [2022-04-15 08:46:59,252 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:46:59,252 INFO L82 GeneralOperation]: Start isEquivalent. First operand 162 states. Second operand has 161 states, 90 states have (on average 1.1666666666666667) internal successors, (105), 92 states have internal predecessors, (105), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:46:59,252 INFO L74 IsIncluded]: Start isIncluded. First operand 162 states. Second operand has 161 states, 90 states have (on average 1.1666666666666667) internal successors, (105), 92 states have internal predecessors, (105), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:46:59,252 INFO L87 Difference]: Start difference. First operand 162 states. Second operand has 161 states, 90 states have (on average 1.1666666666666667) internal successors, (105), 92 states have internal predecessors, (105), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:46:59,255 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:46:59,255 INFO L93 Difference]: Finished difference Result 162 states and 213 transitions. [2022-04-15 08:46:59,256 INFO L276 IsEmpty]: Start isEmpty. Operand 162 states and 213 transitions. [2022-04-15 08:46:59,256 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:46:59,256 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:46:59,256 INFO L74 IsIncluded]: Start isIncluded. First operand has 161 states, 90 states have (on average 1.1666666666666667) internal successors, (105), 92 states have internal predecessors, (105), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) Second operand 162 states. [2022-04-15 08:46:59,256 INFO L87 Difference]: Start difference. First operand has 161 states, 90 states have (on average 1.1666666666666667) internal successors, (105), 92 states have internal predecessors, (105), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) Second operand 162 states. [2022-04-15 08:46:59,259 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:46:59,259 INFO L93 Difference]: Finished difference Result 162 states and 213 transitions. [2022-04-15 08:46:59,259 INFO L276 IsEmpty]: Start isEmpty. Operand 162 states and 213 transitions. [2022-04-15 08:46:59,260 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:46:59,260 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:46:59,260 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:46:59,260 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:46:59,260 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 161 states, 90 states have (on average 1.1666666666666667) internal successors, (105), 92 states have internal predecessors, (105), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:46:59,263 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 161 states to 161 states and 212 transitions. [2022-04-15 08:46:59,263 INFO L78 Accepts]: Start accepts. Automaton has 161 states and 212 transitions. Word has length 91 [2022-04-15 08:46:59,263 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:46:59,263 INFO L478 AbstractCegarLoop]: Abstraction has 161 states and 212 transitions. [2022-04-15 08:46:59,264 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 9 states, 8 states have (on average 2.875) internal successors, (23), 8 states have internal predecessors, (23), 5 states have call successors, (17), 2 states have call predecessors, (17), 1 states have return successors, (15), 4 states have call predecessors, (15), 4 states have call successors, (15) [2022-04-15 08:46:59,264 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 161 states and 212 transitions. [2022-04-15 08:46:59,581 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 212 edges. 212 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:46:59,581 INFO L276 IsEmpty]: Start isEmpty. Operand 161 states and 212 transitions. [2022-04-15 08:46:59,582 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 101 [2022-04-15 08:46:59,582 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:46:59,582 INFO L499 BasicCegarLoop]: trace histogram [10, 9, 9, 6, 6, 6, 3, 3, 3, 3, 3, 3, 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] [2022-04-15 08:46:59,599 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (12)] Ended with exit code 0 [2022-04-15 08:46:59,791 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 12 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable11 [2022-04-15 08:46:59,791 INFO L403 AbstractCegarLoop]: === Iteration 13 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:46:59,792 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:46:59,792 INFO L85 PathProgramCache]: Analyzing trace with hash -663071842, now seen corresponding path program 7 times [2022-04-15 08:46:59,792 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:46:59,792 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [770487921] [2022-04-15 08:46:59,792 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:46:59,792 INFO L85 PathProgramCache]: Analyzing trace with hash -663071842, now seen corresponding path program 8 times [2022-04-15 08:46:59,792 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:46:59,792 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [460007209] [2022-04-15 08:46:59,793 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:46:59,793 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:46:59,802 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:46:59,802 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [889055010] [2022-04-15 08:46:59,802 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:46:59,802 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:46:59,802 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:46:59,803 INFO L229 MonitoredProcess]: Starting monitored process 13 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:46:59,804 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (13)] Waiting until timeout for monitored process [2022-04-15 08:46:59,847 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:46:59,848 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:46:59,848 INFO L263 TraceCheckSpWp]: Trace formula consists of 262 conjuncts, 5 conjunts are in the unsatisfiable core [2022-04-15 08:46:59,860 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:46:59,863 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:47:00,088 INFO L272 TraceCheckUtils]: 0: Hoare triple {9932#true} call ULTIMATE.init(); {9932#true} is VALID [2022-04-15 08:47:00,088 INFO L290 TraceCheckUtils]: 1: Hoare triple {9932#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {9932#true} is VALID [2022-04-15 08:47:00,088 INFO L290 TraceCheckUtils]: 2: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,088 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {9932#true} {9932#true} #103#return; {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L272 TraceCheckUtils]: 4: Hoare triple {9932#true} call #t~ret6 := main(); {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L290 TraceCheckUtils]: 5: Hoare triple {9932#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L272 TraceCheckUtils]: 6: Hoare triple {9932#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L290 TraceCheckUtils]: 7: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L290 TraceCheckUtils]: 8: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L290 TraceCheckUtils]: 9: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {9932#true} {9932#true} #79#return; {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L290 TraceCheckUtils]: 11: Hoare triple {9932#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L272 TraceCheckUtils]: 12: Hoare triple {9932#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L290 TraceCheckUtils]: 13: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L290 TraceCheckUtils]: 14: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L290 TraceCheckUtils]: 15: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {9932#true} {9932#true} #81#return; {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L272 TraceCheckUtils]: 17: Hoare triple {9932#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,089 INFO L290 TraceCheckUtils]: 18: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L290 TraceCheckUtils]: 19: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L290 TraceCheckUtils]: 20: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {9932#true} {9932#true} #83#return; {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L272 TraceCheckUtils]: 22: Hoare triple {9932#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L290 TraceCheckUtils]: 23: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L290 TraceCheckUtils]: 24: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L290 TraceCheckUtils]: 25: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {9932#true} {9932#true} #85#return; {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L290 TraceCheckUtils]: 27: Hoare triple {9932#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L272 TraceCheckUtils]: 28: Hoare triple {9932#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L290 TraceCheckUtils]: 29: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L290 TraceCheckUtils]: 30: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L290 TraceCheckUtils]: 31: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,090 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {9932#true} {9932#true} #87#return; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L272 TraceCheckUtils]: 33: Hoare triple {9932#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L290 TraceCheckUtils]: 34: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L290 TraceCheckUtils]: 35: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L290 TraceCheckUtils]: 36: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {9932#true} {9932#true} #89#return; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L290 TraceCheckUtils]: 38: Hoare triple {9932#true} assume !false; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L290 TraceCheckUtils]: 39: Hoare triple {9932#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L290 TraceCheckUtils]: 40: Hoare triple {9932#true} assume !false; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L272 TraceCheckUtils]: 41: Hoare triple {9932#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L290 TraceCheckUtils]: 42: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L290 TraceCheckUtils]: 43: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L290 TraceCheckUtils]: 44: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {9932#true} {9932#true} #91#return; {9932#true} is VALID [2022-04-15 08:47:00,091 INFO L272 TraceCheckUtils]: 46: Hoare triple {9932#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L290 TraceCheckUtils]: 47: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L290 TraceCheckUtils]: 48: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L290 TraceCheckUtils]: 49: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {9932#true} {9932#true} #93#return; {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L272 TraceCheckUtils]: 51: Hoare triple {9932#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L290 TraceCheckUtils]: 52: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L290 TraceCheckUtils]: 53: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L290 TraceCheckUtils]: 54: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {9932#true} {9932#true} #95#return; {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L272 TraceCheckUtils]: 56: Hoare triple {9932#true} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L290 TraceCheckUtils]: 57: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L290 TraceCheckUtils]: 58: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L290 TraceCheckUtils]: 59: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,092 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {9932#true} {9932#true} #97#return; {9932#true} is VALID [2022-04-15 08:47:00,093 INFO L290 TraceCheckUtils]: 61: Hoare triple {9932#true} assume !(~c~0 >= ~b~0); {10120#(not (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:47:00,093 INFO L290 TraceCheckUtils]: 62: Hoare triple {10120#(not (<= main_~b~0 main_~c~0))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {10124#(< main_~b~0 main_~a~0)} is VALID [2022-04-15 08:47:00,094 INFO L290 TraceCheckUtils]: 63: Hoare triple {10124#(< main_~b~0 main_~a~0)} assume !false; {10124#(< main_~b~0 main_~a~0)} is VALID [2022-04-15 08:47:00,094 INFO L290 TraceCheckUtils]: 64: Hoare triple {10124#(< main_~b~0 main_~a~0)} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {10131#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:47:00,094 INFO L290 TraceCheckUtils]: 65: Hoare triple {10131#(< main_~b~0 main_~c~0)} assume !false; {10131#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:47:00,094 INFO L272 TraceCheckUtils]: 66: Hoare triple {10131#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,094 INFO L290 TraceCheckUtils]: 67: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,094 INFO L290 TraceCheckUtils]: 68: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,095 INFO L290 TraceCheckUtils]: 69: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,095 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {9932#true} {10131#(< main_~b~0 main_~c~0)} #91#return; {10131#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:47:00,095 INFO L272 TraceCheckUtils]: 71: Hoare triple {10131#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,095 INFO L290 TraceCheckUtils]: 72: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,095 INFO L290 TraceCheckUtils]: 73: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,095 INFO L290 TraceCheckUtils]: 74: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,096 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {9932#true} {10131#(< main_~b~0 main_~c~0)} #93#return; {10131#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:47:00,096 INFO L272 TraceCheckUtils]: 76: Hoare triple {10131#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,096 INFO L290 TraceCheckUtils]: 77: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,096 INFO L290 TraceCheckUtils]: 78: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,096 INFO L290 TraceCheckUtils]: 79: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,097 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {9932#true} {10131#(< main_~b~0 main_~c~0)} #95#return; {10131#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:47:00,097 INFO L272 TraceCheckUtils]: 81: Hoare triple {10131#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {9932#true} is VALID [2022-04-15 08:47:00,097 INFO L290 TraceCheckUtils]: 82: Hoare triple {9932#true} ~cond := #in~cond; {9932#true} is VALID [2022-04-15 08:47:00,097 INFO L290 TraceCheckUtils]: 83: Hoare triple {9932#true} assume !(0 == ~cond); {9932#true} is VALID [2022-04-15 08:47:00,097 INFO L290 TraceCheckUtils]: 84: Hoare triple {9932#true} assume true; {9932#true} is VALID [2022-04-15 08:47:00,097 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {9932#true} {10131#(< main_~b~0 main_~c~0)} #97#return; {10131#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:47:00,098 INFO L290 TraceCheckUtils]: 86: Hoare triple {10131#(< main_~b~0 main_~c~0)} assume !(~c~0 >= ~b~0); {9933#false} is VALID [2022-04-15 08:47:00,098 INFO L290 TraceCheckUtils]: 87: Hoare triple {9933#false} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {9933#false} is VALID [2022-04-15 08:47:00,098 INFO L290 TraceCheckUtils]: 88: Hoare triple {9933#false} assume !false; {9933#false} is VALID [2022-04-15 08:47:00,098 INFO L290 TraceCheckUtils]: 89: Hoare triple {9933#false} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {9933#false} is VALID [2022-04-15 08:47:00,098 INFO L290 TraceCheckUtils]: 90: Hoare triple {9933#false} assume !false; {9933#false} is VALID [2022-04-15 08:47:00,098 INFO L272 TraceCheckUtils]: 91: Hoare triple {9933#false} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {9933#false} is VALID [2022-04-15 08:47:00,098 INFO L290 TraceCheckUtils]: 92: Hoare triple {9933#false} ~cond := #in~cond; {9933#false} is VALID [2022-04-15 08:47:00,098 INFO L290 TraceCheckUtils]: 93: Hoare triple {9933#false} assume !(0 == ~cond); {9933#false} is VALID [2022-04-15 08:47:00,098 INFO L290 TraceCheckUtils]: 94: Hoare triple {9933#false} assume true; {9933#false} is VALID [2022-04-15 08:47:00,099 INFO L284 TraceCheckUtils]: 95: Hoare quadruple {9933#false} {9933#false} #91#return; {9933#false} is VALID [2022-04-15 08:47:00,099 INFO L272 TraceCheckUtils]: 96: Hoare triple {9933#false} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {9933#false} is VALID [2022-04-15 08:47:00,099 INFO L290 TraceCheckUtils]: 97: Hoare triple {9933#false} ~cond := #in~cond; {9933#false} is VALID [2022-04-15 08:47:00,099 INFO L290 TraceCheckUtils]: 98: Hoare triple {9933#false} assume 0 == ~cond; {9933#false} is VALID [2022-04-15 08:47:00,099 INFO L290 TraceCheckUtils]: 99: Hoare triple {9933#false} assume !false; {9933#false} is VALID [2022-04-15 08:47:00,099 INFO L134 CoverageAnalysis]: Checked inductivity of 241 backedges. 67 proven. 0 refuted. 0 times theorem prover too weak. 174 trivial. 0 not checked. [2022-04-15 08:47:00,099 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-04-15 08:47:00,099 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:47:00,099 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [460007209] [2022-04-15 08:47:00,099 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:47:00,100 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [889055010] [2022-04-15 08:47:00,100 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [889055010] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:47:00,100 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:47:00,100 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-15 08:47:00,100 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:47:00,100 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [770487921] [2022-04-15 08:47:00,100 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [770487921] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:47:00,100 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:47:00,100 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-04-15 08:47:00,100 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [752578177] [2022-04-15 08:47:00,100 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:47:00,101 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 5.8) internal successors, (29), 5 states have internal predecessors, (29), 3 states have call successors, (18), 2 states have call predecessors, (18), 2 states have return successors, (16), 3 states have call predecessors, (16), 3 states have call successors, (16) Word has length 100 [2022-04-15 08:47:00,101 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:47:00,101 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 5 states, 5 states have (on average 5.8) internal successors, (29), 5 states have internal predecessors, (29), 3 states have call successors, (18), 2 states have call predecessors, (18), 2 states have return successors, (16), 3 states have call predecessors, (16), 3 states have call successors, (16) [2022-04-15 08:47:00,147 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 63 edges. 63 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:47:00,147 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-04-15 08:47:00,147 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:47:00,147 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-04-15 08:47:00,147 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=7, Invalid=13, Unknown=0, NotChecked=0, Total=20 [2022-04-15 08:47:00,148 INFO L87 Difference]: Start difference. First operand 161 states and 212 transitions. Second operand has 5 states, 5 states have (on average 5.8) internal successors, (29), 5 states have internal predecessors, (29), 3 states have call successors, (18), 2 states have call predecessors, (18), 2 states have return successors, (16), 3 states have call predecessors, (16), 3 states have call successors, (16) [2022-04-15 08:47:00,648 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:47:00,648 INFO L93 Difference]: Finished difference Result 209 states and 286 transitions. [2022-04-15 08:47:00,648 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 6 states. [2022-04-15 08:47:00,648 INFO L78 Accepts]: Start accepts. Automaton has has 5 states, 5 states have (on average 5.8) internal successors, (29), 5 states have internal predecessors, (29), 3 states have call successors, (18), 2 states have call predecessors, (18), 2 states have return successors, (16), 3 states have call predecessors, (16), 3 states have call successors, (16) Word has length 100 [2022-04-15 08:47:00,648 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:47:00,649 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 5.8) internal successors, (29), 5 states have internal predecessors, (29), 3 states have call successors, (18), 2 states have call predecessors, (18), 2 states have return successors, (16), 3 states have call predecessors, (16), 3 states have call successors, (16) [2022-04-15 08:47:00,650 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 94 transitions. [2022-04-15 08:47:00,650 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 5 states, 5 states have (on average 5.8) internal successors, (29), 5 states have internal predecessors, (29), 3 states have call successors, (18), 2 states have call predecessors, (18), 2 states have return successors, (16), 3 states have call predecessors, (16), 3 states have call successors, (16) [2022-04-15 08:47:00,650 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 94 transitions. [2022-04-15 08:47:00,651 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 6 states and 94 transitions. [2022-04-15 08:47:00,719 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 94 edges. 94 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:47:00,722 INFO L225 Difference]: With dead ends: 209 [2022-04-15 08:47:00,722 INFO L226 Difference]: Without dead ends: 164 [2022-04-15 08:47:00,722 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 101 GetRequests, 96 SyntacticMatches, 0 SemanticMatches, 5 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 1 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=15, Invalid=27, Unknown=0, NotChecked=0, Total=42 [2022-04-15 08:47:00,723 INFO L913 BasicCegarLoop]: 58 mSDtfsCounter, 6 mSDsluCounter, 105 mSDsCounter, 0 mSdLazyCounter, 69 mSolverCounterSat, 5 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 11 SdHoareTripleChecker+Valid, 163 SdHoareTripleChecker+Invalid, 74 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 5 IncrementalHoareTripleChecker+Valid, 69 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-04-15 08:47:00,723 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [11 Valid, 163 Invalid, 74 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [5 Valid, 69 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-04-15 08:47:00,723 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 164 states. [2022-04-15 08:47:00,995 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 164 to 155. [2022-04-15 08:47:00,995 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:47:00,996 INFO L82 GeneralOperation]: Start isEquivalent. First operand 164 states. Second operand has 155 states, 84 states have (on average 1.119047619047619) internal successors, (94), 86 states have internal predecessors, (94), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:47:00,996 INFO L74 IsIncluded]: Start isIncluded. First operand 164 states. Second operand has 155 states, 84 states have (on average 1.119047619047619) internal successors, (94), 86 states have internal predecessors, (94), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:47:00,996 INFO L87 Difference]: Start difference. First operand 164 states. Second operand has 155 states, 84 states have (on average 1.119047619047619) internal successors, (94), 86 states have internal predecessors, (94), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:47:00,999 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:47:00,999 INFO L93 Difference]: Finished difference Result 164 states and 215 transitions. [2022-04-15 08:47:00,999 INFO L276 IsEmpty]: Start isEmpty. Operand 164 states and 215 transitions. [2022-04-15 08:47:01,000 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:47:01,000 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:47:01,000 INFO L74 IsIncluded]: Start isIncluded. First operand has 155 states, 84 states have (on average 1.119047619047619) internal successors, (94), 86 states have internal predecessors, (94), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) Second operand 164 states. [2022-04-15 08:47:01,000 INFO L87 Difference]: Start difference. First operand has 155 states, 84 states have (on average 1.119047619047619) internal successors, (94), 86 states have internal predecessors, (94), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) Second operand 164 states. [2022-04-15 08:47:01,003 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:47:01,003 INFO L93 Difference]: Finished difference Result 164 states and 215 transitions. [2022-04-15 08:47:01,003 INFO L276 IsEmpty]: Start isEmpty. Operand 164 states and 215 transitions. [2022-04-15 08:47:01,004 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:47:01,004 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:47:01,004 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:47:01,004 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:47:01,004 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 155 states, 84 states have (on average 1.119047619047619) internal successors, (94), 86 states have internal predecessors, (94), 55 states have call successors, (55), 16 states have call predecessors, (55), 15 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:47:01,007 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 155 states to 155 states and 201 transitions. [2022-04-15 08:47:01,007 INFO L78 Accepts]: Start accepts. Automaton has 155 states and 201 transitions. Word has length 100 [2022-04-15 08:47:01,007 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:47:01,007 INFO L478 AbstractCegarLoop]: Abstraction has 155 states and 201 transitions. [2022-04-15 08:47:01,007 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 5.8) internal successors, (29), 5 states have internal predecessors, (29), 3 states have call successors, (18), 2 states have call predecessors, (18), 2 states have return successors, (16), 3 states have call predecessors, (16), 3 states have call successors, (16) [2022-04-15 08:47:01,007 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 155 states and 201 transitions. [2022-04-15 08:47:01,327 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 201 edges. 201 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:47:01,327 INFO L276 IsEmpty]: Start isEmpty. Operand 155 states and 201 transitions. [2022-04-15 08:47:01,328 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 108 [2022-04-15 08:47:01,328 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:47:01,328 INFO L499 BasicCegarLoop]: trace histogram [12, 11, 11, 6, 6, 6, 3, 3, 3, 3, 3, 3, 3, 3, 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] [2022-04-15 08:47:01,343 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (13)] Ended with exit code 0 [2022-04-15 08:47:01,534 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 13 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable12 [2022-04-15 08:47:01,534 INFO L403 AbstractCegarLoop]: === Iteration 14 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:47:01,535 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:47:01,535 INFO L85 PathProgramCache]: Analyzing trace with hash -428114403, now seen corresponding path program 1 times [2022-04-15 08:47:01,535 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:47:01,535 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1509767758] [2022-04-15 08:47:01,535 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:47:01,535 INFO L85 PathProgramCache]: Analyzing trace with hash -428114403, now seen corresponding path program 2 times [2022-04-15 08:47:01,535 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:47:01,535 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [284658586] [2022-04-15 08:47:01,536 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:47:01,536 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:47:01,547 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:47:01,547 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [58825112] [2022-04-15 08:47:01,547 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:47:01,547 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:47:01,547 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:47:01,548 INFO L229 MonitoredProcess]: Starting monitored process 14 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:47:01,549 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (14)] Waiting until timeout for monitored process [2022-04-15 08:47:01,597 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:47:01,597 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:47:01,598 INFO L263 TraceCheckSpWp]: Trace formula consists of 264 conjuncts, 66 conjunts are in the unsatisfiable core [2022-04-15 08:47:01,616 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:47:01,617 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:47:03,073 INFO L272 TraceCheckUtils]: 0: Hoare triple {11296#true} call ULTIMATE.init(); {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L290 TraceCheckUtils]: 1: Hoare triple {11296#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L290 TraceCheckUtils]: 2: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {11296#true} {11296#true} #103#return; {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L272 TraceCheckUtils]: 4: Hoare triple {11296#true} call #t~ret6 := main(); {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L290 TraceCheckUtils]: 5: Hoare triple {11296#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L272 TraceCheckUtils]: 6: Hoare triple {11296#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L290 TraceCheckUtils]: 7: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L290 TraceCheckUtils]: 8: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L290 TraceCheckUtils]: 9: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,073 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {11296#true} {11296#true} #79#return; {11296#true} is VALID [2022-04-15 08:47:03,074 INFO L290 TraceCheckUtils]: 11: Hoare triple {11296#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {11296#true} is VALID [2022-04-15 08:47:03,074 INFO L272 TraceCheckUtils]: 12: Hoare triple {11296#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,074 INFO L290 TraceCheckUtils]: 13: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,074 INFO L290 TraceCheckUtils]: 14: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,074 INFO L290 TraceCheckUtils]: 15: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,074 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {11296#true} {11296#true} #81#return; {11296#true} is VALID [2022-04-15 08:47:03,074 INFO L272 TraceCheckUtils]: 17: Hoare triple {11296#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,074 INFO L290 TraceCheckUtils]: 18: Hoare triple {11296#true} ~cond := #in~cond; {11355#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-04-15 08:47:03,075 INFO L290 TraceCheckUtils]: 19: Hoare triple {11355#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond); {11359#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:47:03,075 INFO L290 TraceCheckUtils]: 20: Hoare triple {11359#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {11359#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:47:03,075 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {11359#(not (= |assume_abort_if_not_#in~cond| 0))} {11296#true} #83#return; {11366#(<= 1 main_~x~0)} is VALID [2022-04-15 08:47:03,075 INFO L272 TraceCheckUtils]: 22: Hoare triple {11366#(<= 1 main_~x~0)} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,075 INFO L290 TraceCheckUtils]: 23: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,075 INFO L290 TraceCheckUtils]: 24: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,076 INFO L290 TraceCheckUtils]: 25: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,076 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {11296#true} {11366#(<= 1 main_~x~0)} #85#return; {11366#(<= 1 main_~x~0)} is VALID [2022-04-15 08:47:03,076 INFO L290 TraceCheckUtils]: 27: Hoare triple {11366#(<= 1 main_~x~0)} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,076 INFO L272 TraceCheckUtils]: 28: Hoare triple {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,077 INFO L290 TraceCheckUtils]: 29: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,077 INFO L290 TraceCheckUtils]: 30: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,077 INFO L290 TraceCheckUtils]: 31: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,077 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {11296#true} {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #87#return; {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,077 INFO L272 TraceCheckUtils]: 33: Hoare triple {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,077 INFO L290 TraceCheckUtils]: 34: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,078 INFO L290 TraceCheckUtils]: 35: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,078 INFO L290 TraceCheckUtils]: 36: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,078 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {11296#true} {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #89#return; {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,079 INFO L290 TraceCheckUtils]: 38: Hoare triple {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,079 INFO L290 TraceCheckUtils]: 39: Hoare triple {11385#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,079 INFO L290 TraceCheckUtils]: 40: Hoare triple {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,080 INFO L272 TraceCheckUtils]: 41: Hoare triple {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,080 INFO L290 TraceCheckUtils]: 42: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,080 INFO L290 TraceCheckUtils]: 43: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,080 INFO L290 TraceCheckUtils]: 44: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,081 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {11296#true} {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,081 INFO L272 TraceCheckUtils]: 46: Hoare triple {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,081 INFO L290 TraceCheckUtils]: 47: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,081 INFO L290 TraceCheckUtils]: 48: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,081 INFO L290 TraceCheckUtils]: 49: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,082 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {11296#true} {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,082 INFO L272 TraceCheckUtils]: 51: Hoare triple {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,082 INFO L290 TraceCheckUtils]: 52: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,082 INFO L290 TraceCheckUtils]: 53: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,082 INFO L290 TraceCheckUtils]: 54: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,083 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {11296#true} {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #95#return; {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,083 INFO L272 TraceCheckUtils]: 56: Hoare triple {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,083 INFO L290 TraceCheckUtils]: 57: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,083 INFO L290 TraceCheckUtils]: 58: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,083 INFO L290 TraceCheckUtils]: 59: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,084 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {11296#true} {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #97#return; {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,085 INFO L290 TraceCheckUtils]: 61: Hoare triple {11422#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {11489#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (<= main_~b~0 main_~a~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,085 INFO L290 TraceCheckUtils]: 62: Hoare triple {11489#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (<= main_~b~0 main_~a~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {11489#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (<= main_~b~0 main_~a~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,085 INFO L272 TraceCheckUtils]: 63: Hoare triple {11489#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (<= main_~b~0 main_~a~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,085 INFO L290 TraceCheckUtils]: 64: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,086 INFO L290 TraceCheckUtils]: 65: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,086 INFO L290 TraceCheckUtils]: 66: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,086 INFO L284 TraceCheckUtils]: 67: Hoare quadruple {11296#true} {11489#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (<= main_~b~0 main_~a~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {11489#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (<= main_~b~0 main_~a~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,086 INFO L272 TraceCheckUtils]: 68: Hoare triple {11489#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (<= main_~b~0 main_~a~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,087 INFO L290 TraceCheckUtils]: 69: Hoare triple {11296#true} ~cond := #in~cond; {11514#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:47:03,087 INFO L290 TraceCheckUtils]: 70: Hoare triple {11514#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:47:03,087 INFO L290 TraceCheckUtils]: 71: Hoare triple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:47:03,089 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} {11489#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= (+ (- 1) main_~k~0) 0) (<= main_~b~0 main_~a~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {11525#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 main_~b~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,089 INFO L272 TraceCheckUtils]: 73: Hoare triple {11525#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 main_~b~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,089 INFO L290 TraceCheckUtils]: 74: Hoare triple {11296#true} ~cond := #in~cond; {11514#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:47:03,089 INFO L290 TraceCheckUtils]: 75: Hoare triple {11514#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:47:03,090 INFO L290 TraceCheckUtils]: 76: Hoare triple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:47:03,090 INFO L284 TraceCheckUtils]: 77: Hoare quadruple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} {11525#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 main_~b~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} #95#return; {11525#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 main_~b~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,090 INFO L272 TraceCheckUtils]: 78: Hoare triple {11525#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 main_~b~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,091 INFO L290 TraceCheckUtils]: 79: Hoare triple {11296#true} ~cond := #in~cond; {11514#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:47:03,091 INFO L290 TraceCheckUtils]: 80: Hoare triple {11514#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:47:03,091 INFO L290 TraceCheckUtils]: 81: Hoare triple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:47:03,092 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} {11525#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 main_~b~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} #97#return; {11525#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 main_~b~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,092 INFO L290 TraceCheckUtils]: 83: Hoare triple {11525#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 main_~b~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} assume !(~c~0 >= ~b~0); {11559#(and (= main_~r~0 0) (< main_~c~0 main_~y~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= (+ main_~c~0 main_~y~0) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} is VALID [2022-04-15 08:47:03,093 INFO L290 TraceCheckUtils]: 84: Hoare triple {11559#(and (= main_~r~0 0) (< main_~c~0 main_~y~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= (+ main_~c~0 main_~y~0) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} is VALID [2022-04-15 08:47:03,094 INFO L290 TraceCheckUtils]: 85: Hoare triple {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} assume !false; {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} is VALID [2022-04-15 08:47:03,094 INFO L290 TraceCheckUtils]: 86: Hoare triple {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} is VALID [2022-04-15 08:47:03,095 INFO L290 TraceCheckUtils]: 87: Hoare triple {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} assume !false; {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} is VALID [2022-04-15 08:47:03,095 INFO L272 TraceCheckUtils]: 88: Hoare triple {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,095 INFO L290 TraceCheckUtils]: 89: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,095 INFO L290 TraceCheckUtils]: 90: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,095 INFO L290 TraceCheckUtils]: 91: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,096 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {11296#true} {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} #91#return; {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} is VALID [2022-04-15 08:47:03,096 INFO L272 TraceCheckUtils]: 93: Hoare triple {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,096 INFO L290 TraceCheckUtils]: 94: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:47:03,096 INFO L290 TraceCheckUtils]: 95: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:47:03,096 INFO L290 TraceCheckUtils]: 96: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:47:03,096 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {11296#true} {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} #93#return; {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} is VALID [2022-04-15 08:47:03,097 INFO L272 TraceCheckUtils]: 98: Hoare triple {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:47:03,097 INFO L290 TraceCheckUtils]: 99: Hoare triple {11296#true} ~cond := #in~cond; {11514#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:47:03,097 INFO L290 TraceCheckUtils]: 100: Hoare triple {11514#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:47:03,097 INFO L290 TraceCheckUtils]: 101: Hoare triple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:47:03,098 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} #95#return; {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} is VALID [2022-04-15 08:47:03,100 INFO L272 TraceCheckUtils]: 103: Hoare triple {11563#(and (= (+ main_~x~0 (* (- 1) main_~y~0)) main_~b~0) (< main_~x~0 (* main_~y~0 2)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= (+ main_~s~0 1) 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (<= main_~y~0 main_~x~0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {11621#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:47:03,100 INFO L290 TraceCheckUtils]: 104: Hoare triple {11621#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {11625#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:47:03,100 INFO L290 TraceCheckUtils]: 105: Hoare triple {11625#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {11297#false} is VALID [2022-04-15 08:47:03,100 INFO L290 TraceCheckUtils]: 106: Hoare triple {11297#false} assume !false; {11297#false} is VALID [2022-04-15 08:47:03,101 INFO L134 CoverageAnalysis]: Checked inductivity of 320 backedges. 90 proven. 49 refuted. 0 times theorem prover too weak. 181 trivial. 0 not checked. [2022-04-15 08:47:03,101 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:49:10,638 INFO L290 TraceCheckUtils]: 106: Hoare triple {11297#false} assume !false; {11297#false} is VALID [2022-04-15 08:49:10,638 INFO L290 TraceCheckUtils]: 105: Hoare triple {11625#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {11297#false} is VALID [2022-04-15 08:49:10,639 INFO L290 TraceCheckUtils]: 104: Hoare triple {11621#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {11625#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:49:10,639 INFO L272 TraceCheckUtils]: 103: Hoare triple {11641#(= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {11621#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:49:10,640 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #95#return; {11641#(= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))} is VALID [2022-04-15 08:49:10,641 INFO L290 TraceCheckUtils]: 101: Hoare triple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:10,641 INFO L290 TraceCheckUtils]: 100: Hoare triple {11655#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:10,641 INFO L290 TraceCheckUtils]: 99: Hoare triple {11296#true} ~cond := #in~cond; {11655#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:49:10,642 INFO L272 TraceCheckUtils]: 98: Hoare triple {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:10,642 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {11296#true} {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #93#return; {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:49:10,642 INFO L290 TraceCheckUtils]: 96: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:10,642 INFO L290 TraceCheckUtils]: 95: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:10,643 INFO L290 TraceCheckUtils]: 94: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:10,643 INFO L272 TraceCheckUtils]: 93: Hoare triple {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:10,643 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {11296#true} {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #91#return; {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:49:10,644 INFO L290 TraceCheckUtils]: 91: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:10,644 INFO L290 TraceCheckUtils]: 90: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:10,644 INFO L290 TraceCheckUtils]: 89: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:10,644 INFO L272 TraceCheckUtils]: 88: Hoare triple {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:10,644 INFO L290 TraceCheckUtils]: 87: Hoare triple {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} assume !false; {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:49:10,645 INFO L290 TraceCheckUtils]: 86: Hoare triple {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:49:10,645 INFO L290 TraceCheckUtils]: 85: Hoare triple {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} assume !false; {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:49:12,647 WARN L290 TraceCheckUtils]: 84: Hoare triple {11701#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {11645#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is UNKNOWN [2022-04-15 08:49:12,648 INFO L290 TraceCheckUtils]: 83: Hoare triple {11705#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} assume !(~c~0 >= ~b~0); {11701#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:49:12,649 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} {11709#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} #97#return; {11705#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:49:12,650 INFO L290 TraceCheckUtils]: 81: Hoare triple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:12,650 INFO L290 TraceCheckUtils]: 80: Hoare triple {11655#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:12,650 INFO L290 TraceCheckUtils]: 79: Hoare triple {11296#true} ~cond := #in~cond; {11655#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:49:12,650 INFO L272 TraceCheckUtils]: 78: Hoare triple {11709#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:12,651 INFO L284 TraceCheckUtils]: 77: Hoare quadruple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} {11725#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} #95#return; {11709#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:49:12,652 INFO L290 TraceCheckUtils]: 76: Hoare triple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:12,652 INFO L290 TraceCheckUtils]: 75: Hoare triple {11655#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:12,652 INFO L290 TraceCheckUtils]: 74: Hoare triple {11296#true} ~cond := #in~cond; {11655#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:49:12,652 INFO L272 TraceCheckUtils]: 73: Hoare triple {11725#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:12,653 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} {11741#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} #93#return; {11725#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:49:12,654 INFO L290 TraceCheckUtils]: 71: Hoare triple {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:12,654 INFO L290 TraceCheckUtils]: 70: Hoare triple {11655#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {11518#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:12,654 INFO L290 TraceCheckUtils]: 69: Hoare triple {11296#true} ~cond := #in~cond; {11655#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:49:12,654 INFO L272 TraceCheckUtils]: 68: Hoare triple {11741#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:12,655 INFO L284 TraceCheckUtils]: 67: Hoare quadruple {11296#true} {11741#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} #91#return; {11741#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:49:12,655 INFO L290 TraceCheckUtils]: 66: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:12,655 INFO L290 TraceCheckUtils]: 65: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:12,655 INFO L290 TraceCheckUtils]: 64: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:12,655 INFO L272 TraceCheckUtils]: 63: Hoare triple {11741#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:12,656 INFO L290 TraceCheckUtils]: 62: Hoare triple {11741#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} assume !false; {11741#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:49:14,658 WARN L290 TraceCheckUtils]: 61: Hoare triple {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {11741#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~c~0 (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)) (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~c~0 main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is UNKNOWN [2022-04-15 08:49:14,660 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {11296#true} {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} #97#return; {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} is VALID [2022-04-15 08:49:14,660 INFO L290 TraceCheckUtils]: 59: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,660 INFO L290 TraceCheckUtils]: 58: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,660 INFO L290 TraceCheckUtils]: 57: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,660 INFO L272 TraceCheckUtils]: 56: Hoare triple {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,661 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {11296#true} {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} #95#return; {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} is VALID [2022-04-15 08:49:14,661 INFO L290 TraceCheckUtils]: 54: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,661 INFO L290 TraceCheckUtils]: 53: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,661 INFO L290 TraceCheckUtils]: 52: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,661 INFO L272 TraceCheckUtils]: 51: Hoare triple {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,662 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {11296#true} {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} #93#return; {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} is VALID [2022-04-15 08:49:14,662 INFO L290 TraceCheckUtils]: 49: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,662 INFO L290 TraceCheckUtils]: 48: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,662 INFO L290 TraceCheckUtils]: 47: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,662 INFO L272 TraceCheckUtils]: 46: Hoare triple {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,663 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {11296#true} {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} #91#return; {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} is VALID [2022-04-15 08:49:14,663 INFO L290 TraceCheckUtils]: 44: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,663 INFO L290 TraceCheckUtils]: 43: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,663 INFO L290 TraceCheckUtils]: 42: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,663 INFO L272 TraceCheckUtils]: 41: Hoare triple {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,664 INFO L290 TraceCheckUtils]: 40: Hoare triple {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} assume !false; {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} is VALID [2022-04-15 08:49:14,687 INFO L290 TraceCheckUtils]: 39: Hoare triple {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {11775#(or (<= (* main_~b~0 2) main_~c~0) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) main_~c~0 (* (- 1) main_~b~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~c~0 (* (- 1) main_~b~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (<= main_~b~0 main_~c~0)))} is VALID [2022-04-15 08:49:14,688 INFO L290 TraceCheckUtils]: 38: Hoare triple {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} assume !false; {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} is VALID [2022-04-15 08:49:14,689 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {11296#true} {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} #89#return; {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} is VALID [2022-04-15 08:49:14,689 INFO L290 TraceCheckUtils]: 36: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,689 INFO L290 TraceCheckUtils]: 35: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,689 INFO L290 TraceCheckUtils]: 34: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,689 INFO L272 TraceCheckUtils]: 33: Hoare triple {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,690 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {11296#true} {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} #87#return; {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} is VALID [2022-04-15 08:49:14,690 INFO L290 TraceCheckUtils]: 31: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,690 INFO L290 TraceCheckUtils]: 30: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,690 INFO L290 TraceCheckUtils]: 29: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,690 INFO L272 TraceCheckUtils]: 28: Hoare triple {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,691 INFO L290 TraceCheckUtils]: 27: Hoare triple {11296#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {11842#(or (< (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* main_~s~0 main_~yy~0) (* main_~y~0 main_~y~0 main_~r~0) (* main_~q~0 main_~xy~0) (* main_~p~0 main_~y~0 main_~x~0)) (+ (* main_~q~0 main_~y~0 main_~x~0) (* main_~y~0 main_~y~0 main_~s~0) (* main_~p~0 main_~xy~0) (* main_~r~0 main_~yy~0))) (<= (+ (* main_~q~0 main_~x~0) main_~b~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= (+ (* main_~q~0 main_~x~0) main_~a~0 (* main_~y~0 main_~s~0)) (+ (* main_~y~0 main_~r~0) main_~b~0 (* main_~p~0 main_~x~0)))))} is VALID [2022-04-15 08:49:14,691 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {11296#true} {11296#true} #85#return; {11296#true} is VALID [2022-04-15 08:49:14,691 INFO L290 TraceCheckUtils]: 25: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,691 INFO L290 TraceCheckUtils]: 24: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,691 INFO L290 TraceCheckUtils]: 23: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,691 INFO L272 TraceCheckUtils]: 22: Hoare triple {11296#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,691 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {11296#true} {11296#true} #83#return; {11296#true} is VALID [2022-04-15 08:49:14,691 INFO L290 TraceCheckUtils]: 20: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L290 TraceCheckUtils]: 19: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L290 TraceCheckUtils]: 18: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L272 TraceCheckUtils]: 17: Hoare triple {11296#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {11296#true} {11296#true} #81#return; {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L290 TraceCheckUtils]: 15: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L290 TraceCheckUtils]: 14: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L290 TraceCheckUtils]: 13: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L272 TraceCheckUtils]: 12: Hoare triple {11296#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L290 TraceCheckUtils]: 11: Hoare triple {11296#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {11296#true} {11296#true} #79#return; {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L290 TraceCheckUtils]: 9: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L290 TraceCheckUtils]: 8: Hoare triple {11296#true} assume !(0 == ~cond); {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L290 TraceCheckUtils]: 7: Hoare triple {11296#true} ~cond := #in~cond; {11296#true} is VALID [2022-04-15 08:49:14,692 INFO L272 TraceCheckUtils]: 6: Hoare triple {11296#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {11296#true} is VALID [2022-04-15 08:49:14,693 INFO L290 TraceCheckUtils]: 5: Hoare triple {11296#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {11296#true} is VALID [2022-04-15 08:49:14,693 INFO L272 TraceCheckUtils]: 4: Hoare triple {11296#true} call #t~ret6 := main(); {11296#true} is VALID [2022-04-15 08:49:14,693 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {11296#true} {11296#true} #103#return; {11296#true} is VALID [2022-04-15 08:49:14,693 INFO L290 TraceCheckUtils]: 2: Hoare triple {11296#true} assume true; {11296#true} is VALID [2022-04-15 08:49:14,693 INFO L290 TraceCheckUtils]: 1: Hoare triple {11296#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {11296#true} is VALID [2022-04-15 08:49:14,693 INFO L272 TraceCheckUtils]: 0: Hoare triple {11296#true} call ULTIMATE.init(); {11296#true} is VALID [2022-04-15 08:49:14,693 INFO L134 CoverageAnalysis]: Checked inductivity of 320 backedges. 84 proven. 40 refuted. 0 times theorem prover too weak. 196 trivial. 0 not checked. [2022-04-15 08:49:14,694 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:49:14,694 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [284658586] [2022-04-15 08:49:14,694 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:49:14,694 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [58825112] [2022-04-15 08:49:14,694 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [58825112] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:49:14,694 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:49:14,694 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [15, 15] total 25 [2022-04-15 08:49:14,694 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:49:14,694 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1509767758] [2022-04-15 08:49:14,694 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1509767758] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:49:14,694 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:49:14,694 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [15] imperfect sequences [] total 15 [2022-04-15 08:49:14,694 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [611927232] [2022-04-15 08:49:14,695 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:49:14,695 INFO L78 Accepts]: Start accepts. Automaton has has 15 states, 15 states have (on average 2.0) internal successors, (30), 12 states have internal predecessors, (30), 7 states have call successors, (20), 2 states have call predecessors, (20), 3 states have return successors, (18), 7 states have call predecessors, (18), 7 states have call successors, (18) Word has length 107 [2022-04-15 08:49:14,695 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:49:14,695 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 15 states, 15 states have (on average 2.0) internal successors, (30), 12 states have internal predecessors, (30), 7 states have call successors, (20), 2 states have call predecessors, (20), 3 states have return successors, (18), 7 states have call predecessors, (18), 7 states have call successors, (18) [2022-04-15 08:49:14,757 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 68 edges. 68 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:49:14,757 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 15 states [2022-04-15 08:49:14,757 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:49:14,758 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 15 interpolants. [2022-04-15 08:49:14,758 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=125, Invalid=474, Unknown=1, NotChecked=0, Total=600 [2022-04-15 08:49:14,758 INFO L87 Difference]: Start difference. First operand 155 states and 201 transitions. Second operand has 15 states, 15 states have (on average 2.0) internal successors, (30), 12 states have internal predecessors, (30), 7 states have call successors, (20), 2 states have call predecessors, (20), 3 states have return successors, (18), 7 states have call predecessors, (18), 7 states have call successors, (18) [2022-04-15 08:49:18,037 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:49:18,037 INFO L93 Difference]: Finished difference Result 162 states and 207 transitions. [2022-04-15 08:49:18,037 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2022-04-15 08:49:18,038 INFO L78 Accepts]: Start accepts. Automaton has has 15 states, 15 states have (on average 2.0) internal successors, (30), 12 states have internal predecessors, (30), 7 states have call successors, (20), 2 states have call predecessors, (20), 3 states have return successors, (18), 7 states have call predecessors, (18), 7 states have call successors, (18) Word has length 107 [2022-04-15 08:49:18,038 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:49:18,038 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 15 states, 15 states have (on average 2.0) internal successors, (30), 12 states have internal predecessors, (30), 7 states have call successors, (20), 2 states have call predecessors, (20), 3 states have return successors, (18), 7 states have call predecessors, (18), 7 states have call successors, (18) [2022-04-15 08:49:18,039 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 103 transitions. [2022-04-15 08:49:18,039 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 15 states, 15 states have (on average 2.0) internal successors, (30), 12 states have internal predecessors, (30), 7 states have call successors, (20), 2 states have call predecessors, (20), 3 states have return successors, (18), 7 states have call predecessors, (18), 7 states have call successors, (18) [2022-04-15 08:49:18,040 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 103 transitions. [2022-04-15 08:49:18,040 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 14 states and 103 transitions. [2022-04-15 08:49:18,160 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 103 edges. 103 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:49:18,163 INFO L225 Difference]: With dead ends: 162 [2022-04-15 08:49:18,163 INFO L226 Difference]: Without dead ends: 160 [2022-04-15 08:49:18,163 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 217 GetRequests, 188 SyntacticMatches, 2 SemanticMatches, 27 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 181 ImplicationChecksByTransitivity, 14.2s TimeCoverageRelationStatistics Valid=158, Invalid=653, Unknown=1, NotChecked=0, Total=812 [2022-04-15 08:49:18,163 INFO L913 BasicCegarLoop]: 37 mSDtfsCounter, 40 mSDsluCounter, 133 mSDsCounter, 0 mSdLazyCounter, 543 mSolverCounterSat, 55 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 1.8s Time, 0 mProtectedPredicate, 0 mProtectedAction, 53 SdHoareTripleChecker+Valid, 170 SdHoareTripleChecker+Invalid, 598 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 55 IncrementalHoareTripleChecker+Valid, 543 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 1.8s IncrementalHoareTripleChecker+Time [2022-04-15 08:49:18,164 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [53 Valid, 170 Invalid, 598 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [55 Valid, 543 Invalid, 0 Unknown, 0 Unchecked, 1.8s Time] [2022-04-15 08:49:18,164 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 160 states. [2022-04-15 08:49:18,460 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 160 to 159. [2022-04-15 08:49:18,460 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:49:18,460 INFO L82 GeneralOperation]: Start isEquivalent. First operand 160 states. Second operand has 159 states, 87 states have (on average 1.1149425287356323) internal successors, (97), 89 states have internal predecessors, (97), 55 states have call successors, (55), 17 states have call predecessors, (55), 16 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:49:18,461 INFO L74 IsIncluded]: Start isIncluded. First operand 160 states. Second operand has 159 states, 87 states have (on average 1.1149425287356323) internal successors, (97), 89 states have internal predecessors, (97), 55 states have call successors, (55), 17 states have call predecessors, (55), 16 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:49:18,461 INFO L87 Difference]: Start difference. First operand 160 states. Second operand has 159 states, 87 states have (on average 1.1149425287356323) internal successors, (97), 89 states have internal predecessors, (97), 55 states have call successors, (55), 17 states have call predecessors, (55), 16 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:49:18,463 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:49:18,464 INFO L93 Difference]: Finished difference Result 160 states and 205 transitions. [2022-04-15 08:49:18,464 INFO L276 IsEmpty]: Start isEmpty. Operand 160 states and 205 transitions. [2022-04-15 08:49:18,464 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:49:18,464 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:49:18,464 INFO L74 IsIncluded]: Start isIncluded. First operand has 159 states, 87 states have (on average 1.1149425287356323) internal successors, (97), 89 states have internal predecessors, (97), 55 states have call successors, (55), 17 states have call predecessors, (55), 16 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) Second operand 160 states. [2022-04-15 08:49:18,465 INFO L87 Difference]: Start difference. First operand has 159 states, 87 states have (on average 1.1149425287356323) internal successors, (97), 89 states have internal predecessors, (97), 55 states have call successors, (55), 17 states have call predecessors, (55), 16 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) Second operand 160 states. [2022-04-15 08:49:18,467 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:49:18,467 INFO L93 Difference]: Finished difference Result 160 states and 205 transitions. [2022-04-15 08:49:18,467 INFO L276 IsEmpty]: Start isEmpty. Operand 160 states and 205 transitions. [2022-04-15 08:49:18,468 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:49:18,468 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:49:18,468 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:49:18,468 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:49:18,468 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 159 states, 87 states have (on average 1.1149425287356323) internal successors, (97), 89 states have internal predecessors, (97), 55 states have call successors, (55), 17 states have call predecessors, (55), 16 states have return successors, (52), 52 states have call predecessors, (52), 52 states have call successors, (52) [2022-04-15 08:49:18,471 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 159 states to 159 states and 204 transitions. [2022-04-15 08:49:18,471 INFO L78 Accepts]: Start accepts. Automaton has 159 states and 204 transitions. Word has length 107 [2022-04-15 08:49:18,471 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:49:18,471 INFO L478 AbstractCegarLoop]: Abstraction has 159 states and 204 transitions. [2022-04-15 08:49:18,471 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 15 states, 15 states have (on average 2.0) internal successors, (30), 12 states have internal predecessors, (30), 7 states have call successors, (20), 2 states have call predecessors, (20), 3 states have return successors, (18), 7 states have call predecessors, (18), 7 states have call successors, (18) [2022-04-15 08:49:18,471 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 159 states and 204 transitions. [2022-04-15 08:49:18,822 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 204 edges. 204 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:49:18,822 INFO L276 IsEmpty]: Start isEmpty. Operand 159 states and 204 transitions. [2022-04-15 08:49:18,823 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 114 [2022-04-15 08:49:18,823 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:49:18,823 INFO L499 BasicCegarLoop]: trace histogram [13, 12, 12, 6, 6, 6, 3, 3, 3, 3, 3, 3, 3, 3, 3, 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] [2022-04-15 08:49:18,841 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (14)] Forceful destruction successful, exit code 0 [2022-04-15 08:49:19,035 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 14 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable13 [2022-04-15 08:49:19,035 INFO L403 AbstractCegarLoop]: === Iteration 15 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:49:19,036 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:49:19,036 INFO L85 PathProgramCache]: Analyzing trace with hash 1185765869, now seen corresponding path program 3 times [2022-04-15 08:49:19,036 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:49:19,036 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1315804759] [2022-04-15 08:49:19,036 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:49:19,036 INFO L85 PathProgramCache]: Analyzing trace with hash 1185765869, now seen corresponding path program 4 times [2022-04-15 08:49:19,036 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:49:19,036 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1797003146] [2022-04-15 08:49:19,036 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:49:19,037 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:49:19,050 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:49:19,050 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [156505591] [2022-04-15 08:49:19,050 INFO L93 rtionOrderModulation]: Changing assertion order to TERMS_WITH_SMALL_CONSTANTS_FIRST [2022-04-15 08:49:19,050 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:49:19,050 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:49:19,051 INFO L229 MonitoredProcess]: Starting monitored process 15 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:49:19,051 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (15)] Waiting until timeout for monitored process [2022-04-15 08:49:19,100 INFO L228 tOrderPrioritization]: Assert order TERMS_WITH_SMALL_CONSTANTS_FIRST issued 0 check-sat command(s) [2022-04-15 08:49:19,101 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:49:19,102 INFO L263 TraceCheckSpWp]: Trace formula consists of 236 conjuncts, 57 conjunts are in the unsatisfiable core [2022-04-15 08:49:19,123 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:49:19,125 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:49:25,667 WARN L914 QuantifierPusher]: no eliminatee completely removed, nonetheless the elimination was considered successful [2022-04-15 08:49:27,364 INFO L272 TraceCheckUtils]: 0: Hoare triple {12932#true} call ULTIMATE.init(); {12932#true} is VALID [2022-04-15 08:49:27,364 INFO L290 TraceCheckUtils]: 1: Hoare triple {12932#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {12932#true} is VALID [2022-04-15 08:49:27,364 INFO L290 TraceCheckUtils]: 2: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,364 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12932#true} {12932#true} #103#return; {12932#true} is VALID [2022-04-15 08:49:27,364 INFO L272 TraceCheckUtils]: 4: Hoare triple {12932#true} call #t~ret6 := main(); {12932#true} is VALID [2022-04-15 08:49:27,364 INFO L290 TraceCheckUtils]: 5: Hoare triple {12932#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {12932#true} is VALID [2022-04-15 08:49:27,364 INFO L272 TraceCheckUtils]: 6: Hoare triple {12932#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,364 INFO L290 TraceCheckUtils]: 7: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L290 TraceCheckUtils]: 8: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L290 TraceCheckUtils]: 9: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {12932#true} {12932#true} #79#return; {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L290 TraceCheckUtils]: 11: Hoare triple {12932#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L272 TraceCheckUtils]: 12: Hoare triple {12932#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L290 TraceCheckUtils]: 13: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L290 TraceCheckUtils]: 14: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L290 TraceCheckUtils]: 15: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {12932#true} {12932#true} #81#return; {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L272 TraceCheckUtils]: 17: Hoare triple {12932#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,365 INFO L290 TraceCheckUtils]: 18: Hoare triple {12932#true} ~cond := #in~cond; {12991#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-04-15 08:49:27,366 INFO L290 TraceCheckUtils]: 19: Hoare triple {12991#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond); {12995#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:49:27,366 INFO L290 TraceCheckUtils]: 20: Hoare triple {12995#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {12995#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:49:27,366 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {12995#(not (= |assume_abort_if_not_#in~cond| 0))} {12932#true} #83#return; {13002#(<= 1 main_~x~0)} is VALID [2022-04-15 08:49:27,367 INFO L272 TraceCheckUtils]: 22: Hoare triple {13002#(<= 1 main_~x~0)} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,367 INFO L290 TraceCheckUtils]: 23: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,367 INFO L290 TraceCheckUtils]: 24: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,367 INFO L290 TraceCheckUtils]: 25: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,367 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {12932#true} {13002#(<= 1 main_~x~0)} #85#return; {13002#(<= 1 main_~x~0)} is VALID [2022-04-15 08:49:27,368 INFO L290 TraceCheckUtils]: 27: Hoare triple {13002#(<= 1 main_~x~0)} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,368 INFO L272 TraceCheckUtils]: 28: Hoare triple {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,368 INFO L290 TraceCheckUtils]: 29: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,368 INFO L290 TraceCheckUtils]: 30: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,368 INFO L290 TraceCheckUtils]: 31: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,368 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {12932#true} {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #87#return; {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,369 INFO L272 TraceCheckUtils]: 33: Hoare triple {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,369 INFO L290 TraceCheckUtils]: 34: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,369 INFO L290 TraceCheckUtils]: 35: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,369 INFO L290 TraceCheckUtils]: 36: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,369 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {12932#true} {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #89#return; {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,370 INFO L290 TraceCheckUtils]: 38: Hoare triple {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,370 INFO L290 TraceCheckUtils]: 39: Hoare triple {13021#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,370 INFO L290 TraceCheckUtils]: 40: Hoare triple {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,371 INFO L272 TraceCheckUtils]: 41: Hoare triple {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,371 INFO L290 TraceCheckUtils]: 42: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,371 INFO L290 TraceCheckUtils]: 43: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,371 INFO L290 TraceCheckUtils]: 44: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,371 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {12932#true} {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,371 INFO L272 TraceCheckUtils]: 46: Hoare triple {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,372 INFO L290 TraceCheckUtils]: 47: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,372 INFO L290 TraceCheckUtils]: 48: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,372 INFO L290 TraceCheckUtils]: 49: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,372 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {12932#true} {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,372 INFO L272 TraceCheckUtils]: 51: Hoare triple {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,372 INFO L290 TraceCheckUtils]: 52: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,373 INFO L290 TraceCheckUtils]: 53: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,373 INFO L290 TraceCheckUtils]: 54: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,374 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {12932#true} {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #95#return; {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,374 INFO L272 TraceCheckUtils]: 56: Hoare triple {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,374 INFO L290 TraceCheckUtils]: 57: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,374 INFO L290 TraceCheckUtils]: 58: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,374 INFO L290 TraceCheckUtils]: 59: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,375 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {12932#true} {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #97#return; {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,376 INFO L290 TraceCheckUtils]: 61: Hoare triple {13058#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {13125#(and (= main_~r~0 0) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,376 INFO L290 TraceCheckUtils]: 62: Hoare triple {13125#(and (= main_~r~0 0) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {13125#(and (= main_~r~0 0) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,376 INFO L272 TraceCheckUtils]: 63: Hoare triple {13125#(and (= main_~r~0 0) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,377 INFO L290 TraceCheckUtils]: 64: Hoare triple {12932#true} ~cond := #in~cond; {13135#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:49:27,377 INFO L290 TraceCheckUtils]: 65: Hoare triple {13135#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:27,377 INFO L290 TraceCheckUtils]: 66: Hoare triple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:27,378 INFO L284 TraceCheckUtils]: 67: Hoare quadruple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} {13125#(and (= main_~r~0 0) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,378 INFO L272 TraceCheckUtils]: 68: Hoare triple {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,378 INFO L290 TraceCheckUtils]: 69: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,378 INFO L290 TraceCheckUtils]: 70: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,378 INFO L290 TraceCheckUtils]: 71: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,379 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {12932#true} {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,379 INFO L272 TraceCheckUtils]: 73: Hoare triple {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,379 INFO L290 TraceCheckUtils]: 74: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,379 INFO L290 TraceCheckUtils]: 75: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,379 INFO L290 TraceCheckUtils]: 76: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,380 INFO L284 TraceCheckUtils]: 77: Hoare quadruple {12932#true} {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #95#return; {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,380 INFO L272 TraceCheckUtils]: 78: Hoare triple {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,380 INFO L290 TraceCheckUtils]: 79: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,380 INFO L290 TraceCheckUtils]: 80: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,380 INFO L290 TraceCheckUtils]: 81: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,381 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {12932#true} {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #97#return; {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,382 INFO L290 TraceCheckUtils]: 83: Hoare triple {13146#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~k~0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {13195#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ main_~c~0 main_~b~0)) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,382 INFO L290 TraceCheckUtils]: 84: Hoare triple {13195#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ main_~c~0 main_~b~0)) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {13195#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ main_~c~0 main_~b~0)) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,382 INFO L272 TraceCheckUtils]: 85: Hoare triple {13195#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ main_~c~0 main_~b~0)) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,383 INFO L290 TraceCheckUtils]: 86: Hoare triple {12932#true} ~cond := #in~cond; {13135#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:49:27,383 INFO L290 TraceCheckUtils]: 87: Hoare triple {13135#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:27,383 INFO L290 TraceCheckUtils]: 88: Hoare triple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:27,384 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} {13195#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ main_~c~0 main_~b~0)) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {13214#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ main_~c~0 main_~b~0)) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,384 INFO L272 TraceCheckUtils]: 90: Hoare triple {13214#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ main_~c~0 main_~b~0)) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,384 INFO L290 TraceCheckUtils]: 91: Hoare triple {12932#true} ~cond := #in~cond; {13135#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:49:27,385 INFO L290 TraceCheckUtils]: 92: Hoare triple {13135#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:27,385 INFO L290 TraceCheckUtils]: 93: Hoare triple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:49:27,386 INFO L284 TraceCheckUtils]: 94: Hoare quadruple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} {13214#(and (= main_~r~0 0) (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ main_~c~0 main_~b~0)) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {13230#(and (= main_~r~0 0) (= main_~x~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (* main_~b~0 main_~k~0) (* main_~b~0 2)) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,386 INFO L272 TraceCheckUtils]: 95: Hoare triple {13230#(and (= main_~r~0 0) (= main_~x~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (* main_~b~0 main_~k~0) (* main_~b~0 2)) (= main_~q~0 0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,386 INFO L290 TraceCheckUtils]: 96: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,386 INFO L290 TraceCheckUtils]: 97: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,386 INFO L290 TraceCheckUtils]: 98: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,387 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {12932#true} {13230#(and (= main_~r~0 0) (= main_~x~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (* main_~b~0 main_~k~0) (* main_~b~0 2)) (= main_~q~0 0) (= main_~p~0 1))} #95#return; {13230#(and (= main_~r~0 0) (= main_~x~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (* main_~b~0 main_~k~0) (* main_~b~0 2)) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,387 INFO L272 TraceCheckUtils]: 100: Hoare triple {13230#(and (= main_~r~0 0) (= main_~x~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (* main_~b~0 main_~k~0) (* main_~b~0 2)) (= main_~q~0 0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:49:27,387 INFO L290 TraceCheckUtils]: 101: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:49:27,387 INFO L290 TraceCheckUtils]: 102: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:49:27,387 INFO L290 TraceCheckUtils]: 103: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:49:27,388 INFO L284 TraceCheckUtils]: 104: Hoare quadruple {12932#true} {13230#(and (= main_~r~0 0) (= main_~x~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (* main_~b~0 main_~k~0) (* main_~b~0 2)) (= main_~q~0 0) (= main_~p~0 1))} #97#return; {13230#(and (= main_~r~0 0) (= main_~x~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (* main_~b~0 main_~k~0) (* main_~b~0 2)) (= main_~q~0 0) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,389 INFO L290 TraceCheckUtils]: 105: Hoare triple {13230#(and (= main_~r~0 0) (= main_~x~0 (+ main_~c~0 (* main_~b~0 main_~k~0))) (<= 1 main_~x~0) (= main_~s~0 1) (<= 2 main_~k~0) (<= 0 main_~c~0) (= main_~b~0 main_~y~0) (= (* main_~b~0 main_~k~0) (* main_~b~0 2)) (= main_~q~0 0) (= main_~p~0 1))} assume !(~c~0 >= ~b~0); {13264#(and (= main_~r~0 0) (< main_~c~0 main_~y~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= (* main_~y~0 2) (* main_~k~0 main_~y~0)) (= main_~p~0 1))} is VALID [2022-04-15 08:49:27,390 INFO L290 TraceCheckUtils]: 106: Hoare triple {13264#(and (= main_~r~0 0) (< main_~c~0 main_~y~0) (= main_~s~0 1) (<= 0 main_~c~0) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= (* main_~y~0 2) (* main_~k~0 main_~y~0)) (= main_~p~0 1))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {13268#(and (<= 0 (+ main_~x~0 (* main_~y~0 main_~s~0))) (< (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~y~0) (= (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~b~0) (= (* main_~y~0 (* (- 1) main_~s~0)) (* main_~y~0 2)) (= main_~q~0 1))} is VALID [2022-04-15 08:49:27,390 INFO L290 TraceCheckUtils]: 107: Hoare triple {13268#(and (<= 0 (+ main_~x~0 (* main_~y~0 main_~s~0))) (< (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~y~0) (= (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~b~0) (= (* main_~y~0 (* (- 1) main_~s~0)) (* main_~y~0 2)) (= main_~q~0 1))} assume !false; {13268#(and (<= 0 (+ main_~x~0 (* main_~y~0 main_~s~0))) (< (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~y~0) (= (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~b~0) (= (* main_~y~0 (* (- 1) main_~s~0)) (* main_~y~0 2)) (= main_~q~0 1))} is VALID [2022-04-15 08:49:27,391 INFO L290 TraceCheckUtils]: 108: Hoare triple {13268#(and (<= 0 (+ main_~x~0 (* main_~y~0 main_~s~0))) (< (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~y~0) (= (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~b~0) (= (* main_~y~0 (* (- 1) main_~s~0)) (* main_~y~0 2)) (= main_~q~0 1))} assume !(0 != ~b~0); {13275#(and (= (+ main_~x~0 (* main_~y~0 main_~s~0)) 0) (= (+ (* main_~y~0 2) (* main_~y~0 main_~s~0)) 0) (< (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~y~0) (= main_~q~0 1))} is VALID [2022-04-15 08:49:27,391 INFO L272 TraceCheckUtils]: 109: Hoare triple {13275#(and (= (+ main_~x~0 (* main_~y~0 main_~s~0)) 0) (= (+ (* main_~y~0 2) (* main_~y~0 main_~s~0)) 0) (< (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~y~0) (= main_~q~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {13279#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:49:27,392 INFO L290 TraceCheckUtils]: 110: Hoare triple {13279#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {13283#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:49:27,392 INFO L290 TraceCheckUtils]: 111: Hoare triple {13283#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {12933#false} is VALID [2022-04-15 08:49:27,392 INFO L290 TraceCheckUtils]: 112: Hoare triple {12933#false} assume !false; {12933#false} is VALID [2022-04-15 08:49:27,393 INFO L134 CoverageAnalysis]: Checked inductivity of 368 backedges. 81 proven. 59 refuted. 0 times theorem prover too weak. 228 trivial. 0 not checked. [2022-04-15 08:49:27,393 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:51:17,274 WARN L914 QuantifierPusher]: no eliminatee completely removed, nonetheless the elimination was considered successful [2022-04-15 08:51:17,311 WARN L914 QuantifierPusher]: no eliminatee completely removed, nonetheless the elimination was considered successful [2022-04-15 08:51:43,077 WARN L914 QuantifierPusher]: no eliminatee completely removed, nonetheless the elimination was considered successful [2022-04-15 08:52:04,826 INFO L290 TraceCheckUtils]: 112: Hoare triple {12933#false} assume !false; {12933#false} is VALID [2022-04-15 08:52:04,826 INFO L290 TraceCheckUtils]: 111: Hoare triple {13283#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {12933#false} is VALID [2022-04-15 08:52:04,826 INFO L290 TraceCheckUtils]: 110: Hoare triple {13279#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {13283#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:04,827 INFO L272 TraceCheckUtils]: 109: Hoare triple {13299#(= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0)} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {13279#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:52:04,827 INFO L290 TraceCheckUtils]: 108: Hoare triple {13303#(or (not (= main_~b~0 0)) (= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0))} assume !(0 != ~b~0); {13299#(= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0)} is VALID [2022-04-15 08:52:04,828 INFO L290 TraceCheckUtils]: 107: Hoare triple {13303#(or (not (= main_~b~0 0)) (= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0))} assume !false; {13303#(or (not (= main_~b~0 0)) (= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0))} is VALID [2022-04-15 08:52:05,916 INFO L290 TraceCheckUtils]: 106: Hoare triple {13310#(or (not (= main_~c~0 0)) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {13303#(or (not (= main_~b~0 0)) (= (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) 0))} is VALID [2022-04-15 08:52:05,917 INFO L290 TraceCheckUtils]: 105: Hoare triple {13314#(or (not (= main_~c~0 0)) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} assume !(~c~0 >= ~b~0); {13310#(or (not (= main_~c~0 0)) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} is VALID [2022-04-15 08:52:05,918 INFO L284 TraceCheckUtils]: 104: Hoare quadruple {12932#true} {13314#(or (not (= main_~c~0 0)) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} #97#return; {13314#(or (not (= main_~c~0 0)) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} is VALID [2022-04-15 08:52:05,918 INFO L290 TraceCheckUtils]: 103: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:05,918 INFO L290 TraceCheckUtils]: 102: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:05,918 INFO L290 TraceCheckUtils]: 101: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:05,918 INFO L272 TraceCheckUtils]: 100: Hoare triple {13314#(or (not (= main_~c~0 0)) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:05,918 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {12932#true} {13314#(or (not (= main_~c~0 0)) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} #95#return; {13314#(or (not (= main_~c~0 0)) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} is VALID [2022-04-15 08:52:05,919 INFO L290 TraceCheckUtils]: 98: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:05,919 INFO L290 TraceCheckUtils]: 97: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:05,919 INFO L290 TraceCheckUtils]: 96: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:05,919 INFO L272 TraceCheckUtils]: 95: Hoare triple {13314#(or (not (= main_~c~0 0)) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:05,920 INFO L284 TraceCheckUtils]: 94: Hoare quadruple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} {13348#(or (not (= main_~c~0 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} #93#return; {13314#(or (not (= main_~c~0 0)) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} is VALID [2022-04-15 08:52:05,920 INFO L290 TraceCheckUtils]: 93: Hoare triple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:05,920 INFO L290 TraceCheckUtils]: 92: Hoare triple {13358#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:05,920 INFO L290 TraceCheckUtils]: 91: Hoare triple {12932#true} ~cond := #in~cond; {13358#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:52:05,921 INFO L272 TraceCheckUtils]: 90: Hoare triple {13348#(or (not (= main_~c~0 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:05,921 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} {13365#(or (not (= main_~c~0 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} #91#return; {13348#(or (not (= main_~c~0 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} is VALID [2022-04-15 08:52:05,922 INFO L290 TraceCheckUtils]: 88: Hoare triple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:05,922 INFO L290 TraceCheckUtils]: 87: Hoare triple {13358#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:05,922 INFO L290 TraceCheckUtils]: 86: Hoare triple {12932#true} ~cond := #in~cond; {13358#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:52:05,922 INFO L272 TraceCheckUtils]: 85: Hoare triple {13365#(or (not (= main_~c~0 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:05,923 INFO L290 TraceCheckUtils]: 84: Hoare triple {13365#(or (not (= main_~c~0 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} assume !false; {13365#(or (not (= main_~c~0 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} is VALID [2022-04-15 08:52:07,924 WARN L290 TraceCheckUtils]: 83: Hoare triple {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {13365#(or (not (= main_~c~0 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) 0))} is UNKNOWN [2022-04-15 08:52:07,925 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {12932#true} {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} #97#return; {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:07,926 INFO L290 TraceCheckUtils]: 81: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:07,926 INFO L290 TraceCheckUtils]: 80: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:07,926 INFO L290 TraceCheckUtils]: 79: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:07,926 INFO L272 TraceCheckUtils]: 78: Hoare triple {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:07,926 INFO L284 TraceCheckUtils]: 77: Hoare quadruple {12932#true} {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} #95#return; {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:07,926 INFO L290 TraceCheckUtils]: 76: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:07,927 INFO L290 TraceCheckUtils]: 75: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:07,927 INFO L290 TraceCheckUtils]: 74: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:07,927 INFO L272 TraceCheckUtils]: 73: Hoare triple {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:07,927 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {12932#true} {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} #93#return; {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:07,927 INFO L290 TraceCheckUtils]: 71: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:07,928 INFO L290 TraceCheckUtils]: 70: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:07,928 INFO L290 TraceCheckUtils]: 69: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:07,928 INFO L272 TraceCheckUtils]: 68: Hoare triple {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:07,929 INFO L284 TraceCheckUtils]: 67: Hoare quadruple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} {13433#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (< main_~c~0 main_~b~0) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* main_~b~0 (div main_~a~0 main_~b~0))))))} #91#return; {13384#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div main_~a~0 main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* (+ (* (- 1) (* main_~s~0 (div main_~a~0 main_~b~0))) main_~r~0) main_~y~0) (* (+ (* (- 1) main_~q~0 (div main_~a~0 main_~b~0)) main_~p~0) main_~x~0)) 0) (not (<= main_~b~0 main_~c~0)) (not (= (+ main_~a~0 (* (- 1) main_~b~0 (div main_~a~0 main_~b~0))) (+ main_~c~0 (* (- 1) main_~b~0)))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:07,929 INFO L290 TraceCheckUtils]: 66: Hoare triple {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:07,930 INFO L290 TraceCheckUtils]: 65: Hoare triple {13358#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {13139#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:07,930 INFO L290 TraceCheckUtils]: 64: Hoare triple {12932#true} ~cond := #in~cond; {13358#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:52:07,930 INFO L272 TraceCheckUtils]: 63: Hoare triple {13433#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (< main_~c~0 main_~b~0) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* main_~b~0 (div main_~a~0 main_~b~0))))))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:07,931 INFO L290 TraceCheckUtils]: 62: Hoare triple {13433#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (< main_~c~0 main_~b~0) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* main_~b~0 (div main_~a~0 main_~b~0))))))} assume !false; {13433#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (< main_~c~0 main_~b~0) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* main_~b~0 (div main_~a~0 main_~b~0))))))} is VALID [2022-04-15 08:52:09,933 WARN L290 TraceCheckUtils]: 61: Hoare triple {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {13433#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (not (= main_~a~0 (+ main_~c~0 (* main_~b~0 main_~k~0)))) (< main_~c~0 main_~b~0) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* main_~b~0 (div main_~a~0 main_~b~0))))))} is UNKNOWN [2022-04-15 08:52:09,934 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {12932#true} {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} #97#return; {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,934 INFO L290 TraceCheckUtils]: 59: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,934 INFO L290 TraceCheckUtils]: 58: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,934 INFO L290 TraceCheckUtils]: 57: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,934 INFO L272 TraceCheckUtils]: 56: Hoare triple {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,935 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {12932#true} {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} #95#return; {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,935 INFO L290 TraceCheckUtils]: 54: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,935 INFO L290 TraceCheckUtils]: 53: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,935 INFO L290 TraceCheckUtils]: 52: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,935 INFO L272 TraceCheckUtils]: 51: Hoare triple {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,936 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {12932#true} {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} #93#return; {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,936 INFO L290 TraceCheckUtils]: 49: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,936 INFO L290 TraceCheckUtils]: 48: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,936 INFO L290 TraceCheckUtils]: 47: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,936 INFO L272 TraceCheckUtils]: 46: Hoare triple {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,937 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {12932#true} {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} #91#return; {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,937 INFO L290 TraceCheckUtils]: 44: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,937 INFO L290 TraceCheckUtils]: 43: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,937 INFO L290 TraceCheckUtils]: 42: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,937 INFO L272 TraceCheckUtils]: 41: Hoare triple {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,938 INFO L290 TraceCheckUtils]: 40: Hoare triple {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} assume !false; {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,938 INFO L290 TraceCheckUtils]: 39: Hoare triple {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {13452#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (+ main_~b~0 main_~a~0) (+ main_~c~0 (* (- 1) main_~b~0) (* main_~b~0 (div main_~a~0 main_~b~0))))) (not (= (mod (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0) 0)) (not (<= (+ main_~k~0 1) (div (+ (* (- 1) main_~c~0) main_~b~0 main_~a~0) main_~b~0))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~c~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,939 INFO L290 TraceCheckUtils]: 38: Hoare triple {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} assume !false; {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,939 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {12932#true} {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} #89#return; {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,939 INFO L290 TraceCheckUtils]: 36: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,939 INFO L290 TraceCheckUtils]: 35: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,940 INFO L290 TraceCheckUtils]: 34: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,940 INFO L272 TraceCheckUtils]: 33: Hoare triple {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,940 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {12932#true} {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} #87#return; {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,940 INFO L290 TraceCheckUtils]: 31: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,940 INFO L290 TraceCheckUtils]: 30: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,940 INFO L290 TraceCheckUtils]: 29: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,941 INFO L272 TraceCheckUtils]: 28: Hoare triple {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,942 INFO L290 TraceCheckUtils]: 27: Hoare triple {12932#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {13519#(or (not (= (mod main_~a~0 main_~b~0) 0)) (not (= (* main_~b~0 (div main_~a~0 main_~b~0)) (* main_~b~0 2))) (not (= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))) (< main_~a~0 (* main_~b~0 2)) (= (+ (* main_~y~0 main_~s~0 (div main_~a~0 main_~b~0)) (* main_~q~0 main_~x~0 (div main_~a~0 main_~b~0))) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (<= (+ main_~b~0 (* main_~b~0 (div main_~a~0 main_~b~0))) main_~a~0))} is VALID [2022-04-15 08:52:09,942 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {12932#true} {12932#true} #85#return; {12932#true} is VALID [2022-04-15 08:52:09,942 INFO L290 TraceCheckUtils]: 25: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,942 INFO L290 TraceCheckUtils]: 24: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,942 INFO L290 TraceCheckUtils]: 23: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,942 INFO L272 TraceCheckUtils]: 22: Hoare triple {12932#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,942 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {12932#true} {12932#true} #83#return; {12932#true} is VALID [2022-04-15 08:52:09,942 INFO L290 TraceCheckUtils]: 20: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,942 INFO L290 TraceCheckUtils]: 19: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,942 INFO L290 TraceCheckUtils]: 18: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L272 TraceCheckUtils]: 17: Hoare triple {12932#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {12932#true} {12932#true} #81#return; {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L290 TraceCheckUtils]: 15: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L290 TraceCheckUtils]: 14: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L290 TraceCheckUtils]: 13: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L272 TraceCheckUtils]: 12: Hoare triple {12932#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L290 TraceCheckUtils]: 11: Hoare triple {12932#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {12932#true} {12932#true} #79#return; {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L290 TraceCheckUtils]: 9: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L290 TraceCheckUtils]: 8: Hoare triple {12932#true} assume !(0 == ~cond); {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L290 TraceCheckUtils]: 7: Hoare triple {12932#true} ~cond := #in~cond; {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L272 TraceCheckUtils]: 6: Hoare triple {12932#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L290 TraceCheckUtils]: 5: Hoare triple {12932#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {12932#true} is VALID [2022-04-15 08:52:09,943 INFO L272 TraceCheckUtils]: 4: Hoare triple {12932#true} call #t~ret6 := main(); {12932#true} is VALID [2022-04-15 08:52:09,944 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {12932#true} {12932#true} #103#return; {12932#true} is VALID [2022-04-15 08:52:09,944 INFO L290 TraceCheckUtils]: 2: Hoare triple {12932#true} assume true; {12932#true} is VALID [2022-04-15 08:52:09,944 INFO L290 TraceCheckUtils]: 1: Hoare triple {12932#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {12932#true} is VALID [2022-04-15 08:52:09,944 INFO L272 TraceCheckUtils]: 0: Hoare triple {12932#true} call ULTIMATE.init(); {12932#true} is VALID [2022-04-15 08:52:09,944 INFO L134 CoverageAnalysis]: Checked inductivity of 368 backedges. 75 proven. 50 refuted. 0 times theorem prover too weak. 243 trivial. 0 not checked. [2022-04-15 08:52:09,944 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:52:09,944 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1797003146] [2022-04-15 08:52:09,945 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:52:09,945 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [156505591] [2022-04-15 08:52:09,945 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [156505591] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:52:09,945 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:52:09,945 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [19, 16] total 30 [2022-04-15 08:52:09,945 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:52:09,945 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1315804759] [2022-04-15 08:52:09,945 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1315804759] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:52:09,945 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:52:09,945 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [19] imperfect sequences [] total 19 [2022-04-15 08:52:09,945 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [713032142] [2022-04-15 08:52:09,945 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:52:09,946 INFO L78 Accepts]: Start accepts. Automaton has has 19 states, 17 states have (on average 1.8235294117647058) internal successors, (31), 14 states have internal predecessors, (31), 10 states have call successors, (21), 2 states have call predecessors, (21), 3 states have return successors, (19), 7 states have call predecessors, (19), 9 states have call successors, (19) Word has length 113 [2022-04-15 08:52:09,946 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:52:09,946 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 19 states, 17 states have (on average 1.8235294117647058) internal successors, (31), 14 states have internal predecessors, (31), 10 states have call successors, (21), 2 states have call predecessors, (21), 3 states have return successors, (19), 7 states have call predecessors, (19), 9 states have call successors, (19) [2022-04-15 08:52:10,015 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 71 edges. 71 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:10,015 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 19 states [2022-04-15 08:52:10,015 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:52:10,016 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 19 interpolants. [2022-04-15 08:52:10,016 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=154, Invalid=714, Unknown=2, NotChecked=0, Total=870 [2022-04-15 08:52:10,016 INFO L87 Difference]: Start difference. First operand 159 states and 204 transitions. Second operand has 19 states, 17 states have (on average 1.8235294117647058) internal successors, (31), 14 states have internal predecessors, (31), 10 states have call successors, (21), 2 states have call predecessors, (21), 3 states have return successors, (19), 7 states have call predecessors, (19), 9 states have call successors, (19) [2022-04-15 08:52:18,408 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:18,408 INFO L93 Difference]: Finished difference Result 192 states and 250 transitions. [2022-04-15 08:52:18,408 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 16 states. [2022-04-15 08:52:18,408 INFO L78 Accepts]: Start accepts. Automaton has has 19 states, 17 states have (on average 1.8235294117647058) internal successors, (31), 14 states have internal predecessors, (31), 10 states have call successors, (21), 2 states have call predecessors, (21), 3 states have return successors, (19), 7 states have call predecessors, (19), 9 states have call successors, (19) Word has length 113 [2022-04-15 08:52:18,409 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:52:18,409 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 19 states, 17 states have (on average 1.8235294117647058) internal successors, (31), 14 states have internal predecessors, (31), 10 states have call successors, (21), 2 states have call predecessors, (21), 3 states have return successors, (19), 7 states have call predecessors, (19), 9 states have call successors, (19) [2022-04-15 08:52:18,410 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 16 states to 16 states and 117 transitions. [2022-04-15 08:52:18,410 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 19 states, 17 states have (on average 1.8235294117647058) internal successors, (31), 14 states have internal predecessors, (31), 10 states have call successors, (21), 2 states have call predecessors, (21), 3 states have return successors, (19), 7 states have call predecessors, (19), 9 states have call successors, (19) [2022-04-15 08:52:18,411 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 16 states to 16 states and 117 transitions. [2022-04-15 08:52:18,411 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 16 states and 117 transitions. [2022-04-15 08:52:18,561 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 117 edges. 117 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:18,564 INFO L225 Difference]: With dead ends: 192 [2022-04-15 08:52:18,564 INFO L226 Difference]: Without dead ends: 189 [2022-04-15 08:52:18,565 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 230 GetRequests, 196 SyntacticMatches, 1 SemanticMatches, 33 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 313 ImplicationChecksByTransitivity, 10.1s TimeCoverageRelationStatistics Valid=202, Invalid=986, Unknown=2, NotChecked=0, Total=1190 [2022-04-15 08:52:18,565 INFO L913 BasicCegarLoop]: 43 mSDtfsCounter, 45 mSDsluCounter, 184 mSDsCounter, 0 mSdLazyCounter, 821 mSolverCounterSat, 52 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 3.7s Time, 0 mProtectedPredicate, 0 mProtectedAction, 61 SdHoareTripleChecker+Valid, 227 SdHoareTripleChecker+Invalid, 873 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 52 IncrementalHoareTripleChecker+Valid, 821 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 3.7s IncrementalHoareTripleChecker+Time [2022-04-15 08:52:18,565 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [61 Valid, 227 Invalid, 873 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [52 Valid, 821 Invalid, 0 Unknown, 0 Unchecked, 3.7s Time] [2022-04-15 08:52:18,566 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 189 states. [2022-04-15 08:52:18,938 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 189 to 188. [2022-04-15 08:52:18,939 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:52:18,939 INFO L82 GeneralOperation]: Start isEquivalent. First operand 189 states. Second operand has 188 states, 102 states have (on average 1.1176470588235294) internal successors, (114), 104 states have internal predecessors, (114), 67 states have call successors, (67), 19 states have call predecessors, (67), 18 states have return successors, (64), 64 states have call predecessors, (64), 64 states have call successors, (64) [2022-04-15 08:52:18,939 INFO L74 IsIncluded]: Start isIncluded. First operand 189 states. Second operand has 188 states, 102 states have (on average 1.1176470588235294) internal successors, (114), 104 states have internal predecessors, (114), 67 states have call successors, (67), 19 states have call predecessors, (67), 18 states have return successors, (64), 64 states have call predecessors, (64), 64 states have call successors, (64) [2022-04-15 08:52:18,940 INFO L87 Difference]: Start difference. First operand 189 states. Second operand has 188 states, 102 states have (on average 1.1176470588235294) internal successors, (114), 104 states have internal predecessors, (114), 67 states have call successors, (67), 19 states have call predecessors, (67), 18 states have return successors, (64), 64 states have call predecessors, (64), 64 states have call successors, (64) [2022-04-15 08:52:18,943 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:18,943 INFO L93 Difference]: Finished difference Result 189 states and 246 transitions. [2022-04-15 08:52:18,943 INFO L276 IsEmpty]: Start isEmpty. Operand 189 states and 246 transitions. [2022-04-15 08:52:18,943 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:52:18,943 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:52:18,944 INFO L74 IsIncluded]: Start isIncluded. First operand has 188 states, 102 states have (on average 1.1176470588235294) internal successors, (114), 104 states have internal predecessors, (114), 67 states have call successors, (67), 19 states have call predecessors, (67), 18 states have return successors, (64), 64 states have call predecessors, (64), 64 states have call successors, (64) Second operand 189 states. [2022-04-15 08:52:18,944 INFO L87 Difference]: Start difference. First operand has 188 states, 102 states have (on average 1.1176470588235294) internal successors, (114), 104 states have internal predecessors, (114), 67 states have call successors, (67), 19 states have call predecessors, (67), 18 states have return successors, (64), 64 states have call predecessors, (64), 64 states have call successors, (64) Second operand 189 states. [2022-04-15 08:52:18,948 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:18,948 INFO L93 Difference]: Finished difference Result 189 states and 246 transitions. [2022-04-15 08:52:18,948 INFO L276 IsEmpty]: Start isEmpty. Operand 189 states and 246 transitions. [2022-04-15 08:52:18,948 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:52:18,948 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:52:18,948 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:52:18,949 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:52:18,949 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 188 states, 102 states have (on average 1.1176470588235294) internal successors, (114), 104 states have internal predecessors, (114), 67 states have call successors, (67), 19 states have call predecessors, (67), 18 states have return successors, (64), 64 states have call predecessors, (64), 64 states have call successors, (64) [2022-04-15 08:52:18,952 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 188 states to 188 states and 245 transitions. [2022-04-15 08:52:18,952 INFO L78 Accepts]: Start accepts. Automaton has 188 states and 245 transitions. Word has length 113 [2022-04-15 08:52:18,952 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:52:18,953 INFO L478 AbstractCegarLoop]: Abstraction has 188 states and 245 transitions. [2022-04-15 08:52:18,953 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 19 states, 17 states have (on average 1.8235294117647058) internal successors, (31), 14 states have internal predecessors, (31), 10 states have call successors, (21), 2 states have call predecessors, (21), 3 states have return successors, (19), 7 states have call predecessors, (19), 9 states have call successors, (19) [2022-04-15 08:52:18,953 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 188 states and 245 transitions. [2022-04-15 08:52:19,389 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 245 edges. 245 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:19,389 INFO L276 IsEmpty]: Start isEmpty. Operand 188 states and 245 transitions. [2022-04-15 08:52:19,390 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 117 [2022-04-15 08:52:19,390 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:52:19,390 INFO L499 BasicCegarLoop]: trace histogram [13, 12, 12, 6, 6, 6, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 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] [2022-04-15 08:52:19,409 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (15)] Forceful destruction successful, exit code 0 [2022-04-15 08:52:19,590 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable14,15 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:52:19,590 INFO L403 AbstractCegarLoop]: === Iteration 16 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:52:19,591 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:52:19,591 INFO L85 PathProgramCache]: Analyzing trace with hash 884638574, now seen corresponding path program 5 times [2022-04-15 08:52:19,591 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:52:19,591 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1256446506] [2022-04-15 08:52:19,591 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:52:19,591 INFO L85 PathProgramCache]: Analyzing trace with hash 884638574, now seen corresponding path program 6 times [2022-04-15 08:52:19,591 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:52:19,591 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1124911896] [2022-04-15 08:52:19,592 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:52:19,592 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:52:19,606 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:52:19,606 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [648778429] [2022-04-15 08:52:19,606 INFO L93 rtionOrderModulation]: Changing assertion order to MIX_INSIDE_OUTSIDE [2022-04-15 08:52:19,606 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:52:19,606 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:52:19,611 INFO L229 MonitoredProcess]: Starting monitored process 16 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:52:19,612 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (16)] Waiting until timeout for monitored process [2022-04-15 08:52:19,673 INFO L228 tOrderPrioritization]: Assert order MIX_INSIDE_OUTSIDE issued 5 check-sat command(s) [2022-04-15 08:52:19,673 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:52:19,674 INFO L263 TraceCheckSpWp]: Trace formula consists of 255 conjuncts, 7 conjunts are in the unsatisfiable core [2022-04-15 08:52:19,688 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:52:19,689 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:52:19,950 INFO L272 TraceCheckUtils]: 0: Hoare triple {14787#true} call ULTIMATE.init(); {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L290 TraceCheckUtils]: 1: Hoare triple {14787#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L290 TraceCheckUtils]: 2: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {14787#true} {14787#true} #103#return; {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L272 TraceCheckUtils]: 4: Hoare triple {14787#true} call #t~ret6 := main(); {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L290 TraceCheckUtils]: 5: Hoare triple {14787#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L272 TraceCheckUtils]: 6: Hoare triple {14787#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L290 TraceCheckUtils]: 7: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L290 TraceCheckUtils]: 8: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L290 TraceCheckUtils]: 9: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {14787#true} {14787#true} #79#return; {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L290 TraceCheckUtils]: 11: Hoare triple {14787#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L272 TraceCheckUtils]: 12: Hoare triple {14787#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L290 TraceCheckUtils]: 13: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,951 INFO L290 TraceCheckUtils]: 14: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L290 TraceCheckUtils]: 15: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {14787#true} {14787#true} #81#return; {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L272 TraceCheckUtils]: 17: Hoare triple {14787#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L290 TraceCheckUtils]: 18: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L290 TraceCheckUtils]: 19: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L290 TraceCheckUtils]: 20: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {14787#true} {14787#true} #83#return; {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L272 TraceCheckUtils]: 22: Hoare triple {14787#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L290 TraceCheckUtils]: 23: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L290 TraceCheckUtils]: 24: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L290 TraceCheckUtils]: 25: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {14787#true} {14787#true} #85#return; {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L290 TraceCheckUtils]: 27: Hoare triple {14787#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {14787#true} is VALID [2022-04-15 08:52:19,952 INFO L272 TraceCheckUtils]: 28: Hoare triple {14787#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,960 INFO L290 TraceCheckUtils]: 29: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,960 INFO L290 TraceCheckUtils]: 30: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,960 INFO L290 TraceCheckUtils]: 31: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,960 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {14787#true} {14787#true} #87#return; {14787#true} is VALID [2022-04-15 08:52:19,960 INFO L272 TraceCheckUtils]: 33: Hoare triple {14787#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,960 INFO L290 TraceCheckUtils]: 34: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L290 TraceCheckUtils]: 35: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L290 TraceCheckUtils]: 36: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {14787#true} {14787#true} #89#return; {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L290 TraceCheckUtils]: 38: Hoare triple {14787#true} assume !false; {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L290 TraceCheckUtils]: 39: Hoare triple {14787#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L290 TraceCheckUtils]: 40: Hoare triple {14787#true} assume !false; {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L272 TraceCheckUtils]: 41: Hoare triple {14787#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L290 TraceCheckUtils]: 42: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L290 TraceCheckUtils]: 43: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L290 TraceCheckUtils]: 44: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {14787#true} {14787#true} #91#return; {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L272 TraceCheckUtils]: 46: Hoare triple {14787#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,961 INFO L290 TraceCheckUtils]: 47: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L290 TraceCheckUtils]: 48: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L290 TraceCheckUtils]: 49: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {14787#true} {14787#true} #93#return; {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L272 TraceCheckUtils]: 51: Hoare triple {14787#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L290 TraceCheckUtils]: 52: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L290 TraceCheckUtils]: 53: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L290 TraceCheckUtils]: 54: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {14787#true} {14787#true} #95#return; {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L272 TraceCheckUtils]: 56: Hoare triple {14787#true} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L290 TraceCheckUtils]: 57: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L290 TraceCheckUtils]: 58: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L290 TraceCheckUtils]: 59: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,962 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {14787#true} {14787#true} #97#return; {14787#true} is VALID [2022-04-15 08:52:19,963 INFO L290 TraceCheckUtils]: 61: Hoare triple {14787#true} assume !(~c~0 >= ~b~0); {14975#(not (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:19,963 INFO L290 TraceCheckUtils]: 62: Hoare triple {14975#(not (<= main_~b~0 main_~c~0))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {14979#(< main_~b~0 main_~a~0)} is VALID [2022-04-15 08:52:19,964 INFO L290 TraceCheckUtils]: 63: Hoare triple {14979#(< main_~b~0 main_~a~0)} assume !false; {14979#(< main_~b~0 main_~a~0)} is VALID [2022-04-15 08:52:19,964 INFO L290 TraceCheckUtils]: 64: Hoare triple {14979#(< main_~b~0 main_~a~0)} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:19,964 INFO L290 TraceCheckUtils]: 65: Hoare triple {14986#(< main_~b~0 main_~c~0)} assume !false; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:19,964 INFO L272 TraceCheckUtils]: 66: Hoare triple {14986#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,964 INFO L290 TraceCheckUtils]: 67: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,964 INFO L290 TraceCheckUtils]: 68: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,965 INFO L290 TraceCheckUtils]: 69: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,965 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {14787#true} {14986#(< main_~b~0 main_~c~0)} #91#return; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:19,965 INFO L272 TraceCheckUtils]: 71: Hoare triple {14986#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,965 INFO L290 TraceCheckUtils]: 72: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,965 INFO L290 TraceCheckUtils]: 73: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,965 INFO L290 TraceCheckUtils]: 74: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,966 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {14787#true} {14986#(< main_~b~0 main_~c~0)} #93#return; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:19,966 INFO L272 TraceCheckUtils]: 76: Hoare triple {14986#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,966 INFO L290 TraceCheckUtils]: 77: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,966 INFO L290 TraceCheckUtils]: 78: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,966 INFO L290 TraceCheckUtils]: 79: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,967 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {14787#true} {14986#(< main_~b~0 main_~c~0)} #95#return; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:19,967 INFO L272 TraceCheckUtils]: 81: Hoare triple {14986#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,967 INFO L290 TraceCheckUtils]: 82: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,967 INFO L290 TraceCheckUtils]: 83: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,967 INFO L290 TraceCheckUtils]: 84: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,967 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {14787#true} {14986#(< main_~b~0 main_~c~0)} #97#return; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:19,968 INFO L290 TraceCheckUtils]: 86: Hoare triple {14986#(< main_~b~0 main_~c~0)} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:19,969 INFO L290 TraceCheckUtils]: 87: Hoare triple {15053#(< 0 main_~c~0)} assume !false; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:19,969 INFO L272 TraceCheckUtils]: 88: Hoare triple {15053#(< 0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,969 INFO L290 TraceCheckUtils]: 89: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,969 INFO L290 TraceCheckUtils]: 90: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,969 INFO L290 TraceCheckUtils]: 91: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,969 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {14787#true} {15053#(< 0 main_~c~0)} #91#return; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:19,970 INFO L272 TraceCheckUtils]: 93: Hoare triple {15053#(< 0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,970 INFO L290 TraceCheckUtils]: 94: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,970 INFO L290 TraceCheckUtils]: 95: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,970 INFO L290 TraceCheckUtils]: 96: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,970 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {14787#true} {15053#(< 0 main_~c~0)} #93#return; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:19,970 INFO L272 TraceCheckUtils]: 98: Hoare triple {15053#(< 0 main_~c~0)} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,970 INFO L290 TraceCheckUtils]: 99: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,970 INFO L290 TraceCheckUtils]: 100: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,971 INFO L290 TraceCheckUtils]: 101: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,971 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {14787#true} {15053#(< 0 main_~c~0)} #95#return; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:19,971 INFO L272 TraceCheckUtils]: 103: Hoare triple {15053#(< 0 main_~c~0)} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:19,971 INFO L290 TraceCheckUtils]: 104: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:19,971 INFO L290 TraceCheckUtils]: 105: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:19,971 INFO L290 TraceCheckUtils]: 106: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:19,972 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {14787#true} {15053#(< 0 main_~c~0)} #97#return; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:19,972 INFO L290 TraceCheckUtils]: 108: Hoare triple {15053#(< 0 main_~c~0)} assume !(~c~0 >= ~b~0); {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:19,973 INFO L290 TraceCheckUtils]: 109: Hoare triple {15053#(< 0 main_~c~0)} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {15123#(< 0 main_~b~0)} is VALID [2022-04-15 08:52:19,973 INFO L290 TraceCheckUtils]: 110: Hoare triple {15123#(< 0 main_~b~0)} assume !false; {15123#(< 0 main_~b~0)} is VALID [2022-04-15 08:52:19,973 INFO L290 TraceCheckUtils]: 111: Hoare triple {15123#(< 0 main_~b~0)} assume !(0 != ~b~0); {14788#false} is VALID [2022-04-15 08:52:19,973 INFO L272 TraceCheckUtils]: 112: Hoare triple {14788#false} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {14788#false} is VALID [2022-04-15 08:52:19,973 INFO L290 TraceCheckUtils]: 113: Hoare triple {14788#false} ~cond := #in~cond; {14788#false} is VALID [2022-04-15 08:52:19,973 INFO L290 TraceCheckUtils]: 114: Hoare triple {14788#false} assume 0 == ~cond; {14788#false} is VALID [2022-04-15 08:52:19,973 INFO L290 TraceCheckUtils]: 115: Hoare triple {14788#false} assume !false; {14788#false} is VALID [2022-04-15 08:52:19,974 INFO L134 CoverageAnalysis]: Checked inductivity of 373 backedges. 40 proven. 9 refuted. 0 times theorem prover too weak. 324 trivial. 0 not checked. [2022-04-15 08:52:19,974 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:52:20,278 INFO L290 TraceCheckUtils]: 115: Hoare triple {14788#false} assume !false; {14788#false} is VALID [2022-04-15 08:52:20,278 INFO L290 TraceCheckUtils]: 114: Hoare triple {14788#false} assume 0 == ~cond; {14788#false} is VALID [2022-04-15 08:52:20,278 INFO L290 TraceCheckUtils]: 113: Hoare triple {14788#false} ~cond := #in~cond; {14788#false} is VALID [2022-04-15 08:52:20,278 INFO L272 TraceCheckUtils]: 112: Hoare triple {14788#false} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {14788#false} is VALID [2022-04-15 08:52:20,279 INFO L290 TraceCheckUtils]: 111: Hoare triple {15123#(< 0 main_~b~0)} assume !(0 != ~b~0); {14788#false} is VALID [2022-04-15 08:52:20,279 INFO L290 TraceCheckUtils]: 110: Hoare triple {15123#(< 0 main_~b~0)} assume !false; {15123#(< 0 main_~b~0)} is VALID [2022-04-15 08:52:20,279 INFO L290 TraceCheckUtils]: 109: Hoare triple {15053#(< 0 main_~c~0)} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {15123#(< 0 main_~b~0)} is VALID [2022-04-15 08:52:20,280 INFO L290 TraceCheckUtils]: 108: Hoare triple {15053#(< 0 main_~c~0)} assume !(~c~0 >= ~b~0); {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:20,280 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {14787#true} {15053#(< 0 main_~c~0)} #97#return; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:20,280 INFO L290 TraceCheckUtils]: 106: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,280 INFO L290 TraceCheckUtils]: 105: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,280 INFO L290 TraceCheckUtils]: 104: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,280 INFO L272 TraceCheckUtils]: 103: Hoare triple {15053#(< 0 main_~c~0)} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,281 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {14787#true} {15053#(< 0 main_~c~0)} #95#return; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:20,281 INFO L290 TraceCheckUtils]: 101: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,281 INFO L290 TraceCheckUtils]: 100: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,281 INFO L290 TraceCheckUtils]: 99: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,281 INFO L272 TraceCheckUtils]: 98: Hoare triple {15053#(< 0 main_~c~0)} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,285 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {14787#true} {15053#(< 0 main_~c~0)} #93#return; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:20,285 INFO L290 TraceCheckUtils]: 96: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,285 INFO L290 TraceCheckUtils]: 95: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,286 INFO L290 TraceCheckUtils]: 94: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,286 INFO L272 TraceCheckUtils]: 93: Hoare triple {15053#(< 0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,286 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {14787#true} {15053#(< 0 main_~c~0)} #91#return; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:20,286 INFO L290 TraceCheckUtils]: 91: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,286 INFO L290 TraceCheckUtils]: 90: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,286 INFO L290 TraceCheckUtils]: 89: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,286 INFO L272 TraceCheckUtils]: 88: Hoare triple {15053#(< 0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,287 INFO L290 TraceCheckUtils]: 87: Hoare triple {15053#(< 0 main_~c~0)} assume !false; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:20,288 INFO L290 TraceCheckUtils]: 86: Hoare triple {14986#(< main_~b~0 main_~c~0)} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {15053#(< 0 main_~c~0)} is VALID [2022-04-15 08:52:20,288 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {14787#true} {14986#(< main_~b~0 main_~c~0)} #97#return; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:20,288 INFO L290 TraceCheckUtils]: 84: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,288 INFO L290 TraceCheckUtils]: 83: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,288 INFO L290 TraceCheckUtils]: 82: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,288 INFO L272 TraceCheckUtils]: 81: Hoare triple {14986#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,289 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {14787#true} {14986#(< main_~b~0 main_~c~0)} #95#return; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:20,289 INFO L290 TraceCheckUtils]: 79: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,289 INFO L290 TraceCheckUtils]: 78: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,289 INFO L290 TraceCheckUtils]: 77: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,289 INFO L272 TraceCheckUtils]: 76: Hoare triple {14986#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,290 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {14787#true} {14986#(< main_~b~0 main_~c~0)} #93#return; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:20,290 INFO L290 TraceCheckUtils]: 74: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,290 INFO L290 TraceCheckUtils]: 73: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,290 INFO L290 TraceCheckUtils]: 72: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,290 INFO L272 TraceCheckUtils]: 71: Hoare triple {14986#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,290 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {14787#true} {14986#(< main_~b~0 main_~c~0)} #91#return; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:20,291 INFO L290 TraceCheckUtils]: 69: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,291 INFO L290 TraceCheckUtils]: 68: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,291 INFO L290 TraceCheckUtils]: 67: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,291 INFO L272 TraceCheckUtils]: 66: Hoare triple {14986#(< main_~b~0 main_~c~0)} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,291 INFO L290 TraceCheckUtils]: 65: Hoare triple {14986#(< main_~b~0 main_~c~0)} assume !false; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:20,291 INFO L290 TraceCheckUtils]: 64: Hoare triple {14979#(< main_~b~0 main_~a~0)} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {14986#(< main_~b~0 main_~c~0)} is VALID [2022-04-15 08:52:20,292 INFO L290 TraceCheckUtils]: 63: Hoare triple {14979#(< main_~b~0 main_~a~0)} assume !false; {14979#(< main_~b~0 main_~a~0)} is VALID [2022-04-15 08:52:20,292 INFO L290 TraceCheckUtils]: 62: Hoare triple {14975#(not (<= main_~b~0 main_~c~0))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {14979#(< main_~b~0 main_~a~0)} is VALID [2022-04-15 08:52:20,292 INFO L290 TraceCheckUtils]: 61: Hoare triple {14787#true} assume !(~c~0 >= ~b~0); {14975#(not (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:20,292 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {14787#true} {14787#true} #97#return; {14787#true} is VALID [2022-04-15 08:52:20,292 INFO L290 TraceCheckUtils]: 59: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,292 INFO L290 TraceCheckUtils]: 58: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L290 TraceCheckUtils]: 57: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L272 TraceCheckUtils]: 56: Hoare triple {14787#true} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {14787#true} {14787#true} #95#return; {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L290 TraceCheckUtils]: 54: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L290 TraceCheckUtils]: 53: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L290 TraceCheckUtils]: 52: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L272 TraceCheckUtils]: 51: Hoare triple {14787#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {14787#true} {14787#true} #93#return; {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L290 TraceCheckUtils]: 49: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L290 TraceCheckUtils]: 48: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L290 TraceCheckUtils]: 47: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L272 TraceCheckUtils]: 46: Hoare triple {14787#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {14787#true} {14787#true} #91#return; {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L290 TraceCheckUtils]: 44: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,293 INFO L290 TraceCheckUtils]: 43: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L290 TraceCheckUtils]: 42: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L272 TraceCheckUtils]: 41: Hoare triple {14787#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L290 TraceCheckUtils]: 40: Hoare triple {14787#true} assume !false; {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L290 TraceCheckUtils]: 39: Hoare triple {14787#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L290 TraceCheckUtils]: 38: Hoare triple {14787#true} assume !false; {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {14787#true} {14787#true} #89#return; {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L290 TraceCheckUtils]: 36: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L290 TraceCheckUtils]: 35: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L290 TraceCheckUtils]: 34: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L272 TraceCheckUtils]: 33: Hoare triple {14787#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {14787#true} {14787#true} #87#return; {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L290 TraceCheckUtils]: 31: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,294 INFO L290 TraceCheckUtils]: 30: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L290 TraceCheckUtils]: 29: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L272 TraceCheckUtils]: 28: Hoare triple {14787#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L290 TraceCheckUtils]: 27: Hoare triple {14787#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {14787#true} {14787#true} #85#return; {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L290 TraceCheckUtils]: 25: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L290 TraceCheckUtils]: 24: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L290 TraceCheckUtils]: 23: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L272 TraceCheckUtils]: 22: Hoare triple {14787#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {14787#true} {14787#true} #83#return; {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L290 TraceCheckUtils]: 20: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L290 TraceCheckUtils]: 19: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L290 TraceCheckUtils]: 18: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,295 INFO L272 TraceCheckUtils]: 17: Hoare triple {14787#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {14787#true} {14787#true} #81#return; {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L290 TraceCheckUtils]: 15: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L290 TraceCheckUtils]: 14: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L290 TraceCheckUtils]: 13: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L272 TraceCheckUtils]: 12: Hoare triple {14787#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L290 TraceCheckUtils]: 11: Hoare triple {14787#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {14787#true} {14787#true} #79#return; {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L290 TraceCheckUtils]: 9: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L290 TraceCheckUtils]: 8: Hoare triple {14787#true} assume !(0 == ~cond); {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L290 TraceCheckUtils]: 7: Hoare triple {14787#true} ~cond := #in~cond; {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L272 TraceCheckUtils]: 6: Hoare triple {14787#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L290 TraceCheckUtils]: 5: Hoare triple {14787#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L272 TraceCheckUtils]: 4: Hoare triple {14787#true} call #t~ret6 := main(); {14787#true} is VALID [2022-04-15 08:52:20,296 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {14787#true} {14787#true} #103#return; {14787#true} is VALID [2022-04-15 08:52:20,297 INFO L290 TraceCheckUtils]: 2: Hoare triple {14787#true} assume true; {14787#true} is VALID [2022-04-15 08:52:20,297 INFO L290 TraceCheckUtils]: 1: Hoare triple {14787#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {14787#true} is VALID [2022-04-15 08:52:20,297 INFO L272 TraceCheckUtils]: 0: Hoare triple {14787#true} call ULTIMATE.init(); {14787#true} is VALID [2022-04-15 08:52:20,297 INFO L134 CoverageAnalysis]: Checked inductivity of 373 backedges. 40 proven. 9 refuted. 0 times theorem prover too weak. 324 trivial. 0 not checked. [2022-04-15 08:52:20,297 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:52:20,297 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1124911896] [2022-04-15 08:52:20,297 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:52:20,297 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [648778429] [2022-04-15 08:52:20,297 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [648778429] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:52:20,297 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:52:20,298 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [7, 7] total 7 [2022-04-15 08:52:20,298 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:52:20,298 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1256446506] [2022-04-15 08:52:20,298 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1256446506] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:52:20,298 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:52:20,298 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [7] imperfect sequences [] total 7 [2022-04-15 08:52:20,298 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [117833418] [2022-04-15 08:52:20,298 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:52:20,298 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 4.0) internal successors, (28), 7 states have internal predecessors, (28), 4 states have call successors, (21), 2 states have call predecessors, (21), 1 states have return successors, (19), 3 states have call predecessors, (19), 3 states have call successors, (19) Word has length 116 [2022-04-15 08:52:20,299 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:52:20,299 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 7 states, 7 states have (on average 4.0) internal successors, (28), 7 states have internal predecessors, (28), 4 states have call successors, (21), 2 states have call predecessors, (21), 1 states have return successors, (19), 3 states have call predecessors, (19), 3 states have call successors, (19) [2022-04-15 08:52:20,357 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 68 edges. 68 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:20,357 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 7 states [2022-04-15 08:52:20,357 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:52:20,357 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 7 interpolants. [2022-04-15 08:52:20,357 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=11, Invalid=31, Unknown=0, NotChecked=0, Total=42 [2022-04-15 08:52:20,357 INFO L87 Difference]: Start difference. First operand 188 states and 245 transitions. Second operand has 7 states, 7 states have (on average 4.0) internal successors, (28), 7 states have internal predecessors, (28), 4 states have call successors, (21), 2 states have call predecessors, (21), 1 states have return successors, (19), 3 states have call predecessors, (19), 3 states have call successors, (19) [2022-04-15 08:52:21,948 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:21,948 INFO L93 Difference]: Finished difference Result 248 states and 345 transitions. [2022-04-15 08:52:21,948 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 12 states. [2022-04-15 08:52:21,948 INFO L78 Accepts]: Start accepts. Automaton has has 7 states, 7 states have (on average 4.0) internal successors, (28), 7 states have internal predecessors, (28), 4 states have call successors, (21), 2 states have call predecessors, (21), 1 states have return successors, (19), 3 states have call predecessors, (19), 3 states have call successors, (19) Word has length 116 [2022-04-15 08:52:21,948 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:52:21,949 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 4.0) internal successors, (28), 7 states have internal predecessors, (28), 4 states have call successors, (21), 2 states have call predecessors, (21), 1 states have return successors, (19), 3 states have call predecessors, (19), 3 states have call successors, (19) [2022-04-15 08:52:21,951 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 12 states to 12 states and 126 transitions. [2022-04-15 08:52:21,951 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 7 states, 7 states have (on average 4.0) internal successors, (28), 7 states have internal predecessors, (28), 4 states have call successors, (21), 2 states have call predecessors, (21), 1 states have return successors, (19), 3 states have call predecessors, (19), 3 states have call successors, (19) [2022-04-15 08:52:21,953 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 12 states to 12 states and 126 transitions. [2022-04-15 08:52:21,953 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 12 states and 126 transitions. [2022-04-15 08:52:22,070 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 126 edges. 126 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:22,075 INFO L225 Difference]: With dead ends: 248 [2022-04-15 08:52:22,075 INFO L226 Difference]: Without dead ends: 240 [2022-04-15 08:52:22,076 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 242 GetRequests, 227 SyntacticMatches, 2 SemanticMatches, 13 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 22 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=62, Invalid=148, Unknown=0, NotChecked=0, Total=210 [2022-04-15 08:52:22,077 INFO L913 BasicCegarLoop]: 85 mSDtfsCounter, 14 mSDsluCounter, 195 mSDsCounter, 0 mSdLazyCounter, 205 mSolverCounterSat, 40 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.5s Time, 0 mProtectedPredicate, 0 mProtectedAction, 19 SdHoareTripleChecker+Valid, 280 SdHoareTripleChecker+Invalid, 245 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 40 IncrementalHoareTripleChecker+Valid, 205 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.5s IncrementalHoareTripleChecker+Time [2022-04-15 08:52:22,078 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [19 Valid, 280 Invalid, 245 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [40 Valid, 205 Invalid, 0 Unknown, 0 Unchecked, 0.5s Time] [2022-04-15 08:52:22,078 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 240 states. [2022-04-15 08:52:22,576 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 240 to 221. [2022-04-15 08:52:22,576 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:52:22,577 INFO L82 GeneralOperation]: Start isEquivalent. First operand 240 states. Second operand has 221 states, 115 states have (on average 1.1478260869565218) internal successors, (132), 117 states have internal predecessors, (132), 87 states have call successors, (87), 19 states have call predecessors, (87), 18 states have return successors, (84), 84 states have call predecessors, (84), 84 states have call successors, (84) [2022-04-15 08:52:22,577 INFO L74 IsIncluded]: Start isIncluded. First operand 240 states. Second operand has 221 states, 115 states have (on average 1.1478260869565218) internal successors, (132), 117 states have internal predecessors, (132), 87 states have call successors, (87), 19 states have call predecessors, (87), 18 states have return successors, (84), 84 states have call predecessors, (84), 84 states have call successors, (84) [2022-04-15 08:52:22,577 INFO L87 Difference]: Start difference. First operand 240 states. Second operand has 221 states, 115 states have (on average 1.1478260869565218) internal successors, (132), 117 states have internal predecessors, (132), 87 states have call successors, (87), 19 states have call predecessors, (87), 18 states have return successors, (84), 84 states have call predecessors, (84), 84 states have call successors, (84) [2022-04-15 08:52:22,582 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:22,582 INFO L93 Difference]: Finished difference Result 240 states and 336 transitions. [2022-04-15 08:52:22,582 INFO L276 IsEmpty]: Start isEmpty. Operand 240 states and 336 transitions. [2022-04-15 08:52:22,583 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:52:22,583 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:52:22,583 INFO L74 IsIncluded]: Start isIncluded. First operand has 221 states, 115 states have (on average 1.1478260869565218) internal successors, (132), 117 states have internal predecessors, (132), 87 states have call successors, (87), 19 states have call predecessors, (87), 18 states have return successors, (84), 84 states have call predecessors, (84), 84 states have call successors, (84) Second operand 240 states. [2022-04-15 08:52:22,584 INFO L87 Difference]: Start difference. First operand has 221 states, 115 states have (on average 1.1478260869565218) internal successors, (132), 117 states have internal predecessors, (132), 87 states have call successors, (87), 19 states have call predecessors, (87), 18 states have return successors, (84), 84 states have call predecessors, (84), 84 states have call successors, (84) Second operand 240 states. [2022-04-15 08:52:22,589 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:22,589 INFO L93 Difference]: Finished difference Result 240 states and 336 transitions. [2022-04-15 08:52:22,589 INFO L276 IsEmpty]: Start isEmpty. Operand 240 states and 336 transitions. [2022-04-15 08:52:22,589 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:52:22,589 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:52:22,590 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:52:22,590 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:52:22,590 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 221 states, 115 states have (on average 1.1478260869565218) internal successors, (132), 117 states have internal predecessors, (132), 87 states have call successors, (87), 19 states have call predecessors, (87), 18 states have return successors, (84), 84 states have call predecessors, (84), 84 states have call successors, (84) [2022-04-15 08:52:22,594 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 221 states to 221 states and 303 transitions. [2022-04-15 08:52:22,595 INFO L78 Accepts]: Start accepts. Automaton has 221 states and 303 transitions. Word has length 116 [2022-04-15 08:52:22,595 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:52:22,595 INFO L478 AbstractCegarLoop]: Abstraction has 221 states and 303 transitions. [2022-04-15 08:52:22,595 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 7 states, 7 states have (on average 4.0) internal successors, (28), 7 states have internal predecessors, (28), 4 states have call successors, (21), 2 states have call predecessors, (21), 1 states have return successors, (19), 3 states have call predecessors, (19), 3 states have call successors, (19) [2022-04-15 08:52:22,595 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 221 states and 303 transitions. [2022-04-15 08:52:23,199 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 303 edges. 303 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:23,199 INFO L276 IsEmpty]: Start isEmpty. Operand 221 states and 303 transitions. [2022-04-15 08:52:23,200 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 123 [2022-04-15 08:52:23,200 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:52:23,200 INFO L499 BasicCegarLoop]: trace histogram [14, 13, 13, 6, 6, 6, 4, 4, 4, 4, 3, 3, 3, 3, 3, 3, 3, 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] [2022-04-15 08:52:23,219 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (16)] Forceful destruction successful, exit code 0 [2022-04-15 08:52:23,400 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 16 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable15 [2022-04-15 08:52:23,401 INFO L403 AbstractCegarLoop]: === Iteration 17 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:52:23,401 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:52:23,401 INFO L85 PathProgramCache]: Analyzing trace with hash -743412771, now seen corresponding path program 3 times [2022-04-15 08:52:23,401 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:52:23,401 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [1045709567] [2022-04-15 08:52:23,401 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:52:23,401 INFO L85 PathProgramCache]: Analyzing trace with hash -743412771, now seen corresponding path program 4 times [2022-04-15 08:52:23,402 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:52:23,402 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1130925263] [2022-04-15 08:52:23,402 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:52:23,402 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:52:23,411 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:52:23,412 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1144715736] [2022-04-15 08:52:23,412 INFO L93 rtionOrderModulation]: Changing assertion order to TERMS_WITH_SMALL_CONSTANTS_FIRST [2022-04-15 08:52:23,412 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:52:23,412 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:52:23,413 INFO L229 MonitoredProcess]: Starting monitored process 17 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:52:23,414 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (17)] Waiting until timeout for monitored process [2022-04-15 08:52:23,470 INFO L228 tOrderPrioritization]: Assert order TERMS_WITH_SMALL_CONSTANTS_FIRST issued 0 check-sat command(s) [2022-04-15 08:52:23,470 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:52:23,471 INFO L263 TraceCheckSpWp]: Trace formula consists of 265 conjuncts, 14 conjunts are in the unsatisfiable core [2022-04-15 08:52:23,486 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:52:23,487 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:52:23,723 INFO L272 TraceCheckUtils]: 0: Hoare triple {16926#true} call ULTIMATE.init(); {16926#true} is VALID [2022-04-15 08:52:23,723 INFO L290 TraceCheckUtils]: 1: Hoare triple {16926#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {16926#true} is VALID [2022-04-15 08:52:23,723 INFO L290 TraceCheckUtils]: 2: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,723 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {16926#true} {16926#true} #103#return; {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L272 TraceCheckUtils]: 4: Hoare triple {16926#true} call #t~ret6 := main(); {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L290 TraceCheckUtils]: 5: Hoare triple {16926#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L272 TraceCheckUtils]: 6: Hoare triple {16926#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L290 TraceCheckUtils]: 7: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L290 TraceCheckUtils]: 8: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L290 TraceCheckUtils]: 9: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {16926#true} {16926#true} #79#return; {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L290 TraceCheckUtils]: 11: Hoare triple {16926#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L272 TraceCheckUtils]: 12: Hoare triple {16926#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L290 TraceCheckUtils]: 13: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L290 TraceCheckUtils]: 14: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L290 TraceCheckUtils]: 15: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {16926#true} {16926#true} #81#return; {16926#true} is VALID [2022-04-15 08:52:23,724 INFO L272 TraceCheckUtils]: 17: Hoare triple {16926#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 18: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 19: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 20: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {16926#true} {16926#true} #83#return; {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L272 TraceCheckUtils]: 22: Hoare triple {16926#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 23: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 24: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 25: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {16926#true} {16926#true} #85#return; {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 27: Hoare triple {16926#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L272 TraceCheckUtils]: 28: Hoare triple {16926#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 29: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 30: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L290 TraceCheckUtils]: 31: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,725 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {16926#true} {16926#true} #87#return; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L272 TraceCheckUtils]: 33: Hoare triple {16926#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L290 TraceCheckUtils]: 34: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L290 TraceCheckUtils]: 35: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L290 TraceCheckUtils]: 36: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {16926#true} {16926#true} #89#return; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L290 TraceCheckUtils]: 38: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L290 TraceCheckUtils]: 39: Hoare triple {16926#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L290 TraceCheckUtils]: 40: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L272 TraceCheckUtils]: 41: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L290 TraceCheckUtils]: 42: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L290 TraceCheckUtils]: 43: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L290 TraceCheckUtils]: 44: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {16926#true} {16926#true} #91#return; {16926#true} is VALID [2022-04-15 08:52:23,726 INFO L272 TraceCheckUtils]: 46: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L290 TraceCheckUtils]: 47: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L290 TraceCheckUtils]: 48: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L290 TraceCheckUtils]: 49: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {16926#true} {16926#true} #93#return; {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L272 TraceCheckUtils]: 51: Hoare triple {16926#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L290 TraceCheckUtils]: 52: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L290 TraceCheckUtils]: 53: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L290 TraceCheckUtils]: 54: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {16926#true} {16926#true} #95#return; {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L272 TraceCheckUtils]: 56: Hoare triple {16926#true} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L290 TraceCheckUtils]: 57: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L290 TraceCheckUtils]: 58: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L290 TraceCheckUtils]: 59: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,727 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {16926#true} {16926#true} #97#return; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 61: Hoare triple {16926#true} assume !(~c~0 >= ~b~0); {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 62: Hoare triple {16926#true} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 63: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 64: Hoare triple {16926#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 65: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L272 TraceCheckUtils]: 66: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 67: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 68: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 69: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {16926#true} {16926#true} #91#return; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L272 TraceCheckUtils]: 71: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 72: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 73: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L290 TraceCheckUtils]: 74: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,728 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {16926#true} {16926#true} #93#return; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L272 TraceCheckUtils]: 76: Hoare triple {16926#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 77: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 78: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 79: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {16926#true} {16926#true} #95#return; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L272 TraceCheckUtils]: 81: Hoare triple {16926#true} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 82: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 83: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 84: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {16926#true} {16926#true} #97#return; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 86: Hoare triple {16926#true} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 87: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L272 TraceCheckUtils]: 88: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 89: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,729 INFO L290 TraceCheckUtils]: 90: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,730 INFO L290 TraceCheckUtils]: 91: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,730 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {16926#true} {16926#true} #91#return; {16926#true} is VALID [2022-04-15 08:52:23,730 INFO L272 TraceCheckUtils]: 93: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,730 INFO L290 TraceCheckUtils]: 94: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,730 INFO L290 TraceCheckUtils]: 95: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,730 INFO L290 TraceCheckUtils]: 96: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,730 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {16926#true} {16926#true} #93#return; {16926#true} is VALID [2022-04-15 08:52:23,730 INFO L272 TraceCheckUtils]: 98: Hoare triple {16926#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,730 INFO L290 TraceCheckUtils]: 99: Hoare triple {16926#true} ~cond := #in~cond; {17228#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:23,731 INFO L290 TraceCheckUtils]: 100: Hoare triple {17228#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {17232#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:23,731 INFO L290 TraceCheckUtils]: 101: Hoare triple {17232#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {17232#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:23,732 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {17232#(not (= |__VERIFIER_assert_#in~cond| 0))} {16926#true} #95#return; {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:23,732 INFO L272 TraceCheckUtils]: 103: Hoare triple {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,732 INFO L290 TraceCheckUtils]: 104: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,732 INFO L290 TraceCheckUtils]: 105: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,732 INFO L290 TraceCheckUtils]: 106: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,732 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {16926#true} {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} #97#return; {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:23,733 INFO L290 TraceCheckUtils]: 108: Hoare triple {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} assume !(~c~0 >= ~b~0); {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:23,733 INFO L290 TraceCheckUtils]: 109: Hoare triple {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:23,734 INFO L290 TraceCheckUtils]: 110: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} assume !false; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:23,734 INFO L290 TraceCheckUtils]: 111: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:23,734 INFO L290 TraceCheckUtils]: 112: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} assume !false; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:23,734 INFO L272 TraceCheckUtils]: 113: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:23,734 INFO L290 TraceCheckUtils]: 114: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:23,735 INFO L290 TraceCheckUtils]: 115: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:23,735 INFO L290 TraceCheckUtils]: 116: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:23,735 INFO L284 TraceCheckUtils]: 117: Hoare quadruple {16926#true} {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} #91#return; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:23,736 INFO L272 TraceCheckUtils]: 118: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {17289#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:52:23,736 INFO L290 TraceCheckUtils]: 119: Hoare triple {17289#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {17293#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:23,736 INFO L290 TraceCheckUtils]: 120: Hoare triple {17293#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {16927#false} is VALID [2022-04-15 08:52:23,736 INFO L290 TraceCheckUtils]: 121: Hoare triple {16927#false} assume !false; {16927#false} is VALID [2022-04-15 08:52:23,737 INFO L134 CoverageAnalysis]: Checked inductivity of 432 backedges. 73 proven. 7 refuted. 0 times theorem prover too weak. 352 trivial. 0 not checked. [2022-04-15 08:52:23,737 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:52:37,209 INFO L290 TraceCheckUtils]: 121: Hoare triple {16927#false} assume !false; {16927#false} is VALID [2022-04-15 08:52:37,210 INFO L290 TraceCheckUtils]: 120: Hoare triple {17293#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {16927#false} is VALID [2022-04-15 08:52:37,210 INFO L290 TraceCheckUtils]: 119: Hoare triple {17289#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {17293#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:37,210 INFO L272 TraceCheckUtils]: 118: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {17289#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:52:37,211 INFO L284 TraceCheckUtils]: 117: Hoare quadruple {16926#true} {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} #91#return; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:37,211 INFO L290 TraceCheckUtils]: 116: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,211 INFO L290 TraceCheckUtils]: 115: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,211 INFO L290 TraceCheckUtils]: 114: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,211 INFO L272 TraceCheckUtils]: 113: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,212 INFO L290 TraceCheckUtils]: 112: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} assume !false; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:37,212 INFO L290 TraceCheckUtils]: 111: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:37,212 INFO L290 TraceCheckUtils]: 110: Hoare triple {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} assume !false; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:37,213 INFO L290 TraceCheckUtils]: 109: Hoare triple {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {17261#(= main_~a~0 (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)))} is VALID [2022-04-15 08:52:37,213 INFO L290 TraceCheckUtils]: 108: Hoare triple {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} assume !(~c~0 >= ~b~0); {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:37,214 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {16926#true} {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} #97#return; {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:37,214 INFO L290 TraceCheckUtils]: 106: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,214 INFO L290 TraceCheckUtils]: 105: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,214 INFO L290 TraceCheckUtils]: 104: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,214 INFO L272 TraceCheckUtils]: 103: Hoare triple {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,214 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {17232#(not (= |__VERIFIER_assert_#in~cond| 0))} {16926#true} #95#return; {17239#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:37,215 INFO L290 TraceCheckUtils]: 101: Hoare triple {17232#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {17232#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:37,215 INFO L290 TraceCheckUtils]: 100: Hoare triple {17366#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {17232#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:37,215 INFO L290 TraceCheckUtils]: 99: Hoare triple {16926#true} ~cond := #in~cond; {17366#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:52:37,215 INFO L272 TraceCheckUtils]: 98: Hoare triple {16926#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {16926#true} {16926#true} #93#return; {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L290 TraceCheckUtils]: 96: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L290 TraceCheckUtils]: 95: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L290 TraceCheckUtils]: 94: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L272 TraceCheckUtils]: 93: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {16926#true} {16926#true} #91#return; {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L290 TraceCheckUtils]: 91: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L290 TraceCheckUtils]: 90: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L290 TraceCheckUtils]: 89: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L272 TraceCheckUtils]: 88: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L290 TraceCheckUtils]: 87: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L290 TraceCheckUtils]: 86: Hoare triple {16926#true} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {16926#true} is VALID [2022-04-15 08:52:37,216 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {16926#true} {16926#true} #97#return; {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L290 TraceCheckUtils]: 84: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L290 TraceCheckUtils]: 83: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L290 TraceCheckUtils]: 82: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L272 TraceCheckUtils]: 81: Hoare triple {16926#true} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {16926#true} {16926#true} #95#return; {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L290 TraceCheckUtils]: 79: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L290 TraceCheckUtils]: 78: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L290 TraceCheckUtils]: 77: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L272 TraceCheckUtils]: 76: Hoare triple {16926#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {16926#true} {16926#true} #93#return; {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L290 TraceCheckUtils]: 74: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L290 TraceCheckUtils]: 73: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L290 TraceCheckUtils]: 72: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,217 INFO L272 TraceCheckUtils]: 71: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {16926#true} {16926#true} #91#return; {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 69: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 68: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 67: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L272 TraceCheckUtils]: 66: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 65: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 64: Hoare triple {16926#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 63: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 62: Hoare triple {16926#true} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 61: Hoare triple {16926#true} assume !(~c~0 >= ~b~0); {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {16926#true} {16926#true} #97#return; {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 59: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 58: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,218 INFO L290 TraceCheckUtils]: 57: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L272 TraceCheckUtils]: 56: Hoare triple {16926#true} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {16926#true} {16926#true} #95#return; {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L290 TraceCheckUtils]: 54: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L290 TraceCheckUtils]: 53: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L290 TraceCheckUtils]: 52: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L272 TraceCheckUtils]: 51: Hoare triple {16926#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {16926#true} {16926#true} #93#return; {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L290 TraceCheckUtils]: 49: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L290 TraceCheckUtils]: 48: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L290 TraceCheckUtils]: 47: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L272 TraceCheckUtils]: 46: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {16926#true} {16926#true} #91#return; {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L290 TraceCheckUtils]: 44: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,219 INFO L290 TraceCheckUtils]: 43: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 42: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L272 TraceCheckUtils]: 41: Hoare triple {16926#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 40: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 39: Hoare triple {16926#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 38: Hoare triple {16926#true} assume !false; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {16926#true} {16926#true} #89#return; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 36: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 35: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 34: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L272 TraceCheckUtils]: 33: Hoare triple {16926#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {16926#true} {16926#true} #87#return; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 31: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 30: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L290 TraceCheckUtils]: 29: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,220 INFO L272 TraceCheckUtils]: 28: Hoare triple {16926#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L290 TraceCheckUtils]: 27: Hoare triple {16926#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {16926#true} {16926#true} #85#return; {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L290 TraceCheckUtils]: 25: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L290 TraceCheckUtils]: 24: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L290 TraceCheckUtils]: 23: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L272 TraceCheckUtils]: 22: Hoare triple {16926#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {16926#true} {16926#true} #83#return; {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L290 TraceCheckUtils]: 20: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L290 TraceCheckUtils]: 19: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L290 TraceCheckUtils]: 18: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L272 TraceCheckUtils]: 17: Hoare triple {16926#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {16926#true} {16926#true} #81#return; {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L290 TraceCheckUtils]: 15: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,221 INFO L290 TraceCheckUtils]: 14: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L290 TraceCheckUtils]: 13: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L272 TraceCheckUtils]: 12: Hoare triple {16926#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L290 TraceCheckUtils]: 11: Hoare triple {16926#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {16926#true} {16926#true} #79#return; {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L290 TraceCheckUtils]: 9: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L290 TraceCheckUtils]: 8: Hoare triple {16926#true} assume !(0 == ~cond); {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L290 TraceCheckUtils]: 7: Hoare triple {16926#true} ~cond := #in~cond; {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L272 TraceCheckUtils]: 6: Hoare triple {16926#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L290 TraceCheckUtils]: 5: Hoare triple {16926#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L272 TraceCheckUtils]: 4: Hoare triple {16926#true} call #t~ret6 := main(); {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {16926#true} {16926#true} #103#return; {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L290 TraceCheckUtils]: 2: Hoare triple {16926#true} assume true; {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L290 TraceCheckUtils]: 1: Hoare triple {16926#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {16926#true} is VALID [2022-04-15 08:52:37,222 INFO L272 TraceCheckUtils]: 0: Hoare triple {16926#true} call ULTIMATE.init(); {16926#true} is VALID [2022-04-15 08:52:37,223 INFO L134 CoverageAnalysis]: Checked inductivity of 432 backedges. 73 proven. 7 refuted. 0 times theorem prover too weak. 352 trivial. 0 not checked. [2022-04-15 08:52:37,223 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:52:37,223 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1130925263] [2022-04-15 08:52:37,223 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:52:37,223 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1144715736] [2022-04-15 08:52:37,223 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1144715736] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:52:37,223 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:52:37,223 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [8, 8] total 9 [2022-04-15 08:52:37,223 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:52:37,224 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [1045709567] [2022-04-15 08:52:37,224 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [1045709567] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:52:37,224 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:52:37,224 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [8] imperfect sequences [] total 8 [2022-04-15 08:52:37,224 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [612197943] [2022-04-15 08:52:37,224 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:52:37,224 INFO L78 Accepts]: Start accepts. Automaton has has 8 states, 8 states have (on average 3.5) internal successors, (28), 7 states have internal predecessors, (28), 3 states have call successors, (15), 2 states have call predecessors, (15), 2 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) Word has length 122 [2022-04-15 08:52:37,224 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:52:37,225 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 8 states, 8 states have (on average 3.5) internal successors, (28), 7 states have internal predecessors, (28), 3 states have call successors, (15), 2 states have call predecessors, (15), 2 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-04-15 08:52:37,264 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 57 edges. 57 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:37,264 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 8 states [2022-04-15 08:52:37,264 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:52:37,265 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 8 interpolants. [2022-04-15 08:52:37,265 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=19, Invalid=53, Unknown=0, NotChecked=0, Total=72 [2022-04-15 08:52:37,265 INFO L87 Difference]: Start difference. First operand 221 states and 303 transitions. Second operand has 8 states, 8 states have (on average 3.5) internal successors, (28), 7 states have internal predecessors, (28), 3 states have call successors, (15), 2 states have call predecessors, (15), 2 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-04-15 08:52:38,348 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:38,348 INFO L93 Difference]: Finished difference Result 235 states and 314 transitions. [2022-04-15 08:52:38,348 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 8 states. [2022-04-15 08:52:38,348 INFO L78 Accepts]: Start accepts. Automaton has has 8 states, 8 states have (on average 3.5) internal successors, (28), 7 states have internal predecessors, (28), 3 states have call successors, (15), 2 states have call predecessors, (15), 2 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) Word has length 122 [2022-04-15 08:52:38,348 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:52:38,348 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 8 states, 8 states have (on average 3.5) internal successors, (28), 7 states have internal predecessors, (28), 3 states have call successors, (15), 2 states have call predecessors, (15), 2 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-04-15 08:52:38,349 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 60 transitions. [2022-04-15 08:52:38,349 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 8 states, 8 states have (on average 3.5) internal successors, (28), 7 states have internal predecessors, (28), 3 states have call successors, (15), 2 states have call predecessors, (15), 2 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-04-15 08:52:38,350 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 60 transitions. [2022-04-15 08:52:38,350 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 8 states and 60 transitions. [2022-04-15 08:52:38,411 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 60 edges. 60 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:38,414 INFO L225 Difference]: With dead ends: 235 [2022-04-15 08:52:38,414 INFO L226 Difference]: Without dead ends: 232 [2022-04-15 08:52:38,415 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 246 GetRequests, 235 SyntacticMatches, 1 SemanticMatches, 10 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 7 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=36, Invalid=96, Unknown=0, NotChecked=0, Total=132 [2022-04-15 08:52:38,415 INFO L913 BasicCegarLoop]: 36 mSDtfsCounter, 17 mSDsluCounter, 120 mSDsCounter, 0 mSdLazyCounter, 112 mSolverCounterSat, 17 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.2s Time, 0 mProtectedPredicate, 0 mProtectedAction, 20 SdHoareTripleChecker+Valid, 156 SdHoareTripleChecker+Invalid, 129 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 17 IncrementalHoareTripleChecker+Valid, 112 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.2s IncrementalHoareTripleChecker+Time [2022-04-15 08:52:38,415 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [20 Valid, 156 Invalid, 129 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [17 Valid, 112 Invalid, 0 Unknown, 0 Unchecked, 0.2s Time] [2022-04-15 08:52:38,416 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 232 states. [2022-04-15 08:52:38,928 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 232 to 231. [2022-04-15 08:52:38,928 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:52:38,929 INFO L82 GeneralOperation]: Start isEquivalent. First operand 232 states. Second operand has 231 states, 124 states have (on average 1.1370967741935485) internal successors, (141), 125 states have internal predecessors, (141), 85 states have call successors, (85), 22 states have call predecessors, (85), 21 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:52:38,929 INFO L74 IsIncluded]: Start isIncluded. First operand 232 states. Second operand has 231 states, 124 states have (on average 1.1370967741935485) internal successors, (141), 125 states have internal predecessors, (141), 85 states have call successors, (85), 22 states have call predecessors, (85), 21 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:52:38,929 INFO L87 Difference]: Start difference. First operand 232 states. Second operand has 231 states, 124 states have (on average 1.1370967741935485) internal successors, (141), 125 states have internal predecessors, (141), 85 states have call successors, (85), 22 states have call predecessors, (85), 21 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:52:38,934 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:38,934 INFO L93 Difference]: Finished difference Result 232 states and 310 transitions. [2022-04-15 08:52:38,934 INFO L276 IsEmpty]: Start isEmpty. Operand 232 states and 310 transitions. [2022-04-15 08:52:38,934 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:52:38,935 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:52:38,935 INFO L74 IsIncluded]: Start isIncluded. First operand has 231 states, 124 states have (on average 1.1370967741935485) internal successors, (141), 125 states have internal predecessors, (141), 85 states have call successors, (85), 22 states have call predecessors, (85), 21 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) Second operand 232 states. [2022-04-15 08:52:38,935 INFO L87 Difference]: Start difference. First operand has 231 states, 124 states have (on average 1.1370967741935485) internal successors, (141), 125 states have internal predecessors, (141), 85 states have call successors, (85), 22 states have call predecessors, (85), 21 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) Second operand 232 states. [2022-04-15 08:52:38,940 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:38,940 INFO L93 Difference]: Finished difference Result 232 states and 310 transitions. [2022-04-15 08:52:38,940 INFO L276 IsEmpty]: Start isEmpty. Operand 232 states and 310 transitions. [2022-04-15 08:52:38,940 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:52:38,940 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:52:38,940 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:52:38,940 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:52:38,941 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 231 states, 124 states have (on average 1.1370967741935485) internal successors, (141), 125 states have internal predecessors, (141), 85 states have call successors, (85), 22 states have call predecessors, (85), 21 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:52:38,945 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 231 states to 231 states and 309 transitions. [2022-04-15 08:52:38,945 INFO L78 Accepts]: Start accepts. Automaton has 231 states and 309 transitions. Word has length 122 [2022-04-15 08:52:38,946 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:52:38,946 INFO L478 AbstractCegarLoop]: Abstraction has 231 states and 309 transitions. [2022-04-15 08:52:38,946 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 8 states, 8 states have (on average 3.5) internal successors, (28), 7 states have internal predecessors, (28), 3 states have call successors, (15), 2 states have call predecessors, (15), 2 states have return successors, (14), 3 states have call predecessors, (14), 3 states have call successors, (14) [2022-04-15 08:52:38,946 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 231 states and 309 transitions. [2022-04-15 08:52:39,543 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 309 edges. 309 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:39,543 INFO L276 IsEmpty]: Start isEmpty. Operand 231 states and 309 transitions. [2022-04-15 08:52:39,544 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 128 [2022-04-15 08:52:39,544 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:52:39,544 INFO L499 BasicCegarLoop]: trace histogram [15, 14, 14, 6, 6, 6, 4, 4, 4, 4, 4, 4, 3, 3, 3, 3, 3, 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] [2022-04-15 08:52:39,561 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (17)] Forceful destruction successful, exit code 0 [2022-04-15 08:52:39,747 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 17 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable16 [2022-04-15 08:52:39,747 INFO L403 AbstractCegarLoop]: === Iteration 18 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:52:39,747 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:52:39,747 INFO L85 PathProgramCache]: Analyzing trace with hash 541794983, now seen corresponding path program 5 times [2022-04-15 08:52:39,747 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:52:39,748 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [530722062] [2022-04-15 08:52:39,748 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:52:39,748 INFO L85 PathProgramCache]: Analyzing trace with hash 541794983, now seen corresponding path program 6 times [2022-04-15 08:52:39,748 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:52:39,748 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [2145559408] [2022-04-15 08:52:39,748 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:52:39,748 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:52:39,758 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:52:39,758 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1741116475] [2022-04-15 08:52:39,758 INFO L93 rtionOrderModulation]: Changing assertion order to MIX_INSIDE_OUTSIDE [2022-04-15 08:52:39,759 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:52:39,759 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:52:39,759 INFO L229 MonitoredProcess]: Starting monitored process 18 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:52:39,760 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (18)] Waiting until timeout for monitored process [2022-04-15 08:52:39,831 INFO L228 tOrderPrioritization]: Assert order MIX_INSIDE_OUTSIDE issued 5 check-sat command(s) [2022-04-15 08:52:39,832 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:52:39,833 INFO L263 TraceCheckSpWp]: Trace formula consists of 277 conjuncts, 51 conjunts are in the unsatisfiable core [2022-04-15 08:52:39,850 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:52:39,851 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:52:40,969 INFO L272 TraceCheckUtils]: 0: Hoare triple {19068#true} call ULTIMATE.init(); {19068#true} is VALID [2022-04-15 08:52:40,969 INFO L290 TraceCheckUtils]: 1: Hoare triple {19068#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {19068#true} is VALID [2022-04-15 08:52:40,969 INFO L290 TraceCheckUtils]: 2: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,969 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {19068#true} {19068#true} #103#return; {19068#true} is VALID [2022-04-15 08:52:40,969 INFO L272 TraceCheckUtils]: 4: Hoare triple {19068#true} call #t~ret6 := main(); {19068#true} is VALID [2022-04-15 08:52:40,969 INFO L290 TraceCheckUtils]: 5: Hoare triple {19068#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {19068#true} is VALID [2022-04-15 08:52:40,969 INFO L272 TraceCheckUtils]: 6: Hoare triple {19068#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,969 INFO L290 TraceCheckUtils]: 7: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L290 TraceCheckUtils]: 8: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L290 TraceCheckUtils]: 9: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {19068#true} {19068#true} #79#return; {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L290 TraceCheckUtils]: 11: Hoare triple {19068#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L272 TraceCheckUtils]: 12: Hoare triple {19068#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L290 TraceCheckUtils]: 13: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L290 TraceCheckUtils]: 14: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L290 TraceCheckUtils]: 15: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {19068#true} {19068#true} #81#return; {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L272 TraceCheckUtils]: 17: Hoare triple {19068#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L290 TraceCheckUtils]: 18: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,970 INFO L290 TraceCheckUtils]: 19: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,971 INFO L290 TraceCheckUtils]: 20: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,971 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {19068#true} {19068#true} #83#return; {19068#true} is VALID [2022-04-15 08:52:40,971 INFO L272 TraceCheckUtils]: 22: Hoare triple {19068#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,971 INFO L290 TraceCheckUtils]: 23: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,971 INFO L290 TraceCheckUtils]: 24: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,971 INFO L290 TraceCheckUtils]: 25: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,971 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {19068#true} {19068#true} #85#return; {19068#true} is VALID [2022-04-15 08:52:40,972 INFO L290 TraceCheckUtils]: 27: Hoare triple {19068#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,972 INFO L272 TraceCheckUtils]: 28: Hoare triple {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,972 INFO L290 TraceCheckUtils]: 29: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,972 INFO L290 TraceCheckUtils]: 30: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,972 INFO L290 TraceCheckUtils]: 31: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,973 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {19068#true} {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #87#return; {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,973 INFO L272 TraceCheckUtils]: 33: Hoare triple {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,973 INFO L290 TraceCheckUtils]: 34: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,973 INFO L290 TraceCheckUtils]: 35: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,973 INFO L290 TraceCheckUtils]: 36: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,975 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {19068#true} {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #89#return; {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,975 INFO L290 TraceCheckUtils]: 38: Hoare triple {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,975 INFO L290 TraceCheckUtils]: 39: Hoare triple {19154#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,976 INFO L290 TraceCheckUtils]: 40: Hoare triple {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} assume !false; {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,976 INFO L272 TraceCheckUtils]: 41: Hoare triple {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,976 INFO L290 TraceCheckUtils]: 42: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,976 INFO L290 TraceCheckUtils]: 43: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,976 INFO L290 TraceCheckUtils]: 44: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,977 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {19068#true} {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #91#return; {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,977 INFO L272 TraceCheckUtils]: 46: Hoare triple {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,977 INFO L290 TraceCheckUtils]: 47: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,977 INFO L290 TraceCheckUtils]: 48: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,977 INFO L290 TraceCheckUtils]: 49: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,978 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {19068#true} {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #93#return; {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,978 INFO L272 TraceCheckUtils]: 51: Hoare triple {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,978 INFO L290 TraceCheckUtils]: 52: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,978 INFO L290 TraceCheckUtils]: 53: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,978 INFO L290 TraceCheckUtils]: 54: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,979 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {19068#true} {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #95#return; {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,979 INFO L272 TraceCheckUtils]: 56: Hoare triple {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,979 INFO L290 TraceCheckUtils]: 57: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,979 INFO L290 TraceCheckUtils]: 58: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,979 INFO L290 TraceCheckUtils]: 59: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,979 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {19068#true} {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #97#return; {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,980 INFO L290 TraceCheckUtils]: 61: Hoare triple {19191#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} assume !(~c~0 >= ~b~0); {19258#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (not (<= main_~b~0 main_~c~0)) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:40,981 INFO L290 TraceCheckUtils]: 62: Hoare triple {19258#(and (= main_~r~0 0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (not (<= main_~b~0 main_~c~0)) (= main_~q~0 0) (= main_~c~0 main_~x~0) (= main_~p~0 1))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {19262#(and (= main_~s~0 0) (= main_~p~0 0) (not (<= main_~a~0 main_~x~0)) (= main_~r~0 1) (= main_~a~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} is VALID [2022-04-15 08:52:40,982 INFO L290 TraceCheckUtils]: 63: Hoare triple {19262#(and (= main_~s~0 0) (= main_~p~0 0) (not (<= main_~a~0 main_~x~0)) (= main_~r~0 1) (= main_~a~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} assume !false; {19262#(and (= main_~s~0 0) (= main_~p~0 0) (not (<= main_~a~0 main_~x~0)) (= main_~r~0 1) (= main_~a~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} is VALID [2022-04-15 08:52:40,982 INFO L290 TraceCheckUtils]: 64: Hoare triple {19262#(and (= main_~s~0 0) (= main_~p~0 0) (not (<= main_~a~0 main_~x~0)) (= main_~r~0 1) (= main_~a~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} is VALID [2022-04-15 08:52:40,983 INFO L290 TraceCheckUtils]: 65: Hoare triple {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} assume !false; {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} is VALID [2022-04-15 08:52:40,983 INFO L272 TraceCheckUtils]: 66: Hoare triple {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,983 INFO L290 TraceCheckUtils]: 67: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,983 INFO L290 TraceCheckUtils]: 68: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,983 INFO L290 TraceCheckUtils]: 69: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,983 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {19068#true} {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} #91#return; {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} is VALID [2022-04-15 08:52:40,984 INFO L272 TraceCheckUtils]: 71: Hoare triple {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,984 INFO L290 TraceCheckUtils]: 72: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,984 INFO L290 TraceCheckUtils]: 73: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,984 INFO L290 TraceCheckUtils]: 74: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,984 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {19068#true} {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} #93#return; {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} is VALID [2022-04-15 08:52:40,985 INFO L272 TraceCheckUtils]: 76: Hoare triple {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,985 INFO L290 TraceCheckUtils]: 77: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,985 INFO L290 TraceCheckUtils]: 78: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,985 INFO L290 TraceCheckUtils]: 79: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,985 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {19068#true} {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} #95#return; {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} is VALID [2022-04-15 08:52:40,985 INFO L272 TraceCheckUtils]: 81: Hoare triple {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,986 INFO L290 TraceCheckUtils]: 82: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,986 INFO L290 TraceCheckUtils]: 83: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,986 INFO L290 TraceCheckUtils]: 84: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,986 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {19068#true} {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} #97#return; {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} is VALID [2022-04-15 08:52:40,987 INFO L290 TraceCheckUtils]: 86: Hoare triple {19269#(and (= main_~s~0 0) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~q~0 1) (not (<= main_~c~0 main_~x~0)))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} is VALID [2022-04-15 08:52:40,987 INFO L290 TraceCheckUtils]: 87: Hoare triple {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} assume !false; {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} is VALID [2022-04-15 08:52:40,987 INFO L272 TraceCheckUtils]: 88: Hoare triple {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,988 INFO L290 TraceCheckUtils]: 89: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,988 INFO L290 TraceCheckUtils]: 90: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,988 INFO L290 TraceCheckUtils]: 91: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,988 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {19068#true} {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} #91#return; {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} is VALID [2022-04-15 08:52:40,988 INFO L272 TraceCheckUtils]: 93: Hoare triple {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,988 INFO L290 TraceCheckUtils]: 94: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,989 INFO L290 TraceCheckUtils]: 95: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,989 INFO L290 TraceCheckUtils]: 96: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,989 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {19068#true} {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} #93#return; {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} is VALID [2022-04-15 08:52:40,989 INFO L272 TraceCheckUtils]: 98: Hoare triple {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,989 INFO L290 TraceCheckUtils]: 99: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,990 INFO L290 TraceCheckUtils]: 100: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,990 INFO L290 TraceCheckUtils]: 101: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,990 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {19068#true} {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} #95#return; {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} is VALID [2022-04-15 08:52:40,990 INFO L272 TraceCheckUtils]: 103: Hoare triple {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,990 INFO L290 TraceCheckUtils]: 104: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,991 INFO L290 TraceCheckUtils]: 105: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,991 INFO L290 TraceCheckUtils]: 106: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,991 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {19068#true} {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} #97#return; {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} is VALID [2022-04-15 08:52:40,993 INFO L290 TraceCheckUtils]: 108: Hoare triple {19336#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~b~0 main_~x~0) (= main_~q~0 1))} assume !(~c~0 >= ~b~0); {19403#(and (= main_~x~0 (+ (* (- 1) main_~c~0) main_~y~0)) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (not (<= main_~y~0 (* main_~c~0 2))) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~q~0 1))} is VALID [2022-04-15 08:52:40,994 INFO L290 TraceCheckUtils]: 109: Hoare triple {19403#(and (= main_~x~0 (+ (* (- 1) main_~c~0) main_~y~0)) (= main_~s~0 0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (not (<= main_~y~0 (* main_~c~0 2))) (= main_~r~0 1) (= (+ (- 1) main_~k~0) 0) (= main_~q~0 1))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} is VALID [2022-04-15 08:52:40,994 INFO L290 TraceCheckUtils]: 110: Hoare triple {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} assume !false; {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} is VALID [2022-04-15 08:52:40,995 INFO L290 TraceCheckUtils]: 111: Hoare triple {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} is VALID [2022-04-15 08:52:40,995 INFO L290 TraceCheckUtils]: 112: Hoare triple {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} assume !false; {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} is VALID [2022-04-15 08:52:40,995 INFO L272 TraceCheckUtils]: 113: Hoare triple {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,995 INFO L290 TraceCheckUtils]: 114: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,995 INFO L290 TraceCheckUtils]: 115: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,995 INFO L290 TraceCheckUtils]: 116: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,996 INFO L284 TraceCheckUtils]: 117: Hoare quadruple {19068#true} {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} #91#return; {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} is VALID [2022-04-15 08:52:40,996 INFO L272 TraceCheckUtils]: 118: Hoare triple {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:40,996 INFO L290 TraceCheckUtils]: 119: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:40,996 INFO L290 TraceCheckUtils]: 120: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:40,996 INFO L290 TraceCheckUtils]: 121: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:40,997 INFO L284 TraceCheckUtils]: 122: Hoare quadruple {19068#true} {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} #93#return; {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} is VALID [2022-04-15 08:52:40,998 INFO L272 TraceCheckUtils]: 123: Hoare triple {19407#(and (not (<= main_~y~0 main_~x~0)) (= main_~s~0 1) (not (<= (* main_~x~0 2) main_~y~0)) (= (+ (- 1) (* (- 1) main_~q~0)) 0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {19450#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:52:40,998 INFO L290 TraceCheckUtils]: 124: Hoare triple {19450#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {19454#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:40,998 INFO L290 TraceCheckUtils]: 125: Hoare triple {19454#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {19069#false} is VALID [2022-04-15 08:52:40,998 INFO L290 TraceCheckUtils]: 126: Hoare triple {19069#false} assume !false; {19069#false} is VALID [2022-04-15 08:52:40,999 INFO L134 CoverageAnalysis]: Checked inductivity of 489 backedges. 28 proven. 37 refuted. 0 times theorem prover too weak. 424 trivial. 0 not checked. [2022-04-15 08:52:40,999 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:52:42,510 INFO L290 TraceCheckUtils]: 126: Hoare triple {19069#false} assume !false; {19069#false} is VALID [2022-04-15 08:52:42,510 INFO L290 TraceCheckUtils]: 125: Hoare triple {19454#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {19069#false} is VALID [2022-04-15 08:52:42,510 INFO L290 TraceCheckUtils]: 124: Hoare triple {19450#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {19454#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:42,511 INFO L272 TraceCheckUtils]: 123: Hoare triple {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {19450#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:52:42,512 INFO L284 TraceCheckUtils]: 122: Hoare quadruple {19068#true} {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} #93#return; {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:42,512 INFO L290 TraceCheckUtils]: 121: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:42,512 INFO L290 TraceCheckUtils]: 120: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:42,512 INFO L290 TraceCheckUtils]: 119: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:42,512 INFO L272 TraceCheckUtils]: 118: Hoare triple {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:42,512 INFO L284 TraceCheckUtils]: 117: Hoare quadruple {19068#true} {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} #91#return; {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:42,513 INFO L290 TraceCheckUtils]: 116: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:42,513 INFO L290 TraceCheckUtils]: 115: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:42,513 INFO L290 TraceCheckUtils]: 114: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:42,513 INFO L272 TraceCheckUtils]: 113: Hoare triple {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:42,513 INFO L290 TraceCheckUtils]: 112: Hoare triple {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} assume !false; {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:42,513 INFO L290 TraceCheckUtils]: 111: Hoare triple {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:42,514 INFO L290 TraceCheckUtils]: 110: Hoare triple {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} assume !false; {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is VALID [2022-04-15 08:52:44,515 WARN L290 TraceCheckUtils]: 109: Hoare triple {19513#(= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {19470#(= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))} is UNKNOWN [2022-04-15 08:52:44,516 INFO L290 TraceCheckUtils]: 108: Hoare triple {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} assume !(~c~0 >= ~b~0); {19513#(= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)} is VALID [2022-04-15 08:52:44,517 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {19068#true} {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} #97#return; {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:44,517 INFO L290 TraceCheckUtils]: 106: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:44,517 INFO L290 TraceCheckUtils]: 105: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:44,517 INFO L290 TraceCheckUtils]: 104: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:44,517 INFO L272 TraceCheckUtils]: 103: Hoare triple {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:44,518 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {19068#true} {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} #95#return; {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:44,518 INFO L290 TraceCheckUtils]: 101: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:44,518 INFO L290 TraceCheckUtils]: 100: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:44,518 INFO L290 TraceCheckUtils]: 99: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:44,518 INFO L272 TraceCheckUtils]: 98: Hoare triple {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:44,519 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {19068#true} {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} #93#return; {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:44,519 INFO L290 TraceCheckUtils]: 96: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:44,519 INFO L290 TraceCheckUtils]: 95: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:44,519 INFO L290 TraceCheckUtils]: 94: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:44,519 INFO L272 TraceCheckUtils]: 93: Hoare triple {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:44,519 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {19068#true} {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} #91#return; {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:44,520 INFO L290 TraceCheckUtils]: 91: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:44,520 INFO L290 TraceCheckUtils]: 90: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:44,520 INFO L290 TraceCheckUtils]: 89: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:44,520 INFO L272 TraceCheckUtils]: 88: Hoare triple {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:44,520 INFO L290 TraceCheckUtils]: 87: Hoare triple {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} assume !false; {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:45,181 INFO L290 TraceCheckUtils]: 86: Hoare triple {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {19517#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:45,182 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {19068#true} {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} #97#return; {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} is VALID [2022-04-15 08:52:45,182 INFO L290 TraceCheckUtils]: 84: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,182 INFO L290 TraceCheckUtils]: 83: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,183 INFO L290 TraceCheckUtils]: 82: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,183 INFO L272 TraceCheckUtils]: 81: Hoare triple {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,183 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {19068#true} {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} #95#return; {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} is VALID [2022-04-15 08:52:45,183 INFO L290 TraceCheckUtils]: 79: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,183 INFO L290 TraceCheckUtils]: 78: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,184 INFO L290 TraceCheckUtils]: 77: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,184 INFO L272 TraceCheckUtils]: 76: Hoare triple {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,199 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {19068#true} {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} #93#return; {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} is VALID [2022-04-15 08:52:45,200 INFO L290 TraceCheckUtils]: 74: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,200 INFO L290 TraceCheckUtils]: 73: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,200 INFO L290 TraceCheckUtils]: 72: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,200 INFO L272 TraceCheckUtils]: 71: Hoare triple {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,201 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {19068#true} {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} #91#return; {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} is VALID [2022-04-15 08:52:45,201 INFO L290 TraceCheckUtils]: 69: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,201 INFO L290 TraceCheckUtils]: 68: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,201 INFO L290 TraceCheckUtils]: 67: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,201 INFO L272 TraceCheckUtils]: 66: Hoare triple {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,201 INFO L290 TraceCheckUtils]: 65: Hoare triple {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} assume !false; {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} is VALID [2022-04-15 08:52:45,202 INFO L290 TraceCheckUtils]: 64: Hoare triple {19651#(or (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))))) (<= (* main_~b~0 2) main_~a~0))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {19584#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0))))} is VALID [2022-04-15 08:52:45,202 INFO L290 TraceCheckUtils]: 63: Hoare triple {19651#(or (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))))) (<= (* main_~b~0 2) main_~a~0))} assume !false; {19651#(or (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))))) (<= (* main_~b~0 2) main_~a~0))} is VALID [2022-04-15 08:52:45,317 INFO L290 TraceCheckUtils]: 62: Hoare triple {19658#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {19651#(or (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))))) (<= (* main_~b~0 2) main_~a~0))} is VALID [2022-04-15 08:52:45,318 INFO L290 TraceCheckUtils]: 61: Hoare triple {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} assume !(~c~0 >= ~b~0); {19658#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)))} is VALID [2022-04-15 08:52:45,319 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {19068#true} {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} #97#return; {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:45,319 INFO L290 TraceCheckUtils]: 59: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,319 INFO L290 TraceCheckUtils]: 58: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,319 INFO L290 TraceCheckUtils]: 57: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,319 INFO L272 TraceCheckUtils]: 56: Hoare triple {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,320 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {19068#true} {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} #95#return; {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:45,320 INFO L290 TraceCheckUtils]: 54: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,320 INFO L290 TraceCheckUtils]: 53: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,320 INFO L290 TraceCheckUtils]: 52: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,320 INFO L272 TraceCheckUtils]: 51: Hoare triple {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,321 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {19068#true} {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} #93#return; {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:45,321 INFO L290 TraceCheckUtils]: 49: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,321 INFO L290 TraceCheckUtils]: 48: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,321 INFO L290 TraceCheckUtils]: 47: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,321 INFO L272 TraceCheckUtils]: 46: Hoare triple {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,321 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {19068#true} {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} #91#return; {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:45,321 INFO L290 TraceCheckUtils]: 44: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,322 INFO L290 TraceCheckUtils]: 43: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,322 INFO L290 TraceCheckUtils]: 42: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,322 INFO L272 TraceCheckUtils]: 41: Hoare triple {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,322 INFO L290 TraceCheckUtils]: 40: Hoare triple {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} assume !false; {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:45,323 INFO L290 TraceCheckUtils]: 39: Hoare triple {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {19662#(or (<= (* main_~c~0 2) main_~b~0) (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* (- 1) main_~c~0) main_~b~0)) (<= main_~b~0 main_~c~0))} is VALID [2022-04-15 08:52:45,323 INFO L290 TraceCheckUtils]: 38: Hoare triple {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} assume !false; {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} is VALID [2022-04-15 08:52:45,324 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {19068#true} {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} #89#return; {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} is VALID [2022-04-15 08:52:45,324 INFO L290 TraceCheckUtils]: 36: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,324 INFO L290 TraceCheckUtils]: 35: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,324 INFO L290 TraceCheckUtils]: 34: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,324 INFO L272 TraceCheckUtils]: 33: Hoare triple {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,324 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {19068#true} {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} #87#return; {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} is VALID [2022-04-15 08:52:45,325 INFO L290 TraceCheckUtils]: 31: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,325 INFO L290 TraceCheckUtils]: 30: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,325 INFO L290 TraceCheckUtils]: 29: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,325 INFO L272 TraceCheckUtils]: 28: Hoare triple {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,325 INFO L290 TraceCheckUtils]: 27: Hoare triple {19068#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {19729#(or (<= main_~b~0 main_~a~0) (<= (* main_~a~0 2) main_~b~0) (= (+ (* (+ main_~s~0 (* (- 1) main_~r~0)) main_~y~0) (* main_~x~0 (+ main_~q~0 (* (- 1) main_~p~0)))) (+ (* (- 1) main_~a~0) main_~b~0)))} is VALID [2022-04-15 08:52:45,325 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {19068#true} {19068#true} #85#return; {19068#true} is VALID [2022-04-15 08:52:45,325 INFO L290 TraceCheckUtils]: 25: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,325 INFO L290 TraceCheckUtils]: 24: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,325 INFO L290 TraceCheckUtils]: 23: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L272 TraceCheckUtils]: 22: Hoare triple {19068#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {19068#true} {19068#true} #83#return; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L290 TraceCheckUtils]: 20: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L290 TraceCheckUtils]: 19: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L290 TraceCheckUtils]: 18: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L272 TraceCheckUtils]: 17: Hoare triple {19068#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {19068#true} {19068#true} #81#return; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L290 TraceCheckUtils]: 15: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L290 TraceCheckUtils]: 14: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L290 TraceCheckUtils]: 13: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L272 TraceCheckUtils]: 12: Hoare triple {19068#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L290 TraceCheckUtils]: 11: Hoare triple {19068#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {19068#true} {19068#true} #79#return; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L290 TraceCheckUtils]: 9: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,326 INFO L290 TraceCheckUtils]: 8: Hoare triple {19068#true} assume !(0 == ~cond); {19068#true} is VALID [2022-04-15 08:52:45,327 INFO L290 TraceCheckUtils]: 7: Hoare triple {19068#true} ~cond := #in~cond; {19068#true} is VALID [2022-04-15 08:52:45,327 INFO L272 TraceCheckUtils]: 6: Hoare triple {19068#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {19068#true} is VALID [2022-04-15 08:52:45,327 INFO L290 TraceCheckUtils]: 5: Hoare triple {19068#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {19068#true} is VALID [2022-04-15 08:52:45,327 INFO L272 TraceCheckUtils]: 4: Hoare triple {19068#true} call #t~ret6 := main(); {19068#true} is VALID [2022-04-15 08:52:45,327 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {19068#true} {19068#true} #103#return; {19068#true} is VALID [2022-04-15 08:52:45,327 INFO L290 TraceCheckUtils]: 2: Hoare triple {19068#true} assume true; {19068#true} is VALID [2022-04-15 08:52:45,327 INFO L290 TraceCheckUtils]: 1: Hoare triple {19068#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {19068#true} is VALID [2022-04-15 08:52:45,327 INFO L272 TraceCheckUtils]: 0: Hoare triple {19068#true} call ULTIMATE.init(); {19068#true} is VALID [2022-04-15 08:52:45,328 INFO L134 CoverageAnalysis]: Checked inductivity of 489 backedges. 36 proven. 29 refuted. 0 times theorem prover too weak. 424 trivial. 0 not checked. [2022-04-15 08:52:45,328 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:52:45,328 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [2145559408] [2022-04-15 08:52:45,328 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:52:45,328 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1741116475] [2022-04-15 08:52:45,328 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1741116475] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:52:45,328 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:52:45,328 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [12, 12] total 20 [2022-04-15 08:52:45,328 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:52:45,328 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [530722062] [2022-04-15 08:52:45,328 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [530722062] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:52:45,328 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:52:45,329 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [12] imperfect sequences [] total 12 [2022-04-15 08:52:45,329 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [19528669] [2022-04-15 08:52:45,329 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:52:45,329 INFO L78 Accepts]: Start accepts. Automaton has has 12 states, 12 states have (on average 2.4166666666666665) internal successors, (29), 11 states have internal predecessors, (29), 6 states have call successors, (23), 2 states have call predecessors, (23), 1 states have return successors, (21), 6 states have call predecessors, (21), 6 states have call successors, (21) Word has length 127 [2022-04-15 08:52:45,329 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:52:45,329 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 12 states, 12 states have (on average 2.4166666666666665) internal successors, (29), 11 states have internal predecessors, (29), 6 states have call successors, (23), 2 states have call predecessors, (23), 1 states have return successors, (21), 6 states have call predecessors, (21), 6 states have call successors, (21) [2022-04-15 08:52:45,402 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 73 edges. 73 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:45,402 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 12 states [2022-04-15 08:52:45,402 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:52:45,402 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 12 interpolants. [2022-04-15 08:52:45,403 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=75, Invalid=305, Unknown=0, NotChecked=0, Total=380 [2022-04-15 08:52:45,403 INFO L87 Difference]: Start difference. First operand 231 states and 309 transitions. Second operand has 12 states, 12 states have (on average 2.4166666666666665) internal successors, (29), 11 states have internal predecessors, (29), 6 states have call successors, (23), 2 states have call predecessors, (23), 1 states have return successors, (21), 6 states have call predecessors, (21), 6 states have call successors, (21) [2022-04-15 08:52:48,662 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:48,662 INFO L93 Difference]: Finished difference Result 269 states and 358 transitions. [2022-04-15 08:52:48,663 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 12 states. [2022-04-15 08:52:48,663 INFO L78 Accepts]: Start accepts. Automaton has has 12 states, 12 states have (on average 2.4166666666666665) internal successors, (29), 11 states have internal predecessors, (29), 6 states have call successors, (23), 2 states have call predecessors, (23), 1 states have return successors, (21), 6 states have call predecessors, (21), 6 states have call successors, (21) Word has length 127 [2022-04-15 08:52:48,663 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:52:48,663 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 12 states, 12 states have (on average 2.4166666666666665) internal successors, (29), 11 states have internal predecessors, (29), 6 states have call successors, (23), 2 states have call predecessors, (23), 1 states have return successors, (21), 6 states have call predecessors, (21), 6 states have call successors, (21) [2022-04-15 08:52:48,664 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 12 states to 12 states and 125 transitions. [2022-04-15 08:52:48,664 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 12 states, 12 states have (on average 2.4166666666666665) internal successors, (29), 11 states have internal predecessors, (29), 6 states have call successors, (23), 2 states have call predecessors, (23), 1 states have return successors, (21), 6 states have call predecessors, (21), 6 states have call successors, (21) [2022-04-15 08:52:48,666 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 12 states to 12 states and 125 transitions. [2022-04-15 08:52:48,666 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 12 states and 125 transitions. [2022-04-15 08:52:48,802 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 125 edges. 125 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:48,807 INFO L225 Difference]: With dead ends: 269 [2022-04-15 08:52:48,808 INFO L226 Difference]: Without dead ends: 267 [2022-04-15 08:52:48,808 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 259 GetRequests, 234 SyntacticMatches, 1 SemanticMatches, 24 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 62 ImplicationChecksByTransitivity, 1.2s TimeCoverageRelationStatistics Valid=143, Invalid=507, Unknown=0, NotChecked=0, Total=650 [2022-04-15 08:52:48,808 INFO L913 BasicCegarLoop]: 65 mSDtfsCounter, 22 mSDsluCounter, 313 mSDsCounter, 0 mSdLazyCounter, 589 mSolverCounterSat, 28 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 1.2s Time, 0 mProtectedPredicate, 0 mProtectedAction, 32 SdHoareTripleChecker+Valid, 378 SdHoareTripleChecker+Invalid, 617 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 28 IncrementalHoareTripleChecker+Valid, 589 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 1.2s IncrementalHoareTripleChecker+Time [2022-04-15 08:52:48,809 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [32 Valid, 378 Invalid, 617 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [28 Valid, 589 Invalid, 0 Unknown, 0 Unchecked, 1.2s Time] [2022-04-15 08:52:48,809 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 267 states. [2022-04-15 08:52:49,445 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 267 to 264. [2022-04-15 08:52:49,445 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:52:49,446 INFO L82 GeneralOperation]: Start isEquivalent. First operand 267 states. Second operand has 264 states, 142 states have (on average 1.1338028169014085) internal successors, (161), 143 states have internal predecessors, (161), 97 states have call successors, (97), 25 states have call predecessors, (97), 24 states have return successors, (95), 95 states have call predecessors, (95), 95 states have call successors, (95) [2022-04-15 08:52:49,446 INFO L74 IsIncluded]: Start isIncluded. First operand 267 states. Second operand has 264 states, 142 states have (on average 1.1338028169014085) internal successors, (161), 143 states have internal predecessors, (161), 97 states have call successors, (97), 25 states have call predecessors, (97), 24 states have return successors, (95), 95 states have call predecessors, (95), 95 states have call successors, (95) [2022-04-15 08:52:49,447 INFO L87 Difference]: Start difference. First operand 267 states. Second operand has 264 states, 142 states have (on average 1.1338028169014085) internal successors, (161), 143 states have internal predecessors, (161), 97 states have call successors, (97), 25 states have call predecessors, (97), 24 states have return successors, (95), 95 states have call predecessors, (95), 95 states have call successors, (95) [2022-04-15 08:52:49,452 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:49,452 INFO L93 Difference]: Finished difference Result 267 states and 356 transitions. [2022-04-15 08:52:49,452 INFO L276 IsEmpty]: Start isEmpty. Operand 267 states and 356 transitions. [2022-04-15 08:52:49,453 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:52:49,453 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:52:49,453 INFO L74 IsIncluded]: Start isIncluded. First operand has 264 states, 142 states have (on average 1.1338028169014085) internal successors, (161), 143 states have internal predecessors, (161), 97 states have call successors, (97), 25 states have call predecessors, (97), 24 states have return successors, (95), 95 states have call predecessors, (95), 95 states have call successors, (95) Second operand 267 states. [2022-04-15 08:52:49,453 INFO L87 Difference]: Start difference. First operand has 264 states, 142 states have (on average 1.1338028169014085) internal successors, (161), 143 states have internal predecessors, (161), 97 states have call successors, (97), 25 states have call predecessors, (97), 24 states have return successors, (95), 95 states have call predecessors, (95), 95 states have call successors, (95) Second operand 267 states. [2022-04-15 08:52:49,458 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:52:49,458 INFO L93 Difference]: Finished difference Result 267 states and 356 transitions. [2022-04-15 08:52:49,458 INFO L276 IsEmpty]: Start isEmpty. Operand 267 states and 356 transitions. [2022-04-15 08:52:49,459 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:52:49,459 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:52:49,459 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:52:49,459 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:52:49,459 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 264 states, 142 states have (on average 1.1338028169014085) internal successors, (161), 143 states have internal predecessors, (161), 97 states have call successors, (97), 25 states have call predecessors, (97), 24 states have return successors, (95), 95 states have call predecessors, (95), 95 states have call successors, (95) [2022-04-15 08:52:49,464 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 264 states to 264 states and 353 transitions. [2022-04-15 08:52:49,465 INFO L78 Accepts]: Start accepts. Automaton has 264 states and 353 transitions. Word has length 127 [2022-04-15 08:52:49,465 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:52:49,465 INFO L478 AbstractCegarLoop]: Abstraction has 264 states and 353 transitions. [2022-04-15 08:52:49,465 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 12 states, 12 states have (on average 2.4166666666666665) internal successors, (29), 11 states have internal predecessors, (29), 6 states have call successors, (23), 2 states have call predecessors, (23), 1 states have return successors, (21), 6 states have call predecessors, (21), 6 states have call successors, (21) [2022-04-15 08:52:49,465 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 264 states and 353 transitions. [2022-04-15 08:52:50,195 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 353 edges. 353 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:52:50,195 INFO L276 IsEmpty]: Start isEmpty. Operand 264 states and 353 transitions. [2022-04-15 08:52:50,212 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 130 [2022-04-15 08:52:50,212 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:52:50,212 INFO L499 BasicCegarLoop]: trace histogram [16, 15, 15, 6, 6, 6, 4, 4, 4, 4, 4, 4, 4, 4, 3, 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] [2022-04-15 08:52:50,247 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (18)] Forceful destruction successful, exit code 0 [2022-04-15 08:52:50,412 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 18 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable17 [2022-04-15 08:52:50,413 INFO L403 AbstractCegarLoop]: === Iteration 19 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:52:50,413 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:52:50,413 INFO L85 PathProgramCache]: Analyzing trace with hash -2138166692, now seen corresponding path program 7 times [2022-04-15 08:52:50,413 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:52:50,413 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [233886928] [2022-04-15 08:52:50,413 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:52:50,413 INFO L85 PathProgramCache]: Analyzing trace with hash -2138166692, now seen corresponding path program 8 times [2022-04-15 08:52:50,413 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:52:50,414 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1236476483] [2022-04-15 08:52:50,414 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:52:50,414 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:52:50,425 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:52:50,425 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [681127838] [2022-04-15 08:52:50,425 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:52:50,425 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:52:50,426 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:52:50,426 INFO L229 MonitoredProcess]: Starting monitored process 19 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:52:50,427 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (19)] Waiting until timeout for monitored process [2022-04-15 08:52:50,488 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:52:50,488 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:52:50,490 INFO L263 TraceCheckSpWp]: Trace formula consists of 306 conjuncts, 72 conjunts are in the unsatisfiable core [2022-04-15 08:52:50,509 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:52:50,511 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:52:57,789 INFO L272 TraceCheckUtils]: 0: Hoare triple {21461#true} call ULTIMATE.init(); {21461#true} is VALID [2022-04-15 08:52:57,789 INFO L290 TraceCheckUtils]: 1: Hoare triple {21461#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {21461#true} is VALID [2022-04-15 08:52:57,789 INFO L290 TraceCheckUtils]: 2: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,789 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {21461#true} {21461#true} #103#return; {21461#true} is VALID [2022-04-15 08:52:57,789 INFO L272 TraceCheckUtils]: 4: Hoare triple {21461#true} call #t~ret6 := main(); {21461#true} is VALID [2022-04-15 08:52:57,789 INFO L290 TraceCheckUtils]: 5: Hoare triple {21461#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {21461#true} is VALID [2022-04-15 08:52:57,789 INFO L272 TraceCheckUtils]: 6: Hoare triple {21461#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,789 INFO L290 TraceCheckUtils]: 7: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,789 INFO L290 TraceCheckUtils]: 8: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,789 INFO L290 TraceCheckUtils]: 9: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,790 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {21461#true} {21461#true} #79#return; {21461#true} is VALID [2022-04-15 08:52:57,790 INFO L290 TraceCheckUtils]: 11: Hoare triple {21461#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {21461#true} is VALID [2022-04-15 08:52:57,790 INFO L272 TraceCheckUtils]: 12: Hoare triple {21461#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,790 INFO L290 TraceCheckUtils]: 13: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,790 INFO L290 TraceCheckUtils]: 14: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,790 INFO L290 TraceCheckUtils]: 15: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,790 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {21461#true} {21461#true} #81#return; {21461#true} is VALID [2022-04-15 08:52:57,790 INFO L272 TraceCheckUtils]: 17: Hoare triple {21461#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,790 INFO L290 TraceCheckUtils]: 18: Hoare triple {21461#true} ~cond := #in~cond; {21520#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-04-15 08:52:57,791 INFO L290 TraceCheckUtils]: 19: Hoare triple {21520#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond); {21524#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:52:57,791 INFO L290 TraceCheckUtils]: 20: Hoare triple {21524#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {21524#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:52:57,791 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {21524#(not (= |assume_abort_if_not_#in~cond| 0))} {21461#true} #83#return; {21531#(<= 1 main_~x~0)} is VALID [2022-04-15 08:52:57,791 INFO L272 TraceCheckUtils]: 22: Hoare triple {21531#(<= 1 main_~x~0)} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,791 INFO L290 TraceCheckUtils]: 23: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,792 INFO L290 TraceCheckUtils]: 24: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,792 INFO L290 TraceCheckUtils]: 25: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,792 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {21461#true} {21531#(<= 1 main_~x~0)} #85#return; {21531#(<= 1 main_~x~0)} is VALID [2022-04-15 08:52:57,792 INFO L290 TraceCheckUtils]: 27: Hoare triple {21531#(<= 1 main_~x~0)} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,792 INFO L272 TraceCheckUtils]: 28: Hoare triple {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,793 INFO L290 TraceCheckUtils]: 29: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,793 INFO L290 TraceCheckUtils]: 30: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,793 INFO L290 TraceCheckUtils]: 31: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,793 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {21461#true} {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #87#return; {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,793 INFO L272 TraceCheckUtils]: 33: Hoare triple {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,793 INFO L290 TraceCheckUtils]: 34: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,794 INFO L290 TraceCheckUtils]: 35: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,794 INFO L290 TraceCheckUtils]: 36: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,794 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {21461#true} {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #89#return; {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,795 INFO L290 TraceCheckUtils]: 38: Hoare triple {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,795 INFO L290 TraceCheckUtils]: 39: Hoare triple {21550#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,795 INFO L290 TraceCheckUtils]: 40: Hoare triple {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,796 INFO L272 TraceCheckUtils]: 41: Hoare triple {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,796 INFO L290 TraceCheckUtils]: 42: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,796 INFO L290 TraceCheckUtils]: 43: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,796 INFO L290 TraceCheckUtils]: 44: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,796 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {21461#true} {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,797 INFO L272 TraceCheckUtils]: 46: Hoare triple {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,797 INFO L290 TraceCheckUtils]: 47: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,797 INFO L290 TraceCheckUtils]: 48: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,797 INFO L290 TraceCheckUtils]: 49: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,797 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {21461#true} {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,797 INFO L272 TraceCheckUtils]: 51: Hoare triple {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,798 INFO L290 TraceCheckUtils]: 52: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,798 INFO L290 TraceCheckUtils]: 53: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,798 INFO L290 TraceCheckUtils]: 54: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,798 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {21461#true} {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #95#return; {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,798 INFO L272 TraceCheckUtils]: 56: Hoare triple {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,799 INFO L290 TraceCheckUtils]: 57: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,799 INFO L290 TraceCheckUtils]: 58: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,799 INFO L290 TraceCheckUtils]: 59: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,799 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {21461#true} {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #97#return; {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,800 INFO L290 TraceCheckUtils]: 61: Hoare triple {21587#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,801 INFO L290 TraceCheckUtils]: 62: Hoare triple {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,801 INFO L272 TraceCheckUtils]: 63: Hoare triple {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,801 INFO L290 TraceCheckUtils]: 64: Hoare triple {21461#true} ~cond := #in~cond; {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:57,802 INFO L290 TraceCheckUtils]: 65: Hoare triple {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,802 INFO L290 TraceCheckUtils]: 66: Hoare triple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,803 INFO L284 TraceCheckUtils]: 67: Hoare quadruple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,803 INFO L272 TraceCheckUtils]: 68: Hoare triple {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,803 INFO L290 TraceCheckUtils]: 69: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,803 INFO L290 TraceCheckUtils]: 70: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,803 INFO L290 TraceCheckUtils]: 71: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,804 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {21461#true} {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,804 INFO L272 TraceCheckUtils]: 73: Hoare triple {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,804 INFO L290 TraceCheckUtils]: 74: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,804 INFO L290 TraceCheckUtils]: 75: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,804 INFO L290 TraceCheckUtils]: 76: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,805 INFO L284 TraceCheckUtils]: 77: Hoare quadruple {21461#true} {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #95#return; {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,805 INFO L272 TraceCheckUtils]: 78: Hoare triple {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,805 INFO L290 TraceCheckUtils]: 79: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,805 INFO L290 TraceCheckUtils]: 80: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,805 INFO L290 TraceCheckUtils]: 81: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,806 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {21461#true} {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #97#return; {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,807 INFO L290 TraceCheckUtils]: 83: Hoare triple {21654#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= (+ main_~a~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {21723#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ (* (- 2) main_~b~0) main_~a~0) main_~c~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (<= (* main_~b~0 2) main_~a~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,807 INFO L290 TraceCheckUtils]: 84: Hoare triple {21723#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ (* (- 2) main_~b~0) main_~a~0) main_~c~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (<= (* main_~b~0 2) main_~a~0) (= main_~p~0 1))} assume !false; {21723#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ (* (- 2) main_~b~0) main_~a~0) main_~c~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (<= (* main_~b~0 2) main_~a~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,807 INFO L272 TraceCheckUtils]: 85: Hoare triple {21723#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ (* (- 2) main_~b~0) main_~a~0) main_~c~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (<= (* main_~b~0 2) main_~a~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,807 INFO L290 TraceCheckUtils]: 86: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,807 INFO L290 TraceCheckUtils]: 87: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,807 INFO L290 TraceCheckUtils]: 88: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,808 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {21461#true} {21723#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ (* (- 2) main_~b~0) main_~a~0) main_~c~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (<= (* main_~b~0 2) main_~a~0) (= main_~p~0 1))} #91#return; {21723#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ (* (- 2) main_~b~0) main_~a~0) main_~c~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (<= (* main_~b~0 2) main_~a~0) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,808 INFO L272 TraceCheckUtils]: 90: Hoare triple {21723#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ (* (- 2) main_~b~0) main_~a~0) main_~c~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (<= (* main_~b~0 2) main_~a~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,808 INFO L290 TraceCheckUtils]: 91: Hoare triple {21461#true} ~cond := #in~cond; {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:57,809 INFO L290 TraceCheckUtils]: 92: Hoare triple {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,809 INFO L290 TraceCheckUtils]: 93: Hoare triple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,810 INFO L284 TraceCheckUtils]: 94: Hoare quadruple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} {21723#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ (* (- 2) main_~b~0) main_~a~0) main_~c~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (<= (* main_~b~0 2) main_~a~0) (= main_~p~0 1))} #93#return; {21757#(and (= main_~r~0 0) (<= 1 main_~x~0) (<= (* main_~b~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= (+ main_~c~0 (* main_~b~0 2)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,810 INFO L272 TraceCheckUtils]: 95: Hoare triple {21757#(and (= main_~r~0 0) (<= 1 main_~x~0) (<= (* main_~b~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= (+ main_~c~0 (* main_~b~0 2)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,811 INFO L290 TraceCheckUtils]: 96: Hoare triple {21461#true} ~cond := #in~cond; {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:57,811 INFO L290 TraceCheckUtils]: 97: Hoare triple {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,811 INFO L290 TraceCheckUtils]: 98: Hoare triple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,812 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} {21757#(and (= main_~r~0 0) (<= 1 main_~x~0) (<= (* main_~b~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= (+ main_~c~0 (* main_~b~0 2)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~p~0 1))} #95#return; {21757#(and (= main_~r~0 0) (<= 1 main_~x~0) (<= (* main_~b~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= (+ main_~c~0 (* main_~b~0 2)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,812 INFO L272 TraceCheckUtils]: 100: Hoare triple {21757#(and (= main_~r~0 0) (<= 1 main_~x~0) (<= (* main_~b~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= (+ main_~c~0 (* main_~b~0 2)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,814 INFO L290 TraceCheckUtils]: 101: Hoare triple {21461#true} ~cond := #in~cond; {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:57,814 INFO L290 TraceCheckUtils]: 102: Hoare triple {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,814 INFO L290 TraceCheckUtils]: 103: Hoare triple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,815 INFO L284 TraceCheckUtils]: 104: Hoare quadruple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} {21757#(and (= main_~r~0 0) (<= 1 main_~x~0) (<= (* main_~b~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= (+ main_~c~0 (* main_~b~0 2)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~p~0 1))} #97#return; {21757#(and (= main_~r~0 0) (<= 1 main_~x~0) (<= (* main_~b~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= (+ main_~c~0 (* main_~b~0 2)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,816 INFO L290 TraceCheckUtils]: 105: Hoare triple {21757#(and (= main_~r~0 0) (<= 1 main_~x~0) (<= (* main_~b~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= (+ main_~c~0 (* main_~b~0 2)) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~p~0 1))} assume !(~c~0 >= ~b~0); {21791#(and (= main_~r~0 0) (< main_~c~0 main_~y~0) (= main_~s~0 1) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 (* main_~y~0 2))) (<= (* main_~y~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} is VALID [2022-04-15 08:52:57,818 INFO L290 TraceCheckUtils]: 106: Hoare triple {21791#(and (= main_~r~0 0) (< main_~c~0 main_~y~0) (= main_~s~0 1) (= (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0)) (+ main_~c~0 (* main_~y~0 2))) (<= (* main_~y~0 2) (+ (* main_~y~0 main_~r~0) (* main_~p~0 main_~x~0))) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~p~0 1))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {21795#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:52:57,818 INFO L290 TraceCheckUtils]: 107: Hoare triple {21795#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !false; {21795#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:52:57,819 INFO L290 TraceCheckUtils]: 108: Hoare triple {21795#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:52:57,819 INFO L290 TraceCheckUtils]: 109: Hoare triple {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !false; {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:52:57,819 INFO L272 TraceCheckUtils]: 110: Hoare triple {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,819 INFO L290 TraceCheckUtils]: 111: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,819 INFO L290 TraceCheckUtils]: 112: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,820 INFO L290 TraceCheckUtils]: 113: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,820 INFO L284 TraceCheckUtils]: 114: Hoare quadruple {21461#true} {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #91#return; {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:52:57,820 INFO L272 TraceCheckUtils]: 115: Hoare triple {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,820 INFO L290 TraceCheckUtils]: 116: Hoare triple {21461#true} ~cond := #in~cond; {21461#true} is VALID [2022-04-15 08:52:57,820 INFO L290 TraceCheckUtils]: 117: Hoare triple {21461#true} assume !(0 == ~cond); {21461#true} is VALID [2022-04-15 08:52:57,820 INFO L290 TraceCheckUtils]: 118: Hoare triple {21461#true} assume true; {21461#true} is VALID [2022-04-15 08:52:57,821 INFO L284 TraceCheckUtils]: 119: Hoare quadruple {21461#true} {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #93#return; {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:52:57,821 INFO L272 TraceCheckUtils]: 120: Hoare triple {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {21461#true} is VALID [2022-04-15 08:52:57,821 INFO L290 TraceCheckUtils]: 121: Hoare triple {21461#true} ~cond := #in~cond; {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:57,822 INFO L290 TraceCheckUtils]: 122: Hoare triple {21664#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,822 INFO L290 TraceCheckUtils]: 123: Hoare triple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:52:57,823 INFO L284 TraceCheckUtils]: 124: Hoare quadruple {21668#(not (= |__VERIFIER_assert_#in~cond| 0))} {21802#(and (<= (* main_~y~0 2) main_~x~0) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #95#return; {21851#(and (<= (* main_~y~0 2) main_~x~0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:52:57,825 INFO L272 TraceCheckUtils]: 125: Hoare triple {21851#(and (<= (* main_~y~0 2) main_~x~0) (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0))) (< main_~x~0 (* main_~y~0 3)) (not (= main_~b~0 0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~b~0 (+ main_~x~0 (* (- 2) main_~y~0))) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {21855#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:52:57,825 INFO L290 TraceCheckUtils]: 126: Hoare triple {21855#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {21859#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:52:57,826 INFO L290 TraceCheckUtils]: 127: Hoare triple {21859#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {21462#false} is VALID [2022-04-15 08:52:57,826 INFO L290 TraceCheckUtils]: 128: Hoare triple {21462#false} assume !false; {21462#false} is VALID [2022-04-15 08:52:57,826 INFO L134 CoverageAnalysis]: Checked inductivity of 545 backedges. 145 proven. 85 refuted. 0 times theorem prover too weak. 315 trivial. 0 not checked. [2022-04-15 08:52:57,826 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:53:59,410 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:53:59,410 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1236476483] [2022-04-15 08:53:59,410 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:53:59,410 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [681127838] [2022-04-15 08:53:59,410 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [681127838] provided 0 perfect and 1 imperfect interpolant sequences [2022-04-15 08:53:59,411 INFO L184 FreeRefinementEngine]: Found 0 perfect and 1 imperfect interpolant sequences. [2022-04-15 08:53:59,411 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [18] total 18 [2022-04-15 08:53:59,411 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:53:59,411 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [233886928] [2022-04-15 08:53:59,411 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [233886928] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:53:59,411 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:53:59,411 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [18] imperfect sequences [] total 18 [2022-04-15 08:53:59,411 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1367231946] [2022-04-15 08:53:59,411 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:53:59,412 INFO L78 Accepts]: Start accepts. Automaton has has 18 states, 17 states have (on average 1.8823529411764706) internal successors, (32), 14 states have internal predecessors, (32), 9 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 9 states have call predecessors, (22), 8 states have call successors, (22) Word has length 129 [2022-04-15 08:53:59,412 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:53:59,412 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 18 states, 17 states have (on average 1.8823529411764706) internal successors, (32), 14 states have internal predecessors, (32), 9 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 9 states have call predecessors, (22), 8 states have call successors, (22) [2022-04-15 08:53:59,512 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 78 edges. 78 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:53:59,512 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 18 states [2022-04-15 08:53:59,512 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:53:59,512 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 18 interpolants. [2022-04-15 08:53:59,513 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=124, Invalid=476, Unknown=0, NotChecked=0, Total=600 [2022-04-15 08:53:59,513 INFO L87 Difference]: Start difference. First operand 264 states and 353 transitions. Second operand has 18 states, 17 states have (on average 1.8823529411764706) internal successors, (32), 14 states have internal predecessors, (32), 9 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 9 states have call predecessors, (22), 8 states have call successors, (22) [2022-04-15 08:54:06,472 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:54:06,473 INFO L93 Difference]: Finished difference Result 272 states and 360 transitions. [2022-04-15 08:54:06,473 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 17 states. [2022-04-15 08:54:06,473 INFO L78 Accepts]: Start accepts. Automaton has has 18 states, 17 states have (on average 1.8823529411764706) internal successors, (32), 14 states have internal predecessors, (32), 9 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 9 states have call predecessors, (22), 8 states have call successors, (22) Word has length 129 [2022-04-15 08:54:06,473 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:54:06,473 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 18 states, 17 states have (on average 1.8823529411764706) internal successors, (32), 14 states have internal predecessors, (32), 9 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 9 states have call predecessors, (22), 8 states have call successors, (22) [2022-04-15 08:54:06,475 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 17 states to 17 states and 120 transitions. [2022-04-15 08:54:06,475 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 18 states, 17 states have (on average 1.8823529411764706) internal successors, (32), 14 states have internal predecessors, (32), 9 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 9 states have call predecessors, (22), 8 states have call successors, (22) [2022-04-15 08:54:06,476 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 17 states to 17 states and 120 transitions. [2022-04-15 08:54:06,476 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 17 states and 120 transitions. [2022-04-15 08:54:06,634 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 120 edges. 120 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:54:06,638 INFO L225 Difference]: With dead ends: 272 [2022-04-15 08:54:06,639 INFO L226 Difference]: Without dead ends: 270 [2022-04-15 08:54:06,639 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 157 GetRequests, 128 SyntacticMatches, 2 SemanticMatches, 27 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 205 ImplicationChecksByTransitivity, 5.2s TimeCoverageRelationStatistics Valid=154, Invalid=658, Unknown=0, NotChecked=0, Total=812 [2022-04-15 08:54:06,639 INFO L913 BasicCegarLoop]: 47 mSDtfsCounter, 45 mSDsluCounter, 171 mSDsCounter, 0 mSdLazyCounter, 756 mSolverCounterSat, 78 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 3.2s Time, 0 mProtectedPredicate, 0 mProtectedAction, 60 SdHoareTripleChecker+Valid, 218 SdHoareTripleChecker+Invalid, 834 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 78 IncrementalHoareTripleChecker+Valid, 756 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 3.2s IncrementalHoareTripleChecker+Time [2022-04-15 08:54:06,639 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [60 Valid, 218 Invalid, 834 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [78 Valid, 756 Invalid, 0 Unknown, 0 Unchecked, 3.2s Time] [2022-04-15 08:54:06,640 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 270 states. [2022-04-15 08:54:07,275 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 270 to 235. [2022-04-15 08:54:07,276 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:54:07,276 INFO L82 GeneralOperation]: Start isEquivalent. First operand 270 states. Second operand has 235 states, 127 states have (on average 1.1338582677165354) internal successors, (144), 128 states have internal predecessors, (144), 85 states have call successors, (85), 23 states have call predecessors, (85), 22 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:54:07,276 INFO L74 IsIncluded]: Start isIncluded. First operand 270 states. Second operand has 235 states, 127 states have (on average 1.1338582677165354) internal successors, (144), 128 states have internal predecessors, (144), 85 states have call successors, (85), 23 states have call predecessors, (85), 22 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:54:07,277 INFO L87 Difference]: Start difference. First operand 270 states. Second operand has 235 states, 127 states have (on average 1.1338582677165354) internal successors, (144), 128 states have internal predecessors, (144), 85 states have call successors, (85), 23 states have call predecessors, (85), 22 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:54:07,282 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:54:07,282 INFO L93 Difference]: Finished difference Result 270 states and 358 transitions. [2022-04-15 08:54:07,282 INFO L276 IsEmpty]: Start isEmpty. Operand 270 states and 358 transitions. [2022-04-15 08:54:07,283 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:54:07,283 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:54:07,283 INFO L74 IsIncluded]: Start isIncluded. First operand has 235 states, 127 states have (on average 1.1338582677165354) internal successors, (144), 128 states have internal predecessors, (144), 85 states have call successors, (85), 23 states have call predecessors, (85), 22 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) Second operand 270 states. [2022-04-15 08:54:07,283 INFO L87 Difference]: Start difference. First operand has 235 states, 127 states have (on average 1.1338582677165354) internal successors, (144), 128 states have internal predecessors, (144), 85 states have call successors, (85), 23 states have call predecessors, (85), 22 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) Second operand 270 states. [2022-04-15 08:54:07,288 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:54:07,288 INFO L93 Difference]: Finished difference Result 270 states and 358 transitions. [2022-04-15 08:54:07,288 INFO L276 IsEmpty]: Start isEmpty. Operand 270 states and 358 transitions. [2022-04-15 08:54:07,289 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:54:07,289 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:54:07,289 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:54:07,289 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:54:07,290 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 235 states, 127 states have (on average 1.1338582677165354) internal successors, (144), 128 states have internal predecessors, (144), 85 states have call successors, (85), 23 states have call predecessors, (85), 22 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:54:07,295 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 235 states to 235 states and 312 transitions. [2022-04-15 08:54:07,295 INFO L78 Accepts]: Start accepts. Automaton has 235 states and 312 transitions. Word has length 129 [2022-04-15 08:54:07,295 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:54:07,295 INFO L478 AbstractCegarLoop]: Abstraction has 235 states and 312 transitions. [2022-04-15 08:54:07,295 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 18 states, 17 states have (on average 1.8823529411764706) internal successors, (32), 14 states have internal predecessors, (32), 9 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 9 states have call predecessors, (22), 8 states have call successors, (22) [2022-04-15 08:54:07,295 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 235 states and 312 transitions. [2022-04-15 08:54:07,969 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 312 edges. 312 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:54:07,969 INFO L276 IsEmpty]: Start isEmpty. Operand 235 states and 312 transitions. [2022-04-15 08:54:07,976 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 133 [2022-04-15 08:54:07,976 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:54:07,976 INFO L499 BasicCegarLoop]: trace histogram [16, 15, 15, 6, 6, 6, 4, 4, 4, 4, 4, 4, 4, 4, 3, 3, 3, 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] [2022-04-15 08:54:07,995 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (19)] Forceful destruction successful, exit code 0 [2022-04-15 08:54:08,192 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable18,19 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:54:08,193 INFO L403 AbstractCegarLoop]: === Iteration 20 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:54:08,193 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:54:08,193 INFO L85 PathProgramCache]: Analyzing trace with hash -1899875875, now seen corresponding path program 9 times [2022-04-15 08:54:08,193 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:54:08,193 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [2092109103] [2022-04-15 08:54:08,194 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:54:08,194 INFO L85 PathProgramCache]: Analyzing trace with hash -1899875875, now seen corresponding path program 10 times [2022-04-15 08:54:08,194 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:54:08,194 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1092348641] [2022-04-15 08:54:08,194 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:54:08,194 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:54:08,203 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:54:08,203 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [451378360] [2022-04-15 08:54:08,203 INFO L93 rtionOrderModulation]: Changing assertion order to TERMS_WITH_SMALL_CONSTANTS_FIRST [2022-04-15 08:54:08,203 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:54:08,203 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:54:08,209 INFO L229 MonitoredProcess]: Starting monitored process 20 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:54:08,212 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (20)] Waiting until timeout for monitored process [2022-04-15 08:54:08,278 INFO L228 tOrderPrioritization]: Assert order TERMS_WITH_SMALL_CONSTANTS_FIRST issued 0 check-sat command(s) [2022-04-15 08:54:08,278 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:54:08,279 INFO L263 TraceCheckSpWp]: Trace formula consists of 283 conjuncts, 85 conjunts are in the unsatisfiable core [2022-04-15 08:54:08,300 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:54:08,303 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:54:10,482 INFO L272 TraceCheckUtils]: 0: Hoare triple {23509#true} call ULTIMATE.init(); {23509#true} is VALID [2022-04-15 08:54:10,482 INFO L290 TraceCheckUtils]: 1: Hoare triple {23509#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {23509#true} is VALID [2022-04-15 08:54:10,482 INFO L290 TraceCheckUtils]: 2: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {23509#true} {23509#true} #103#return; {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L272 TraceCheckUtils]: 4: Hoare triple {23509#true} call #t~ret6 := main(); {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L290 TraceCheckUtils]: 5: Hoare triple {23509#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L272 TraceCheckUtils]: 6: Hoare triple {23509#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L290 TraceCheckUtils]: 7: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L290 TraceCheckUtils]: 8: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L290 TraceCheckUtils]: 9: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {23509#true} {23509#true} #79#return; {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L290 TraceCheckUtils]: 11: Hoare triple {23509#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L272 TraceCheckUtils]: 12: Hoare triple {23509#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L290 TraceCheckUtils]: 13: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L290 TraceCheckUtils]: 14: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L290 TraceCheckUtils]: 15: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,483 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {23509#true} {23509#true} #81#return; {23509#true} is VALID [2022-04-15 08:54:10,484 INFO L272 TraceCheckUtils]: 17: Hoare triple {23509#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,484 INFO L290 TraceCheckUtils]: 18: Hoare triple {23509#true} ~cond := #in~cond; {23568#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} is VALID [2022-04-15 08:54:10,484 INFO L290 TraceCheckUtils]: 19: Hoare triple {23568#(= assume_abort_if_not_~cond |assume_abort_if_not_#in~cond|)} assume !(0 == ~cond); {23572#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:54:10,484 INFO L290 TraceCheckUtils]: 20: Hoare triple {23572#(not (= |assume_abort_if_not_#in~cond| 0))} assume true; {23572#(not (= |assume_abort_if_not_#in~cond| 0))} is VALID [2022-04-15 08:54:10,485 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {23572#(not (= |assume_abort_if_not_#in~cond| 0))} {23509#true} #83#return; {23579#(<= 1 main_~x~0)} is VALID [2022-04-15 08:54:10,485 INFO L272 TraceCheckUtils]: 22: Hoare triple {23579#(<= 1 main_~x~0)} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,485 INFO L290 TraceCheckUtils]: 23: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,485 INFO L290 TraceCheckUtils]: 24: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,485 INFO L290 TraceCheckUtils]: 25: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,485 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {23509#true} {23579#(<= 1 main_~x~0)} #85#return; {23579#(<= 1 main_~x~0)} is VALID [2022-04-15 08:54:10,486 INFO L290 TraceCheckUtils]: 27: Hoare triple {23579#(<= 1 main_~x~0)} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,486 INFO L272 TraceCheckUtils]: 28: Hoare triple {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,486 INFO L290 TraceCheckUtils]: 29: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,486 INFO L290 TraceCheckUtils]: 30: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,486 INFO L290 TraceCheckUtils]: 31: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,487 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {23509#true} {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #87#return; {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,487 INFO L272 TraceCheckUtils]: 33: Hoare triple {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,487 INFO L290 TraceCheckUtils]: 34: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,487 INFO L290 TraceCheckUtils]: 35: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,487 INFO L290 TraceCheckUtils]: 36: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,488 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {23509#true} {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #89#return; {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,488 INFO L290 TraceCheckUtils]: 38: Hoare triple {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,489 INFO L290 TraceCheckUtils]: 39: Hoare triple {23598#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,489 INFO L290 TraceCheckUtils]: 40: Hoare triple {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} assume !false; {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,489 INFO L272 TraceCheckUtils]: 41: Hoare triple {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,489 INFO L290 TraceCheckUtils]: 42: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,489 INFO L290 TraceCheckUtils]: 43: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,489 INFO L290 TraceCheckUtils]: 44: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,490 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {23509#true} {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #91#return; {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,490 INFO L272 TraceCheckUtils]: 46: Hoare triple {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,490 INFO L290 TraceCheckUtils]: 47: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,490 INFO L290 TraceCheckUtils]: 48: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,490 INFO L290 TraceCheckUtils]: 49: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,491 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {23509#true} {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #93#return; {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,491 INFO L272 TraceCheckUtils]: 51: Hoare triple {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,491 INFO L290 TraceCheckUtils]: 52: Hoare triple {23509#true} ~cond := #in~cond; {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:54:10,492 INFO L290 TraceCheckUtils]: 53: Hoare triple {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,492 INFO L290 TraceCheckUtils]: 54: Hoare triple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,493 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #95#return; {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,493 INFO L272 TraceCheckUtils]: 56: Hoare triple {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,493 INFO L290 TraceCheckUtils]: 57: Hoare triple {23509#true} ~cond := #in~cond; {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:54:10,493 INFO L290 TraceCheckUtils]: 58: Hoare triple {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,494 INFO L290 TraceCheckUtils]: 59: Hoare triple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,494 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} #97#return; {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,495 INFO L290 TraceCheckUtils]: 61: Hoare triple {23635#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} assume !(~c~0 >= ~b~0); {23704#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (not (<= main_~b~0 main_~c~0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:54:10,495 INFO L290 TraceCheckUtils]: 62: Hoare triple {23704#(and (= main_~r~0 0) (<= 1 main_~x~0) (= main_~k~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (not (<= main_~b~0 main_~c~0)) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 0) (= main_~xy~0 (* main_~y~0 main_~x~0)) (= main_~c~0 main_~x~0) (= main_~p~0 1))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {23708#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~a~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,496 INFO L290 TraceCheckUtils]: 63: Hoare triple {23708#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~a~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !false; {23708#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~a~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,496 INFO L290 TraceCheckUtils]: 64: Hoare triple {23708#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~a~0 main_~y~0) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,497 INFO L290 TraceCheckUtils]: 65: Hoare triple {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !false; {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,497 INFO L272 TraceCheckUtils]: 66: Hoare triple {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,497 INFO L290 TraceCheckUtils]: 67: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,497 INFO L290 TraceCheckUtils]: 68: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,497 INFO L290 TraceCheckUtils]: 69: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,498 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {23509#true} {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #91#return; {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,498 INFO L272 TraceCheckUtils]: 71: Hoare triple {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,498 INFO L290 TraceCheckUtils]: 72: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,498 INFO L290 TraceCheckUtils]: 73: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,498 INFO L290 TraceCheckUtils]: 74: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,499 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {23509#true} {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #93#return; {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,499 INFO L272 TraceCheckUtils]: 76: Hoare triple {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,499 INFO L290 TraceCheckUtils]: 77: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,499 INFO L290 TraceCheckUtils]: 78: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,499 INFO L290 TraceCheckUtils]: 79: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,500 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {23509#true} {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #95#return; {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,500 INFO L272 TraceCheckUtils]: 81: Hoare triple {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,500 INFO L290 TraceCheckUtils]: 82: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,500 INFO L290 TraceCheckUtils]: 83: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,500 INFO L290 TraceCheckUtils]: 84: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,501 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {23509#true} {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #97#return; {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,501 INFO L290 TraceCheckUtils]: 86: Hoare triple {23715#(and (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~k~0 0) (= main_~c~0 main_~y~0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,502 INFO L290 TraceCheckUtils]: 87: Hoare triple {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !false; {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,502 INFO L272 TraceCheckUtils]: 88: Hoare triple {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,502 INFO L290 TraceCheckUtils]: 89: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,502 INFO L290 TraceCheckUtils]: 90: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,502 INFO L290 TraceCheckUtils]: 91: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,503 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {23509#true} {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #91#return; {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,503 INFO L272 TraceCheckUtils]: 93: Hoare triple {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,503 INFO L290 TraceCheckUtils]: 94: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,503 INFO L290 TraceCheckUtils]: 95: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,503 INFO L290 TraceCheckUtils]: 96: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,504 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {23509#true} {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #93#return; {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,504 INFO L272 TraceCheckUtils]: 98: Hoare triple {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,504 INFO L290 TraceCheckUtils]: 99: Hoare triple {23509#true} ~cond := #in~cond; {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:54:10,504 INFO L290 TraceCheckUtils]: 100: Hoare triple {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,505 INFO L290 TraceCheckUtils]: 101: Hoare triple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,505 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #95#return; {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,505 INFO L272 TraceCheckUtils]: 103: Hoare triple {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,506 INFO L290 TraceCheckUtils]: 104: Hoare triple {23509#true} ~cond := #in~cond; {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:54:10,506 INFO L290 TraceCheckUtils]: 105: Hoare triple {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,506 INFO L290 TraceCheckUtils]: 106: Hoare triple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,507 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #97#return; {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,508 INFO L290 TraceCheckUtils]: 108: Hoare triple {23782#(and (= (+ main_~y~0 (* (- 1) main_~b~0)) main_~c~0) (= main_~s~0 0) (<= 1 main_~x~0) (not (<= main_~y~0 main_~x~0)) (= main_~p~0 0) (= main_~r~0 1) (= main_~b~0 main_~x~0) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !(~c~0 >= ~b~0); {23849#(and (= (+ main_~c~0 main_~x~0) main_~y~0) (= main_~s~0 0) (= main_~p~0 0) (< main_~x~0 main_~y~0) (= main_~r~0 1) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)) (< (* main_~c~0 2) main_~y~0))} is VALID [2022-04-15 08:54:10,510 INFO L290 TraceCheckUtils]: 109: Hoare triple {23849#(and (= (+ main_~c~0 main_~x~0) main_~y~0) (= main_~s~0 0) (= main_~p~0 0) (< main_~x~0 main_~y~0) (= main_~r~0 1) (= main_~k~0 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~q~0 1) (= main_~xy~0 (* main_~y~0 main_~x~0)) (< (* main_~c~0 2) main_~y~0))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,510 INFO L290 TraceCheckUtils]: 110: Hoare triple {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !false; {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,511 INFO L290 TraceCheckUtils]: 111: Hoare triple {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,511 INFO L290 TraceCheckUtils]: 112: Hoare triple {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} assume !false; {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,511 INFO L272 TraceCheckUtils]: 113: Hoare triple {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,512 INFO L290 TraceCheckUtils]: 114: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,512 INFO L290 TraceCheckUtils]: 115: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,512 INFO L290 TraceCheckUtils]: 116: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,512 INFO L284 TraceCheckUtils]: 117: Hoare quadruple {23509#true} {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #91#return; {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,512 INFO L272 TraceCheckUtils]: 118: Hoare triple {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,512 INFO L290 TraceCheckUtils]: 119: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:54:10,513 INFO L290 TraceCheckUtils]: 120: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:54:10,513 INFO L290 TraceCheckUtils]: 121: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:54:10,513 INFO L284 TraceCheckUtils]: 122: Hoare quadruple {23509#true} {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #93#return; {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,513 INFO L272 TraceCheckUtils]: 123: Hoare triple {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:54:10,514 INFO L290 TraceCheckUtils]: 124: Hoare triple {23509#true} ~cond := #in~cond; {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:54:10,514 INFO L290 TraceCheckUtils]: 125: Hoare triple {23675#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,514 INFO L290 TraceCheckUtils]: 126: Hoare triple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:54:10,515 INFO L284 TraceCheckUtils]: 127: Hoare quadruple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} #95#return; {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} is VALID [2022-04-15 08:54:10,517 INFO L272 TraceCheckUtils]: 128: Hoare triple {23853#(and (< main_~y~0 (* main_~x~0 2)) (= main_~s~0 1) (< main_~x~0 main_~y~0) (= main_~b~0 (+ main_~y~0 (* (- 1) main_~x~0))) (= (* (- 1) main_~q~0) 1) (= main_~yy~0 (* main_~y~0 main_~y~0)) (= main_~xy~0 (* main_~y~0 main_~x~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {23911#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:54:10,517 INFO L290 TraceCheckUtils]: 129: Hoare triple {23911#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {23915#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:54:10,517 INFO L290 TraceCheckUtils]: 130: Hoare triple {23915#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {23510#false} is VALID [2022-04-15 08:54:10,517 INFO L290 TraceCheckUtils]: 131: Hoare triple {23510#false} assume !false; {23510#false} is VALID [2022-04-15 08:54:10,518 INFO L134 CoverageAnalysis]: Checked inductivity of 550 backedges. 121 proven. 114 refuted. 0 times theorem prover too weak. 315 trivial. 0 not checked. [2022-04-15 08:54:10,518 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:56:37,956 WARN L232 SmtUtils]: Spent 11.97s on a formula simplification that was a NOOP. DAG size: 67 (called from [L 360] de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.smt.predicates.PredicateUnifier.getOrConstructPredicate) [2022-04-15 08:56:54,461 WARN L855 $PredicateComparison]: unable to prove that (let ((.cse7 (* c_main_~s~0 c_main_~k~0)) (.cse8 (* (- 1) c_main_~q~0 c_main_~k~0))) (let ((.cse11 (* (- 1) c_main_~q~0 c_main_~x~0 c_main_~k~0)) (.cse13 (* (- 1) c_main_~s~0 c_main_~y~0)) (.cse14 (* (- 1) c_main_~s~0 c_main_~y~0 c_main_~k~0)) (.cse1 (* c_main_~p~0 c_main_~x~0)) (.cse0 (* c_main_~r~0 c_main_~y~0)) (.cse15 (* (- 1) c_main_~q~0 c_main_~x~0)) (.cse12 (+ c_main_~p~0 .cse8)) (.cse16 (+ c_main_~r~0 (* (- 1) .cse7)))) (let ((.cse9 (* .cse16 c_main_~y~0)) (.cse10 (* .cse12 c_main_~x~0)) (.cse2 (+ c_main_~b~0 .cse11 .cse13 .cse14 .cse1 .cse0 .cse15))) (or (<= (+ c_main_~b~0 (* 2 .cse0) (* 2 .cse1)) (+ (* (* c_main_~q~0 c_main_~x~0) 2) (* 2 (* c_main_~s~0 c_main_~y~0)) (* 2 (* c_main_~q~0 c_main_~x~0 c_main_~k~0)) (* 2 (* c_main_~s~0 c_main_~y~0 c_main_~k~0)))) (not (= c_main_~c~0 .cse2)) (let ((.cse4 (+ c_main_~q~0 (* (- 1) c_main_~p~0) (* (- 1) .cse8))) (.cse6 (+ c_main_~s~0 .cse7 (* (- 1) c_main_~r~0)))) (let ((.cse3 (* .cse6 c_main_~y~0)) (.cse5 (* .cse4 c_main_~x~0))) (= (+ .cse3 (* .cse4 c_main_~xy~0) .cse5 (* c_main_~yy~0 .cse6)) (+ (* (+ .cse3 .cse5) c_main_~y~0) .cse3 .cse5)))) (not (= (+ .cse9 .cse10) .cse2)) (<= c_main_~b~0 c_main_~c~0) (not (= (+ c_main_~b~0 .cse11 (* c_main_~xy~0 .cse12) .cse13 .cse14 .cse1 .cse0 .cse15 (* c_main_~yy~0 .cse16)) (+ .cse9 .cse10 (* .cse2 c_main_~y~0)))))))) is different from true [2022-04-15 08:57:42,742 INFO L290 TraceCheckUtils]: 131: Hoare triple {23510#false} assume !false; {23510#false} is VALID [2022-04-15 08:57:42,742 INFO L290 TraceCheckUtils]: 130: Hoare triple {23915#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {23510#false} is VALID [2022-04-15 08:57:42,743 INFO L290 TraceCheckUtils]: 129: Hoare triple {23911#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {23915#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:57:42,744 INFO L272 TraceCheckUtils]: 128: Hoare triple {23931#(= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {23911#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:57:42,744 INFO L284 TraceCheckUtils]: 127: Hoare quadruple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #95#return; {23931#(= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))} is VALID [2022-04-15 08:57:42,745 INFO L290 TraceCheckUtils]: 126: Hoare triple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:42,745 INFO L290 TraceCheckUtils]: 125: Hoare triple {23945#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:42,745 INFO L290 TraceCheckUtils]: 124: Hoare triple {23509#true} ~cond := #in~cond; {23945#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:57:42,745 INFO L272 TraceCheckUtils]: 123: Hoare triple {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:42,746 INFO L284 TraceCheckUtils]: 122: Hoare quadruple {23509#true} {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #93#return; {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:42,746 INFO L290 TraceCheckUtils]: 121: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:42,746 INFO L290 TraceCheckUtils]: 120: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:42,746 INFO L290 TraceCheckUtils]: 119: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:42,746 INFO L272 TraceCheckUtils]: 118: Hoare triple {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:42,747 INFO L284 TraceCheckUtils]: 117: Hoare quadruple {23509#true} {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #91#return; {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:42,747 INFO L290 TraceCheckUtils]: 116: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:42,747 INFO L290 TraceCheckUtils]: 115: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:42,747 INFO L290 TraceCheckUtils]: 114: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:42,747 INFO L272 TraceCheckUtils]: 113: Hoare triple {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:42,747 INFO L290 TraceCheckUtils]: 112: Hoare triple {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} assume !false; {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:42,748 INFO L290 TraceCheckUtils]: 111: Hoare triple {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:42,748 INFO L290 TraceCheckUtils]: 110: Hoare triple {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} assume !false; {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:44,750 WARN L290 TraceCheckUtils]: 109: Hoare triple {23991#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {23935#(or (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is UNKNOWN [2022-04-15 08:57:44,751 INFO L290 TraceCheckUtils]: 108: Hoare triple {23995#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} assume !(~c~0 >= ~b~0); {23991#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:57:44,752 INFO L284 TraceCheckUtils]: 107: Hoare quadruple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} {23999#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} #97#return; {23995#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:57:44,752 INFO L290 TraceCheckUtils]: 106: Hoare triple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:44,753 INFO L290 TraceCheckUtils]: 105: Hoare triple {23945#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:44,753 INFO L290 TraceCheckUtils]: 104: Hoare triple {23509#true} ~cond := #in~cond; {23945#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:57:44,753 INFO L272 TraceCheckUtils]: 103: Hoare triple {23999#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:44,754 INFO L284 TraceCheckUtils]: 102: Hoare quadruple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} #95#return; {23999#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:57:44,755 INFO L290 TraceCheckUtils]: 101: Hoare triple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:44,755 INFO L290 TraceCheckUtils]: 100: Hoare triple {23945#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:44,755 INFO L290 TraceCheckUtils]: 99: Hoare triple {23509#true} ~cond := #in~cond; {23945#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:57:44,756 INFO L272 TraceCheckUtils]: 98: Hoare triple {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:44,757 INFO L284 TraceCheckUtils]: 97: Hoare quadruple {23509#true} {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} #93#return; {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:57:44,757 INFO L290 TraceCheckUtils]: 96: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:44,757 INFO L290 TraceCheckUtils]: 95: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:44,757 INFO L290 TraceCheckUtils]: 94: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:44,757 INFO L272 TraceCheckUtils]: 93: Hoare triple {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:44,758 INFO L284 TraceCheckUtils]: 92: Hoare quadruple {23509#true} {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} #91#return; {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:57:44,758 INFO L290 TraceCheckUtils]: 91: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:44,758 INFO L290 TraceCheckUtils]: 90: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:44,758 INFO L290 TraceCheckUtils]: 89: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:44,758 INFO L272 TraceCheckUtils]: 88: Hoare triple {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:44,759 INFO L290 TraceCheckUtils]: 87: Hoare triple {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} assume !false; {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:57:44,939 INFO L290 TraceCheckUtils]: 86: Hoare triple {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {24015#(or (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~y~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) main_~c~0)))} is VALID [2022-04-15 08:57:44,940 INFO L284 TraceCheckUtils]: 85: Hoare quadruple {23509#true} {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #97#return; {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:44,941 INFO L290 TraceCheckUtils]: 84: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:44,941 INFO L290 TraceCheckUtils]: 83: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:44,941 INFO L290 TraceCheckUtils]: 82: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:44,941 INFO L272 TraceCheckUtils]: 81: Hoare triple {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:44,941 INFO L284 TraceCheckUtils]: 80: Hoare quadruple {23509#true} {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #95#return; {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:44,942 INFO L290 TraceCheckUtils]: 79: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:44,942 INFO L290 TraceCheckUtils]: 78: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:44,942 INFO L290 TraceCheckUtils]: 77: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:44,942 INFO L272 TraceCheckUtils]: 76: Hoare triple {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:44,943 INFO L284 TraceCheckUtils]: 75: Hoare quadruple {23509#true} {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #93#return; {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:44,943 INFO L290 TraceCheckUtils]: 74: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:44,943 INFO L290 TraceCheckUtils]: 73: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:44,943 INFO L290 TraceCheckUtils]: 72: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:44,943 INFO L272 TraceCheckUtils]: 71: Hoare triple {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:44,944 INFO L284 TraceCheckUtils]: 70: Hoare quadruple {23509#true} {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} #91#return; {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:44,944 INFO L290 TraceCheckUtils]: 69: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:44,944 INFO L290 TraceCheckUtils]: 68: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:44,944 INFO L290 TraceCheckUtils]: 67: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:44,944 INFO L272 TraceCheckUtils]: 66: Hoare triple {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:44,945 INFO L290 TraceCheckUtils]: 65: Hoare triple {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} assume !false; {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:44,946 INFO L290 TraceCheckUtils]: 64: Hoare triple {24131#(or (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~yy~0) (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))) (* main_~xy~0 (+ main_~p~0 (* (- 1) main_~q~0)))) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))) (* (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0)))) main_~y~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0)))))) (<= (* main_~b~0 2) main_~a~0))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {24064#(or (<= (* main_~b~0 2) main_~c~0) (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))) (* (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) main_~y~0)) (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0)) main_~xy~0) (* (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))) main_~yy~0) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1)))))) (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= (+ (* main_~x~0 (+ main_~p~0 (* (- 1) (+ main_~k~0 1) main_~q~0))) (* main_~y~0 (+ main_~r~0 (* (* (+ main_~k~0 1) main_~s~0) (- 1))))) (+ main_~c~0 (* (- 1) main_~b~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))))} is VALID [2022-04-15 08:57:44,946 INFO L290 TraceCheckUtils]: 63: Hoare triple {24131#(or (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~yy~0) (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))) (* main_~xy~0 (+ main_~p~0 (* (- 1) main_~q~0)))) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))) (* (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0)))) main_~y~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0)))))) (<= (* main_~b~0 2) main_~a~0))} assume !false; {24131#(or (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~yy~0) (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))) (* main_~xy~0 (+ main_~p~0 (* (- 1) main_~q~0)))) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))) (* (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0)))) main_~y~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0)))))) (<= (* main_~b~0 2) main_~a~0))} is VALID [2022-04-15 08:57:46,950 WARN L290 TraceCheckUtils]: 62: Hoare triple {24138#(or (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~yy~0) (* main_~xy~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) main_~y~0) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0))) (<= (+ main_~b~0 (* (* main_~y~0 main_~r~0) 2) (* 2 (* main_~p~0 main_~x~0))) (+ (* 2 (* main_~y~0 main_~s~0)) (* (* main_~q~0 main_~x~0) 2) (* 2 (* main_~q~0 main_~k~0 main_~x~0)) (* (* main_~k~0 main_~y~0 main_~s~0) 2))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0)))) (not (= main_~c~0 (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0)))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~y~0 (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0))) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)))))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {24131#(or (not (= (+ (* main_~b~0 main_~y~0) (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)) (+ (* main_~s~0 main_~yy~0) main_~b~0 (* main_~q~0 main_~xy~0)))) (not (= main_~b~0 (+ (* main_~q~0 main_~x~0) (* main_~y~0 main_~s~0)))) (= (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~yy~0) (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))) (* main_~xy~0 (+ main_~p~0 (* (- 1) main_~q~0)))) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0))) (* (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0)))) main_~y~0))) (not (= (+ main_~a~0 (* (- 1) main_~b~0)) (+ (* (+ main_~r~0 (* (- 1) main_~s~0)) main_~y~0) (* main_~x~0 (+ main_~p~0 (* (- 1) main_~q~0)))))) (<= (* main_~b~0 2) main_~a~0))} is UNKNOWN [2022-04-15 08:57:46,952 INFO L290 TraceCheckUtils]: 61: Hoare triple {24142#(or (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~yy~0) (* main_~xy~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) main_~y~0) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0))) (<= (+ main_~b~0 (* (* main_~y~0 main_~r~0) 2) (* 2 (* main_~p~0 main_~x~0))) (+ (* 2 (* main_~y~0 main_~s~0)) (* (* main_~q~0 main_~x~0) 2) (* 2 (* main_~q~0 main_~k~0 main_~x~0)) (* (* main_~k~0 main_~y~0 main_~s~0) 2))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0)))) (not (= main_~c~0 (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~y~0 (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0))) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)))))} assume !(~c~0 >= ~b~0); {24138#(or (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~yy~0) (* main_~xy~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) main_~y~0) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0))) (<= (+ main_~b~0 (* (* main_~y~0 main_~r~0) 2) (* 2 (* main_~p~0 main_~x~0))) (+ (* 2 (* main_~y~0 main_~s~0)) (* (* main_~q~0 main_~x~0) 2) (* 2 (* main_~q~0 main_~k~0 main_~x~0)) (* (* main_~k~0 main_~y~0 main_~s~0) 2))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0)))) (not (= main_~c~0 (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0)))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~y~0 (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0))) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)))))} is VALID [2022-04-15 08:57:46,953 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} {23509#true} #97#return; {24142#(or (= (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~yy~0) (* main_~xy~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~x~0 (+ main_~q~0 (* (- 1) (* (- 1) main_~q~0 main_~k~0)) (* (- 1) main_~p~0))) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0)) main_~y~0) (* (+ (* main_~k~0 main_~s~0) main_~s~0 (* (- 1) main_~r~0)) main_~y~0))) (<= (+ main_~b~0 (* (* main_~y~0 main_~r~0) 2) (* 2 (* main_~p~0 main_~x~0))) (+ (* 2 (* main_~y~0 main_~s~0)) (* (* main_~q~0 main_~x~0) 2) (* 2 (* main_~q~0 main_~k~0 main_~x~0)) (* (* main_~k~0 main_~y~0 main_~s~0) 2))) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0)))) (not (= main_~c~0 (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0)))) (<= main_~b~0 main_~c~0) (not (= (+ (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~y~0) (* main_~y~0 (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0))) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~x~0)) (+ (* (- 1) main_~y~0 main_~s~0) (* (- 1) main_~k~0 main_~y~0 main_~s~0) (* main_~y~0 main_~r~0) (* (+ (* (* main_~k~0 main_~s~0) (- 1)) main_~r~0) main_~yy~0) main_~b~0 (* (- 1) main_~q~0 main_~x~0) (* (- 1) main_~q~0 main_~k~0 main_~x~0) (* main_~p~0 main_~x~0) (* (+ main_~p~0 (* (- 1) main_~q~0 main_~k~0)) main_~xy~0)))))} is VALID [2022-04-15 08:57:46,954 INFO L290 TraceCheckUtils]: 59: Hoare triple {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:46,954 INFO L290 TraceCheckUtils]: 58: Hoare triple {23945#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} assume !(0 == ~cond); {23679#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:46,954 INFO L290 TraceCheckUtils]: 57: Hoare triple {23509#true} ~cond := #in~cond; {23945#(or (not (= |__VERIFIER_assert_#in~cond| 0)) (= __VERIFIER_assert_~cond 0))} is VALID [2022-04-15 08:57:46,954 INFO L272 TraceCheckUtils]: 56: Hoare triple {23509#true} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {23509#true} {23509#true} #95#return; {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L290 TraceCheckUtils]: 54: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L290 TraceCheckUtils]: 53: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L290 TraceCheckUtils]: 52: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L272 TraceCheckUtils]: 51: Hoare triple {23509#true} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {23509#true} {23509#true} #93#return; {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L290 TraceCheckUtils]: 49: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L290 TraceCheckUtils]: 48: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L290 TraceCheckUtils]: 47: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L272 TraceCheckUtils]: 46: Hoare triple {23509#true} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {23509#true} {23509#true} #91#return; {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L290 TraceCheckUtils]: 44: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L290 TraceCheckUtils]: 43: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:46,955 INFO L290 TraceCheckUtils]: 42: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L272 TraceCheckUtils]: 41: Hoare triple {23509#true} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 40: Hoare triple {23509#true} assume !false; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 39: Hoare triple {23509#true} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 38: Hoare triple {23509#true} assume !false; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {23509#true} {23509#true} #89#return; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 36: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 35: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 34: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L272 TraceCheckUtils]: 33: Hoare triple {23509#true} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {23509#true} {23509#true} #87#return; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 31: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 30: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 29: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L272 TraceCheckUtils]: 28: Hoare triple {23509#true} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,956 INFO L290 TraceCheckUtils]: 27: Hoare triple {23509#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {23509#true} {23509#true} #85#return; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L290 TraceCheckUtils]: 25: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L290 TraceCheckUtils]: 24: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L290 TraceCheckUtils]: 23: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L272 TraceCheckUtils]: 22: Hoare triple {23509#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {23509#true} {23509#true} #83#return; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L290 TraceCheckUtils]: 20: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L290 TraceCheckUtils]: 19: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L290 TraceCheckUtils]: 18: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L272 TraceCheckUtils]: 17: Hoare triple {23509#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {23509#true} {23509#true} #81#return; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L290 TraceCheckUtils]: 15: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L290 TraceCheckUtils]: 14: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L290 TraceCheckUtils]: 13: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:46,957 INFO L272 TraceCheckUtils]: 12: Hoare triple {23509#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L290 TraceCheckUtils]: 11: Hoare triple {23509#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {23509#true} {23509#true} #79#return; {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L290 TraceCheckUtils]: 9: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L290 TraceCheckUtils]: 8: Hoare triple {23509#true} assume !(0 == ~cond); {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L290 TraceCheckUtils]: 7: Hoare triple {23509#true} ~cond := #in~cond; {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L272 TraceCheckUtils]: 6: Hoare triple {23509#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L290 TraceCheckUtils]: 5: Hoare triple {23509#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L272 TraceCheckUtils]: 4: Hoare triple {23509#true} call #t~ret6 := main(); {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {23509#true} {23509#true} #103#return; {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L290 TraceCheckUtils]: 2: Hoare triple {23509#true} assume true; {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L290 TraceCheckUtils]: 1: Hoare triple {23509#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {23509#true} is VALID [2022-04-15 08:57:46,958 INFO L272 TraceCheckUtils]: 0: Hoare triple {23509#true} call ULTIMATE.init(); {23509#true} is VALID [2022-04-15 08:57:46,959 INFO L134 CoverageAnalysis]: Checked inductivity of 550 backedges. 141 proven. 59 refuted. 0 times theorem prover too weak. 348 trivial. 2 not checked. [2022-04-15 08:57:46,959 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:57:46,959 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1092348641] [2022-04-15 08:57:46,959 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:57:46,959 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [451378360] [2022-04-15 08:57:46,959 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [451378360] provided 0 perfect and 2 imperfect interpolant sequences [2022-04-15 08:57:46,959 INFO L184 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-04-15 08:57:46,960 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [17, 16] total 28 [2022-04-15 08:57:46,960 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:57:46,960 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [2092109103] [2022-04-15 08:57:46,960 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [2092109103] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:57:46,960 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:57:46,960 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [17] imperfect sequences [] total 17 [2022-04-15 08:57:46,960 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [351826975] [2022-04-15 08:57:46,960 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:57:46,960 INFO L78 Accepts]: Start accepts. Automaton has has 17 states, 17 states have (on average 2.0588235294117645) internal successors, (35), 15 states have internal predecessors, (35), 7 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 7 states have call predecessors, (22), 7 states have call successors, (22) Word has length 132 [2022-04-15 08:57:46,961 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:57:46,961 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 17 states, 17 states have (on average 2.0588235294117645) internal successors, (35), 15 states have internal predecessors, (35), 7 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 7 states have call predecessors, (22), 7 states have call successors, (22) [2022-04-15 08:57:47,072 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 81 edges. 81 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:57:47,072 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 17 states [2022-04-15 08:57:47,072 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:57:47,072 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 17 interpolants. [2022-04-15 08:57:47,072 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=147, Invalid=558, Unknown=1, NotChecked=50, Total=756 [2022-04-15 08:57:47,073 INFO L87 Difference]: Start difference. First operand 235 states and 312 transitions. Second operand has 17 states, 17 states have (on average 2.0588235294117645) internal successors, (35), 15 states have internal predecessors, (35), 7 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 7 states have call predecessors, (22), 7 states have call successors, (22) [2022-04-15 08:57:54,091 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:57:54,092 INFO L93 Difference]: Finished difference Result 244 states and 320 transitions. [2022-04-15 08:57:54,092 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 17 states. [2022-04-15 08:57:54,092 INFO L78 Accepts]: Start accepts. Automaton has has 17 states, 17 states have (on average 2.0588235294117645) internal successors, (35), 15 states have internal predecessors, (35), 7 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 7 states have call predecessors, (22), 7 states have call successors, (22) Word has length 132 [2022-04-15 08:57:54,092 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:57:54,092 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 17 states, 17 states have (on average 2.0588235294117645) internal successors, (35), 15 states have internal predecessors, (35), 7 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 7 states have call predecessors, (22), 7 states have call successors, (22) [2022-04-15 08:57:54,093 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 17 states to 17 states and 125 transitions. [2022-04-15 08:57:54,093 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 17 states, 17 states have (on average 2.0588235294117645) internal successors, (35), 15 states have internal predecessors, (35), 7 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 7 states have call predecessors, (22), 7 states have call successors, (22) [2022-04-15 08:57:54,094 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 17 states to 17 states and 125 transitions. [2022-04-15 08:57:54,095 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 17 states and 125 transitions. [2022-04-15 08:57:54,273 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 125 edges. 125 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:57:54,277 INFO L225 Difference]: With dead ends: 244 [2022-04-15 08:57:54,277 INFO L226 Difference]: Without dead ends: 242 [2022-04-15 08:57:54,278 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 271 GetRequests, 233 SyntacticMatches, 4 SemanticMatches, 34 ConstructedPredicates, 1 IntricatePredicates, 0 DeprecatedPredicates, 222 ImplicationChecksByTransitivity, 16.2s TimeCoverageRelationStatistics Valid=238, Invalid=955, Unknown=1, NotChecked=66, Total=1260 [2022-04-15 08:57:54,278 INFO L913 BasicCegarLoop]: 42 mSDtfsCounter, 40 mSDsluCounter, 240 mSDsCounter, 0 mSdLazyCounter, 989 mSolverCounterSat, 43 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 2.8s Time, 0 mProtectedPredicate, 0 mProtectedAction, 53 SdHoareTripleChecker+Valid, 282 SdHoareTripleChecker+Invalid, 1032 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 43 IncrementalHoareTripleChecker+Valid, 989 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 2.8s IncrementalHoareTripleChecker+Time [2022-04-15 08:57:54,278 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [53 Valid, 282 Invalid, 1032 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [43 Valid, 989 Invalid, 0 Unknown, 0 Unchecked, 2.8s Time] [2022-04-15 08:57:54,278 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 242 states. [2022-04-15 08:57:54,870 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 242 to 239. [2022-04-15 08:57:54,870 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:57:54,870 INFO L82 GeneralOperation]: Start isEquivalent. First operand 242 states. Second operand has 239 states, 130 states have (on average 1.1307692307692307) internal successors, (147), 131 states have internal predecessors, (147), 85 states have call successors, (85), 24 states have call predecessors, (85), 23 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:57:54,871 INFO L74 IsIncluded]: Start isIncluded. First operand 242 states. Second operand has 239 states, 130 states have (on average 1.1307692307692307) internal successors, (147), 131 states have internal predecessors, (147), 85 states have call successors, (85), 24 states have call predecessors, (85), 23 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:57:54,871 INFO L87 Difference]: Start difference. First operand 242 states. Second operand has 239 states, 130 states have (on average 1.1307692307692307) internal successors, (147), 131 states have internal predecessors, (147), 85 states have call successors, (85), 24 states have call predecessors, (85), 23 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:57:54,875 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:57:54,875 INFO L93 Difference]: Finished difference Result 242 states and 318 transitions. [2022-04-15 08:57:54,875 INFO L276 IsEmpty]: Start isEmpty. Operand 242 states and 318 transitions. [2022-04-15 08:57:54,876 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:57:54,876 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:57:54,876 INFO L74 IsIncluded]: Start isIncluded. First operand has 239 states, 130 states have (on average 1.1307692307692307) internal successors, (147), 131 states have internal predecessors, (147), 85 states have call successors, (85), 24 states have call predecessors, (85), 23 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) Second operand 242 states. [2022-04-15 08:57:54,876 INFO L87 Difference]: Start difference. First operand has 239 states, 130 states have (on average 1.1307692307692307) internal successors, (147), 131 states have internal predecessors, (147), 85 states have call successors, (85), 24 states have call predecessors, (85), 23 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) Second operand 242 states. [2022-04-15 08:57:54,880 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:57:54,880 INFO L93 Difference]: Finished difference Result 242 states and 318 transitions. [2022-04-15 08:57:54,880 INFO L276 IsEmpty]: Start isEmpty. Operand 242 states and 318 transitions. [2022-04-15 08:57:54,881 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:57:54,881 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:57:54,881 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:57:54,881 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:57:54,881 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 239 states, 130 states have (on average 1.1307692307692307) internal successors, (147), 131 states have internal predecessors, (147), 85 states have call successors, (85), 24 states have call predecessors, (85), 23 states have return successors, (83), 83 states have call predecessors, (83), 83 states have call successors, (83) [2022-04-15 08:57:54,885 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 239 states to 239 states and 315 transitions. [2022-04-15 08:57:54,886 INFO L78 Accepts]: Start accepts. Automaton has 239 states and 315 transitions. Word has length 132 [2022-04-15 08:57:54,886 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:57:54,886 INFO L478 AbstractCegarLoop]: Abstraction has 239 states and 315 transitions. [2022-04-15 08:57:54,886 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 17 states, 17 states have (on average 2.0588235294117645) internal successors, (35), 15 states have internal predecessors, (35), 7 states have call successors, (24), 2 states have call predecessors, (24), 3 states have return successors, (22), 7 states have call predecessors, (22), 7 states have call successors, (22) [2022-04-15 08:57:54,886 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 239 states and 315 transitions. [2022-04-15 08:57:55,631 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 315 edges. 315 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:57:55,631 INFO L276 IsEmpty]: Start isEmpty. Operand 239 states and 315 transitions. [2022-04-15 08:57:55,639 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 136 [2022-04-15 08:57:55,639 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:57:55,639 INFO L499 BasicCegarLoop]: trace histogram [17, 16, 16, 6, 6, 6, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 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] [2022-04-15 08:57:55,656 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (20)] Forceful destruction successful, exit code 0 [2022-04-15 08:57:55,851 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable19,20 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:57:55,853 INFO L403 AbstractCegarLoop]: === Iteration 21 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:57:55,853 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:57:55,854 INFO L85 PathProgramCache]: Analyzing trace with hash 1068997356, now seen corresponding path program 7 times [2022-04-15 08:57:55,854 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:57:55,854 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [608753464] [2022-04-15 08:57:55,854 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:57:55,854 INFO L85 PathProgramCache]: Analyzing trace with hash 1068997356, now seen corresponding path program 8 times [2022-04-15 08:57:55,854 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:57:55,854 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [513376053] [2022-04-15 08:57:55,854 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:57:55,854 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:57:55,864 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:57:55,864 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1428468756] [2022-04-15 08:57:55,864 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-04-15 08:57:55,864 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:57:55,864 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:57:55,865 INFO L229 MonitoredProcess]: Starting monitored process 21 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:57:55,869 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (21)] Waiting until timeout for monitored process [2022-04-15 08:57:55,931 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-04-15 08:57:55,931 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:57:55,933 INFO L263 TraceCheckSpWp]: Trace formula consists of 317 conjuncts, 44 conjunts are in the unsatisfiable core [2022-04-15 08:57:55,950 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:57:55,952 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-04-15 08:57:56,990 INFO L272 TraceCheckUtils]: 0: Hoare triple {25794#true} call ULTIMATE.init(); {25794#true} is VALID [2022-04-15 08:57:56,990 INFO L290 TraceCheckUtils]: 1: Hoare triple {25794#true} #NULL.base, #NULL.offset := 0, 0;assume 0 == #valid[0];assume 0 < #StackHeapBarrier;call #Ultimate.allocInit(2, 1);call write~init~int(48, 1, 0, 1);call write~init~int(0, 1, 1, 1);call #Ultimate.allocInit(11, 2);call #Ultimate.allocInit(12, 3); {25794#true} is VALID [2022-04-15 08:57:56,990 INFO L290 TraceCheckUtils]: 2: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L284 TraceCheckUtils]: 3: Hoare quadruple {25794#true} {25794#true} #103#return; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L272 TraceCheckUtils]: 4: Hoare triple {25794#true} call #t~ret6 := main(); {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L290 TraceCheckUtils]: 5: Hoare triple {25794#true} havoc ~x~0;havoc ~y~0;havoc ~a~0;havoc ~b~0;havoc ~p~0;havoc ~q~0;havoc ~r~0;havoc ~s~0;havoc ~c~0;havoc ~k~0;havoc ~xy~0;havoc ~yy~0;assume -2147483648 <= #t~nondet4 && #t~nondet4 <= 2147483647;~x~0 := #t~nondet4;havoc #t~nondet4; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L272 TraceCheckUtils]: 6: Hoare triple {25794#true} call assume_abort_if_not((if ~x~0 >= 0 && ~x~0 <= 5 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L290 TraceCheckUtils]: 7: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L290 TraceCheckUtils]: 8: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L290 TraceCheckUtils]: 9: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L284 TraceCheckUtils]: 10: Hoare quadruple {25794#true} {25794#true} #79#return; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L290 TraceCheckUtils]: 11: Hoare triple {25794#true} assume -2147483648 <= #t~nondet5 && #t~nondet5 <= 2147483647;~y~0 := #t~nondet5;havoc #t~nondet5; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L272 TraceCheckUtils]: 12: Hoare triple {25794#true} call assume_abort_if_not((if ~y~0 >= 0 && ~y~0 <= 5 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L290 TraceCheckUtils]: 13: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L290 TraceCheckUtils]: 14: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L290 TraceCheckUtils]: 15: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L284 TraceCheckUtils]: 16: Hoare quadruple {25794#true} {25794#true} #81#return; {25794#true} is VALID [2022-04-15 08:57:56,991 INFO L272 TraceCheckUtils]: 17: Hoare triple {25794#true} call assume_abort_if_not((if ~x~0 >= 1 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L290 TraceCheckUtils]: 18: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L290 TraceCheckUtils]: 19: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L290 TraceCheckUtils]: 20: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L284 TraceCheckUtils]: 21: Hoare quadruple {25794#true} {25794#true} #83#return; {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L272 TraceCheckUtils]: 22: Hoare triple {25794#true} call assume_abort_if_not((if ~y~0 >= 1 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L290 TraceCheckUtils]: 23: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L290 TraceCheckUtils]: 24: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L290 TraceCheckUtils]: 25: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L284 TraceCheckUtils]: 26: Hoare quadruple {25794#true} {25794#true} #85#return; {25794#true} is VALID [2022-04-15 08:57:56,992 INFO L290 TraceCheckUtils]: 27: Hoare triple {25794#true} ~a~0 := ~x~0;~b~0 := ~y~0;~p~0 := 1;~q~0 := 0;~r~0 := 0;~s~0 := 1;~c~0 := 0;~k~0 := 0;~xy~0 := ~x~0 * ~y~0;~yy~0 := ~y~0 * ~y~0; {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:56,993 INFO L272 TraceCheckUtils]: 28: Hoare triple {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~xy~0 < 2147483647 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,993 INFO L290 TraceCheckUtils]: 29: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,993 INFO L290 TraceCheckUtils]: 30: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,993 INFO L290 TraceCheckUtils]: 31: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,993 INFO L284 TraceCheckUtils]: 32: Hoare quadruple {25794#true} {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #87#return; {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:56,993 INFO L272 TraceCheckUtils]: 33: Hoare triple {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call assume_abort_if_not((if ~yy~0 < 2147483647 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,994 INFO L290 TraceCheckUtils]: 34: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,994 INFO L290 TraceCheckUtils]: 35: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,994 INFO L290 TraceCheckUtils]: 36: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,994 INFO L284 TraceCheckUtils]: 37: Hoare quadruple {25794#true} {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #89#return; {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:56,995 INFO L290 TraceCheckUtils]: 38: Hoare triple {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:56,995 INFO L290 TraceCheckUtils]: 39: Hoare triple {25880#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(0 != ~b~0);~c~0 := ~a~0;~k~0 := 0; {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:56,995 INFO L290 TraceCheckUtils]: 40: Hoare triple {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:56,995 INFO L272 TraceCheckUtils]: 41: Hoare triple {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,996 INFO L290 TraceCheckUtils]: 42: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,996 INFO L290 TraceCheckUtils]: 43: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,996 INFO L290 TraceCheckUtils]: 44: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,996 INFO L284 TraceCheckUtils]: 45: Hoare quadruple {25794#true} {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:56,996 INFO L272 TraceCheckUtils]: 46: Hoare triple {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,996 INFO L290 TraceCheckUtils]: 47: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,996 INFO L290 TraceCheckUtils]: 48: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,997 INFO L290 TraceCheckUtils]: 49: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,997 INFO L284 TraceCheckUtils]: 50: Hoare quadruple {25794#true} {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:56,997 INFO L272 TraceCheckUtils]: 51: Hoare triple {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,997 INFO L290 TraceCheckUtils]: 52: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,997 INFO L290 TraceCheckUtils]: 53: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,997 INFO L290 TraceCheckUtils]: 54: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,998 INFO L284 TraceCheckUtils]: 55: Hoare quadruple {25794#true} {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #95#return; {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:56,998 INFO L272 TraceCheckUtils]: 56: Hoare triple {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:56,998 INFO L290 TraceCheckUtils]: 57: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:56,998 INFO L290 TraceCheckUtils]: 58: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:56,998 INFO L290 TraceCheckUtils]: 59: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:56,999 INFO L284 TraceCheckUtils]: 60: Hoare quadruple {25794#true} {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #97#return; {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,001 INFO L290 TraceCheckUtils]: 61: Hoare triple {25917#(and (= main_~r~0 0) (= main_~c~0 main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,001 INFO L290 TraceCheckUtils]: 62: Hoare triple {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,001 INFO L272 TraceCheckUtils]: 63: Hoare triple {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,001 INFO L290 TraceCheckUtils]: 64: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,001 INFO L290 TraceCheckUtils]: 65: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,001 INFO L290 TraceCheckUtils]: 66: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,002 INFO L284 TraceCheckUtils]: 67: Hoare quadruple {25794#true} {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,002 INFO L272 TraceCheckUtils]: 68: Hoare triple {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,002 INFO L290 TraceCheckUtils]: 69: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,002 INFO L290 TraceCheckUtils]: 70: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,002 INFO L290 TraceCheckUtils]: 71: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,003 INFO L284 TraceCheckUtils]: 72: Hoare quadruple {25794#true} {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,003 INFO L272 TraceCheckUtils]: 73: Hoare triple {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,003 INFO L290 TraceCheckUtils]: 74: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,003 INFO L290 TraceCheckUtils]: 75: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,003 INFO L290 TraceCheckUtils]: 76: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,004 INFO L284 TraceCheckUtils]: 77: Hoare quadruple {25794#true} {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #95#return; {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,004 INFO L272 TraceCheckUtils]: 78: Hoare triple {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,004 INFO L290 TraceCheckUtils]: 79: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,004 INFO L290 TraceCheckUtils]: 80: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,004 INFO L290 TraceCheckUtils]: 81: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,005 INFO L284 TraceCheckUtils]: 82: Hoare quadruple {25794#true} {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #97#return; {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,006 INFO L290 TraceCheckUtils]: 83: Hoare triple {25984#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~a~0 (+ main_~c~0 main_~b~0)) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,006 INFO L290 TraceCheckUtils]: 84: Hoare triple {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,006 INFO L272 TraceCheckUtils]: 85: Hoare triple {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,006 INFO L290 TraceCheckUtils]: 86: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,006 INFO L290 TraceCheckUtils]: 87: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,006 INFO L290 TraceCheckUtils]: 88: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,007 INFO L284 TraceCheckUtils]: 89: Hoare quadruple {25794#true} {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,007 INFO L272 TraceCheckUtils]: 90: Hoare triple {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,007 INFO L290 TraceCheckUtils]: 91: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,007 INFO L290 TraceCheckUtils]: 92: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,007 INFO L290 TraceCheckUtils]: 93: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,008 INFO L284 TraceCheckUtils]: 94: Hoare quadruple {25794#true} {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #93#return; {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,008 INFO L272 TraceCheckUtils]: 95: Hoare triple {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,008 INFO L290 TraceCheckUtils]: 96: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,008 INFO L290 TraceCheckUtils]: 97: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,008 INFO L290 TraceCheckUtils]: 98: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,009 INFO L284 TraceCheckUtils]: 99: Hoare quadruple {25794#true} {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #95#return; {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,009 INFO L272 TraceCheckUtils]: 100: Hoare triple {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,009 INFO L290 TraceCheckUtils]: 101: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,009 INFO L290 TraceCheckUtils]: 102: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,009 INFO L290 TraceCheckUtils]: 103: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,009 INFO L284 TraceCheckUtils]: 104: Hoare quadruple {25794#true} {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #97#return; {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,010 INFO L290 TraceCheckUtils]: 105: Hoare triple {26051#(and (= main_~r~0 0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= (+ main_~c~0 (* main_~b~0 2)) main_~a~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !!(~c~0 >= ~b~0);~c~0 := ~c~0 - ~b~0;~k~0 := 1 + ~k~0; {26118#(and (= main_~r~0 0) (= (+ main_~c~0 (* main_~b~0 3)) main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,011 INFO L290 TraceCheckUtils]: 106: Hoare triple {26118#(and (= main_~r~0 0) (= (+ main_~c~0 (* main_~b~0 3)) main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} assume !false; {26118#(and (= main_~r~0 0) (= (+ main_~c~0 (* main_~b~0 3)) main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,011 INFO L272 TraceCheckUtils]: 107: Hoare triple {26118#(and (= main_~r~0 0) (= (+ main_~c~0 (* main_~b~0 3)) main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~k~0 * ~b~0 + ~c~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,011 INFO L290 TraceCheckUtils]: 108: Hoare triple {25794#true} ~cond := #in~cond; {26128#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:57:57,011 INFO L290 TraceCheckUtils]: 109: Hoare triple {26128#(= |__VERIFIER_assert_#in~cond| __VERIFIER_assert_~cond)} assume !(0 == ~cond); {26132#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:57,012 INFO L290 TraceCheckUtils]: 110: Hoare triple {26132#(not (= |__VERIFIER_assert_#in~cond| 0))} assume true; {26132#(not (= |__VERIFIER_assert_#in~cond| 0))} is VALID [2022-04-15 08:57:57,015 INFO L284 TraceCheckUtils]: 111: Hoare quadruple {26132#(not (= |__VERIFIER_assert_#in~cond| 0))} {26118#(and (= main_~r~0 0) (= (+ main_~c~0 (* main_~b~0 3)) main_~a~0) (= main_~s~0 1) (= main_~b~0 main_~y~0) (= main_~q~0 0) (= main_~a~0 main_~x~0) (= main_~p~0 1))} #91#return; {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,015 INFO L272 TraceCheckUtils]: 112: Hoare triple {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} call __VERIFIER_assert((if ~a~0 == ~y~0 * ~r~0 + ~x~0 * ~p~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,015 INFO L290 TraceCheckUtils]: 113: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,015 INFO L290 TraceCheckUtils]: 114: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,015 INFO L290 TraceCheckUtils]: 115: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,016 INFO L284 TraceCheckUtils]: 116: Hoare quadruple {25794#true} {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} #93#return; {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,016 INFO L272 TraceCheckUtils]: 117: Hoare triple {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} call __VERIFIER_assert((if ~b~0 == ~x~0 * ~q~0 + ~y~0 * ~s~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,016 INFO L290 TraceCheckUtils]: 118: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,016 INFO L290 TraceCheckUtils]: 119: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,016 INFO L290 TraceCheckUtils]: 120: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,017 INFO L284 TraceCheckUtils]: 121: Hoare quadruple {25794#true} {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} #95#return; {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,017 INFO L272 TraceCheckUtils]: 122: Hoare triple {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~xy~0 + ~s~0 * ~yy~0 - ~q~0 * ~x~0 - ~b~0 * ~y~0 - ~s~0 * ~y~0 + ~b~0 then 1 else 0)); {25794#true} is VALID [2022-04-15 08:57:57,017 INFO L290 TraceCheckUtils]: 123: Hoare triple {25794#true} ~cond := #in~cond; {25794#true} is VALID [2022-04-15 08:57:57,017 INFO L290 TraceCheckUtils]: 124: Hoare triple {25794#true} assume !(0 == ~cond); {25794#true} is VALID [2022-04-15 08:57:57,017 INFO L290 TraceCheckUtils]: 125: Hoare triple {25794#true} assume true; {25794#true} is VALID [2022-04-15 08:57:57,018 INFO L284 TraceCheckUtils]: 126: Hoare quadruple {25794#true} {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} #97#return; {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,018 INFO L290 TraceCheckUtils]: 127: Hoare triple {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} assume !(~c~0 >= ~b~0); {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} is VALID [2022-04-15 08:57:57,020 INFO L290 TraceCheckUtils]: 128: Hoare triple {26139#(and (= main_~r~0 0) (= main_~s~0 1) (= (+ main_~c~0 (* main_~y~0 3)) (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~q~0 0) (= main_~x~0 (+ main_~c~0 (* main_~k~0 main_~y~0))) (= main_~p~0 1))} ~a~0 := ~b~0;~b~0 := ~c~0;havoc ~temp~0;~temp~0 := ~p~0;~p~0 := ~q~0;~q~0 := ~temp~0 - ~q~0 * ~k~0;~temp~0 := ~r~0;~r~0 := ~s~0;~s~0 := ~temp~0 - ~s~0 * ~k~0; {26191#(and (= (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~b~0) (= (+ main_~x~0 (* main_~y~0 3) (* main_~y~0 main_~s~0)) (+ (* main_~y~0 (* (- 1) main_~s~0)) main_~x~0 (* main_~y~0 main_~s~0))) (= main_~q~0 1))} is VALID [2022-04-15 08:57:57,020 INFO L290 TraceCheckUtils]: 129: Hoare triple {26191#(and (= (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~b~0) (= (+ main_~x~0 (* main_~y~0 3) (* main_~y~0 main_~s~0)) (+ (* main_~y~0 (* (- 1) main_~s~0)) main_~x~0 (* main_~y~0 main_~s~0))) (= main_~q~0 1))} assume !false; {26191#(and (= (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~b~0) (= (+ main_~x~0 (* main_~y~0 3) (* main_~y~0 main_~s~0)) (+ (* main_~y~0 (* (- 1) main_~s~0)) main_~x~0 (* main_~y~0 main_~s~0))) (= main_~q~0 1))} is VALID [2022-04-15 08:57:57,021 INFO L290 TraceCheckUtils]: 130: Hoare triple {26191#(and (= (+ main_~x~0 (* main_~y~0 main_~s~0)) main_~b~0) (= (+ main_~x~0 (* main_~y~0 3) (* main_~y~0 main_~s~0)) (+ (* main_~y~0 (* (- 1) main_~s~0)) main_~x~0 (* main_~y~0 main_~s~0))) (= main_~q~0 1))} assume !(0 != ~b~0); {26198#(and (= (+ main_~x~0 (* main_~y~0 main_~s~0)) 0) (= (+ main_~x~0 (* main_~y~0 3) (* main_~y~0 main_~s~0)) (+ (* main_~y~0 (* (- 1) main_~s~0)) main_~x~0 (* main_~y~0 main_~s~0))) (= main_~q~0 1))} is VALID [2022-04-15 08:57:57,021 INFO L272 TraceCheckUtils]: 131: Hoare triple {26198#(and (= (+ main_~x~0 (* main_~y~0 main_~s~0)) 0) (= (+ main_~x~0 (* main_~y~0 3) (* main_~y~0 main_~s~0)) (+ (* main_~y~0 (* (- 1) main_~s~0)) main_~x~0 (* main_~y~0 main_~s~0))) (= main_~q~0 1))} call __VERIFIER_assert((if 0 == ~q~0 * ~x~0 + ~s~0 * ~y~0 then 1 else 0)); {26202#(<= 1 |__VERIFIER_assert_#in~cond|)} is VALID [2022-04-15 08:57:57,021 INFO L290 TraceCheckUtils]: 132: Hoare triple {26202#(<= 1 |__VERIFIER_assert_#in~cond|)} ~cond := #in~cond; {26206#(<= 1 __VERIFIER_assert_~cond)} is VALID [2022-04-15 08:57:57,022 INFO L290 TraceCheckUtils]: 133: Hoare triple {26206#(<= 1 __VERIFIER_assert_~cond)} assume 0 == ~cond; {25795#false} is VALID [2022-04-15 08:57:57,022 INFO L290 TraceCheckUtils]: 134: Hoare triple {25795#false} assume !false; {25795#false} is VALID [2022-04-15 08:57:57,022 INFO L134 CoverageAnalysis]: Checked inductivity of 610 backedges. 67 proven. 48 refuted. 0 times theorem prover too weak. 495 trivial. 0 not checked. [2022-04-15 08:57:57,022 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-04-15 08:58:09,155 WARN L914 QuantifierPusher]: no eliminatee completely removed, nonetheless the elimination was considered successful [2022-04-15 08:58:09,243 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-04-15 08:58:09,243 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [513376053] [2022-04-15 08:58:09,244 WARN L310 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-04-15 08:58:09,244 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1428468756] [2022-04-15 08:58:09,244 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1428468756] provided 0 perfect and 1 imperfect interpolant sequences [2022-04-15 08:58:09,244 INFO L184 FreeRefinementEngine]: Found 0 perfect and 1 imperfect interpolant sequences. [2022-04-15 08:58:09,244 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [14] total 14 [2022-04-15 08:58:09,244 INFO L136 FreeRefinementEngine]: Strategy ACCELERATED_INTERPOLATION found an infeasible trace [2022-04-15 08:58:09,244 INFO L333 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleAcceleratedInterpolation [608753464] [2022-04-15 08:58:09,244 INFO L157 FreeRefinementEngine]: IpTcStrategyModuleAcceleratedInterpolation [608753464] provided 1 perfect and 0 imperfect interpolant sequences [2022-04-15 08:58:09,244 INFO L184 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-04-15 08:58:09,244 INFO L197 FreeRefinementEngine]: Number of different interpolants: perfect sequences [14] imperfect sequences [] total 14 [2022-04-15 08:58:09,244 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1760216745] [2022-04-15 08:58:09,244 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-04-15 08:58:09,245 INFO L78 Accepts]: Start accepts. Automaton has has 14 states, 13 states have (on average 2.3076923076923075) internal successors, (30), 13 states have internal predecessors, (30), 8 states have call successors, (25), 2 states have call predecessors, (25), 2 states have return successors, (23), 6 states have call predecessors, (23), 7 states have call successors, (23) Word has length 135 [2022-04-15 08:58:09,245 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-04-15 08:58:09,245 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with has 14 states, 13 states have (on average 2.3076923076923075) internal successors, (30), 13 states have internal predecessors, (30), 8 states have call successors, (25), 2 states have call predecessors, (25), 2 states have return successors, (23), 6 states have call predecessors, (23), 7 states have call successors, (23) [2022-04-15 08:58:09,340 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 78 edges. 78 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:58:09,340 INFO L554 AbstractCegarLoop]: INTERPOLANT automaton has 14 states [2022-04-15 08:58:09,340 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy ACCELERATED_INTERPOLATION [2022-04-15 08:58:09,340 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 14 interpolants. [2022-04-15 08:58:09,340 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=53, Invalid=253, Unknown=0, NotChecked=0, Total=306 [2022-04-15 08:58:09,341 INFO L87 Difference]: Start difference. First operand 239 states and 315 transitions. Second operand has 14 states, 13 states have (on average 2.3076923076923075) internal successors, (30), 13 states have internal predecessors, (30), 8 states have call successors, (25), 2 states have call predecessors, (25), 2 states have return successors, (23), 6 states have call predecessors, (23), 7 states have call successors, (23) [2022-04-15 08:58:13,763 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:58:13,763 INFO L93 Difference]: Finished difference Result 280 states and 374 transitions. [2022-04-15 08:58:13,763 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2022-04-15 08:58:13,764 INFO L78 Accepts]: Start accepts. Automaton has has 14 states, 13 states have (on average 2.3076923076923075) internal successors, (30), 13 states have internal predecessors, (30), 8 states have call successors, (25), 2 states have call predecessors, (25), 2 states have return successors, (23), 6 states have call predecessors, (23), 7 states have call successors, (23) Word has length 135 [2022-04-15 08:58:13,764 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-04-15 08:58:13,764 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 14 states, 13 states have (on average 2.3076923076923075) internal successors, (30), 13 states have internal predecessors, (30), 8 states have call successors, (25), 2 states have call predecessors, (25), 2 states have return successors, (23), 6 states have call predecessors, (23), 7 states have call successors, (23) [2022-04-15 08:58:13,767 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 127 transitions. [2022-04-15 08:58:13,767 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 14 states, 13 states have (on average 2.3076923076923075) internal successors, (30), 13 states have internal predecessors, (30), 8 states have call successors, (25), 2 states have call predecessors, (25), 2 states have return successors, (23), 6 states have call predecessors, (23), 7 states have call successors, (23) [2022-04-15 08:58:13,768 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 14 states to 14 states and 127 transitions. [2022-04-15 08:58:13,769 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 14 states and 127 transitions. [2022-04-15 08:58:13,924 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 127 edges. 127 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:58:13,929 INFO L225 Difference]: With dead ends: 280 [2022-04-15 08:58:13,929 INFO L226 Difference]: Without dead ends: 277 [2022-04-15 08:58:13,929 INFO L912 BasicCegarLoop]: 0 DeclaredPredicates, 162 GetRequests, 141 SyntacticMatches, 1 SemanticMatches, 20 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 86 ImplicationChecksByTransitivity, 0.8s TimeCoverageRelationStatistics Valid=78, Invalid=384, Unknown=0, NotChecked=0, Total=462 [2022-04-15 08:58:13,930 INFO L913 BasicCegarLoop]: 57 mSDtfsCounter, 28 mSDsluCounter, 271 mSDsCounter, 0 mSdLazyCounter, 789 mSolverCounterSat, 42 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 1.7s Time, 0 mProtectedPredicate, 0 mProtectedAction, 37 SdHoareTripleChecker+Valid, 328 SdHoareTripleChecker+Invalid, 831 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 42 IncrementalHoareTripleChecker+Valid, 789 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 1.7s IncrementalHoareTripleChecker+Time [2022-04-15 08:58:13,930 INFO L914 BasicCegarLoop]: SdHoareTripleChecker [37 Valid, 328 Invalid, 831 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [42 Valid, 789 Invalid, 0 Unknown, 0 Unchecked, 1.7s Time] [2022-04-15 08:58:13,930 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 277 states. [2022-04-15 08:58:14,634 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 277 to 274. [2022-04-15 08:58:14,634 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-04-15 08:58:14,634 INFO L82 GeneralOperation]: Start isEquivalent. First operand 277 states. Second operand has 274 states, 147 states have (on average 1.1360544217687074) internal successors, (167), 148 states have internal predecessors, (167), 101 states have call successors, (101), 26 states have call predecessors, (101), 25 states have return successors, (99), 99 states have call predecessors, (99), 99 states have call successors, (99) [2022-04-15 08:58:14,635 INFO L74 IsIncluded]: Start isIncluded. First operand 277 states. Second operand has 274 states, 147 states have (on average 1.1360544217687074) internal successors, (167), 148 states have internal predecessors, (167), 101 states have call successors, (101), 26 states have call predecessors, (101), 25 states have return successors, (99), 99 states have call predecessors, (99), 99 states have call successors, (99) [2022-04-15 08:58:14,635 INFO L87 Difference]: Start difference. First operand 277 states. Second operand has 274 states, 147 states have (on average 1.1360544217687074) internal successors, (167), 148 states have internal predecessors, (167), 101 states have call successors, (101), 26 states have call predecessors, (101), 25 states have return successors, (99), 99 states have call predecessors, (99), 99 states have call successors, (99) [2022-04-15 08:58:14,640 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:58:14,640 INFO L93 Difference]: Finished difference Result 277 states and 370 transitions. [2022-04-15 08:58:14,640 INFO L276 IsEmpty]: Start isEmpty. Operand 277 states and 370 transitions. [2022-04-15 08:58:14,640 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:58:14,640 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:58:14,641 INFO L74 IsIncluded]: Start isIncluded. First operand has 274 states, 147 states have (on average 1.1360544217687074) internal successors, (167), 148 states have internal predecessors, (167), 101 states have call successors, (101), 26 states have call predecessors, (101), 25 states have return successors, (99), 99 states have call predecessors, (99), 99 states have call successors, (99) Second operand 277 states. [2022-04-15 08:58:14,641 INFO L87 Difference]: Start difference. First operand has 274 states, 147 states have (on average 1.1360544217687074) internal successors, (167), 148 states have internal predecessors, (167), 101 states have call successors, (101), 26 states have call predecessors, (101), 25 states have return successors, (99), 99 states have call predecessors, (99), 99 states have call successors, (99) Second operand 277 states. [2022-04-15 08:58:14,646 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-04-15 08:58:14,646 INFO L93 Difference]: Finished difference Result 277 states and 370 transitions. [2022-04-15 08:58:14,646 INFO L276 IsEmpty]: Start isEmpty. Operand 277 states and 370 transitions. [2022-04-15 08:58:14,646 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-04-15 08:58:14,646 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-04-15 08:58:14,646 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-04-15 08:58:14,646 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-04-15 08:58:14,647 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 274 states, 147 states have (on average 1.1360544217687074) internal successors, (167), 148 states have internal predecessors, (167), 101 states have call successors, (101), 26 states have call predecessors, (101), 25 states have return successors, (99), 99 states have call predecessors, (99), 99 states have call successors, (99) [2022-04-15 08:58:14,652 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 274 states to 274 states and 367 transitions. [2022-04-15 08:58:14,652 INFO L78 Accepts]: Start accepts. Automaton has 274 states and 367 transitions. Word has length 135 [2022-04-15 08:58:14,652 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-04-15 08:58:14,652 INFO L478 AbstractCegarLoop]: Abstraction has 274 states and 367 transitions. [2022-04-15 08:58:14,652 INFO L479 AbstractCegarLoop]: INTERPOLANT automaton has has 14 states, 13 states have (on average 2.3076923076923075) internal successors, (30), 13 states have internal predecessors, (30), 8 states have call successors, (25), 2 states have call predecessors, (25), 2 states have return successors, (23), 6 states have call predecessors, (23), 7 states have call successors, (23) [2022-04-15 08:58:14,653 INFO L86 InductivityCheck]: Starting inductivity check of a Floyd-Hoare automaton with 274 states and 367 transitions. [2022-04-15 08:58:15,522 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 367 edges. 367 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-04-15 08:58:15,522 INFO L276 IsEmpty]: Start isEmpty. Operand 274 states and 367 transitions. [2022-04-15 08:58:15,523 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 139 [2022-04-15 08:58:15,523 INFO L491 BasicCegarLoop]: Found error trace [2022-04-15 08:58:15,523 INFO L499 BasicCegarLoop]: trace histogram [17, 16, 16, 6, 6, 6, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 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] [2022-04-15 08:58:15,541 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (21)] Forceful destruction successful, exit code 0 [2022-04-15 08:58:15,723 WARN L460 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 21 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable20 [2022-04-15 08:58:15,724 INFO L403 AbstractCegarLoop]: === Iteration 22 === Targeting __VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION === [__VERIFIER_assertErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-04-15 08:58:15,724 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-04-15 08:58:15,724 INFO L85 PathProgramCache]: Analyzing trace with hash -896647763, now seen corresponding path program 9 times [2022-04-15 08:58:15,724 INFO L118 FreeRefinementEngine]: Executing refinement strategy ACCELERATED_INTERPOLATION [2022-04-15 08:58:15,724 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleAcceleratedInterpolation [78984746] [2022-04-15 08:58:15,724 INFO L202 tedInterpolationCore]: No loops in this trace, falling back to nested interpolation [2022-04-15 08:58:15,724 INFO L85 PathProgramCache]: Analyzing trace with hash -896647763, now seen corresponding path program 10 times [2022-04-15 08:58:15,725 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-04-15 08:58:15,725 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [2106082194] [2022-04-15 08:58:15,725 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-04-15 08:58:15,725 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-04-15 08:58:15,738 ERROR L245 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-04-15 08:58:15,738 INFO L333 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1010738809] [2022-04-15 08:58:15,738 INFO L93 rtionOrderModulation]: Changing assertion order to TERMS_WITH_SMALL_CONSTANTS_FIRST [2022-04-15 08:58:15,738 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-04-15 08:58:15,738 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-04-15 08:58:15,739 INFO L229 MonitoredProcess]: Starting monitored process 22 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-04-15 08:58:15,740 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (22)] Waiting until timeout for monitored process [2022-04-15 08:58:15,801 INFO L228 tOrderPrioritization]: Assert order TERMS_WITH_SMALL_CONSTANTS_FIRST issued 0 check-sat command(s) [2022-04-15 08:58:15,802 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-04-15 08:58:15,803 INFO L263 TraceCheckSpWp]: Trace formula consists of 294 conjuncts, 80 conjunts are in the unsatisfiable core [2022-04-15 08:58:15,834 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-04-15 08:58:15,836 INFO L286 TraceCheckSpWp]: Computing forward predicates...