./Ultimate.py --spec ../sv-benchmarks/c/properties/unreach-call.prp --file ../sv-benchmarks/c/array-programs/partial_mod_count_limited_5.c --full-output -ea --architecture 32bit -------------------------------------------------------------------------------- Checking for ERROR reachability Using default analysis Version 03d7b7b3 Calling Ultimate with: /usr/bin/java -Dosgi.configuration.area=/storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/config -Xmx15G -Xms4m -ea -jar /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/plugins/org.eclipse.equinox.launcher_1.5.800.v20200727-1323.jar -data @noDefault -ultimatedata /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data -tc /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/AutomizerReach.xml -i ../sv-benchmarks/c/array-programs/partial_mod_count_limited_5.c -s /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/svcomp-Reach-32bit-Automizer_Default.epf --cacsl2boogietranslator.entry.function main --witnessprinter.witness.directory /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux --witnessprinter.witness.filename witness.graphml --witnessprinter.write.witness.besides.input.file false --witnessprinter.graph.data.specification CHECK( init(main()), LTL(G ! call(reach_error())) ) --witnessprinter.graph.data.producer Automizer --witnessprinter.graph.data.architecture 32bit --witnessprinter.graph.data.programhash 2535b8df62b232497a5d3d6ff06546d8e28bdaf58cbf4426ff971bf84e825948 --- Real Ultimate output --- This is Ultimate 0.2.2-dev-03d7b7b [2022-02-20 14:16:40,347 INFO L177 SettingsManager]: Resetting all preferences to default values... [2022-02-20 14:16:40,349 INFO L181 SettingsManager]: Resetting UltimateCore preferences to default values [2022-02-20 14:16:40,370 INFO L184 SettingsManager]: Ultimate Commandline Interface provides no preferences, ignoring... [2022-02-20 14:16:40,370 INFO L181 SettingsManager]: Resetting Boogie Preprocessor preferences to default values [2022-02-20 14:16:40,371 INFO L181 SettingsManager]: Resetting Boogie Procedure Inliner preferences to default values [2022-02-20 14:16:40,372 INFO L181 SettingsManager]: Resetting Abstract Interpretation preferences to default values [2022-02-20 14:16:40,373 INFO L181 SettingsManager]: Resetting LassoRanker preferences to default values [2022-02-20 14:16:40,374 INFO L181 SettingsManager]: Resetting Reaching Definitions preferences to default values [2022-02-20 14:16:40,375 INFO L181 SettingsManager]: Resetting SyntaxChecker preferences to default values [2022-02-20 14:16:40,375 INFO L181 SettingsManager]: Resetting Sifa preferences to default values [2022-02-20 14:16:40,376 INFO L184 SettingsManager]: Büchi Program Product provides no preferences, ignoring... [2022-02-20 14:16:40,376 INFO L181 SettingsManager]: Resetting LTL2Aut preferences to default values [2022-02-20 14:16:40,377 INFO L181 SettingsManager]: Resetting PEA to Boogie preferences to default values [2022-02-20 14:16:40,377 INFO L181 SettingsManager]: Resetting BlockEncodingV2 preferences to default values [2022-02-20 14:16:40,378 INFO L181 SettingsManager]: Resetting ChcToBoogie preferences to default values [2022-02-20 14:16:40,379 INFO L181 SettingsManager]: Resetting AutomataScriptInterpreter preferences to default values [2022-02-20 14:16:40,379 INFO L181 SettingsManager]: Resetting BuchiAutomizer preferences to default values [2022-02-20 14:16:40,380 INFO L181 SettingsManager]: Resetting CACSL2BoogieTranslator preferences to default values [2022-02-20 14:16:40,381 INFO L181 SettingsManager]: Resetting CodeCheck preferences to default values [2022-02-20 14:16:40,382 INFO L181 SettingsManager]: Resetting InvariantSynthesis preferences to default values [2022-02-20 14:16:40,383 INFO L181 SettingsManager]: Resetting RCFGBuilder preferences to default values [2022-02-20 14:16:40,384 INFO L181 SettingsManager]: Resetting Referee preferences to default values [2022-02-20 14:16:40,385 INFO L181 SettingsManager]: Resetting TraceAbstraction preferences to default values [2022-02-20 14:16:40,386 INFO L184 SettingsManager]: TraceAbstractionConcurrent provides no preferences, ignoring... [2022-02-20 14:16:40,387 INFO L184 SettingsManager]: TraceAbstractionWithAFAs provides no preferences, ignoring... [2022-02-20 14:16:40,387 INFO L181 SettingsManager]: Resetting TreeAutomizer preferences to default values [2022-02-20 14:16:40,387 INFO L181 SettingsManager]: Resetting IcfgToChc preferences to default values [2022-02-20 14:16:40,388 INFO L181 SettingsManager]: Resetting IcfgTransformer preferences to default values [2022-02-20 14:16:40,388 INFO L184 SettingsManager]: ReqToTest provides no preferences, ignoring... [2022-02-20 14:16:40,389 INFO L181 SettingsManager]: Resetting Boogie Printer preferences to default values [2022-02-20 14:16:40,389 INFO L181 SettingsManager]: Resetting ChcSmtPrinter preferences to default values [2022-02-20 14:16:40,389 INFO L181 SettingsManager]: Resetting ReqPrinter preferences to default values [2022-02-20 14:16:40,390 INFO L181 SettingsManager]: Resetting Witness Printer preferences to default values [2022-02-20 14:16:40,391 INFO L184 SettingsManager]: Boogie PL CUP Parser provides no preferences, ignoring... [2022-02-20 14:16:40,391 INFO L181 SettingsManager]: Resetting CDTParser preferences to default values [2022-02-20 14:16:40,391 INFO L184 SettingsManager]: AutomataScriptParser provides no preferences, ignoring... [2022-02-20 14:16:40,391 INFO L184 SettingsManager]: ReqParser provides no preferences, ignoring... [2022-02-20 14:16:40,392 INFO L181 SettingsManager]: Resetting SmtParser preferences to default values [2022-02-20 14:16:40,392 INFO L181 SettingsManager]: Resetting Witness Parser preferences to default values [2022-02-20 14:16:40,393 INFO L188 SettingsManager]: Finished resetting all preferences to default values... [2022-02-20 14:16:40,395 INFO L101 SettingsManager]: Beginning loading settings from /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/svcomp-Reach-32bit-Automizer_Default.epf [2022-02-20 14:16:40,409 INFO L113 SettingsManager]: Loading preferences was successful [2022-02-20 14:16:40,409 INFO L115 SettingsManager]: Preferences different from defaults after loading the file: [2022-02-20 14:16:40,409 INFO L136 SettingsManager]: Preferences of UltimateCore differ from their defaults: [2022-02-20 14:16:40,409 INFO L138 SettingsManager]: * Log level for class=de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=ERROR; [2022-02-20 14:16:40,410 INFO L136 SettingsManager]: Preferences of Boogie Procedure Inliner differ from their defaults: [2022-02-20 14:16:40,410 INFO L138 SettingsManager]: * Ignore calls to procedures called more than once=ONLY_FOR_SEQUENTIAL_PROGRAMS [2022-02-20 14:16:40,410 INFO L136 SettingsManager]: Preferences of BlockEncodingV2 differ from their defaults: [2022-02-20 14:16:40,411 INFO L138 SettingsManager]: * Create parallel compositions if possible=false [2022-02-20 14:16:40,411 INFO L138 SettingsManager]: * Use SBE=true [2022-02-20 14:16:40,411 INFO L136 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2022-02-20 14:16:40,411 INFO L138 SettingsManager]: * sizeof long=4 [2022-02-20 14:16:40,411 INFO L138 SettingsManager]: * Overapproximate operations on floating types=true [2022-02-20 14:16:40,411 INFO L138 SettingsManager]: * sizeof POINTER=4 [2022-02-20 14:16:40,412 INFO L138 SettingsManager]: * Check division by zero=IGNORE [2022-02-20 14:16:40,412 INFO L138 SettingsManager]: * Pointer to allocated memory at dereference=IGNORE [2022-02-20 14:16:40,412 INFO L138 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=IGNORE [2022-02-20 14:16:40,412 INFO L138 SettingsManager]: * Check array bounds for arrays that are off heap=IGNORE [2022-02-20 14:16:40,412 INFO L138 SettingsManager]: * sizeof long double=12 [2022-02-20 14:16:40,412 INFO L138 SettingsManager]: * Check if freed pointer was valid=false [2022-02-20 14:16:40,412 INFO L138 SettingsManager]: * Use constant arrays=true [2022-02-20 14:16:40,412 INFO L138 SettingsManager]: * Pointer base address is valid at dereference=IGNORE [2022-02-20 14:16:40,413 INFO L136 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2022-02-20 14:16:40,413 INFO L138 SettingsManager]: * Size of a code block=SequenceOfStatements [2022-02-20 14:16:40,413 INFO L138 SettingsManager]: * SMT solver=External_DefaultMode [2022-02-20 14:16:40,413 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 14:16:40,413 INFO L136 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2022-02-20 14:16:40,413 INFO L138 SettingsManager]: * Compute Interpolants along a Counterexample=FPandBP [2022-02-20 14:16:40,413 INFO L138 SettingsManager]: * Positions where we compute the Hoare Annotation=LoopsAndPotentialCycles [2022-02-20 14:16:40,414 INFO L138 SettingsManager]: * Trace refinement strategy=CAMEL [2022-02-20 14:16:40,414 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in [2022-02-20 14:16:40,414 INFO L138 SettingsManager]: * Large block encoding in concurrent analysis=OFF [2022-02-20 14:16:40,414 INFO L138 SettingsManager]: * Automaton type used in concurrency analysis=PETRI_NET [2022-02-20 14:16:40,414 INFO L138 SettingsManager]: * Compute Hoare Annotation of negated interpolant automaton, abstraction and CFG=true [2022-02-20 14:16:40,414 INFO L138 SettingsManager]: * SMT solver=External_ModelsAndUnsatCoreMode 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.plugins.generator.cacsl2boogietranslator: Entry function -> main Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Witness directory -> /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Witness filename -> witness.graphml Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Write witness besides input file -> false Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data specification -> CHECK( init(main()), LTL(G ! call(reach_error())) ) Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data producer -> Automizer Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data architecture -> 32bit Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data programhash -> 2535b8df62b232497a5d3d6ff06546d8e28bdaf58cbf4426ff971bf84e825948 [2022-02-20 14:16:40,584 INFO L75 nceAwareModelManager]: Repository-Root is: /tmp [2022-02-20 14:16:40,605 INFO L261 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2022-02-20 14:16:40,607 INFO L217 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2022-02-20 14:16:40,608 INFO L271 PluginConnector]: Initializing CDTParser... [2022-02-20 14:16:40,608 INFO L275 PluginConnector]: CDTParser initialized [2022-02-20 14:16:40,609 INFO L432 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../sv-benchmarks/c/array-programs/partial_mod_count_limited_5.c [2022-02-20 14:16:40,662 INFO L220 CDTParser]: Created temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/791a64bef/cc7c30ebc1fa46ff9f1dc0d90a396fed/FLAGc1ad91817 [2022-02-20 14:16:41,037 INFO L306 CDTParser]: Found 1 translation units. [2022-02-20 14:16:41,038 INFO L160 CDTParser]: Scanning /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/array-programs/partial_mod_count_limited_5.c [2022-02-20 14:16:41,045 INFO L349 CDTParser]: About to delete temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/791a64bef/cc7c30ebc1fa46ff9f1dc0d90a396fed/FLAGc1ad91817 [2022-02-20 14:16:41,057 INFO L357 CDTParser]: Successfully deleted /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/791a64bef/cc7c30ebc1fa46ff9f1dc0d90a396fed [2022-02-20 14:16:41,059 INFO L299 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2022-02-20 14:16:41,061 INFO L131 ToolchainWalker]: Walking toolchain with 6 elements. [2022-02-20 14:16:41,065 INFO L113 PluginConnector]: ------------------------CACSL2BoogieTranslator---------------------------- [2022-02-20 14:16:41,065 INFO L271 PluginConnector]: Initializing CACSL2BoogieTranslator... [2022-02-20 14:16:41,068 INFO L275 PluginConnector]: CACSL2BoogieTranslator initialized [2022-02-20 14:16:41,072 INFO L185 PluginConnector]: Executing the observer ACSLObjectContainerObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,073 INFO L205 PluginConnector]: Invalid model from CACSL2BoogieTranslator for observer de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator.ACSLObjectContainerObserver@282a777a and model type de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41, skipping insertion in model container [2022-02-20 14:16:41,073 INFO L185 PluginConnector]: Executing the observer CACSL2BoogieTranslatorObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,079 INFO L145 MainTranslator]: Starting translation in SV-COMP mode [2022-02-20 14:16:41,090 INFO L178 MainTranslator]: Built tables and reachable declarations [2022-02-20 14:16:41,217 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/array-programs/partial_mod_count_limited_5.c[331,344] [2022-02-20 14:16:41,245 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 14:16:41,253 INFO L203 MainTranslator]: Completed pre-run [2022-02-20 14:16:41,263 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/array-programs/partial_mod_count_limited_5.c[331,344] [2022-02-20 14:16:41,277 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 14:16:41,288 INFO L208 MainTranslator]: Completed translation [2022-02-20 14:16:41,288 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41 WrapperNode [2022-02-20 14:16:41,289 INFO L132 PluginConnector]: ------------------------ END CACSL2BoogieTranslator---------------------------- [2022-02-20 14:16:41,289 INFO L113 PluginConnector]: ------------------------Boogie Procedure Inliner---------------------------- [2022-02-20 14:16:41,289 INFO L271 PluginConnector]: Initializing Boogie Procedure Inliner... [2022-02-20 14:16:41,290 INFO L275 PluginConnector]: Boogie Procedure Inliner initialized [2022-02-20 14:16:41,295 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,301 INFO L185 PluginConnector]: Executing the observer Inliner from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,334 INFO L137 Inliner]: procedures = 15, calls = 16, calls flagged for inlining = 4, calls inlined = 4, statements flattened = 68 [2022-02-20 14:16:41,334 INFO L132 PluginConnector]: ------------------------ END Boogie Procedure Inliner---------------------------- [2022-02-20 14:16:41,335 INFO L113 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2022-02-20 14:16:41,335 INFO L271 PluginConnector]: Initializing Boogie Preprocessor... [2022-02-20 14:16:41,336 INFO L275 PluginConnector]: Boogie Preprocessor initialized [2022-02-20 14:16:41,341 INFO L185 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,341 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,347 INFO L185 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,348 INFO L185 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,359 INFO L185 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,362 INFO L185 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,368 INFO L185 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,370 INFO L132 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2022-02-20 14:16:41,371 INFO L113 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2022-02-20 14:16:41,371 INFO L271 PluginConnector]: Initializing RCFGBuilder... [2022-02-20 14:16:41,372 INFO L275 PluginConnector]: RCFGBuilder initialized [2022-02-20 14:16:41,373 INFO L185 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (1/1) ... [2022-02-20 14:16:41,377 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 14:16:41,384 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:16:41,395 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-02-20 14:16:41,413 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-02-20 14:16:41,425 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocInit [2022-02-20 14:16:41,426 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~int [2022-02-20 14:16:41,426 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocOnStack [2022-02-20 14:16:41,426 INFO L130 BoogieDeclarations]: Found specification of procedure write~int [2022-02-20 14:16:41,426 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2022-02-20 14:16:41,426 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2022-02-20 14:16:41,426 INFO L130 BoogieDeclarations]: Found specification of procedure read~int [2022-02-20 14:16:41,426 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.dealloc [2022-02-20 14:16:41,471 INFO L234 CfgBuilder]: Building ICFG [2022-02-20 14:16:41,473 INFO L260 CfgBuilder]: Building CFG for each procedure with an implementation [2022-02-20 14:16:41,709 INFO L275 CfgBuilder]: Performing block encoding [2022-02-20 14:16:41,713 INFO L294 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2022-02-20 14:16:41,713 INFO L299 CfgBuilder]: Removed 2 assume(true) statements. [2022-02-20 14:16:41,714 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 02:16:41 BoogieIcfgContainer [2022-02-20 14:16:41,714 INFO L132 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2022-02-20 14:16:41,715 INFO L113 PluginConnector]: ------------------------TraceAbstraction---------------------------- [2022-02-20 14:16:41,717 INFO L271 PluginConnector]: Initializing TraceAbstraction... [2022-02-20 14:16:41,719 INFO L275 PluginConnector]: TraceAbstraction initialized [2022-02-20 14:16:41,735 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "CDTParser AST 20.02 02:16:41" (1/3) ... [2022-02-20 14:16:41,736 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@73277ea4 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 02:16:41, skipping insertion in model container [2022-02-20 14:16:41,736 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 02:16:41" (2/3) ... [2022-02-20 14:16:41,736 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@73277ea4 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 02:16:41, skipping insertion in model container [2022-02-20 14:16:41,737 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 02:16:41" (3/3) ... [2022-02-20 14:16:41,738 INFO L111 eAbstractionObserver]: Analyzing ICFG partial_mod_count_limited_5.c [2022-02-20 14:16:41,741 INFO L205 ceAbstractionStarter]: Automizer settings: Hoare:true NWA Interpolation:FPandBP Determinization: PREDICATE_ABSTRACTION [2022-02-20 14:16:41,741 INFO L164 ceAbstractionStarter]: Applying trace abstraction to program that has 1 error locations. [2022-02-20 14:16:41,775 INFO L338 AbstractCegarLoop]: ======== Iteration 0 == of CEGAR loop == AllErrorsAtOnce ======== [2022-02-20 14:16:41,780 INFO L339 AbstractCegarLoop]: Settings: SEPARATE_VIOLATION_CHECK=true, mInterprocedural=true, mMaxIterations=1000000, mWatchIteration=1000000, mArtifact=RCFG, mInterpolation=FPandBP, mInterpolantAutomaton=STRAIGHT_LINE, mDumpAutomata=false, mAutomataFormat=ATS_NUMERATE, mDumpPath=., mDeterminiation=PREDICATE_ABSTRACTION, mMinimize=MINIMIZE_SEVPA, mHoare=true, mAutomataTypeConcurrency=PETRI_NET, mHoareTripleChecks=INCREMENTAL, mHoareAnnotationPositions=LoopsAndPotentialCycles, 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, mLoopAccelerationTechnique=FAST_UPR [2022-02-20 14:16:41,780 INFO L340 AbstractCegarLoop]: Starting to check reachability of 1 error locations. [2022-02-20 14:16:41,790 INFO L276 IsEmpty]: Start isEmpty. Operand has 22 states, 20 states have (on average 1.5) internal successors, (30), 21 states have internal predecessors, (30), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:41,794 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 12 [2022-02-20 14:16:41,794 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 14:16:41,794 INFO L514 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 14:16:41,795 INFO L402 AbstractCegarLoop]: === Iteration 1 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 14:16:41,798 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 14:16:41,799 INFO L85 PathProgramCache]: Analyzing trace with hash -1939796378, now seen corresponding path program 1 times [2022-02-20 14:16:41,805 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 14:16:41,805 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1557756703] [2022-02-20 14:16:41,805 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:41,806 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 14:16:41,886 ERROR L252 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-02-20 14:16:41,887 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [648029975] [2022-02-20 14:16:41,888 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:41,888 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:41,888 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:16:41,890 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-02-20 14:16:41,891 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-02-20 14:16:41,953 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:41,956 INFO L263 TraceCheckSpWp]: Trace formula consists of 68 conjuncts, 1 conjunts are in the unsatisfiable core [2022-02-20 14:16:41,969 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:41,972 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 14:16:42,026 INFO L290 TraceCheckUtils]: 0: Hoare triple {25#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {25#true} is VALID [2022-02-20 14:16:42,027 INFO L290 TraceCheckUtils]: 1: Hoare triple {25#true} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {25#true} is VALID [2022-02-20 14:16:42,028 INFO L290 TraceCheckUtils]: 2: Hoare triple {25#true} assume 0 == assume_abort_if_not_~cond#1;assume false; {26#false} is VALID [2022-02-20 14:16:42,028 INFO L290 TraceCheckUtils]: 3: Hoare triple {26#false} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {26#false} is VALID [2022-02-20 14:16:42,029 INFO L290 TraceCheckUtils]: 4: Hoare triple {26#false} assume !true; {26#false} is VALID [2022-02-20 14:16:42,029 INFO L290 TraceCheckUtils]: 5: Hoare triple {26#false} main_~i~0#1 := 0; {26#false} is VALID [2022-02-20 14:16:42,029 INFO L290 TraceCheckUtils]: 6: Hoare triple {26#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {26#false} is VALID [2022-02-20 14:16:42,030 INFO L290 TraceCheckUtils]: 7: Hoare triple {26#false} assume !(0 == main_#t~mem9#1);havoc main_#t~mem9#1; {26#false} is VALID [2022-02-20 14:16:42,030 INFO L290 TraceCheckUtils]: 8: Hoare triple {26#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {26#false} is VALID [2022-02-20 14:16:42,030 INFO L290 TraceCheckUtils]: 9: Hoare triple {26#false} assume 0 == __VERIFIER_assert_~cond#1; {26#false} is VALID [2022-02-20 14:16:42,031 INFO L290 TraceCheckUtils]: 10: Hoare triple {26#false} assume !false; {26#false} is VALID [2022-02-20 14:16:42,031 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 14:16:42,032 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 14:16:42,032 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 14:16:42,032 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1557756703] [2022-02-20 14:16:42,032 WARN L317 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-02-20 14:16:42,033 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [648029975] [2022-02-20 14:16:42,033 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [648029975] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 14:16:42,033 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 14:16:42,034 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [2] imperfect sequences [] total 2 [2022-02-20 14:16:42,039 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1260523035] [2022-02-20 14:16:42,041 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 14:16:42,065 INFO L78 Accepts]: Start accepts. Automaton has has 2 states, 2 states have (on average 5.5) internal successors, (11), 2 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 11 [2022-02-20 14:16:42,066 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 14:16:42,068 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 2 states, 2 states have (on average 5.5) internal successors, (11), 2 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,080 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 11 edges. 11 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:42,081 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 2 states [2022-02-20 14:16:42,081 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 14:16:42,100 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 2 interpolants. [2022-02-20 14:16:42,101 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=1, Invalid=1, Unknown=0, NotChecked=0, Total=2 [2022-02-20 14:16:42,103 INFO L87 Difference]: Start difference. First operand has 22 states, 20 states have (on average 1.5) internal successors, (30), 21 states have internal predecessors, (30), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand has 2 states, 2 states have (on average 5.5) internal successors, (11), 2 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,141 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:42,142 INFO L93 Difference]: Finished difference Result 41 states and 56 transitions. [2022-02-20 14:16:42,142 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2022-02-20 14:16:42,142 INFO L78 Accepts]: Start accepts. Automaton has has 2 states, 2 states have (on average 5.5) internal successors, (11), 2 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 11 [2022-02-20 14:16:42,143 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 14:16:42,143 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 2 states, 2 states have (on average 5.5) internal successors, (11), 2 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,149 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 2 states to 2 states and 56 transitions. [2022-02-20 14:16:42,149 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 2 states, 2 states have (on average 5.5) internal successors, (11), 2 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,154 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 2 states to 2 states and 56 transitions. [2022-02-20 14:16:42,155 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 2 states and 56 transitions. [2022-02-20 14:16:42,208 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 56 edges. 56 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:42,216 INFO L225 Difference]: With dead ends: 41 [2022-02-20 14:16:42,216 INFO L226 Difference]: Without dead ends: 18 [2022-02-20 14:16:42,218 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 10 GetRequests, 10 SyntacticMatches, 0 SemanticMatches, 0 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=1, Invalid=1, Unknown=0, NotChecked=0, Total=2 [2022-02-20 14:16:42,221 INFO L933 BasicCegarLoop]: 26 mSDtfsCounter, 0 mSDsluCounter, 0 mSDsCounter, 0 mSdLazyCounter, 0 mSolverCounterSat, 0 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 0 SdHoareTripleChecker+Valid, 26 SdHoareTripleChecker+Invalid, 0 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Valid, 0 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-02-20 14:16:42,223 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [0 Valid, 26 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [0 Valid, 0 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-02-20 14:16:42,234 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 18 states. [2022-02-20 14:16:42,243 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 18 to 18. [2022-02-20 14:16:42,243 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 14:16:42,243 INFO L82 GeneralOperation]: Start isEquivalent. First operand 18 states. Second operand has 18 states, 17 states have (on average 1.2941176470588236) internal successors, (22), 17 states have internal predecessors, (22), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,244 INFO L74 IsIncluded]: Start isIncluded. First operand 18 states. Second operand has 18 states, 17 states have (on average 1.2941176470588236) internal successors, (22), 17 states have internal predecessors, (22), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,245 INFO L87 Difference]: Start difference. First operand 18 states. Second operand has 18 states, 17 states have (on average 1.2941176470588236) internal successors, (22), 17 states have internal predecessors, (22), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,247 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:42,247 INFO L93 Difference]: Finished difference Result 18 states and 22 transitions. [2022-02-20 14:16:42,248 INFO L276 IsEmpty]: Start isEmpty. Operand 18 states and 22 transitions. [2022-02-20 14:16:42,248 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:42,248 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:42,248 INFO L74 IsIncluded]: Start isIncluded. First operand has 18 states, 17 states have (on average 1.2941176470588236) internal successors, (22), 17 states have internal predecessors, (22), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 18 states. [2022-02-20 14:16:42,248 INFO L87 Difference]: Start difference. First operand has 18 states, 17 states have (on average 1.2941176470588236) internal successors, (22), 17 states have internal predecessors, (22), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 18 states. [2022-02-20 14:16:42,250 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:42,250 INFO L93 Difference]: Finished difference Result 18 states and 22 transitions. [2022-02-20 14:16:42,251 INFO L276 IsEmpty]: Start isEmpty. Operand 18 states and 22 transitions. [2022-02-20 14:16:42,251 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:42,252 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:42,252 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 14:16:42,254 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 14:16:42,255 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 18 states, 17 states have (on average 1.2941176470588236) internal successors, (22), 17 states have internal predecessors, (22), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,256 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 18 states to 18 states and 22 transitions. [2022-02-20 14:16:42,257 INFO L78 Accepts]: Start accepts. Automaton has 18 states and 22 transitions. Word has length 11 [2022-02-20 14:16:42,257 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 14:16:42,258 INFO L470 AbstractCegarLoop]: Abstraction has 18 states and 22 transitions. [2022-02-20 14:16:42,258 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 2 states, 2 states have (on average 5.5) internal successors, (11), 2 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,258 INFO L276 IsEmpty]: Start isEmpty. Operand 18 states and 22 transitions. [2022-02-20 14:16:42,259 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 12 [2022-02-20 14:16:42,263 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 14:16:42,263 INFO L514 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 14:16:42,283 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-02-20 14:16:42,477 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 2 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable0 [2022-02-20 14:16:42,478 INFO L402 AbstractCegarLoop]: === Iteration 2 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 14:16:42,479 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 14:16:42,479 INFO L85 PathProgramCache]: Analyzing trace with hash -54935082, now seen corresponding path program 1 times [2022-02-20 14:16:42,479 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 14:16:42,479 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [882196941] [2022-02-20 14:16:42,480 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:42,480 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 14:16:42,499 ERROR L252 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-02-20 14:16:42,503 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [570248408] [2022-02-20 14:16:42,503 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:42,504 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:42,504 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:16:42,505 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-02-20 14:16:42,507 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-02-20 14:16:42,554 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:42,555 INFO L263 TraceCheckSpWp]: Trace formula consists of 68 conjuncts, 3 conjunts are in the unsatisfiable core [2022-02-20 14:16:42,562 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:42,563 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 14:16:42,662 INFO L290 TraceCheckUtils]: 0: Hoare triple {162#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {167#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:42,662 INFO L290 TraceCheckUtils]: 1: Hoare triple {167#(<= 1000 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {167#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:42,663 INFO L290 TraceCheckUtils]: 2: Hoare triple {167#(<= 1000 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {167#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:42,663 INFO L290 TraceCheckUtils]: 3: Hoare triple {167#(<= 1000 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {177#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:42,664 INFO L290 TraceCheckUtils]: 4: Hoare triple {177#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !(main_~i~0#1 < ~N~0); {163#false} is VALID [2022-02-20 14:16:42,664 INFO L290 TraceCheckUtils]: 5: Hoare triple {163#false} main_~i~0#1 := 0; {163#false} is VALID [2022-02-20 14:16:42,664 INFO L290 TraceCheckUtils]: 6: Hoare triple {163#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {163#false} is VALID [2022-02-20 14:16:42,664 INFO L290 TraceCheckUtils]: 7: Hoare triple {163#false} assume !(0 == main_#t~mem9#1);havoc main_#t~mem9#1; {163#false} is VALID [2022-02-20 14:16:42,665 INFO L290 TraceCheckUtils]: 8: Hoare triple {163#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {163#false} is VALID [2022-02-20 14:16:42,665 INFO L290 TraceCheckUtils]: 9: Hoare triple {163#false} assume 0 == __VERIFIER_assert_~cond#1; {163#false} is VALID [2022-02-20 14:16:42,665 INFO L290 TraceCheckUtils]: 10: Hoare triple {163#false} assume !false; {163#false} is VALID [2022-02-20 14:16:42,665 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 14:16:42,665 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 14:16:42,665 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 14:16:42,666 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [882196941] [2022-02-20 14:16:42,666 WARN L317 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-02-20 14:16:42,666 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [570248408] [2022-02-20 14:16:42,667 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [570248408] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 14:16:42,667 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 14:16:42,667 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [] total 3 [2022-02-20 14:16:42,667 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [704189525] [2022-02-20 14:16:42,667 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 14:16:42,668 INFO L78 Accepts]: Start accepts. Automaton has has 4 states, 4 states have (on average 2.75) internal successors, (11), 3 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 11 [2022-02-20 14:16:42,668 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 14:16:42,669 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 4 states, 4 states have (on average 2.75) internal successors, (11), 3 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,678 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 11 edges. 11 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:42,678 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 4 states [2022-02-20 14:16:42,678 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 14:16:42,679 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 4 interpolants. [2022-02-20 14:16:42,679 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=6, Invalid=6, Unknown=0, NotChecked=0, Total=12 [2022-02-20 14:16:42,679 INFO L87 Difference]: Start difference. First operand 18 states and 22 transitions. Second operand has 4 states, 4 states have (on average 2.75) internal successors, (11), 3 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,743 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:42,743 INFO L93 Difference]: Finished difference Result 45 states and 57 transitions. [2022-02-20 14:16:42,743 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 4 states. [2022-02-20 14:16:42,743 INFO L78 Accepts]: Start accepts. Automaton has has 4 states, 4 states have (on average 2.75) internal successors, (11), 3 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 11 [2022-02-20 14:16:42,744 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 14:16:42,744 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 4 states, 4 states have (on average 2.75) internal successors, (11), 3 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,745 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 4 states to 4 states and 57 transitions. [2022-02-20 14:16:42,745 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 4 states, 4 states have (on average 2.75) internal successors, (11), 3 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,747 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 4 states to 4 states and 57 transitions. [2022-02-20 14:16:42,747 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 4 states and 57 transitions. [2022-02-20 14:16:42,788 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 57 edges. 57 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:42,790 INFO L225 Difference]: With dead ends: 45 [2022-02-20 14:16:42,790 INFO L226 Difference]: Without dead ends: 31 [2022-02-20 14:16:42,791 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 10 GetRequests, 8 SyntacticMatches, 0 SemanticMatches, 2 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 0 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=6, Invalid=6, Unknown=0, NotChecked=0, Total=12 [2022-02-20 14:16:42,793 INFO L933 BasicCegarLoop]: 12 mSDtfsCounter, 31 mSDsluCounter, 9 mSDsCounter, 0 mSdLazyCounter, 21 mSolverCounterSat, 4 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.0s Time, 0 mProtectedPredicate, 0 mProtectedAction, 31 SdHoareTripleChecker+Valid, 21 SdHoareTripleChecker+Invalid, 25 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 4 IncrementalHoareTripleChecker+Valid, 21 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.0s IncrementalHoareTripleChecker+Time [2022-02-20 14:16:42,793 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [31 Valid, 21 Invalid, 25 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [4 Valid, 21 Invalid, 0 Unknown, 0 Unchecked, 0.0s Time] [2022-02-20 14:16:42,795 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 31 states. [2022-02-20 14:16:42,799 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 31 to 20. [2022-02-20 14:16:42,799 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 14:16:42,799 INFO L82 GeneralOperation]: Start isEquivalent. First operand 31 states. Second operand has 20 states, 19 states have (on average 1.263157894736842) internal successors, (24), 19 states have internal predecessors, (24), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,800 INFO L74 IsIncluded]: Start isIncluded. First operand 31 states. Second operand has 20 states, 19 states have (on average 1.263157894736842) internal successors, (24), 19 states have internal predecessors, (24), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,800 INFO L87 Difference]: Start difference. First operand 31 states. Second operand has 20 states, 19 states have (on average 1.263157894736842) internal successors, (24), 19 states have internal predecessors, (24), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,801 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:42,801 INFO L93 Difference]: Finished difference Result 31 states and 37 transitions. [2022-02-20 14:16:42,801 INFO L276 IsEmpty]: Start isEmpty. Operand 31 states and 37 transitions. [2022-02-20 14:16:42,801 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:42,802 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:42,802 INFO L74 IsIncluded]: Start isIncluded. First operand has 20 states, 19 states have (on average 1.263157894736842) internal successors, (24), 19 states have internal predecessors, (24), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 31 states. [2022-02-20 14:16:42,802 INFO L87 Difference]: Start difference. First operand has 20 states, 19 states have (on average 1.263157894736842) internal successors, (24), 19 states have internal predecessors, (24), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 31 states. [2022-02-20 14:16:42,803 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:42,803 INFO L93 Difference]: Finished difference Result 31 states and 37 transitions. [2022-02-20 14:16:42,803 INFO L276 IsEmpty]: Start isEmpty. Operand 31 states and 37 transitions. [2022-02-20 14:16:42,804 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:42,804 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:42,804 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 14:16:42,804 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 14:16:42,804 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 20 states, 19 states have (on average 1.263157894736842) internal successors, (24), 19 states have internal predecessors, (24), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,805 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 20 states to 20 states and 24 transitions. [2022-02-20 14:16:42,805 INFO L78 Accepts]: Start accepts. Automaton has 20 states and 24 transitions. Word has length 11 [2022-02-20 14:16:42,805 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 14:16:42,805 INFO L470 AbstractCegarLoop]: Abstraction has 20 states and 24 transitions. [2022-02-20 14:16:42,805 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 4 states, 4 states have (on average 2.75) internal successors, (11), 3 states have internal predecessors, (11), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:42,806 INFO L276 IsEmpty]: Start isEmpty. Operand 20 states and 24 transitions. [2022-02-20 14:16:42,806 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 17 [2022-02-20 14:16:42,806 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 14:16:42,806 INFO L514 BasicCegarLoop]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 14:16:42,825 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-02-20 14:16:43,025 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 3 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable1 [2022-02-20 14:16:43,025 INFO L402 AbstractCegarLoop]: === Iteration 3 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 14:16:43,026 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 14:16:43,026 INFO L85 PathProgramCache]: Analyzing trace with hash 1485448361, now seen corresponding path program 1 times [2022-02-20 14:16:43,026 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 14:16:43,026 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1850915290] [2022-02-20 14:16:43,026 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:43,026 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 14:16:43,039 ERROR L252 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-02-20 14:16:43,040 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [652745010] [2022-02-20 14:16:43,040 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:43,040 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:43,040 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:16:43,041 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-02-20 14:16:43,042 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-02-20 14:16:43,083 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:43,084 INFO L263 TraceCheckSpWp]: Trace formula consists of 82 conjuncts, 4 conjunts are in the unsatisfiable core [2022-02-20 14:16:43,092 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:43,095 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 14:16:43,207 INFO L290 TraceCheckUtils]: 0: Hoare triple {334#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {339#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:43,208 INFO L290 TraceCheckUtils]: 1: Hoare triple {339#(<= 1000 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {339#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:43,208 INFO L290 TraceCheckUtils]: 2: Hoare triple {339#(<= 1000 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {339#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:43,209 INFO L290 TraceCheckUtils]: 3: Hoare triple {339#(<= 1000 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:43,209 INFO L290 TraceCheckUtils]: 4: Hoare triple {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:43,210 INFO L290 TraceCheckUtils]: 5: Hoare triple {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:43,210 INFO L290 TraceCheckUtils]: 6: Hoare triple {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:43,211 INFO L290 TraceCheckUtils]: 7: Hoare triple {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:43,212 INFO L290 TraceCheckUtils]: 8: Hoare triple {349#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {365#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:43,212 INFO L290 TraceCheckUtils]: 9: Hoare triple {365#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume !(main_~i~0#1 < ~N~0); {335#false} is VALID [2022-02-20 14:16:43,212 INFO L290 TraceCheckUtils]: 10: Hoare triple {335#false} main_~i~0#1 := 0; {335#false} is VALID [2022-02-20 14:16:43,212 INFO L290 TraceCheckUtils]: 11: Hoare triple {335#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {335#false} is VALID [2022-02-20 14:16:43,213 INFO L290 TraceCheckUtils]: 12: Hoare triple {335#false} assume !(0 == main_#t~mem9#1);havoc main_#t~mem9#1; {335#false} is VALID [2022-02-20 14:16:43,213 INFO L290 TraceCheckUtils]: 13: Hoare triple {335#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {335#false} is VALID [2022-02-20 14:16:43,213 INFO L290 TraceCheckUtils]: 14: Hoare triple {335#false} assume 0 == __VERIFIER_assert_~cond#1; {335#false} is VALID [2022-02-20 14:16:43,213 INFO L290 TraceCheckUtils]: 15: Hoare triple {335#false} assume !false; {335#false} is VALID [2022-02-20 14:16:43,213 INFO L134 CoverageAnalysis]: Checked inductivity of 1 backedges. 0 proven. 1 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 14:16:43,214 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-02-20 14:16:43,288 INFO L290 TraceCheckUtils]: 15: Hoare triple {335#false} assume !false; {335#false} is VALID [2022-02-20 14:16:43,288 INFO L290 TraceCheckUtils]: 14: Hoare triple {335#false} assume 0 == __VERIFIER_assert_~cond#1; {335#false} is VALID [2022-02-20 14:16:43,288 INFO L290 TraceCheckUtils]: 13: Hoare triple {335#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {335#false} is VALID [2022-02-20 14:16:43,288 INFO L290 TraceCheckUtils]: 12: Hoare triple {335#false} assume !(0 == main_#t~mem9#1);havoc main_#t~mem9#1; {335#false} is VALID [2022-02-20 14:16:43,288 INFO L290 TraceCheckUtils]: 11: Hoare triple {335#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {335#false} is VALID [2022-02-20 14:16:43,289 INFO L290 TraceCheckUtils]: 10: Hoare triple {335#false} main_~i~0#1 := 0; {335#false} is VALID [2022-02-20 14:16:43,289 INFO L290 TraceCheckUtils]: 9: Hoare triple {405#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} assume !(main_~i~0#1 < ~N~0); {335#false} is VALID [2022-02-20 14:16:43,290 INFO L290 TraceCheckUtils]: 8: Hoare triple {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {405#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} is VALID [2022-02-20 14:16:43,290 INFO L290 TraceCheckUtils]: 7: Hoare triple {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:43,290 INFO L290 TraceCheckUtils]: 6: Hoare triple {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:43,291 INFO L290 TraceCheckUtils]: 5: Hoare triple {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:43,291 INFO L290 TraceCheckUtils]: 4: Hoare triple {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:43,292 INFO L290 TraceCheckUtils]: 3: Hoare triple {425#(< 1 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {409#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:43,292 INFO L290 TraceCheckUtils]: 2: Hoare triple {425#(< 1 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {425#(< 1 ~N~0)} is VALID [2022-02-20 14:16:43,292 INFO L290 TraceCheckUtils]: 1: Hoare triple {425#(< 1 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {425#(< 1 ~N~0)} is VALID [2022-02-20 14:16:43,293 INFO L290 TraceCheckUtils]: 0: Hoare triple {334#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {425#(< 1 ~N~0)} is VALID [2022-02-20 14:16:43,293 INFO L134 CoverageAnalysis]: Checked inductivity of 1 backedges. 0 proven. 1 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 14:16:43,293 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 14:16:43,294 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1850915290] [2022-02-20 14:16:43,294 WARN L317 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-02-20 14:16:43,294 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [652745010] [2022-02-20 14:16:43,294 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [652745010] provided 0 perfect and 2 imperfect interpolant sequences [2022-02-20 14:16:43,294 INFO L191 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-02-20 14:16:43,294 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [4, 4] total 7 [2022-02-20 14:16:43,294 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [194653257] [2022-02-20 14:16:43,295 INFO L85 oduleStraightlineAll]: Using 2 imperfect interpolants to construct interpolant automaton [2022-02-20 14:16:43,295 INFO L78 Accepts]: Start accepts. Automaton has has 8 states, 8 states have (on average 3.25) internal successors, (26), 7 states have internal predecessors, (26), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 16 [2022-02-20 14:16:43,295 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 14:16:43,295 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 8 states, 8 states have (on average 3.25) internal successors, (26), 7 states have internal predecessors, (26), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:43,313 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 26 edges. 26 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:43,314 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 8 states [2022-02-20 14:16:43,314 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 14:16:43,314 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 8 interpolants. [2022-02-20 14:16:43,315 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=24, Invalid=32, Unknown=0, NotChecked=0, Total=56 [2022-02-20 14:16:43,315 INFO L87 Difference]: Start difference. First operand 20 states and 24 transitions. Second operand has 8 states, 8 states have (on average 3.25) internal successors, (26), 7 states have internal predecessors, (26), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:43,519 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:43,519 INFO L93 Difference]: Finished difference Result 73 states and 92 transitions. [2022-02-20 14:16:43,519 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2022-02-20 14:16:43,519 INFO L78 Accepts]: Start accepts. Automaton has has 8 states, 8 states have (on average 3.25) internal successors, (26), 7 states have internal predecessors, (26), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 16 [2022-02-20 14:16:43,520 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 14:16:43,520 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 8 states, 8 states have (on average 3.25) internal successors, (26), 7 states have internal predecessors, (26), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:43,521 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 92 transitions. [2022-02-20 14:16:43,521 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 8 states, 8 states have (on average 3.25) internal successors, (26), 7 states have internal predecessors, (26), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:43,522 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 7 states to 7 states and 92 transitions. [2022-02-20 14:16:43,522 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 7 states and 92 transitions. [2022-02-20 14:16:43,592 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 92 edges. 92 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:43,593 INFO L225 Difference]: With dead ends: 73 [2022-02-20 14:16:43,593 INFO L226 Difference]: Without dead ends: 59 [2022-02-20 14:16:43,593 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 32 GetRequests, 24 SyntacticMatches, 0 SemanticMatches, 8 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 10 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=40, Invalid=50, Unknown=0, NotChecked=0, Total=90 [2022-02-20 14:16:43,594 INFO L933 BasicCegarLoop]: 12 mSDtfsCounter, 135 mSDsluCounter, 26 mSDsCounter, 0 mSdLazyCounter, 41 mSolverCounterSat, 26 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 135 SdHoareTripleChecker+Valid, 38 SdHoareTripleChecker+Invalid, 67 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 26 IncrementalHoareTripleChecker+Valid, 41 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-02-20 14:16:43,595 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [135 Valid, 38 Invalid, 67 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [26 Valid, 41 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-02-20 14:16:43,595 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 59 states. [2022-02-20 14:16:43,604 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 59 to 34. [2022-02-20 14:16:43,604 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 14:16:43,604 INFO L82 GeneralOperation]: Start isEquivalent. First operand 59 states. Second operand has 34 states, 33 states have (on average 1.2727272727272727) internal successors, (42), 33 states have internal predecessors, (42), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:43,604 INFO L74 IsIncluded]: Start isIncluded. First operand 59 states. Second operand has 34 states, 33 states have (on average 1.2727272727272727) internal successors, (42), 33 states have internal predecessors, (42), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:43,605 INFO L87 Difference]: Start difference. First operand 59 states. Second operand has 34 states, 33 states have (on average 1.2727272727272727) internal successors, (42), 33 states have internal predecessors, (42), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:43,606 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:43,606 INFO L93 Difference]: Finished difference Result 59 states and 70 transitions. [2022-02-20 14:16:43,606 INFO L276 IsEmpty]: Start isEmpty. Operand 59 states and 70 transitions. [2022-02-20 14:16:43,607 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:43,607 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:43,607 INFO L74 IsIncluded]: Start isIncluded. First operand has 34 states, 33 states have (on average 1.2727272727272727) internal successors, (42), 33 states have internal predecessors, (42), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 59 states. [2022-02-20 14:16:43,607 INFO L87 Difference]: Start difference. First operand has 34 states, 33 states have (on average 1.2727272727272727) internal successors, (42), 33 states have internal predecessors, (42), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 59 states. [2022-02-20 14:16:43,609 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:43,609 INFO L93 Difference]: Finished difference Result 59 states and 70 transitions. [2022-02-20 14:16:43,609 INFO L276 IsEmpty]: Start isEmpty. Operand 59 states and 70 transitions. [2022-02-20 14:16:43,609 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:43,609 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:43,610 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 14:16:43,610 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 14:16:43,610 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 34 states, 33 states have (on average 1.2727272727272727) internal successors, (42), 33 states have internal predecessors, (42), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:43,611 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 34 states to 34 states and 42 transitions. [2022-02-20 14:16:43,611 INFO L78 Accepts]: Start accepts. Automaton has 34 states and 42 transitions. Word has length 16 [2022-02-20 14:16:43,611 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 14:16:43,611 INFO L470 AbstractCegarLoop]: Abstraction has 34 states and 42 transitions. [2022-02-20 14:16:43,611 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 8 states, 8 states have (on average 3.25) internal successors, (26), 7 states have internal predecessors, (26), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:43,611 INFO L276 IsEmpty]: Start isEmpty. Operand 34 states and 42 transitions. [2022-02-20 14:16:43,612 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 32 [2022-02-20 14:16:43,612 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 14:16:43,612 INFO L514 BasicCegarLoop]: trace histogram [4, 4, 4, 4, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 14:16:43,631 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-02-20 14:16:43,827 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable2,4 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:43,828 INFO L402 AbstractCegarLoop]: === Iteration 4 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 14:16:43,828 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 14:16:43,828 INFO L85 PathProgramCache]: Analyzing trace with hash -35725226, now seen corresponding path program 1 times [2022-02-20 14:16:43,828 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 14:16:43,828 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1273607729] [2022-02-20 14:16:43,829 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:43,829 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 14:16:43,852 ERROR L252 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-02-20 14:16:43,852 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1669638834] [2022-02-20 14:16:43,852 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:43,852 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:43,852 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:16:43,853 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-02-20 14:16:43,854 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-02-20 14:16:43,909 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:43,911 INFO L263 TraceCheckSpWp]: Trace formula consists of 134 conjuncts, 7 conjunts are in the unsatisfiable core [2022-02-20 14:16:43,923 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:43,924 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 14:16:44,200 INFO L290 TraceCheckUtils]: 0: Hoare triple {681#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {686#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:44,200 INFO L290 TraceCheckUtils]: 1: Hoare triple {686#(<= 1000 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {686#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:44,202 INFO L290 TraceCheckUtils]: 2: Hoare triple {686#(<= 1000 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {686#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:44,202 INFO L290 TraceCheckUtils]: 3: Hoare triple {686#(<= 1000 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,203 INFO L290 TraceCheckUtils]: 4: Hoare triple {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,203 INFO L290 TraceCheckUtils]: 5: Hoare triple {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,204 INFO L290 TraceCheckUtils]: 6: Hoare triple {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,204 INFO L290 TraceCheckUtils]: 7: Hoare triple {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,205 INFO L290 TraceCheckUtils]: 8: Hoare triple {696#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:44,205 INFO L290 TraceCheckUtils]: 9: Hoare triple {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:44,206 INFO L290 TraceCheckUtils]: 10: Hoare triple {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:44,206 INFO L290 TraceCheckUtils]: 11: Hoare triple {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:44,207 INFO L290 TraceCheckUtils]: 12: Hoare triple {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:44,208 INFO L290 TraceCheckUtils]: 13: Hoare triple {712#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,208 INFO L290 TraceCheckUtils]: 14: Hoare triple {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,210 INFO L290 TraceCheckUtils]: 15: Hoare triple {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,211 INFO L290 TraceCheckUtils]: 16: Hoare triple {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,211 INFO L290 TraceCheckUtils]: 17: Hoare triple {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,212 INFO L290 TraceCheckUtils]: 18: Hoare triple {728#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,212 INFO L290 TraceCheckUtils]: 19: Hoare triple {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,213 INFO L290 TraceCheckUtils]: 20: Hoare triple {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,213 INFO L290 TraceCheckUtils]: 21: Hoare triple {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,213 INFO L290 TraceCheckUtils]: 22: Hoare triple {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,214 INFO L290 TraceCheckUtils]: 23: Hoare triple {744#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {760#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:44,214 INFO L290 TraceCheckUtils]: 24: Hoare triple {760#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume !(main_~i~0#1 < ~N~0); {682#false} is VALID [2022-02-20 14:16:44,215 INFO L290 TraceCheckUtils]: 25: Hoare triple {682#false} main_~i~0#1 := 0; {682#false} is VALID [2022-02-20 14:16:44,215 INFO L290 TraceCheckUtils]: 26: Hoare triple {682#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {682#false} is VALID [2022-02-20 14:16:44,215 INFO L290 TraceCheckUtils]: 27: Hoare triple {682#false} assume !(0 == main_#t~mem9#1);havoc main_#t~mem9#1; {682#false} is VALID [2022-02-20 14:16:44,215 INFO L290 TraceCheckUtils]: 28: Hoare triple {682#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {682#false} is VALID [2022-02-20 14:16:44,215 INFO L290 TraceCheckUtils]: 29: Hoare triple {682#false} assume 0 == __VERIFIER_assert_~cond#1; {682#false} is VALID [2022-02-20 14:16:44,215 INFO L290 TraceCheckUtils]: 30: Hoare triple {682#false} assume !false; {682#false} is VALID [2022-02-20 14:16:44,216 INFO L134 CoverageAnalysis]: Checked inductivity of 34 backedges. 0 proven. 34 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 14:16:44,216 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-02-20 14:16:44,410 INFO L290 TraceCheckUtils]: 30: Hoare triple {682#false} assume !false; {682#false} is VALID [2022-02-20 14:16:44,410 INFO L290 TraceCheckUtils]: 29: Hoare triple {682#false} assume 0 == __VERIFIER_assert_~cond#1; {682#false} is VALID [2022-02-20 14:16:44,411 INFO L290 TraceCheckUtils]: 28: Hoare triple {682#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {682#false} is VALID [2022-02-20 14:16:44,411 INFO L290 TraceCheckUtils]: 27: Hoare triple {682#false} assume !(0 == main_#t~mem9#1);havoc main_#t~mem9#1; {682#false} is VALID [2022-02-20 14:16:44,411 INFO L290 TraceCheckUtils]: 26: Hoare triple {682#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {682#false} is VALID [2022-02-20 14:16:44,411 INFO L290 TraceCheckUtils]: 25: Hoare triple {682#false} main_~i~0#1 := 0; {682#false} is VALID [2022-02-20 14:16:44,414 INFO L290 TraceCheckUtils]: 24: Hoare triple {800#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} assume !(main_~i~0#1 < ~N~0); {682#false} is VALID [2022-02-20 14:16:44,414 INFO L290 TraceCheckUtils]: 23: Hoare triple {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {800#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} is VALID [2022-02-20 14:16:44,415 INFO L290 TraceCheckUtils]: 22: Hoare triple {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:44,415 INFO L290 TraceCheckUtils]: 21: Hoare triple {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:44,415 INFO L290 TraceCheckUtils]: 20: Hoare triple {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:44,416 INFO L290 TraceCheckUtils]: 19: Hoare triple {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:44,417 INFO L290 TraceCheckUtils]: 18: Hoare triple {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {804#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:44,417 INFO L290 TraceCheckUtils]: 17: Hoare triple {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,417 INFO L290 TraceCheckUtils]: 16: Hoare triple {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,418 INFO L290 TraceCheckUtils]: 15: Hoare triple {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,418 INFO L290 TraceCheckUtils]: 14: Hoare triple {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,419 INFO L290 TraceCheckUtils]: 13: Hoare triple {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {820#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,419 INFO L290 TraceCheckUtils]: 12: Hoare triple {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,420 INFO L290 TraceCheckUtils]: 11: Hoare triple {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,420 INFO L290 TraceCheckUtils]: 10: Hoare triple {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,420 INFO L290 TraceCheckUtils]: 9: Hoare triple {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,423 INFO L290 TraceCheckUtils]: 8: Hoare triple {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {836#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:44,423 INFO L290 TraceCheckUtils]: 7: Hoare triple {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:44,423 INFO L290 TraceCheckUtils]: 6: Hoare triple {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:44,424 INFO L290 TraceCheckUtils]: 5: Hoare triple {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:44,424 INFO L290 TraceCheckUtils]: 4: Hoare triple {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:44,425 INFO L290 TraceCheckUtils]: 3: Hoare triple {868#(< 4 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {852#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:44,425 INFO L290 TraceCheckUtils]: 2: Hoare triple {868#(< 4 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {868#(< 4 ~N~0)} is VALID [2022-02-20 14:16:44,425 INFO L290 TraceCheckUtils]: 1: Hoare triple {868#(< 4 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {868#(< 4 ~N~0)} is VALID [2022-02-20 14:16:44,429 INFO L290 TraceCheckUtils]: 0: Hoare triple {681#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {868#(< 4 ~N~0)} is VALID [2022-02-20 14:16:44,429 INFO L134 CoverageAnalysis]: Checked inductivity of 34 backedges. 0 proven. 34 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 14:16:44,429 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 14:16:44,429 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1273607729] [2022-02-20 14:16:44,430 WARN L317 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-02-20 14:16:44,430 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1669638834] [2022-02-20 14:16:44,430 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1669638834] provided 0 perfect and 2 imperfect interpolant sequences [2022-02-20 14:16:44,430 INFO L191 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-02-20 14:16:44,430 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [7, 7] total 13 [2022-02-20 14:16:44,430 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [382125607] [2022-02-20 14:16:44,430 INFO L85 oduleStraightlineAll]: Using 2 imperfect interpolants to construct interpolant automaton [2022-02-20 14:16:44,431 INFO L78 Accepts]: Start accepts. Automaton has has 14 states, 14 states have (on average 4.0) internal successors, (56), 13 states have internal predecessors, (56), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 31 [2022-02-20 14:16:44,431 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 14:16:44,431 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 14 states, 14 states have (on average 4.0) internal successors, (56), 13 states have internal predecessors, (56), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:44,485 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 56 edges. 56 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:44,486 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 14 states [2022-02-20 14:16:44,486 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 14:16:44,486 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 14 interpolants. [2022-02-20 14:16:44,486 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=81, Invalid=101, Unknown=0, NotChecked=0, Total=182 [2022-02-20 14:16:44,487 INFO L87 Difference]: Start difference. First operand 34 states and 42 transitions. Second operand has 14 states, 14 states have (on average 4.0) internal successors, (56), 13 states have internal predecessors, (56), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:44,942 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:44,943 INFO L93 Difference]: Finished difference Result 155 states and 195 transitions. [2022-02-20 14:16:44,943 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 13 states. [2022-02-20 14:16:44,943 INFO L78 Accepts]: Start accepts. Automaton has has 14 states, 14 states have (on average 4.0) internal successors, (56), 13 states have internal predecessors, (56), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 31 [2022-02-20 14:16:44,943 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 14:16:44,943 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 14 states, 14 states have (on average 4.0) internal successors, (56), 13 states have internal predecessors, (56), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:44,945 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 13 states to 13 states and 190 transitions. [2022-02-20 14:16:44,945 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 14 states, 14 states have (on average 4.0) internal successors, (56), 13 states have internal predecessors, (56), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:44,947 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 13 states to 13 states and 190 transitions. [2022-02-20 14:16:44,947 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 13 states and 190 transitions. [2022-02-20 14:16:45,084 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 190 edges. 190 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:45,087 INFO L225 Difference]: With dead ends: 155 [2022-02-20 14:16:45,087 INFO L226 Difference]: Without dead ends: 137 [2022-02-20 14:16:45,087 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 65 GetRequests, 48 SyntacticMatches, 0 SemanticMatches, 17 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 55 ImplicationChecksByTransitivity, 0.1s TimeCoverageRelationStatistics Valid=151, Invalid=191, Unknown=0, NotChecked=0, Total=342 [2022-02-20 14:16:45,088 INFO L933 BasicCegarLoop]: 12 mSDtfsCounter, 309 mSDsluCounter, 77 mSDsCounter, 0 mSdLazyCounter, 96 mSolverCounterSat, 45 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 309 SdHoareTripleChecker+Valid, 89 SdHoareTripleChecker+Invalid, 141 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 45 IncrementalHoareTripleChecker+Valid, 96 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-02-20 14:16:45,088 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [309 Valid, 89 Invalid, 141 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [45 Valid, 96 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-02-20 14:16:45,089 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 137 states. [2022-02-20 14:16:45,108 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 137 to 64. [2022-02-20 14:16:45,108 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 14:16:45,108 INFO L82 GeneralOperation]: Start isEquivalent. First operand 137 states. Second operand has 64 states, 63 states have (on average 1.2857142857142858) internal successors, (81), 63 states have internal predecessors, (81), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:45,108 INFO L74 IsIncluded]: Start isIncluded. First operand 137 states. Second operand has 64 states, 63 states have (on average 1.2857142857142858) internal successors, (81), 63 states have internal predecessors, (81), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:45,109 INFO L87 Difference]: Start difference. First operand 137 states. Second operand has 64 states, 63 states have (on average 1.2857142857142858) internal successors, (81), 63 states have internal predecessors, (81), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:45,111 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:45,111 INFO L93 Difference]: Finished difference Result 137 states and 163 transitions. [2022-02-20 14:16:45,111 INFO L276 IsEmpty]: Start isEmpty. Operand 137 states and 163 transitions. [2022-02-20 14:16:45,112 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:45,112 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:45,112 INFO L74 IsIncluded]: Start isIncluded. First operand has 64 states, 63 states have (on average 1.2857142857142858) internal successors, (81), 63 states have internal predecessors, (81), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 137 states. [2022-02-20 14:16:45,112 INFO L87 Difference]: Start difference. First operand has 64 states, 63 states have (on average 1.2857142857142858) internal successors, (81), 63 states have internal predecessors, (81), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 137 states. [2022-02-20 14:16:45,115 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:45,115 INFO L93 Difference]: Finished difference Result 137 states and 163 transitions. [2022-02-20 14:16:45,115 INFO L276 IsEmpty]: Start isEmpty. Operand 137 states and 163 transitions. [2022-02-20 14:16:45,116 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:45,116 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:45,116 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 14:16:45,116 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 14:16:45,116 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 64 states, 63 states have (on average 1.2857142857142858) internal successors, (81), 63 states have internal predecessors, (81), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:45,117 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 64 states to 64 states and 81 transitions. [2022-02-20 14:16:45,117 INFO L78 Accepts]: Start accepts. Automaton has 64 states and 81 transitions. Word has length 31 [2022-02-20 14:16:45,117 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 14:16:45,118 INFO L470 AbstractCegarLoop]: Abstraction has 64 states and 81 transitions. [2022-02-20 14:16:45,118 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 14 states, 14 states have (on average 4.0) internal successors, (56), 13 states have internal predecessors, (56), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:45,118 INFO L276 IsEmpty]: Start isEmpty. Operand 64 states and 81 transitions. [2022-02-20 14:16:45,118 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 62 [2022-02-20 14:16:45,119 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 14:16:45,119 INFO L514 BasicCegarLoop]: trace histogram [10, 10, 10, 10, 5, 5, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 14:16:45,151 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-02-20 14:16:45,349 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable3,5 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:45,349 INFO L402 AbstractCegarLoop]: === Iteration 5 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 14:16:45,350 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 14:16:45,350 INFO L85 PathProgramCache]: Analyzing trace with hash -1147663820, now seen corresponding path program 2 times [2022-02-20 14:16:45,350 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 14:16:45,350 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [989580540] [2022-02-20 14:16:45,350 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:45,350 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 14:16:45,395 ERROR L252 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-02-20 14:16:45,395 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [800757005] [2022-02-20 14:16:45,395 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-02-20 14:16:45,396 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:45,396 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:16:45,397 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-02-20 14:16:45,398 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-02-20 14:16:45,486 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 1 check-sat command(s) [2022-02-20 14:16:45,486 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-02-20 14:16:45,487 INFO L263 TraceCheckSpWp]: Trace formula consists of 68 conjuncts, 9 conjunts are in the unsatisfiable core [2022-02-20 14:16:45,506 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:45,507 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 14:16:45,971 INFO L290 TraceCheckUtils]: 0: Hoare triple {1417#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {1422#(= ~N~0 1000)} is VALID [2022-02-20 14:16:45,973 INFO L290 TraceCheckUtils]: 1: Hoare triple {1422#(= ~N~0 1000)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,973 INFO L290 TraceCheckUtils]: 2: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(0 == assume_abort_if_not_~cond#1); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,980 INFO L290 TraceCheckUtils]: 3: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,981 INFO L290 TraceCheckUtils]: 4: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,981 INFO L290 TraceCheckUtils]: 5: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,981 INFO L290 TraceCheckUtils]: 6: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,982 INFO L290 TraceCheckUtils]: 7: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,982 INFO L290 TraceCheckUtils]: 8: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,983 INFO L290 TraceCheckUtils]: 9: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,983 INFO L290 TraceCheckUtils]: 10: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,984 INFO L290 TraceCheckUtils]: 11: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,984 INFO L290 TraceCheckUtils]: 12: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,984 INFO L290 TraceCheckUtils]: 13: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,985 INFO L290 TraceCheckUtils]: 14: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,985 INFO L290 TraceCheckUtils]: 15: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,986 INFO L290 TraceCheckUtils]: 16: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,986 INFO L290 TraceCheckUtils]: 17: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,989 INFO L290 TraceCheckUtils]: 18: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,990 INFO L290 TraceCheckUtils]: 19: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,990 INFO L290 TraceCheckUtils]: 20: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,991 INFO L290 TraceCheckUtils]: 21: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,991 INFO L290 TraceCheckUtils]: 22: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,992 INFO L290 TraceCheckUtils]: 23: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,992 INFO L290 TraceCheckUtils]: 24: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,993 INFO L290 TraceCheckUtils]: 25: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,993 INFO L290 TraceCheckUtils]: 26: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,994 INFO L290 TraceCheckUtils]: 27: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,995 INFO L290 TraceCheckUtils]: 28: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,995 INFO L290 TraceCheckUtils]: 29: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,996 INFO L290 TraceCheckUtils]: 30: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,996 INFO L290 TraceCheckUtils]: 31: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,997 INFO L290 TraceCheckUtils]: 32: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,997 INFO L290 TraceCheckUtils]: 33: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,997 INFO L290 TraceCheckUtils]: 34: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,998 INFO L290 TraceCheckUtils]: 35: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,998 INFO L290 TraceCheckUtils]: 36: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:45,999 INFO L290 TraceCheckUtils]: 37: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,000 INFO L290 TraceCheckUtils]: 38: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,000 INFO L290 TraceCheckUtils]: 39: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,001 INFO L290 TraceCheckUtils]: 40: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,001 INFO L290 TraceCheckUtils]: 41: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,002 INFO L290 TraceCheckUtils]: 42: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,002 INFO L290 TraceCheckUtils]: 43: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,002 INFO L290 TraceCheckUtils]: 44: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,003 INFO L290 TraceCheckUtils]: 45: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,003 INFO L290 TraceCheckUtils]: 46: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,004 INFO L290 TraceCheckUtils]: 47: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,004 INFO L290 TraceCheckUtils]: 48: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,005 INFO L290 TraceCheckUtils]: 49: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,005 INFO L290 TraceCheckUtils]: 50: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,006 INFO L290 TraceCheckUtils]: 51: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,006 INFO L290 TraceCheckUtils]: 52: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,006 INFO L290 TraceCheckUtils]: 53: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,007 INFO L290 TraceCheckUtils]: 54: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 < ~N~0); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,007 INFO L290 TraceCheckUtils]: 55: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_~i~0#1 := 0; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,008 INFO L290 TraceCheckUtils]: 56: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,008 INFO L290 TraceCheckUtils]: 57: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(0 == main_#t~mem9#1);havoc main_#t~mem9#1; {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:46,008 INFO L290 TraceCheckUtils]: 58: Hoare triple {1426#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {1598#(<= 1 |ULTIMATE.start___VERIFIER_assert_~cond#1|)} is VALID [2022-02-20 14:16:46,009 INFO L290 TraceCheckUtils]: 59: Hoare triple {1598#(<= 1 |ULTIMATE.start___VERIFIER_assert_~cond#1|)} assume 0 == __VERIFIER_assert_~cond#1; {1418#false} is VALID [2022-02-20 14:16:46,009 INFO L290 TraceCheckUtils]: 60: Hoare triple {1418#false} assume !false; {1418#false} is VALID [2022-02-20 14:16:46,010 INFO L134 CoverageAnalysis]: Checked inductivity of 235 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 235 trivial. 0 not checked. [2022-02-20 14:16:46,010 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 14:16:46,010 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 14:16:46,010 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [989580540] [2022-02-20 14:16:46,010 WARN L317 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-02-20 14:16:46,010 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [800757005] [2022-02-20 14:16:46,011 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [800757005] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 14:16:46,011 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 14:16:46,011 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [4] imperfect sequences [] total 4 [2022-02-20 14:16:46,011 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1878739871] [2022-02-20 14:16:46,011 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 14:16:46,011 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), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 61 [2022-02-20 14:16:46,012 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 14:16:46,012 INFO L86 InductivityCheck]: Starting indutivity 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), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:46,027 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 17 edges. 17 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:46,027 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2022-02-20 14:16:46,028 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 14:16:46,028 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2022-02-20 14:16:46,028 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=8, Invalid=12, Unknown=0, NotChecked=0, Total=20 [2022-02-20 14:16:46,028 INFO L87 Difference]: Start difference. First operand 64 states and 81 transitions. Second operand has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:48,418 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:48,418 INFO L93 Difference]: Finished difference Result 76 states and 95 transitions. [2022-02-20 14:16:48,418 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 6 states. [2022-02-20 14:16:48,419 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), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 61 [2022-02-20 14:16:48,419 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 14:16:48,419 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), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:48,419 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 36 transitions. [2022-02-20 14:16:48,420 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), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:48,420 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 6 states to 6 states and 36 transitions. [2022-02-20 14:16:48,420 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 6 states and 36 transitions. [2022-02-20 14:16:48,460 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 36 edges. 36 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:48,461 INFO L225 Difference]: With dead ends: 76 [2022-02-20 14:16:48,461 INFO L226 Difference]: Without dead ends: 74 [2022-02-20 14:16:48,461 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 62 GetRequests, 57 SyntacticMatches, 0 SemanticMatches, 5 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 2 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=18, Invalid=24, Unknown=0, NotChecked=0, Total=42 [2022-02-20 14:16:48,462 INFO L933 BasicCegarLoop]: 14 mSDtfsCounter, 32 mSDsluCounter, 18 mSDsCounter, 0 mSdLazyCounter, 29 mSolverCounterSat, 2 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 32 SdHoareTripleChecker+Valid, 32 SdHoareTripleChecker+Invalid, 31 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 2 IncrementalHoareTripleChecker+Valid, 29 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-02-20 14:16:48,462 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [32 Valid, 32 Invalid, 31 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [2 Valid, 29 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-02-20 14:16:48,462 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 74 states. [2022-02-20 14:16:48,496 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 74 to 70. [2022-02-20 14:16:48,496 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 14:16:48,496 INFO L82 GeneralOperation]: Start isEquivalent. First operand 74 states. Second operand has 70 states, 69 states have (on average 1.2753623188405796) internal successors, (88), 69 states have internal predecessors, (88), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:48,496 INFO L74 IsIncluded]: Start isIncluded. First operand 74 states. Second operand has 70 states, 69 states have (on average 1.2753623188405796) internal successors, (88), 69 states have internal predecessors, (88), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:48,496 INFO L87 Difference]: Start difference. First operand 74 states. Second operand has 70 states, 69 states have (on average 1.2753623188405796) internal successors, (88), 69 states have internal predecessors, (88), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:48,498 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:48,498 INFO L93 Difference]: Finished difference Result 74 states and 93 transitions. [2022-02-20 14:16:48,498 INFO L276 IsEmpty]: Start isEmpty. Operand 74 states and 93 transitions. [2022-02-20 14:16:48,498 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:48,498 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:48,498 INFO L74 IsIncluded]: Start isIncluded. First operand has 70 states, 69 states have (on average 1.2753623188405796) internal successors, (88), 69 states have internal predecessors, (88), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 74 states. [2022-02-20 14:16:48,498 INFO L87 Difference]: Start difference. First operand has 70 states, 69 states have (on average 1.2753623188405796) internal successors, (88), 69 states have internal predecessors, (88), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 74 states. [2022-02-20 14:16:48,500 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:48,500 INFO L93 Difference]: Finished difference Result 74 states and 93 transitions. [2022-02-20 14:16:48,500 INFO L276 IsEmpty]: Start isEmpty. Operand 74 states and 93 transitions. [2022-02-20 14:16:48,500 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:48,500 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:48,500 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 14:16:48,500 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 14:16:48,501 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 70 states, 69 states have (on average 1.2753623188405796) internal successors, (88), 69 states have internal predecessors, (88), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:48,502 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 70 states to 70 states and 88 transitions. [2022-02-20 14:16:48,502 INFO L78 Accepts]: Start accepts. Automaton has 70 states and 88 transitions. Word has length 61 [2022-02-20 14:16:48,502 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 14:16:48,502 INFO L470 AbstractCegarLoop]: Abstraction has 70 states and 88 transitions. [2022-02-20 14:16:48,502 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 3.4) internal successors, (17), 4 states have internal predecessors, (17), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:48,502 INFO L276 IsEmpty]: Start isEmpty. Operand 70 states and 88 transitions. [2022-02-20 14:16:48,503 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 62 [2022-02-20 14:16:48,503 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 14:16:48,503 INFO L514 BasicCegarLoop]: trace histogram [10, 10, 10, 10, 5, 5, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 14:16:48,522 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (6)] Forceful destruction successful, exit code 0 [2022-02-20 14:16:48,703 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable4,6 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:48,704 INFO L402 AbstractCegarLoop]: === Iteration 6 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 14:16:48,704 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 14:16:48,704 INFO L85 PathProgramCache]: Analyzing trace with hash -1147723402, now seen corresponding path program 1 times [2022-02-20 14:16:48,704 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 14:16:48,704 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [544474460] [2022-02-20 14:16:48,704 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:48,704 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 14:16:48,739 ERROR L252 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-02-20 14:16:48,740 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1545134096] [2022-02-20 14:16:48,740 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:48,740 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:48,740 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:16:48,741 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-02-20 14:16:48,743 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-02-20 14:16:48,834 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:48,836 INFO L263 TraceCheckSpWp]: Trace formula consists of 236 conjuncts, 13 conjunts are in the unsatisfiable core [2022-02-20 14:16:48,847 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:48,848 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 14:16:49,541 INFO L290 TraceCheckUtils]: 0: Hoare triple {1929#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {1934#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:49,542 INFO L290 TraceCheckUtils]: 1: Hoare triple {1934#(<= 1000 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {1934#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:49,542 INFO L290 TraceCheckUtils]: 2: Hoare triple {1934#(<= 1000 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {1934#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:49,542 INFO L290 TraceCheckUtils]: 3: Hoare triple {1934#(<= 1000 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,543 INFO L290 TraceCheckUtils]: 4: Hoare triple {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,543 INFO L290 TraceCheckUtils]: 5: Hoare triple {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,544 INFO L290 TraceCheckUtils]: 6: Hoare triple {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,544 INFO L290 TraceCheckUtils]: 7: Hoare triple {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,545 INFO L290 TraceCheckUtils]: 8: Hoare triple {1944#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:49,546 INFO L290 TraceCheckUtils]: 9: Hoare triple {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:49,546 INFO L290 TraceCheckUtils]: 10: Hoare triple {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:49,546 INFO L290 TraceCheckUtils]: 11: Hoare triple {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:49,547 INFO L290 TraceCheckUtils]: 12: Hoare triple {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:49,548 INFO L290 TraceCheckUtils]: 13: Hoare triple {1960#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,548 INFO L290 TraceCheckUtils]: 14: Hoare triple {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,549 INFO L290 TraceCheckUtils]: 15: Hoare triple {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,550 INFO L290 TraceCheckUtils]: 16: Hoare triple {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,550 INFO L290 TraceCheckUtils]: 17: Hoare triple {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,551 INFO L290 TraceCheckUtils]: 18: Hoare triple {1976#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,551 INFO L290 TraceCheckUtils]: 19: Hoare triple {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,552 INFO L290 TraceCheckUtils]: 20: Hoare triple {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,552 INFO L290 TraceCheckUtils]: 21: Hoare triple {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,552 INFO L290 TraceCheckUtils]: 22: Hoare triple {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,553 INFO L290 TraceCheckUtils]: 23: Hoare triple {1992#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,554 INFO L290 TraceCheckUtils]: 24: Hoare triple {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,554 INFO L290 TraceCheckUtils]: 25: Hoare triple {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,554 INFO L290 TraceCheckUtils]: 26: Hoare triple {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,555 INFO L290 TraceCheckUtils]: 27: Hoare triple {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,559 INFO L290 TraceCheckUtils]: 28: Hoare triple {2008#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:49,559 INFO L290 TraceCheckUtils]: 29: Hoare triple {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:49,560 INFO L290 TraceCheckUtils]: 30: Hoare triple {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:49,560 INFO L290 TraceCheckUtils]: 31: Hoare triple {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:49,561 INFO L290 TraceCheckUtils]: 32: Hoare triple {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:49,561 INFO L290 TraceCheckUtils]: 33: Hoare triple {2024#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:49,562 INFO L290 TraceCheckUtils]: 34: Hoare triple {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:49,562 INFO L290 TraceCheckUtils]: 35: Hoare triple {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:49,563 INFO L290 TraceCheckUtils]: 36: Hoare triple {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:49,563 INFO L290 TraceCheckUtils]: 37: Hoare triple {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:49,564 INFO L290 TraceCheckUtils]: 38: Hoare triple {2040#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:49,564 INFO L290 TraceCheckUtils]: 39: Hoare triple {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:49,565 INFO L290 TraceCheckUtils]: 40: Hoare triple {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:49,565 INFO L290 TraceCheckUtils]: 41: Hoare triple {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:49,565 INFO L290 TraceCheckUtils]: 42: Hoare triple {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:49,566 INFO L290 TraceCheckUtils]: 43: Hoare triple {2056#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,567 INFO L290 TraceCheckUtils]: 44: Hoare triple {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,567 INFO L290 TraceCheckUtils]: 45: Hoare triple {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,568 INFO L290 TraceCheckUtils]: 46: Hoare triple {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,568 INFO L290 TraceCheckUtils]: 47: Hoare triple {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,569 INFO L290 TraceCheckUtils]: 48: Hoare triple {2072#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:49,569 INFO L290 TraceCheckUtils]: 49: Hoare triple {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:49,570 INFO L290 TraceCheckUtils]: 50: Hoare triple {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:49,570 INFO L290 TraceCheckUtils]: 51: Hoare triple {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:49,571 INFO L290 TraceCheckUtils]: 52: Hoare triple {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:49,571 INFO L290 TraceCheckUtils]: 53: Hoare triple {2088#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2104#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:49,572 INFO L290 TraceCheckUtils]: 54: Hoare triple {2104#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} assume !(main_~i~0#1 < ~N~0); {1930#false} is VALID [2022-02-20 14:16:49,572 INFO L290 TraceCheckUtils]: 55: Hoare triple {1930#false} main_~i~0#1 := 0; {1930#false} is VALID [2022-02-20 14:16:49,572 INFO L290 TraceCheckUtils]: 56: Hoare triple {1930#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1930#false} is VALID [2022-02-20 14:16:49,572 INFO L290 TraceCheckUtils]: 57: Hoare triple {1930#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {1930#false} is VALID [2022-02-20 14:16:49,572 INFO L290 TraceCheckUtils]: 58: Hoare triple {1930#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {1930#false} is VALID [2022-02-20 14:16:49,572 INFO L290 TraceCheckUtils]: 59: Hoare triple {1930#false} assume 0 == __VERIFIER_assert_~cond#1; {1930#false} is VALID [2022-02-20 14:16:49,572 INFO L290 TraceCheckUtils]: 60: Hoare triple {1930#false} assume !false; {1930#false} is VALID [2022-02-20 14:16:49,573 INFO L134 CoverageAnalysis]: Checked inductivity of 235 backedges. 0 proven. 235 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 14:16:49,573 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-02-20 14:16:50,189 INFO L290 TraceCheckUtils]: 60: Hoare triple {1930#false} assume !false; {1930#false} is VALID [2022-02-20 14:16:50,189 INFO L290 TraceCheckUtils]: 59: Hoare triple {1930#false} assume 0 == __VERIFIER_assert_~cond#1; {1930#false} is VALID [2022-02-20 14:16:50,189 INFO L290 TraceCheckUtils]: 58: Hoare triple {1930#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {1930#false} is VALID [2022-02-20 14:16:50,189 INFO L290 TraceCheckUtils]: 57: Hoare triple {1930#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {1930#false} is VALID [2022-02-20 14:16:50,190 INFO L290 TraceCheckUtils]: 56: Hoare triple {1930#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {1930#false} is VALID [2022-02-20 14:16:50,190 INFO L290 TraceCheckUtils]: 55: Hoare triple {1930#false} main_~i~0#1 := 0; {1930#false} is VALID [2022-02-20 14:16:50,190 INFO L290 TraceCheckUtils]: 54: Hoare triple {2144#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} assume !(main_~i~0#1 < ~N~0); {1930#false} is VALID [2022-02-20 14:16:50,191 INFO L290 TraceCheckUtils]: 53: Hoare triple {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2144#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} is VALID [2022-02-20 14:16:50,192 INFO L290 TraceCheckUtils]: 52: Hoare triple {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:50,193 INFO L290 TraceCheckUtils]: 51: Hoare triple {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:50,195 INFO L290 TraceCheckUtils]: 50: Hoare triple {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:50,195 INFO L290 TraceCheckUtils]: 49: Hoare triple {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:50,196 INFO L290 TraceCheckUtils]: 48: Hoare triple {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2148#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:50,196 INFO L290 TraceCheckUtils]: 47: Hoare triple {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,196 INFO L290 TraceCheckUtils]: 46: Hoare triple {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,197 INFO L290 TraceCheckUtils]: 45: Hoare triple {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,198 INFO L290 TraceCheckUtils]: 44: Hoare triple {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,201 INFO L290 TraceCheckUtils]: 43: Hoare triple {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2164#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,202 INFO L290 TraceCheckUtils]: 42: Hoare triple {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,202 INFO L290 TraceCheckUtils]: 41: Hoare triple {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,202 INFO L290 TraceCheckUtils]: 40: Hoare triple {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,203 INFO L290 TraceCheckUtils]: 39: Hoare triple {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,203 INFO L290 TraceCheckUtils]: 38: Hoare triple {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2180#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,204 INFO L290 TraceCheckUtils]: 37: Hoare triple {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:50,204 INFO L290 TraceCheckUtils]: 36: Hoare triple {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:50,205 INFO L290 TraceCheckUtils]: 35: Hoare triple {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:50,206 INFO L290 TraceCheckUtils]: 34: Hoare triple {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:50,206 INFO L290 TraceCheckUtils]: 33: Hoare triple {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2196#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:50,207 INFO L290 TraceCheckUtils]: 32: Hoare triple {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,207 INFO L290 TraceCheckUtils]: 31: Hoare triple {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,207 INFO L290 TraceCheckUtils]: 30: Hoare triple {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,208 INFO L290 TraceCheckUtils]: 29: Hoare triple {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,208 INFO L290 TraceCheckUtils]: 28: Hoare triple {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2212#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,209 INFO L290 TraceCheckUtils]: 27: Hoare triple {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,209 INFO L290 TraceCheckUtils]: 26: Hoare triple {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,209 INFO L290 TraceCheckUtils]: 25: Hoare triple {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,210 INFO L290 TraceCheckUtils]: 24: Hoare triple {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,210 INFO L290 TraceCheckUtils]: 23: Hoare triple {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2228#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,210 INFO L290 TraceCheckUtils]: 22: Hoare triple {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,211 INFO L290 TraceCheckUtils]: 21: Hoare triple {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,212 INFO L290 TraceCheckUtils]: 20: Hoare triple {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,212 INFO L290 TraceCheckUtils]: 19: Hoare triple {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,213 INFO L290 TraceCheckUtils]: 18: Hoare triple {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2244#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,214 INFO L290 TraceCheckUtils]: 17: Hoare triple {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:50,214 INFO L290 TraceCheckUtils]: 16: Hoare triple {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:50,215 INFO L290 TraceCheckUtils]: 15: Hoare triple {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:50,215 INFO L290 TraceCheckUtils]: 14: Hoare triple {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:50,216 INFO L290 TraceCheckUtils]: 13: Hoare triple {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2260#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:50,216 INFO L290 TraceCheckUtils]: 12: Hoare triple {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,216 INFO L290 TraceCheckUtils]: 11: Hoare triple {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,216 INFO L290 TraceCheckUtils]: 10: Hoare triple {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,217 INFO L290 TraceCheckUtils]: 9: Hoare triple {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,217 INFO L290 TraceCheckUtils]: 8: Hoare triple {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {2276#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:50,218 INFO L290 TraceCheckUtils]: 7: Hoare triple {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:50,218 INFO L290 TraceCheckUtils]: 6: Hoare triple {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:50,218 INFO L290 TraceCheckUtils]: 5: Hoare triple {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:50,218 INFO L290 TraceCheckUtils]: 4: Hoare triple {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:50,219 INFO L290 TraceCheckUtils]: 3: Hoare triple {2308#(< 10 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {2292#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:50,219 INFO L290 TraceCheckUtils]: 2: Hoare triple {2308#(< 10 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {2308#(< 10 ~N~0)} is VALID [2022-02-20 14:16:50,219 INFO L290 TraceCheckUtils]: 1: Hoare triple {2308#(< 10 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {2308#(< 10 ~N~0)} is VALID [2022-02-20 14:16:50,220 INFO L290 TraceCheckUtils]: 0: Hoare triple {1929#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {2308#(< 10 ~N~0)} is VALID [2022-02-20 14:16:50,220 INFO L134 CoverageAnalysis]: Checked inductivity of 235 backedges. 0 proven. 235 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 14:16:50,220 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 14:16:50,221 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [544474460] [2022-02-20 14:16:50,221 WARN L317 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-02-20 14:16:50,221 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1545134096] [2022-02-20 14:16:50,221 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1545134096] provided 0 perfect and 2 imperfect interpolant sequences [2022-02-20 14:16:50,221 INFO L191 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-02-20 14:16:50,221 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [13, 13] total 25 [2022-02-20 14:16:50,221 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1724663285] [2022-02-20 14:16:50,221 INFO L85 oduleStraightlineAll]: Using 2 imperfect interpolants to construct interpolant automaton [2022-02-20 14:16:50,222 INFO L78 Accepts]: Start accepts. Automaton has has 26 states, 26 states have (on average 4.461538461538462) internal successors, (116), 25 states have internal predecessors, (116), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 61 [2022-02-20 14:16:50,222 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 14:16:50,222 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 26 states, 26 states have (on average 4.461538461538462) internal successors, (116), 25 states have internal predecessors, (116), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:50,327 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 116 edges. 116 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:50,327 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 26 states [2022-02-20 14:16:50,327 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 14:16:50,328 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 26 interpolants. [2022-02-20 14:16:50,329 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=303, Invalid=347, Unknown=0, NotChecked=0, Total=650 [2022-02-20 14:16:50,329 INFO L87 Difference]: Start difference. First operand 70 states and 88 transitions. Second operand has 26 states, 26 states have (on average 4.461538461538462) internal successors, (116), 25 states have internal predecessors, (116), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:52,107 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:52,107 INFO L93 Difference]: Finished difference Result 463 states and 570 transitions. [2022-02-20 14:16:52,107 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 25 states. [2022-02-20 14:16:52,108 INFO L78 Accepts]: Start accepts. Automaton has has 26 states, 26 states have (on average 4.461538461538462) internal successors, (116), 25 states have internal predecessors, (116), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 61 [2022-02-20 14:16:52,108 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 14:16:52,108 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 26 states, 26 states have (on average 4.461538461538462) internal successors, (116), 25 states have internal predecessors, (116), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:52,112 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 25 states to 25 states and 385 transitions. [2022-02-20 14:16:52,113 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 26 states, 26 states have (on average 4.461538461538462) internal successors, (116), 25 states have internal predecessors, (116), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:52,116 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 25 states to 25 states and 385 transitions. [2022-02-20 14:16:52,117 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 25 states and 385 transitions. [2022-02-20 14:16:52,563 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 385 edges. 385 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:52,571 INFO L225 Difference]: With dead ends: 463 [2022-02-20 14:16:52,571 INFO L226 Difference]: Without dead ends: 424 [2022-02-20 14:16:52,572 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 131 GetRequests, 96 SyntacticMatches, 0 SemanticMatches, 35 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 253 ImplicationChecksByTransitivity, 0.6s TimeCoverageRelationStatistics Valid=589, Invalid=743, Unknown=0, NotChecked=0, Total=1332 [2022-02-20 14:16:52,573 INFO L933 BasicCegarLoop]: 12 mSDtfsCounter, 883 mSDsluCounter, 174 mSDsCounter, 0 mSdLazyCounter, 190 mSolverCounterSat, 110 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.3s Time, 0 mProtectedPredicate, 0 mProtectedAction, 883 SdHoareTripleChecker+Valid, 186 SdHoareTripleChecker+Invalid, 300 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 110 IncrementalHoareTripleChecker+Valid, 190 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.4s IncrementalHoareTripleChecker+Time [2022-02-20 14:16:52,573 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [883 Valid, 186 Invalid, 300 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [110 Valid, 190 Invalid, 0 Unknown, 0 Unchecked, 0.4s Time] [2022-02-20 14:16:52,574 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 424 states. [2022-02-20 14:16:52,624 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 424 to 130. [2022-02-20 14:16:52,624 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 14:16:52,624 INFO L82 GeneralOperation]: Start isEquivalent. First operand 424 states. Second operand has 130 states, 129 states have (on average 1.2868217054263567) internal successors, (166), 129 states have internal predecessors, (166), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:52,625 INFO L74 IsIncluded]: Start isIncluded. First operand 424 states. Second operand has 130 states, 129 states have (on average 1.2868217054263567) internal successors, (166), 129 states have internal predecessors, (166), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:52,625 INFO L87 Difference]: Start difference. First operand 424 states. Second operand has 130 states, 129 states have (on average 1.2868217054263567) internal successors, (166), 129 states have internal predecessors, (166), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:52,635 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:52,635 INFO L93 Difference]: Finished difference Result 424 states and 501 transitions. [2022-02-20 14:16:52,635 INFO L276 IsEmpty]: Start isEmpty. Operand 424 states and 501 transitions. [2022-02-20 14:16:52,636 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:52,636 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:52,636 INFO L74 IsIncluded]: Start isIncluded. First operand has 130 states, 129 states have (on average 1.2868217054263567) internal successors, (166), 129 states have internal predecessors, (166), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 424 states. [2022-02-20 14:16:52,637 INFO L87 Difference]: Start difference. First operand has 130 states, 129 states have (on average 1.2868217054263567) internal successors, (166), 129 states have internal predecessors, (166), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 424 states. [2022-02-20 14:16:52,646 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:52,647 INFO L93 Difference]: Finished difference Result 424 states and 501 transitions. [2022-02-20 14:16:52,647 INFO L276 IsEmpty]: Start isEmpty. Operand 424 states and 501 transitions. [2022-02-20 14:16:52,648 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:52,648 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:52,648 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 14:16:52,648 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 14:16:52,648 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 130 states, 129 states have (on average 1.2868217054263567) internal successors, (166), 129 states have internal predecessors, (166), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:52,650 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 130 states to 130 states and 166 transitions. [2022-02-20 14:16:52,651 INFO L78 Accepts]: Start accepts. Automaton has 130 states and 166 transitions. Word has length 61 [2022-02-20 14:16:52,651 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 14:16:52,651 INFO L470 AbstractCegarLoop]: Abstraction has 130 states and 166 transitions. [2022-02-20 14:16:52,651 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 26 states, 26 states have (on average 4.461538461538462) internal successors, (116), 25 states have internal predecessors, (116), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:52,651 INFO L276 IsEmpty]: Start isEmpty. Operand 130 states and 166 transitions. [2022-02-20 14:16:52,652 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 122 [2022-02-20 14:16:52,652 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 14:16:52,652 INFO L514 BasicCegarLoop]: trace histogram [22, 22, 22, 22, 11, 11, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 14:16:52,669 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-02-20 14:16:52,856 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable5,7 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:52,857 INFO L402 AbstractCegarLoop]: === Iteration 7 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 14:16:52,857 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 14:16:52,857 INFO L85 PathProgramCache]: Analyzing trace with hash 4942966, now seen corresponding path program 2 times [2022-02-20 14:16:52,857 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 14:16:52,857 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1378299832] [2022-02-20 14:16:52,858 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:52,858 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 14:16:52,909 ERROR L252 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-02-20 14:16:52,909 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1935430307] [2022-02-20 14:16:52,909 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-02-20 14:16:52,909 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:52,909 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:16:52,910 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-02-20 14:16:52,912 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-02-20 14:16:53,015 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 1 check-sat command(s) [2022-02-20 14:16:53,016 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-02-20 14:16:53,017 INFO L263 TraceCheckSpWp]: Trace formula consists of 71 conjuncts, 11 conjunts are in the unsatisfiable core [2022-02-20 14:16:53,039 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:53,040 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 14:16:54,180 INFO L290 TraceCheckUtils]: 0: Hoare triple {3880#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {3885#(= ~N~0 1000)} is VALID [2022-02-20 14:16:54,181 INFO L290 TraceCheckUtils]: 1: Hoare triple {3885#(= ~N~0 1000)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,181 INFO L290 TraceCheckUtils]: 2: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(0 == assume_abort_if_not_~cond#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,182 INFO L290 TraceCheckUtils]: 3: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,182 INFO L290 TraceCheckUtils]: 4: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,183 INFO L290 TraceCheckUtils]: 5: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,183 INFO L290 TraceCheckUtils]: 6: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,184 INFO L290 TraceCheckUtils]: 7: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,184 INFO L290 TraceCheckUtils]: 8: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,185 INFO L290 TraceCheckUtils]: 9: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,186 INFO L290 TraceCheckUtils]: 10: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,186 INFO L290 TraceCheckUtils]: 11: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,187 INFO L290 TraceCheckUtils]: 12: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,187 INFO L290 TraceCheckUtils]: 13: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,187 INFO L290 TraceCheckUtils]: 14: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,188 INFO L290 TraceCheckUtils]: 15: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,188 INFO L290 TraceCheckUtils]: 16: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,189 INFO L290 TraceCheckUtils]: 17: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,189 INFO L290 TraceCheckUtils]: 18: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,190 INFO L290 TraceCheckUtils]: 19: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,190 INFO L290 TraceCheckUtils]: 20: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,191 INFO L290 TraceCheckUtils]: 21: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,191 INFO L290 TraceCheckUtils]: 22: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,191 INFO L290 TraceCheckUtils]: 23: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,192 INFO L290 TraceCheckUtils]: 24: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,192 INFO L290 TraceCheckUtils]: 25: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,193 INFO L290 TraceCheckUtils]: 26: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,193 INFO L290 TraceCheckUtils]: 27: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,193 INFO L290 TraceCheckUtils]: 28: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,194 INFO L290 TraceCheckUtils]: 29: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,194 INFO L290 TraceCheckUtils]: 30: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,195 INFO L290 TraceCheckUtils]: 31: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,195 INFO L290 TraceCheckUtils]: 32: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,195 INFO L290 TraceCheckUtils]: 33: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,196 INFO L290 TraceCheckUtils]: 34: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,196 INFO L290 TraceCheckUtils]: 35: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,197 INFO L290 TraceCheckUtils]: 36: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,197 INFO L290 TraceCheckUtils]: 37: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,197 INFO L290 TraceCheckUtils]: 38: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,198 INFO L290 TraceCheckUtils]: 39: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,198 INFO L290 TraceCheckUtils]: 40: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,199 INFO L290 TraceCheckUtils]: 41: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,199 INFO L290 TraceCheckUtils]: 42: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,200 INFO L290 TraceCheckUtils]: 43: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,200 INFO L290 TraceCheckUtils]: 44: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,200 INFO L290 TraceCheckUtils]: 45: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,201 INFO L290 TraceCheckUtils]: 46: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,201 INFO L290 TraceCheckUtils]: 47: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,202 INFO L290 TraceCheckUtils]: 48: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,202 INFO L290 TraceCheckUtils]: 49: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,202 INFO L290 TraceCheckUtils]: 50: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,203 INFO L290 TraceCheckUtils]: 51: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,203 INFO L290 TraceCheckUtils]: 52: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,204 INFO L290 TraceCheckUtils]: 53: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,204 INFO L290 TraceCheckUtils]: 54: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,204 INFO L290 TraceCheckUtils]: 55: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,205 INFO L290 TraceCheckUtils]: 56: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,205 INFO L290 TraceCheckUtils]: 57: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,206 INFO L290 TraceCheckUtils]: 58: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,206 INFO L290 TraceCheckUtils]: 59: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,207 INFO L290 TraceCheckUtils]: 60: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,207 INFO L290 TraceCheckUtils]: 61: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,208 INFO L290 TraceCheckUtils]: 62: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,208 INFO L290 TraceCheckUtils]: 63: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,209 INFO L290 TraceCheckUtils]: 64: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,209 INFO L290 TraceCheckUtils]: 65: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,209 INFO L290 TraceCheckUtils]: 66: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,210 INFO L290 TraceCheckUtils]: 67: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,210 INFO L290 TraceCheckUtils]: 68: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,211 INFO L290 TraceCheckUtils]: 69: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,211 INFO L290 TraceCheckUtils]: 70: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,212 INFO L290 TraceCheckUtils]: 71: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,212 INFO L290 TraceCheckUtils]: 72: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,217 INFO L290 TraceCheckUtils]: 73: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,218 INFO L290 TraceCheckUtils]: 74: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,219 INFO L290 TraceCheckUtils]: 75: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,219 INFO L290 TraceCheckUtils]: 76: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,219 INFO L290 TraceCheckUtils]: 77: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,220 INFO L290 TraceCheckUtils]: 78: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,220 INFO L290 TraceCheckUtils]: 79: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,221 INFO L290 TraceCheckUtils]: 80: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,221 INFO L290 TraceCheckUtils]: 81: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,222 INFO L290 TraceCheckUtils]: 82: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,222 INFO L290 TraceCheckUtils]: 83: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,222 INFO L290 TraceCheckUtils]: 84: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,223 INFO L290 TraceCheckUtils]: 85: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,223 INFO L290 TraceCheckUtils]: 86: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,224 INFO L290 TraceCheckUtils]: 87: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,224 INFO L290 TraceCheckUtils]: 88: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,224 INFO L290 TraceCheckUtils]: 89: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,225 INFO L290 TraceCheckUtils]: 90: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,225 INFO L290 TraceCheckUtils]: 91: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,226 INFO L290 TraceCheckUtils]: 92: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,226 INFO L290 TraceCheckUtils]: 93: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,226 INFO L290 TraceCheckUtils]: 94: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,227 INFO L290 TraceCheckUtils]: 95: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,227 INFO L290 TraceCheckUtils]: 96: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,228 INFO L290 TraceCheckUtils]: 97: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,228 INFO L290 TraceCheckUtils]: 98: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,228 INFO L290 TraceCheckUtils]: 99: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,229 INFO L290 TraceCheckUtils]: 100: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,229 INFO L290 TraceCheckUtils]: 101: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,230 INFO L290 TraceCheckUtils]: 102: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,230 INFO L290 TraceCheckUtils]: 103: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,230 INFO L290 TraceCheckUtils]: 104: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,231 INFO L290 TraceCheckUtils]: 105: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,231 INFO L290 TraceCheckUtils]: 106: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,232 INFO L290 TraceCheckUtils]: 107: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,232 INFO L290 TraceCheckUtils]: 108: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,232 INFO L290 TraceCheckUtils]: 109: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,233 INFO L290 TraceCheckUtils]: 110: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,233 INFO L290 TraceCheckUtils]: 111: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,234 INFO L290 TraceCheckUtils]: 112: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,234 INFO L290 TraceCheckUtils]: 113: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,235 INFO L290 TraceCheckUtils]: 114: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !(main_~i~0#1 < ~N~0); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,235 INFO L290 TraceCheckUtils]: 115: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} main_~i~0#1 := 0; {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,235 INFO L290 TraceCheckUtils]: 116: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} is VALID [2022-02-20 14:16:54,236 INFO L290 TraceCheckUtils]: 117: Hoare triple {3889#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= ~N~0 1000) (= |ULTIMATE.start_main_~j~0#1| 0))} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {4238#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= (+ (- 1) |ULTIMATE.start_main_~j~0#1|) 0) (= ~N~0 1000))} is VALID [2022-02-20 14:16:54,236 INFO L290 TraceCheckUtils]: 118: Hoare triple {4238#(and (= 5 |ULTIMATE.start_main_~R~0#1|) (= (+ (- 1) |ULTIMATE.start_main_~j~0#1|) 0) (= ~N~0 1000))} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {4242#(<= 1 |ULTIMATE.start___VERIFIER_assert_~cond#1|)} is VALID [2022-02-20 14:16:54,236 INFO L290 TraceCheckUtils]: 119: Hoare triple {4242#(<= 1 |ULTIMATE.start___VERIFIER_assert_~cond#1|)} assume 0 == __VERIFIER_assert_~cond#1; {3881#false} is VALID [2022-02-20 14:16:54,237 INFO L290 TraceCheckUtils]: 120: Hoare triple {3881#false} assume !false; {3881#false} is VALID [2022-02-20 14:16:54,237 INFO L134 CoverageAnalysis]: Checked inductivity of 1177 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 1177 trivial. 0 not checked. [2022-02-20 14:16:54,237 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 14:16:54,237 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 14:16:54,238 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1378299832] [2022-02-20 14:16:54,238 WARN L317 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-02-20 14:16:54,238 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1935430307] [2022-02-20 14:16:54,238 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1935430307] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 14:16:54,238 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 14:16:54,238 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2022-02-20 14:16:54,238 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1388650851] [2022-02-20 14:16:54,238 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 14:16:54,238 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 2.8333333333333335) internal successors, (17), 5 states have internal predecessors, (17), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 121 [2022-02-20 14:16:54,239 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 14:16:54,239 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 6 states, 6 states have (on average 2.8333333333333335) internal successors, (17), 5 states have internal predecessors, (17), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:54,257 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 17 edges. 17 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:54,258 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 6 states [2022-02-20 14:16:54,259 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 14:16:54,259 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 6 interpolants. [2022-02-20 14:16:54,259 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=11, Invalid=19, Unknown=0, NotChecked=0, Total=30 [2022-02-20 14:16:54,259 INFO L87 Difference]: Start difference. First operand 130 states and 166 transitions. Second operand has 6 states, 6 states have (on average 2.8333333333333335) internal successors, (17), 5 states have internal predecessors, (17), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:54,521 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:54,521 INFO L93 Difference]: Finished difference Result 143 states and 181 transitions. [2022-02-20 14:16:54,521 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 8 states. [2022-02-20 14:16:54,521 INFO L78 Accepts]: Start accepts. Automaton has has 6 states, 6 states have (on average 2.8333333333333335) internal successors, (17), 5 states have internal predecessors, (17), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 121 [2022-02-20 14:16:54,522 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 14:16:54,522 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 2.8333333333333335) internal successors, (17), 5 states have internal predecessors, (17), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:54,522 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 44 transitions. [2022-02-20 14:16:54,522 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 6 states, 6 states have (on average 2.8333333333333335) internal successors, (17), 5 states have internal predecessors, (17), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:54,523 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 8 states to 8 states and 44 transitions. [2022-02-20 14:16:54,523 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 8 states and 44 transitions. [2022-02-20 14:16:54,578 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 44 edges. 44 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:54,579 INFO L225 Difference]: With dead ends: 143 [2022-02-20 14:16:54,579 INFO L226 Difference]: Without dead ends: 141 [2022-02-20 14:16:54,579 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 123 GetRequests, 116 SyntacticMatches, 0 SemanticMatches, 7 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 5 ImplicationChecksByTransitivity, 0.0s TimeCoverageRelationStatistics Valid=27, Invalid=45, Unknown=0, NotChecked=0, Total=72 [2022-02-20 14:16:54,580 INFO L933 BasicCegarLoop]: 17 mSDtfsCounter, 43 mSDsluCounter, 30 mSDsCounter, 0 mSdLazyCounter, 47 mSolverCounterSat, 6 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.1s Time, 0 mProtectedPredicate, 0 mProtectedAction, 43 SdHoareTripleChecker+Valid, 47 SdHoareTripleChecker+Invalid, 53 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 6 IncrementalHoareTripleChecker+Valid, 47 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.1s IncrementalHoareTripleChecker+Time [2022-02-20 14:16:54,580 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [43 Valid, 47 Invalid, 53 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [6 Valid, 47 Invalid, 0 Unknown, 0 Unchecked, 0.1s Time] [2022-02-20 14:16:54,581 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 141 states. [2022-02-20 14:16:54,641 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 141 to 136. [2022-02-20 14:16:54,641 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 14:16:54,641 INFO L82 GeneralOperation]: Start isEquivalent. First operand 141 states. Second operand has 136 states, 135 states have (on average 1.2814814814814814) internal successors, (173), 135 states have internal predecessors, (173), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:54,641 INFO L74 IsIncluded]: Start isIncluded. First operand 141 states. Second operand has 136 states, 135 states have (on average 1.2814814814814814) internal successors, (173), 135 states have internal predecessors, (173), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:54,642 INFO L87 Difference]: Start difference. First operand 141 states. Second operand has 136 states, 135 states have (on average 1.2814814814814814) internal successors, (173), 135 states have internal predecessors, (173), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:54,644 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:54,644 INFO L93 Difference]: Finished difference Result 141 states and 179 transitions. [2022-02-20 14:16:54,644 INFO L276 IsEmpty]: Start isEmpty. Operand 141 states and 179 transitions. [2022-02-20 14:16:54,644 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:54,644 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:54,644 INFO L74 IsIncluded]: Start isIncluded. First operand has 136 states, 135 states have (on average 1.2814814814814814) internal successors, (173), 135 states have internal predecessors, (173), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 141 states. [2022-02-20 14:16:54,645 INFO L87 Difference]: Start difference. First operand has 136 states, 135 states have (on average 1.2814814814814814) internal successors, (173), 135 states have internal predecessors, (173), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 141 states. [2022-02-20 14:16:54,647 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:16:54,647 INFO L93 Difference]: Finished difference Result 141 states and 179 transitions. [2022-02-20 14:16:54,647 INFO L276 IsEmpty]: Start isEmpty. Operand 141 states and 179 transitions. [2022-02-20 14:16:54,647 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:16:54,647 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:16:54,647 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 14:16:54,647 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 14:16:54,647 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 136 states, 135 states have (on average 1.2814814814814814) internal successors, (173), 135 states have internal predecessors, (173), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:54,649 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 136 states to 136 states and 173 transitions. [2022-02-20 14:16:54,649 INFO L78 Accepts]: Start accepts. Automaton has 136 states and 173 transitions. Word has length 121 [2022-02-20 14:16:54,651 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 14:16:54,651 INFO L470 AbstractCegarLoop]: Abstraction has 136 states and 173 transitions. [2022-02-20 14:16:54,652 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 6 states, 6 states have (on average 2.8333333333333335) internal successors, (17), 5 states have internal predecessors, (17), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:54,652 INFO L276 IsEmpty]: Start isEmpty. Operand 136 states and 173 transitions. [2022-02-20 14:16:54,652 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 128 [2022-02-20 14:16:54,653 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 14:16:54,653 INFO L514 BasicCegarLoop]: trace histogram [22, 22, 22, 22, 11, 11, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 14:16:54,671 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-02-20 14:16:54,865 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable6,8 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:54,866 INFO L402 AbstractCegarLoop]: === Iteration 8 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 14:16:54,866 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 14:16:54,866 INFO L85 PathProgramCache]: Analyzing trace with hash 1531894057, now seen corresponding path program 1 times [2022-02-20 14:16:54,866 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 14:16:54,866 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1405176595] [2022-02-20 14:16:54,866 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:54,866 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 14:16:54,922 ERROR L252 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-02-20 14:16:54,922 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1402908152] [2022-02-20 14:16:54,922 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:16:54,922 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:16:54,923 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:16:54,934 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-02-20 14:16:54,937 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-02-20 14:16:55,070 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:55,074 INFO L263 TraceCheckSpWp]: Trace formula consists of 449 conjuncts, 25 conjunts are in the unsatisfiable core [2022-02-20 14:16:55,114 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:16:55,116 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 14:16:56,729 INFO L290 TraceCheckUtils]: 0: Hoare triple {4868#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {4873#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:56,730 INFO L290 TraceCheckUtils]: 1: Hoare triple {4873#(<= 1000 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {4873#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:56,730 INFO L290 TraceCheckUtils]: 2: Hoare triple {4873#(<= 1000 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {4873#(<= 1000 ~N~0)} is VALID [2022-02-20 14:16:56,730 INFO L290 TraceCheckUtils]: 3: Hoare triple {4873#(<= 1000 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,731 INFO L290 TraceCheckUtils]: 4: Hoare triple {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,731 INFO L290 TraceCheckUtils]: 5: Hoare triple {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,732 INFO L290 TraceCheckUtils]: 6: Hoare triple {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,732 INFO L290 TraceCheckUtils]: 7: Hoare triple {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,733 INFO L290 TraceCheckUtils]: 8: Hoare triple {4883#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:56,733 INFO L290 TraceCheckUtils]: 9: Hoare triple {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:56,734 INFO L290 TraceCheckUtils]: 10: Hoare triple {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:56,734 INFO L290 TraceCheckUtils]: 11: Hoare triple {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:56,735 INFO L290 TraceCheckUtils]: 12: Hoare triple {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:16:56,735 INFO L290 TraceCheckUtils]: 13: Hoare triple {4899#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,736 INFO L290 TraceCheckUtils]: 14: Hoare triple {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,736 INFO L290 TraceCheckUtils]: 15: Hoare triple {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,737 INFO L290 TraceCheckUtils]: 16: Hoare triple {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,737 INFO L290 TraceCheckUtils]: 17: Hoare triple {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,738 INFO L290 TraceCheckUtils]: 18: Hoare triple {4915#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,738 INFO L290 TraceCheckUtils]: 19: Hoare triple {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,739 INFO L290 TraceCheckUtils]: 20: Hoare triple {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,739 INFO L290 TraceCheckUtils]: 21: Hoare triple {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,739 INFO L290 TraceCheckUtils]: 22: Hoare triple {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,740 INFO L290 TraceCheckUtils]: 23: Hoare triple {4931#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,741 INFO L290 TraceCheckUtils]: 24: Hoare triple {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,741 INFO L290 TraceCheckUtils]: 25: Hoare triple {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,742 INFO L290 TraceCheckUtils]: 26: Hoare triple {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,742 INFO L290 TraceCheckUtils]: 27: Hoare triple {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,743 INFO L290 TraceCheckUtils]: 28: Hoare triple {4947#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:56,743 INFO L290 TraceCheckUtils]: 29: Hoare triple {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:56,744 INFO L290 TraceCheckUtils]: 30: Hoare triple {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:56,744 INFO L290 TraceCheckUtils]: 31: Hoare triple {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:56,744 INFO L290 TraceCheckUtils]: 32: Hoare triple {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:16:56,745 INFO L290 TraceCheckUtils]: 33: Hoare triple {4963#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:56,746 INFO L290 TraceCheckUtils]: 34: Hoare triple {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:56,746 INFO L290 TraceCheckUtils]: 35: Hoare triple {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:56,746 INFO L290 TraceCheckUtils]: 36: Hoare triple {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:56,747 INFO L290 TraceCheckUtils]: 37: Hoare triple {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:16:56,747 INFO L290 TraceCheckUtils]: 38: Hoare triple {4979#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:56,748 INFO L290 TraceCheckUtils]: 39: Hoare triple {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:56,748 INFO L290 TraceCheckUtils]: 40: Hoare triple {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:56,749 INFO L290 TraceCheckUtils]: 41: Hoare triple {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:56,749 INFO L290 TraceCheckUtils]: 42: Hoare triple {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:16:56,750 INFO L290 TraceCheckUtils]: 43: Hoare triple {4995#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,750 INFO L290 TraceCheckUtils]: 44: Hoare triple {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,751 INFO L290 TraceCheckUtils]: 45: Hoare triple {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,751 INFO L290 TraceCheckUtils]: 46: Hoare triple {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,752 INFO L290 TraceCheckUtils]: 47: Hoare triple {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,752 INFO L290 TraceCheckUtils]: 48: Hoare triple {5011#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:56,753 INFO L290 TraceCheckUtils]: 49: Hoare triple {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:56,753 INFO L290 TraceCheckUtils]: 50: Hoare triple {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:56,754 INFO L290 TraceCheckUtils]: 51: Hoare triple {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:56,754 INFO L290 TraceCheckUtils]: 52: Hoare triple {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:16:56,755 INFO L290 TraceCheckUtils]: 53: Hoare triple {5027#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,756 INFO L290 TraceCheckUtils]: 54: Hoare triple {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,756 INFO L290 TraceCheckUtils]: 55: Hoare triple {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,757 INFO L290 TraceCheckUtils]: 56: Hoare triple {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,757 INFO L290 TraceCheckUtils]: 57: Hoare triple {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,758 INFO L290 TraceCheckUtils]: 58: Hoare triple {5043#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,758 INFO L290 TraceCheckUtils]: 59: Hoare triple {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,759 INFO L290 TraceCheckUtils]: 60: Hoare triple {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,759 INFO L290 TraceCheckUtils]: 61: Hoare triple {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,760 INFO L290 TraceCheckUtils]: 62: Hoare triple {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,772 INFO L290 TraceCheckUtils]: 63: Hoare triple {5059#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,773 INFO L290 TraceCheckUtils]: 64: Hoare triple {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,774 INFO L290 TraceCheckUtils]: 65: Hoare triple {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,774 INFO L290 TraceCheckUtils]: 66: Hoare triple {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,775 INFO L290 TraceCheckUtils]: 67: Hoare triple {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,776 INFO L290 TraceCheckUtils]: 68: Hoare triple {5075#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,776 INFO L290 TraceCheckUtils]: 69: Hoare triple {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,777 INFO L290 TraceCheckUtils]: 70: Hoare triple {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,777 INFO L290 TraceCheckUtils]: 71: Hoare triple {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,778 INFO L290 TraceCheckUtils]: 72: Hoare triple {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,779 INFO L290 TraceCheckUtils]: 73: Hoare triple {5091#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:16:56,780 INFO L290 TraceCheckUtils]: 74: Hoare triple {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:16:56,780 INFO L290 TraceCheckUtils]: 75: Hoare triple {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:16:56,780 INFO L290 TraceCheckUtils]: 76: Hoare triple {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:16:56,781 INFO L290 TraceCheckUtils]: 77: Hoare triple {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:16:56,782 INFO L290 TraceCheckUtils]: 78: Hoare triple {5107#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:16:56,782 INFO L290 TraceCheckUtils]: 79: Hoare triple {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:16:56,783 INFO L290 TraceCheckUtils]: 80: Hoare triple {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:16:56,783 INFO L290 TraceCheckUtils]: 81: Hoare triple {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:16:56,784 INFO L290 TraceCheckUtils]: 82: Hoare triple {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:16:56,785 INFO L290 TraceCheckUtils]: 83: Hoare triple {5123#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,785 INFO L290 TraceCheckUtils]: 84: Hoare triple {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,786 INFO L290 TraceCheckUtils]: 85: Hoare triple {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,786 INFO L290 TraceCheckUtils]: 86: Hoare triple {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,787 INFO L290 TraceCheckUtils]: 87: Hoare triple {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,788 INFO L290 TraceCheckUtils]: 88: Hoare triple {5139#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:16:56,788 INFO L290 TraceCheckUtils]: 89: Hoare triple {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:16:56,789 INFO L290 TraceCheckUtils]: 90: Hoare triple {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:16:56,789 INFO L290 TraceCheckUtils]: 91: Hoare triple {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:16:56,789 INFO L290 TraceCheckUtils]: 92: Hoare triple {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:16:56,790 INFO L290 TraceCheckUtils]: 93: Hoare triple {5155#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:16:56,791 INFO L290 TraceCheckUtils]: 94: Hoare triple {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:16:56,791 INFO L290 TraceCheckUtils]: 95: Hoare triple {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:16:56,792 INFO L290 TraceCheckUtils]: 96: Hoare triple {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:16:56,792 INFO L290 TraceCheckUtils]: 97: Hoare triple {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:16:56,793 INFO L290 TraceCheckUtils]: 98: Hoare triple {5171#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,794 INFO L290 TraceCheckUtils]: 99: Hoare triple {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,794 INFO L290 TraceCheckUtils]: 100: Hoare triple {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,795 INFO L290 TraceCheckUtils]: 101: Hoare triple {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,795 INFO L290 TraceCheckUtils]: 102: Hoare triple {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,796 INFO L290 TraceCheckUtils]: 103: Hoare triple {5187#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,797 INFO L290 TraceCheckUtils]: 104: Hoare triple {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,797 INFO L290 TraceCheckUtils]: 105: Hoare triple {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,798 INFO L290 TraceCheckUtils]: 106: Hoare triple {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,798 INFO L290 TraceCheckUtils]: 107: Hoare triple {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:16:56,799 INFO L290 TraceCheckUtils]: 108: Hoare triple {5203#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:16:56,799 INFO L290 TraceCheckUtils]: 109: Hoare triple {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:16:56,800 INFO L290 TraceCheckUtils]: 110: Hoare triple {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:16:56,800 INFO L290 TraceCheckUtils]: 111: Hoare triple {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:16:56,801 INFO L290 TraceCheckUtils]: 112: Hoare triple {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:16:56,802 INFO L290 TraceCheckUtils]: 113: Hoare triple {5219#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5235#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} is VALID [2022-02-20 14:16:56,802 INFO L290 TraceCheckUtils]: 114: Hoare triple {5235#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} assume !(main_~i~0#1 < ~N~0); {4869#false} is VALID [2022-02-20 14:16:56,802 INFO L290 TraceCheckUtils]: 115: Hoare triple {4869#false} main_~i~0#1 := 0; {4869#false} is VALID [2022-02-20 14:16:56,803 INFO L290 TraceCheckUtils]: 116: Hoare triple {4869#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4869#false} is VALID [2022-02-20 14:16:56,803 INFO L290 TraceCheckUtils]: 117: Hoare triple {4869#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {4869#false} is VALID [2022-02-20 14:16:56,803 INFO L290 TraceCheckUtils]: 118: Hoare triple {4869#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {4869#false} is VALID [2022-02-20 14:16:56,803 INFO L290 TraceCheckUtils]: 119: Hoare triple {4869#false} assume !(0 == __VERIFIER_assert_~cond#1); {4869#false} is VALID [2022-02-20 14:16:56,803 INFO L290 TraceCheckUtils]: 120: Hoare triple {4869#false} assume { :end_inline___VERIFIER_assert } true; {4869#false} is VALID [2022-02-20 14:16:56,803 INFO L290 TraceCheckUtils]: 121: Hoare triple {4869#false} main_#t~post8#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post8#1;havoc main_#t~post8#1; {4869#false} is VALID [2022-02-20 14:16:56,803 INFO L290 TraceCheckUtils]: 122: Hoare triple {4869#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4869#false} is VALID [2022-02-20 14:16:56,804 INFO L290 TraceCheckUtils]: 123: Hoare triple {4869#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {4869#false} is VALID [2022-02-20 14:16:56,804 INFO L290 TraceCheckUtils]: 124: Hoare triple {4869#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {4869#false} is VALID [2022-02-20 14:16:56,804 INFO L290 TraceCheckUtils]: 125: Hoare triple {4869#false} assume 0 == __VERIFIER_assert_~cond#1; {4869#false} is VALID [2022-02-20 14:16:56,804 INFO L290 TraceCheckUtils]: 126: Hoare triple {4869#false} assume !false; {4869#false} is VALID [2022-02-20 14:16:56,805 INFO L134 CoverageAnalysis]: Checked inductivity of 1181 backedges. 0 proven. 1177 refuted. 0 times theorem prover too weak. 4 trivial. 0 not checked. [2022-02-20 14:16:56,805 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 126: Hoare triple {4869#false} assume !false; {4869#false} is VALID [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 125: Hoare triple {4869#false} assume 0 == __VERIFIER_assert_~cond#1; {4869#false} is VALID [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 124: Hoare triple {4869#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {4869#false} is VALID [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 123: Hoare triple {4869#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {4869#false} is VALID [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 122: Hoare triple {4869#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4869#false} is VALID [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 121: Hoare triple {4869#false} main_#t~post8#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post8#1;havoc main_#t~post8#1; {4869#false} is VALID [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 120: Hoare triple {4869#false} assume { :end_inline___VERIFIER_assert } true; {4869#false} is VALID [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 119: Hoare triple {4869#false} assume !(0 == __VERIFIER_assert_~cond#1); {4869#false} is VALID [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 118: Hoare triple {4869#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {4869#false} is VALID [2022-02-20 14:16:58,519 INFO L290 TraceCheckUtils]: 117: Hoare triple {4869#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {4869#false} is VALID [2022-02-20 14:16:58,520 INFO L290 TraceCheckUtils]: 116: Hoare triple {4869#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {4869#false} is VALID [2022-02-20 14:16:58,520 INFO L290 TraceCheckUtils]: 115: Hoare triple {4869#false} main_~i~0#1 := 0; {4869#false} is VALID [2022-02-20 14:16:58,520 INFO L290 TraceCheckUtils]: 114: Hoare triple {5311#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} assume !(main_~i~0#1 < ~N~0); {4869#false} is VALID [2022-02-20 14:16:58,521 INFO L290 TraceCheckUtils]: 113: Hoare triple {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5311#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} is VALID [2022-02-20 14:16:58,521 INFO L290 TraceCheckUtils]: 112: Hoare triple {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:58,521 INFO L290 TraceCheckUtils]: 111: Hoare triple {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:58,522 INFO L290 TraceCheckUtils]: 110: Hoare triple {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:58,522 INFO L290 TraceCheckUtils]: 109: Hoare triple {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:58,523 INFO L290 TraceCheckUtils]: 108: Hoare triple {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5315#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:16:58,523 INFO L290 TraceCheckUtils]: 107: Hoare triple {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,523 INFO L290 TraceCheckUtils]: 106: Hoare triple {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,523 INFO L290 TraceCheckUtils]: 105: Hoare triple {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,524 INFO L290 TraceCheckUtils]: 104: Hoare triple {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,524 INFO L290 TraceCheckUtils]: 103: Hoare triple {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5331#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,525 INFO L290 TraceCheckUtils]: 102: Hoare triple {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,525 INFO L290 TraceCheckUtils]: 101: Hoare triple {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,525 INFO L290 TraceCheckUtils]: 100: Hoare triple {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,525 INFO L290 TraceCheckUtils]: 99: Hoare triple {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,526 INFO L290 TraceCheckUtils]: 98: Hoare triple {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5347#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,526 INFO L290 TraceCheckUtils]: 97: Hoare triple {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:58,526 INFO L290 TraceCheckUtils]: 96: Hoare triple {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:58,527 INFO L290 TraceCheckUtils]: 95: Hoare triple {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:58,527 INFO L290 TraceCheckUtils]: 94: Hoare triple {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:58,528 INFO L290 TraceCheckUtils]: 93: Hoare triple {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5363#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:16:58,528 INFO L290 TraceCheckUtils]: 92: Hoare triple {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,528 INFO L290 TraceCheckUtils]: 91: Hoare triple {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,528 INFO L290 TraceCheckUtils]: 90: Hoare triple {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,529 INFO L290 TraceCheckUtils]: 89: Hoare triple {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,529 INFO L290 TraceCheckUtils]: 88: Hoare triple {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5379#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,530 INFO L290 TraceCheckUtils]: 87: Hoare triple {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,530 INFO L290 TraceCheckUtils]: 86: Hoare triple {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,530 INFO L290 TraceCheckUtils]: 85: Hoare triple {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,530 INFO L290 TraceCheckUtils]: 84: Hoare triple {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,531 INFO L290 TraceCheckUtils]: 83: Hoare triple {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5395#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,531 INFO L290 TraceCheckUtils]: 82: Hoare triple {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,532 INFO L290 TraceCheckUtils]: 81: Hoare triple {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,532 INFO L290 TraceCheckUtils]: 80: Hoare triple {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,532 INFO L290 TraceCheckUtils]: 79: Hoare triple {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,533 INFO L290 TraceCheckUtils]: 78: Hoare triple {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5411#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,533 INFO L290 TraceCheckUtils]: 77: Hoare triple {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:58,533 INFO L290 TraceCheckUtils]: 76: Hoare triple {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:58,538 INFO L290 TraceCheckUtils]: 75: Hoare triple {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:58,539 INFO L290 TraceCheckUtils]: 74: Hoare triple {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:58,540 INFO L290 TraceCheckUtils]: 73: Hoare triple {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5427#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:16:58,540 INFO L290 TraceCheckUtils]: 72: Hoare triple {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,540 INFO L290 TraceCheckUtils]: 71: Hoare triple {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,540 INFO L290 TraceCheckUtils]: 70: Hoare triple {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,541 INFO L290 TraceCheckUtils]: 69: Hoare triple {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,541 INFO L290 TraceCheckUtils]: 68: Hoare triple {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5443#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,541 INFO L290 TraceCheckUtils]: 67: Hoare triple {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:58,542 INFO L290 TraceCheckUtils]: 66: Hoare triple {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:58,542 INFO L290 TraceCheckUtils]: 65: Hoare triple {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:58,542 INFO L290 TraceCheckUtils]: 64: Hoare triple {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:58,543 INFO L290 TraceCheckUtils]: 63: Hoare triple {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5459#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:16:58,543 INFO L290 TraceCheckUtils]: 62: Hoare triple {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:16:58,543 INFO L290 TraceCheckUtils]: 61: Hoare triple {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:16:58,544 INFO L290 TraceCheckUtils]: 60: Hoare triple {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:16:58,544 INFO L290 TraceCheckUtils]: 59: Hoare triple {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:16:58,545 INFO L290 TraceCheckUtils]: 58: Hoare triple {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5475#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:16:58,545 INFO L290 TraceCheckUtils]: 57: Hoare triple {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:16:58,545 INFO L290 TraceCheckUtils]: 56: Hoare triple {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:16:58,546 INFO L290 TraceCheckUtils]: 55: Hoare triple {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:16:58,546 INFO L290 TraceCheckUtils]: 54: Hoare triple {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:16:58,547 INFO L290 TraceCheckUtils]: 53: Hoare triple {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5491#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:16:58,547 INFO L290 TraceCheckUtils]: 52: Hoare triple {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:16:58,547 INFO L290 TraceCheckUtils]: 51: Hoare triple {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:16:58,548 INFO L290 TraceCheckUtils]: 50: Hoare triple {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:16:58,548 INFO L290 TraceCheckUtils]: 49: Hoare triple {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:16:58,549 INFO L290 TraceCheckUtils]: 48: Hoare triple {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5507#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:16:58,549 INFO L290 TraceCheckUtils]: 47: Hoare triple {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,550 INFO L290 TraceCheckUtils]: 46: Hoare triple {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,550 INFO L290 TraceCheckUtils]: 45: Hoare triple {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,550 INFO L290 TraceCheckUtils]: 44: Hoare triple {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,551 INFO L290 TraceCheckUtils]: 43: Hoare triple {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5523#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,551 INFO L290 TraceCheckUtils]: 42: Hoare triple {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:16:58,551 INFO L290 TraceCheckUtils]: 41: Hoare triple {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:16:58,552 INFO L290 TraceCheckUtils]: 40: Hoare triple {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:16:58,552 INFO L290 TraceCheckUtils]: 39: Hoare triple {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:16:58,553 INFO L290 TraceCheckUtils]: 38: Hoare triple {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5539#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:16:58,553 INFO L290 TraceCheckUtils]: 37: Hoare triple {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,553 INFO L290 TraceCheckUtils]: 36: Hoare triple {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,553 INFO L290 TraceCheckUtils]: 35: Hoare triple {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,554 INFO L290 TraceCheckUtils]: 34: Hoare triple {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,554 INFO L290 TraceCheckUtils]: 33: Hoare triple {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5555#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,555 INFO L290 TraceCheckUtils]: 32: Hoare triple {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:16:58,555 INFO L290 TraceCheckUtils]: 31: Hoare triple {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:16:58,555 INFO L290 TraceCheckUtils]: 30: Hoare triple {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:16:58,555 INFO L290 TraceCheckUtils]: 29: Hoare triple {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:16:58,556 INFO L290 TraceCheckUtils]: 28: Hoare triple {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5571#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:16:58,556 INFO L290 TraceCheckUtils]: 27: Hoare triple {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:16:58,557 INFO L290 TraceCheckUtils]: 26: Hoare triple {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:16:58,557 INFO L290 TraceCheckUtils]: 25: Hoare triple {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:16:58,557 INFO L290 TraceCheckUtils]: 24: Hoare triple {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:16:58,558 INFO L290 TraceCheckUtils]: 23: Hoare triple {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5587#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:16:58,558 INFO L290 TraceCheckUtils]: 22: Hoare triple {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,558 INFO L290 TraceCheckUtils]: 21: Hoare triple {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,558 INFO L290 TraceCheckUtils]: 20: Hoare triple {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,559 INFO L290 TraceCheckUtils]: 19: Hoare triple {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,559 INFO L290 TraceCheckUtils]: 18: Hoare triple {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5603#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,560 INFO L290 TraceCheckUtils]: 17: Hoare triple {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:16:58,560 INFO L290 TraceCheckUtils]: 16: Hoare triple {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:16:58,560 INFO L290 TraceCheckUtils]: 15: Hoare triple {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:16:58,561 INFO L290 TraceCheckUtils]: 14: Hoare triple {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:16:58,561 INFO L290 TraceCheckUtils]: 13: Hoare triple {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5619#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:16:58,562 INFO L290 TraceCheckUtils]: 12: Hoare triple {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,562 INFO L290 TraceCheckUtils]: 11: Hoare triple {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,562 INFO L290 TraceCheckUtils]: 10: Hoare triple {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,562 INFO L290 TraceCheckUtils]: 9: Hoare triple {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,563 INFO L290 TraceCheckUtils]: 8: Hoare triple {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {5635#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,563 INFO L290 TraceCheckUtils]: 7: Hoare triple {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,564 INFO L290 TraceCheckUtils]: 6: Hoare triple {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,564 INFO L290 TraceCheckUtils]: 5: Hoare triple {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,564 INFO L290 TraceCheckUtils]: 4: Hoare triple {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,565 INFO L290 TraceCheckUtils]: 3: Hoare triple {5667#(< 22 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {5651#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:16:58,565 INFO L290 TraceCheckUtils]: 2: Hoare triple {5667#(< 22 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {5667#(< 22 ~N~0)} is VALID [2022-02-20 14:16:58,565 INFO L290 TraceCheckUtils]: 1: Hoare triple {5667#(< 22 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {5667#(< 22 ~N~0)} is VALID [2022-02-20 14:16:58,566 INFO L290 TraceCheckUtils]: 0: Hoare triple {4868#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {5667#(< 22 ~N~0)} is VALID [2022-02-20 14:16:58,566 INFO L134 CoverageAnalysis]: Checked inductivity of 1181 backedges. 0 proven. 1177 refuted. 0 times theorem prover too weak. 4 trivial. 0 not checked. [2022-02-20 14:16:58,566 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 14:16:58,567 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1405176595] [2022-02-20 14:16:58,567 WARN L317 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-02-20 14:16:58,567 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1402908152] [2022-02-20 14:16:58,567 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1402908152] provided 0 perfect and 2 imperfect interpolant sequences [2022-02-20 14:16:58,567 INFO L191 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-02-20 14:16:58,567 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [25, 25] total 49 [2022-02-20 14:16:58,567 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [67310658] [2022-02-20 14:16:58,567 INFO L85 oduleStraightlineAll]: Using 2 imperfect interpolants to construct interpolant automaton [2022-02-20 14:16:58,568 INFO L78 Accepts]: Start accepts. Automaton has has 50 states, 50 states have (on average 4.78) internal successors, (239), 49 states have internal predecessors, (239), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 127 [2022-02-20 14:16:58,568 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 14:16:58,568 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 50 states, 50 states have (on average 4.78) internal successors, (239), 49 states have internal predecessors, (239), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:16:58,810 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 239 edges. 239 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:16:58,811 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 50 states [2022-02-20 14:16:58,811 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 14:16:58,811 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 50 interpolants. [2022-02-20 14:16:58,812 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=1179, Invalid=1271, Unknown=0, NotChecked=0, Total=2450 [2022-02-20 14:16:58,812 INFO L87 Difference]: Start difference. First operand 136 states and 173 transitions. Second operand has 50 states, 50 states have (on average 4.78) internal successors, (239), 49 states have internal predecessors, (239), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:05,178 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:17:05,179 INFO L93 Difference]: Finished difference Result 1222 states and 1488 transitions. [2022-02-20 14:17:05,179 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 49 states. [2022-02-20 14:17:05,180 INFO L78 Accepts]: Start accepts. Automaton has has 50 states, 50 states have (on average 4.78) internal successors, (239), 49 states have internal predecessors, (239), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 127 [2022-02-20 14:17:05,180 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 14:17:05,180 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 50 states, 50 states have (on average 4.78) internal successors, (239), 49 states have internal predecessors, (239), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:05,197 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 49 states to 49 states and 773 transitions. [2022-02-20 14:17:05,198 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 50 states, 50 states have (on average 4.78) internal successors, (239), 49 states have internal predecessors, (239), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:05,202 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 49 states to 49 states and 773 transitions. [2022-02-20 14:17:05,203 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 49 states and 773 transitions. [2022-02-20 14:17:06,062 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 773 edges. 773 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:17:06,099 INFO L225 Difference]: With dead ends: 1222 [2022-02-20 14:17:06,099 INFO L226 Difference]: Without dead ends: 1147 [2022-02-20 14:17:06,102 INFO L932 BasicCegarLoop]: 0 DeclaredPredicates, 275 GetRequests, 204 SyntacticMatches, 0 SemanticMatches, 71 ConstructedPredicates, 0 IntricatePredicates, 0 DeprecatedPredicates, 1081 ImplicationChecksByTransitivity, 2.3s TimeCoverageRelationStatistics Valid=2329, Invalid=2927, Unknown=0, NotChecked=0, Total=5256 [2022-02-20 14:17:06,102 INFO L933 BasicCegarLoop]: 12 mSDtfsCounter, 2497 mSDsluCounter, 364 mSDsCounter, 0 mSdLazyCounter, 364 mSolverCounterSat, 344 mSolverCounterUnsat, 0 mSolverCounterUnknown, 0 mSolverCounterNotChecked, 0.8s Time, 0 mProtectedPredicate, 0 mProtectedAction, 2497 SdHoareTripleChecker+Valid, 376 SdHoareTripleChecker+Invalid, 708 SdHoareTripleChecker+Unknown, 0 SdHoareTripleChecker+Unchecked, 0.0s SdHoareTripleChecker+Time, 344 IncrementalHoareTripleChecker+Valid, 364 IncrementalHoareTripleChecker+Invalid, 0 IncrementalHoareTripleChecker+Unknown, 0 IncrementalHoareTripleChecker+Unchecked, 0.9s IncrementalHoareTripleChecker+Time [2022-02-20 14:17:06,102 INFO L934 BasicCegarLoop]: SdHoareTripleChecker [2497 Valid, 376 Invalid, 708 Unknown, 0 Unchecked, 0.0s Time], IncrementalHoareTripleChecker [344 Valid, 364 Invalid, 0 Unknown, 0 Unchecked, 0.9s Time] [2022-02-20 14:17:06,104 INFO L82 GeneralOperation]: Start minimizeSevpa. Operand 1147 states. [2022-02-20 14:17:06,239 INFO L88 GeneralOperation]: Finished minimizeSevpa. Reduced states from 1147 to 256. [2022-02-20 14:17:06,240 INFO L214 AbstractMinimizeNwa]: Start testing correctness of minimizeSevpa [2022-02-20 14:17:06,240 INFO L82 GeneralOperation]: Start isEquivalent. First operand 1147 states. Second operand has 256 states, 255 states have (on average 1.2901960784313726) internal successors, (329), 255 states have internal predecessors, (329), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:06,241 INFO L74 IsIncluded]: Start isIncluded. First operand 1147 states. Second operand has 256 states, 255 states have (on average 1.2901960784313726) internal successors, (329), 255 states have internal predecessors, (329), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:06,241 INFO L87 Difference]: Start difference. First operand 1147 states. Second operand has 256 states, 255 states have (on average 1.2901960784313726) internal successors, (329), 255 states have internal predecessors, (329), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:06,287 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:17:06,288 INFO L93 Difference]: Finished difference Result 1147 states and 1352 transitions. [2022-02-20 14:17:06,288 INFO L276 IsEmpty]: Start isEmpty. Operand 1147 states and 1352 transitions. [2022-02-20 14:17:06,289 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:17:06,289 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:17:06,292 INFO L74 IsIncluded]: Start isIncluded. First operand has 256 states, 255 states have (on average 1.2901960784313726) internal successors, (329), 255 states have internal predecessors, (329), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 1147 states. [2022-02-20 14:17:06,292 INFO L87 Difference]: Start difference. First operand has 256 states, 255 states have (on average 1.2901960784313726) internal successors, (329), 255 states have internal predecessors, (329), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Second operand 1147 states. [2022-02-20 14:17:06,332 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:17:06,332 INFO L93 Difference]: Finished difference Result 1147 states and 1352 transitions. [2022-02-20 14:17:06,332 INFO L276 IsEmpty]: Start isEmpty. Operand 1147 states and 1352 transitions. [2022-02-20 14:17:06,334 INFO L282 IsEmpty]: Finished isEmpty. No accepting run. [2022-02-20 14:17:06,335 INFO L83 IsIncluded]: Finished isIncluded. Language is included [2022-02-20 14:17:06,335 INFO L88 GeneralOperation]: Finished isEquivalent. [2022-02-20 14:17:06,335 INFO L221 AbstractMinimizeNwa]: Finished testing correctness of minimizeSevpa [2022-02-20 14:17:06,335 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 256 states, 255 states have (on average 1.2901960784313726) internal successors, (329), 255 states have internal predecessors, (329), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:06,339 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 256 states to 256 states and 329 transitions. [2022-02-20 14:17:06,339 INFO L78 Accepts]: Start accepts. Automaton has 256 states and 329 transitions. Word has length 127 [2022-02-20 14:17:06,339 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 14:17:06,339 INFO L470 AbstractCegarLoop]: Abstraction has 256 states and 329 transitions. [2022-02-20 14:17:06,340 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 50 states, 50 states have (on average 4.78) internal successors, (239), 49 states have internal predecessors, (239), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:06,340 INFO L276 IsEmpty]: Start isEmpty. Operand 256 states and 329 transitions. [2022-02-20 14:17:06,341 INFO L282 IsEmpty]: Finished isEmpty. Found accepting run of length 248 [2022-02-20 14:17:06,342 INFO L506 BasicCegarLoop]: Found error trace [2022-02-20 14:17:06,342 INFO L514 BasicCegarLoop]: trace histogram [46, 46, 46, 46, 23, 23, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 14:17:06,365 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-02-20 14:17:06,563 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 9 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable7 [2022-02-20 14:17:06,563 INFO L402 AbstractCegarLoop]: === Iteration 9 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION] === [2022-02-20 14:17:06,564 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 14:17:06,564 INFO L85 PathProgramCache]: Analyzing trace with hash -456351959, now seen corresponding path program 2 times [2022-02-20 14:17:06,564 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 14:17:06,564 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1866288453] [2022-02-20 14:17:06,564 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 14:17:06,564 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 14:17:06,633 ERROR L252 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2022-02-20 14:17:06,634 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [721199631] [2022-02-20 14:17:06,634 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-02-20 14:17:06,634 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 14:17:06,634 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 14:17:06,635 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-02-20 14:17:06,636 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-02-20 14:17:06,864 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-02-20 14:17:06,864 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-02-20 14:17:06,870 INFO L263 TraceCheckSpWp]: Trace formula consists of 845 conjuncts, 49 conjunts are in the unsatisfiable core [2022-02-20 14:17:06,915 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 14:17:06,918 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 14:17:10,436 INFO L290 TraceCheckUtils]: 0: Hoare triple {9743#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {9748#(<= 1000 ~N~0)} is VALID [2022-02-20 14:17:10,436 INFO L290 TraceCheckUtils]: 1: Hoare triple {9748#(<= 1000 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {9748#(<= 1000 ~N~0)} is VALID [2022-02-20 14:17:10,437 INFO L290 TraceCheckUtils]: 2: Hoare triple {9748#(<= 1000 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {9748#(<= 1000 ~N~0)} is VALID [2022-02-20 14:17:10,437 INFO L290 TraceCheckUtils]: 3: Hoare triple {9748#(<= 1000 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,437 INFO L290 TraceCheckUtils]: 4: Hoare triple {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,438 INFO L290 TraceCheckUtils]: 5: Hoare triple {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,438 INFO L290 TraceCheckUtils]: 6: Hoare triple {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,439 INFO L290 TraceCheckUtils]: 7: Hoare triple {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,440 INFO L290 TraceCheckUtils]: 8: Hoare triple {9758#(and (<= |ULTIMATE.start_main_~i~0#1| 0) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:17:10,441 INFO L290 TraceCheckUtils]: 9: Hoare triple {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:17:10,441 INFO L290 TraceCheckUtils]: 10: Hoare triple {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:17:10,441 INFO L290 TraceCheckUtils]: 11: Hoare triple {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:17:10,442 INFO L290 TraceCheckUtils]: 12: Hoare triple {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} is VALID [2022-02-20 14:17:10,443 INFO L290 TraceCheckUtils]: 13: Hoare triple {9774#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 1))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,443 INFO L290 TraceCheckUtils]: 14: Hoare triple {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,443 INFO L290 TraceCheckUtils]: 15: Hoare triple {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,444 INFO L290 TraceCheckUtils]: 16: Hoare triple {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,444 INFO L290 TraceCheckUtils]: 17: Hoare triple {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,445 INFO L290 TraceCheckUtils]: 18: Hoare triple {9790#(and (<= |ULTIMATE.start_main_~i~0#1| 2) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,445 INFO L290 TraceCheckUtils]: 19: Hoare triple {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,446 INFO L290 TraceCheckUtils]: 20: Hoare triple {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,446 INFO L290 TraceCheckUtils]: 21: Hoare triple {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,446 INFO L290 TraceCheckUtils]: 22: Hoare triple {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,447 INFO L290 TraceCheckUtils]: 23: Hoare triple {9806#(and (<= |ULTIMATE.start_main_~i~0#1| 3) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,448 INFO L290 TraceCheckUtils]: 24: Hoare triple {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,448 INFO L290 TraceCheckUtils]: 25: Hoare triple {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,448 INFO L290 TraceCheckUtils]: 26: Hoare triple {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,449 INFO L290 TraceCheckUtils]: 27: Hoare triple {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,450 INFO L290 TraceCheckUtils]: 28: Hoare triple {9822#(and (<= |ULTIMATE.start_main_~i~0#1| 4) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:17:10,450 INFO L290 TraceCheckUtils]: 29: Hoare triple {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:17:10,450 INFO L290 TraceCheckUtils]: 30: Hoare triple {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:17:10,451 INFO L290 TraceCheckUtils]: 31: Hoare triple {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:17:10,451 INFO L290 TraceCheckUtils]: 32: Hoare triple {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} is VALID [2022-02-20 14:17:10,452 INFO L290 TraceCheckUtils]: 33: Hoare triple {9838#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 5))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:17:10,452 INFO L290 TraceCheckUtils]: 34: Hoare triple {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:17:10,453 INFO L290 TraceCheckUtils]: 35: Hoare triple {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:17:10,453 INFO L290 TraceCheckUtils]: 36: Hoare triple {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:17:10,453 INFO L290 TraceCheckUtils]: 37: Hoare triple {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} is VALID [2022-02-20 14:17:10,454 INFO L290 TraceCheckUtils]: 38: Hoare triple {9854#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 6))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:17:10,455 INFO L290 TraceCheckUtils]: 39: Hoare triple {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:17:10,455 INFO L290 TraceCheckUtils]: 40: Hoare triple {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:17:10,456 INFO L290 TraceCheckUtils]: 41: Hoare triple {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:17:10,456 INFO L290 TraceCheckUtils]: 42: Hoare triple {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} is VALID [2022-02-20 14:17:10,457 INFO L290 TraceCheckUtils]: 43: Hoare triple {9870#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 7))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,457 INFO L290 TraceCheckUtils]: 44: Hoare triple {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,458 INFO L290 TraceCheckUtils]: 45: Hoare triple {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,458 INFO L290 TraceCheckUtils]: 46: Hoare triple {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,458 INFO L290 TraceCheckUtils]: 47: Hoare triple {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,459 INFO L290 TraceCheckUtils]: 48: Hoare triple {9886#(and (<= |ULTIMATE.start_main_~i~0#1| 8) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:17:10,459 INFO L290 TraceCheckUtils]: 49: Hoare triple {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:17:10,460 INFO L290 TraceCheckUtils]: 50: Hoare triple {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:17:10,460 INFO L290 TraceCheckUtils]: 51: Hoare triple {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:17:10,461 INFO L290 TraceCheckUtils]: 52: Hoare triple {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} is VALID [2022-02-20 14:17:10,461 INFO L290 TraceCheckUtils]: 53: Hoare triple {9902#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 9))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,462 INFO L290 TraceCheckUtils]: 54: Hoare triple {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,462 INFO L290 TraceCheckUtils]: 55: Hoare triple {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,463 INFO L290 TraceCheckUtils]: 56: Hoare triple {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,463 INFO L290 TraceCheckUtils]: 57: Hoare triple {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,464 INFO L290 TraceCheckUtils]: 58: Hoare triple {9918#(and (<= |ULTIMATE.start_main_~i~0#1| 10) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,464 INFO L290 TraceCheckUtils]: 59: Hoare triple {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,465 INFO L290 TraceCheckUtils]: 60: Hoare triple {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,465 INFO L290 TraceCheckUtils]: 61: Hoare triple {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,465 INFO L290 TraceCheckUtils]: 62: Hoare triple {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,466 INFO L290 TraceCheckUtils]: 63: Hoare triple {9934#(and (<= |ULTIMATE.start_main_~i~0#1| 11) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,466 INFO L290 TraceCheckUtils]: 64: Hoare triple {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,467 INFO L290 TraceCheckUtils]: 65: Hoare triple {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,467 INFO L290 TraceCheckUtils]: 66: Hoare triple {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,468 INFO L290 TraceCheckUtils]: 67: Hoare triple {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,468 INFO L290 TraceCheckUtils]: 68: Hoare triple {9950#(and (<= |ULTIMATE.start_main_~i~0#1| 12) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,469 INFO L290 TraceCheckUtils]: 69: Hoare triple {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,469 INFO L290 TraceCheckUtils]: 70: Hoare triple {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,470 INFO L290 TraceCheckUtils]: 71: Hoare triple {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,470 INFO L290 TraceCheckUtils]: 72: Hoare triple {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,471 INFO L290 TraceCheckUtils]: 73: Hoare triple {9966#(and (<= |ULTIMATE.start_main_~i~0#1| 13) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:17:10,471 INFO L290 TraceCheckUtils]: 74: Hoare triple {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:17:10,472 INFO L290 TraceCheckUtils]: 75: Hoare triple {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:17:10,472 INFO L290 TraceCheckUtils]: 76: Hoare triple {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:17:10,472 INFO L290 TraceCheckUtils]: 77: Hoare triple {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} is VALID [2022-02-20 14:17:10,473 INFO L290 TraceCheckUtils]: 78: Hoare triple {9982#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 14))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:17:10,474 INFO L290 TraceCheckUtils]: 79: Hoare triple {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:17:10,474 INFO L290 TraceCheckUtils]: 80: Hoare triple {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:17:10,474 INFO L290 TraceCheckUtils]: 81: Hoare triple {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:17:10,475 INFO L290 TraceCheckUtils]: 82: Hoare triple {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} is VALID [2022-02-20 14:17:10,476 INFO L290 TraceCheckUtils]: 83: Hoare triple {9998#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 15))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,476 INFO L290 TraceCheckUtils]: 84: Hoare triple {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,476 INFO L290 TraceCheckUtils]: 85: Hoare triple {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,477 INFO L290 TraceCheckUtils]: 86: Hoare triple {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,477 INFO L290 TraceCheckUtils]: 87: Hoare triple {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,478 INFO L290 TraceCheckUtils]: 88: Hoare triple {10014#(and (<= |ULTIMATE.start_main_~i~0#1| 16) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:17:10,478 INFO L290 TraceCheckUtils]: 89: Hoare triple {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:17:10,479 INFO L290 TraceCheckUtils]: 90: Hoare triple {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:17:10,479 INFO L290 TraceCheckUtils]: 91: Hoare triple {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:17:10,479 INFO L290 TraceCheckUtils]: 92: Hoare triple {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} is VALID [2022-02-20 14:17:10,480 INFO L290 TraceCheckUtils]: 93: Hoare triple {10030#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 17))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:17:10,480 INFO L290 TraceCheckUtils]: 94: Hoare triple {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:17:10,481 INFO L290 TraceCheckUtils]: 95: Hoare triple {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:17:10,481 INFO L290 TraceCheckUtils]: 96: Hoare triple {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:17:10,482 INFO L290 TraceCheckUtils]: 97: Hoare triple {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} is VALID [2022-02-20 14:17:10,482 INFO L290 TraceCheckUtils]: 98: Hoare triple {10046#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 18))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,483 INFO L290 TraceCheckUtils]: 99: Hoare triple {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,483 INFO L290 TraceCheckUtils]: 100: Hoare triple {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,484 INFO L290 TraceCheckUtils]: 101: Hoare triple {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,484 INFO L290 TraceCheckUtils]: 102: Hoare triple {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,485 INFO L290 TraceCheckUtils]: 103: Hoare triple {10062#(and (<= |ULTIMATE.start_main_~i~0#1| 19) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,485 INFO L290 TraceCheckUtils]: 104: Hoare triple {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,485 INFO L290 TraceCheckUtils]: 105: Hoare triple {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,486 INFO L290 TraceCheckUtils]: 106: Hoare triple {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,486 INFO L290 TraceCheckUtils]: 107: Hoare triple {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,487 INFO L290 TraceCheckUtils]: 108: Hoare triple {10078#(and (<= |ULTIMATE.start_main_~i~0#1| 20) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:17:10,487 INFO L290 TraceCheckUtils]: 109: Hoare triple {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:17:10,488 INFO L290 TraceCheckUtils]: 110: Hoare triple {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:17:10,488 INFO L290 TraceCheckUtils]: 111: Hoare triple {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:17:10,488 INFO L290 TraceCheckUtils]: 112: Hoare triple {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} is VALID [2022-02-20 14:17:10,489 INFO L290 TraceCheckUtils]: 113: Hoare triple {10094#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 21))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} is VALID [2022-02-20 14:17:10,490 INFO L290 TraceCheckUtils]: 114: Hoare triple {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} is VALID [2022-02-20 14:17:10,490 INFO L290 TraceCheckUtils]: 115: Hoare triple {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} is VALID [2022-02-20 14:17:10,504 INFO L290 TraceCheckUtils]: 116: Hoare triple {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} is VALID [2022-02-20 14:17:10,505 INFO L290 TraceCheckUtils]: 117: Hoare triple {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} is VALID [2022-02-20 14:17:10,506 INFO L290 TraceCheckUtils]: 118: Hoare triple {10110#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 22))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,507 INFO L290 TraceCheckUtils]: 119: Hoare triple {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,507 INFO L290 TraceCheckUtils]: 120: Hoare triple {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,508 INFO L290 TraceCheckUtils]: 121: Hoare triple {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,508 INFO L290 TraceCheckUtils]: 122: Hoare triple {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,509 INFO L290 TraceCheckUtils]: 123: Hoare triple {10126#(and (<= |ULTIMATE.start_main_~i~0#1| 23) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} is VALID [2022-02-20 14:17:10,509 INFO L290 TraceCheckUtils]: 124: Hoare triple {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} is VALID [2022-02-20 14:17:10,510 INFO L290 TraceCheckUtils]: 125: Hoare triple {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} is VALID [2022-02-20 14:17:10,510 INFO L290 TraceCheckUtils]: 126: Hoare triple {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} is VALID [2022-02-20 14:17:10,511 INFO L290 TraceCheckUtils]: 127: Hoare triple {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} is VALID [2022-02-20 14:17:10,512 INFO L290 TraceCheckUtils]: 128: Hoare triple {10142#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 24))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} is VALID [2022-02-20 14:17:10,512 INFO L290 TraceCheckUtils]: 129: Hoare triple {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} is VALID [2022-02-20 14:17:10,513 INFO L290 TraceCheckUtils]: 130: Hoare triple {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} is VALID [2022-02-20 14:17:10,513 INFO L290 TraceCheckUtils]: 131: Hoare triple {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} is VALID [2022-02-20 14:17:10,514 INFO L290 TraceCheckUtils]: 132: Hoare triple {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} is VALID [2022-02-20 14:17:10,514 INFO L290 TraceCheckUtils]: 133: Hoare triple {10158#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 25))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} is VALID [2022-02-20 14:17:10,515 INFO L290 TraceCheckUtils]: 134: Hoare triple {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} is VALID [2022-02-20 14:17:10,515 INFO L290 TraceCheckUtils]: 135: Hoare triple {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} is VALID [2022-02-20 14:17:10,516 INFO L290 TraceCheckUtils]: 136: Hoare triple {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} is VALID [2022-02-20 14:17:10,516 INFO L290 TraceCheckUtils]: 137: Hoare triple {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} is VALID [2022-02-20 14:17:10,517 INFO L290 TraceCheckUtils]: 138: Hoare triple {10174#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 26))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,518 INFO L290 TraceCheckUtils]: 139: Hoare triple {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,518 INFO L290 TraceCheckUtils]: 140: Hoare triple {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,519 INFO L290 TraceCheckUtils]: 141: Hoare triple {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,519 INFO L290 TraceCheckUtils]: 142: Hoare triple {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,520 INFO L290 TraceCheckUtils]: 143: Hoare triple {10190#(and (<= |ULTIMATE.start_main_~i~0#1| 27) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,520 INFO L290 TraceCheckUtils]: 144: Hoare triple {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,521 INFO L290 TraceCheckUtils]: 145: Hoare triple {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,521 INFO L290 TraceCheckUtils]: 146: Hoare triple {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,522 INFO L290 TraceCheckUtils]: 147: Hoare triple {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,522 INFO L290 TraceCheckUtils]: 148: Hoare triple {10206#(and (<= |ULTIMATE.start_main_~i~0#1| 28) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,523 INFO L290 TraceCheckUtils]: 149: Hoare triple {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,523 INFO L290 TraceCheckUtils]: 150: Hoare triple {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,524 INFO L290 TraceCheckUtils]: 151: Hoare triple {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,524 INFO L290 TraceCheckUtils]: 152: Hoare triple {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,525 INFO L290 TraceCheckUtils]: 153: Hoare triple {10222#(and (<= |ULTIMATE.start_main_~i~0#1| 29) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,525 INFO L290 TraceCheckUtils]: 154: Hoare triple {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,526 INFO L290 TraceCheckUtils]: 155: Hoare triple {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,526 INFO L290 TraceCheckUtils]: 156: Hoare triple {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,527 INFO L290 TraceCheckUtils]: 157: Hoare triple {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,528 INFO L290 TraceCheckUtils]: 158: Hoare triple {10238#(and (<= |ULTIMATE.start_main_~i~0#1| 30) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} is VALID [2022-02-20 14:17:10,528 INFO L290 TraceCheckUtils]: 159: Hoare triple {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} is VALID [2022-02-20 14:17:10,528 INFO L290 TraceCheckUtils]: 160: Hoare triple {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} is VALID [2022-02-20 14:17:10,529 INFO L290 TraceCheckUtils]: 161: Hoare triple {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} is VALID [2022-02-20 14:17:10,529 INFO L290 TraceCheckUtils]: 162: Hoare triple {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} is VALID [2022-02-20 14:17:10,530 INFO L290 TraceCheckUtils]: 163: Hoare triple {10254#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 31))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} is VALID [2022-02-20 14:17:10,531 INFO L290 TraceCheckUtils]: 164: Hoare triple {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} is VALID [2022-02-20 14:17:10,531 INFO L290 TraceCheckUtils]: 165: Hoare triple {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} is VALID [2022-02-20 14:17:10,532 INFO L290 TraceCheckUtils]: 166: Hoare triple {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} is VALID [2022-02-20 14:17:10,532 INFO L290 TraceCheckUtils]: 167: Hoare triple {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} is VALID [2022-02-20 14:17:10,533 INFO L290 TraceCheckUtils]: 168: Hoare triple {10270#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 32))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} is VALID [2022-02-20 14:17:10,533 INFO L290 TraceCheckUtils]: 169: Hoare triple {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} is VALID [2022-02-20 14:17:10,534 INFO L290 TraceCheckUtils]: 170: Hoare triple {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} is VALID [2022-02-20 14:17:10,534 INFO L290 TraceCheckUtils]: 171: Hoare triple {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} is VALID [2022-02-20 14:17:10,535 INFO L290 TraceCheckUtils]: 172: Hoare triple {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} is VALID [2022-02-20 14:17:10,536 INFO L290 TraceCheckUtils]: 173: Hoare triple {10286#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 33))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} is VALID [2022-02-20 14:17:10,536 INFO L290 TraceCheckUtils]: 174: Hoare triple {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} is VALID [2022-02-20 14:17:10,537 INFO L290 TraceCheckUtils]: 175: Hoare triple {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} is VALID [2022-02-20 14:17:10,537 INFO L290 TraceCheckUtils]: 176: Hoare triple {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} is VALID [2022-02-20 14:17:10,538 INFO L290 TraceCheckUtils]: 177: Hoare triple {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} is VALID [2022-02-20 14:17:10,539 INFO L290 TraceCheckUtils]: 178: Hoare triple {10302#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 34))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} is VALID [2022-02-20 14:17:10,539 INFO L290 TraceCheckUtils]: 179: Hoare triple {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} is VALID [2022-02-20 14:17:10,540 INFO L290 TraceCheckUtils]: 180: Hoare triple {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} is VALID [2022-02-20 14:17:10,540 INFO L290 TraceCheckUtils]: 181: Hoare triple {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} is VALID [2022-02-20 14:17:10,541 INFO L290 TraceCheckUtils]: 182: Hoare triple {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} is VALID [2022-02-20 14:17:10,542 INFO L290 TraceCheckUtils]: 183: Hoare triple {10318#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 35))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} is VALID [2022-02-20 14:17:10,542 INFO L290 TraceCheckUtils]: 184: Hoare triple {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} is VALID [2022-02-20 14:17:10,542 INFO L290 TraceCheckUtils]: 185: Hoare triple {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} is VALID [2022-02-20 14:17:10,543 INFO L290 TraceCheckUtils]: 186: Hoare triple {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} is VALID [2022-02-20 14:17:10,543 INFO L290 TraceCheckUtils]: 187: Hoare triple {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} is VALID [2022-02-20 14:17:10,544 INFO L290 TraceCheckUtils]: 188: Hoare triple {10334#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 36))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,545 INFO L290 TraceCheckUtils]: 189: Hoare triple {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,545 INFO L290 TraceCheckUtils]: 190: Hoare triple {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,546 INFO L290 TraceCheckUtils]: 191: Hoare triple {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,546 INFO L290 TraceCheckUtils]: 192: Hoare triple {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,547 INFO L290 TraceCheckUtils]: 193: Hoare triple {10350#(and (<= |ULTIMATE.start_main_~i~0#1| 37) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,548 INFO L290 TraceCheckUtils]: 194: Hoare triple {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,548 INFO L290 TraceCheckUtils]: 195: Hoare triple {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,548 INFO L290 TraceCheckUtils]: 196: Hoare triple {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,549 INFO L290 TraceCheckUtils]: 197: Hoare triple {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,550 INFO L290 TraceCheckUtils]: 198: Hoare triple {10366#(and (<= |ULTIMATE.start_main_~i~0#1| 38) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} is VALID [2022-02-20 14:17:10,550 INFO L290 TraceCheckUtils]: 199: Hoare triple {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} is VALID [2022-02-20 14:17:10,551 INFO L290 TraceCheckUtils]: 200: Hoare triple {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} is VALID [2022-02-20 14:17:10,551 INFO L290 TraceCheckUtils]: 201: Hoare triple {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} is VALID [2022-02-20 14:17:10,552 INFO L290 TraceCheckUtils]: 202: Hoare triple {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} is VALID [2022-02-20 14:17:10,553 INFO L290 TraceCheckUtils]: 203: Hoare triple {10382#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 39))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,553 INFO L290 TraceCheckUtils]: 204: Hoare triple {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,553 INFO L290 TraceCheckUtils]: 205: Hoare triple {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,554 INFO L290 TraceCheckUtils]: 206: Hoare triple {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,554 INFO L290 TraceCheckUtils]: 207: Hoare triple {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,555 INFO L290 TraceCheckUtils]: 208: Hoare triple {10398#(and (<= |ULTIMATE.start_main_~i~0#1| 40) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,556 INFO L290 TraceCheckUtils]: 209: Hoare triple {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,556 INFO L290 TraceCheckUtils]: 210: Hoare triple {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,557 INFO L290 TraceCheckUtils]: 211: Hoare triple {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,557 INFO L290 TraceCheckUtils]: 212: Hoare triple {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,558 INFO L290 TraceCheckUtils]: 213: Hoare triple {10414#(and (<= |ULTIMATE.start_main_~i~0#1| 41) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} is VALID [2022-02-20 14:17:10,559 INFO L290 TraceCheckUtils]: 214: Hoare triple {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} is VALID [2022-02-20 14:17:10,559 INFO L290 TraceCheckUtils]: 215: Hoare triple {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} is VALID [2022-02-20 14:17:10,560 INFO L290 TraceCheckUtils]: 216: Hoare triple {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} is VALID [2022-02-20 14:17:10,560 INFO L290 TraceCheckUtils]: 217: Hoare triple {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} is VALID [2022-02-20 14:17:10,561 INFO L290 TraceCheckUtils]: 218: Hoare triple {10430#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 42))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,561 INFO L290 TraceCheckUtils]: 219: Hoare triple {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,562 INFO L290 TraceCheckUtils]: 220: Hoare triple {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,562 INFO L290 TraceCheckUtils]: 221: Hoare triple {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,563 INFO L290 TraceCheckUtils]: 222: Hoare triple {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,564 INFO L290 TraceCheckUtils]: 223: Hoare triple {10446#(and (<= |ULTIMATE.start_main_~i~0#1| 43) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} is VALID [2022-02-20 14:17:10,564 INFO L290 TraceCheckUtils]: 224: Hoare triple {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} is VALID [2022-02-20 14:17:10,565 INFO L290 TraceCheckUtils]: 225: Hoare triple {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} is VALID [2022-02-20 14:17:10,565 INFO L290 TraceCheckUtils]: 226: Hoare triple {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} is VALID [2022-02-20 14:17:10,565 INFO L290 TraceCheckUtils]: 227: Hoare triple {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} is VALID [2022-02-20 14:17:10,566 INFO L290 TraceCheckUtils]: 228: Hoare triple {10462#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 44))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,567 INFO L290 TraceCheckUtils]: 229: Hoare triple {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,567 INFO L290 TraceCheckUtils]: 230: Hoare triple {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,568 INFO L290 TraceCheckUtils]: 231: Hoare triple {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,568 INFO L290 TraceCheckUtils]: 232: Hoare triple {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} is VALID [2022-02-20 14:17:10,569 INFO L290 TraceCheckUtils]: 233: Hoare triple {10478#(and (<= |ULTIMATE.start_main_~i~0#1| 45) (<= 1000 ~N~0))} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10494#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 46))} is VALID [2022-02-20 14:17:10,570 INFO L290 TraceCheckUtils]: 234: Hoare triple {10494#(and (<= 1000 ~N~0) (<= |ULTIMATE.start_main_~i~0#1| 46))} assume !(main_~i~0#1 < ~N~0); {9744#false} is VALID [2022-02-20 14:17:10,570 INFO L290 TraceCheckUtils]: 235: Hoare triple {9744#false} main_~i~0#1 := 0; {9744#false} is VALID [2022-02-20 14:17:10,570 INFO L290 TraceCheckUtils]: 236: Hoare triple {9744#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9744#false} is VALID [2022-02-20 14:17:10,570 INFO L290 TraceCheckUtils]: 237: Hoare triple {9744#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {9744#false} is VALID [2022-02-20 14:17:10,570 INFO L290 TraceCheckUtils]: 238: Hoare triple {9744#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {9744#false} is VALID [2022-02-20 14:17:10,571 INFO L290 TraceCheckUtils]: 239: Hoare triple {9744#false} assume !(0 == __VERIFIER_assert_~cond#1); {9744#false} is VALID [2022-02-20 14:17:10,571 INFO L290 TraceCheckUtils]: 240: Hoare triple {9744#false} assume { :end_inline___VERIFIER_assert } true; {9744#false} is VALID [2022-02-20 14:17:10,571 INFO L290 TraceCheckUtils]: 241: Hoare triple {9744#false} main_#t~post8#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post8#1;havoc main_#t~post8#1; {9744#false} is VALID [2022-02-20 14:17:10,571 INFO L290 TraceCheckUtils]: 242: Hoare triple {9744#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9744#false} is VALID [2022-02-20 14:17:10,571 INFO L290 TraceCheckUtils]: 243: Hoare triple {9744#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {9744#false} is VALID [2022-02-20 14:17:10,571 INFO L290 TraceCheckUtils]: 244: Hoare triple {9744#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {9744#false} is VALID [2022-02-20 14:17:10,571 INFO L290 TraceCheckUtils]: 245: Hoare triple {9744#false} assume 0 == __VERIFIER_assert_~cond#1; {9744#false} is VALID [2022-02-20 14:17:10,571 INFO L290 TraceCheckUtils]: 246: Hoare triple {9744#false} assume !false; {9744#false} is VALID [2022-02-20 14:17:10,574 INFO L134 CoverageAnalysis]: Checked inductivity of 5225 backedges. 0 proven. 5221 refuted. 0 times theorem prover too weak. 4 trivial. 0 not checked. [2022-02-20 14:17:10,574 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-02-20 14:17:16,204 INFO L290 TraceCheckUtils]: 246: Hoare triple {9744#false} assume !false; {9744#false} is VALID [2022-02-20 14:17:16,204 INFO L290 TraceCheckUtils]: 245: Hoare triple {9744#false} assume 0 == __VERIFIER_assert_~cond#1; {9744#false} is VALID [2022-02-20 14:17:16,204 INFO L290 TraceCheckUtils]: 244: Hoare triple {9744#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {9744#false} is VALID [2022-02-20 14:17:16,204 INFO L290 TraceCheckUtils]: 243: Hoare triple {9744#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {9744#false} is VALID [2022-02-20 14:17:16,204 INFO L290 TraceCheckUtils]: 242: Hoare triple {9744#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9744#false} is VALID [2022-02-20 14:17:16,204 INFO L290 TraceCheckUtils]: 241: Hoare triple {9744#false} main_#t~post8#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post8#1;havoc main_#t~post8#1; {9744#false} is VALID [2022-02-20 14:17:16,205 INFO L290 TraceCheckUtils]: 240: Hoare triple {9744#false} assume { :end_inline___VERIFIER_assert } true; {9744#false} is VALID [2022-02-20 14:17:16,205 INFO L290 TraceCheckUtils]: 239: Hoare triple {9744#false} assume !(0 == __VERIFIER_assert_~cond#1); {9744#false} is VALID [2022-02-20 14:17:16,205 INFO L290 TraceCheckUtils]: 238: Hoare triple {9744#false} assume { :begin_inline___VERIFIER_assert } true;__VERIFIER_assert_#in~cond#1 := (if main_~j~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (2 * main_~R~0#1 % 4294967296) then (if 2 * main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (2 * main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc __VERIFIER_assert_~cond#1;__VERIFIER_assert_~cond#1 := __VERIFIER_assert_#in~cond#1; {9744#false} is VALID [2022-02-20 14:17:16,205 INFO L290 TraceCheckUtils]: 237: Hoare triple {9744#false} assume 0 == main_#t~mem9#1;havoc main_#t~mem9#1;main_#t~post10#1 := main_~j~0#1;main_~j~0#1 := 1 + main_#t~post10#1;havoc main_#t~post10#1; {9744#false} is VALID [2022-02-20 14:17:16,205 INFO L290 TraceCheckUtils]: 236: Hoare triple {9744#false} assume !!(main_~i~0#1 < ~N~0);call main_#t~mem9#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {9744#false} is VALID [2022-02-20 14:17:16,205 INFO L290 TraceCheckUtils]: 235: Hoare triple {9744#false} main_~i~0#1 := 0; {9744#false} is VALID [2022-02-20 14:17:16,210 INFO L290 TraceCheckUtils]: 234: Hoare triple {10570#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} assume !(main_~i~0#1 < ~N~0); {9744#false} is VALID [2022-02-20 14:17:16,212 INFO L290 TraceCheckUtils]: 233: Hoare triple {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10570#(< |ULTIMATE.start_main_~i~0#1| ~N~0)} is VALID [2022-02-20 14:17:16,213 INFO L290 TraceCheckUtils]: 232: Hoare triple {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:17:16,213 INFO L290 TraceCheckUtils]: 231: Hoare triple {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:17:16,213 INFO L290 TraceCheckUtils]: 230: Hoare triple {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:17:16,214 INFO L290 TraceCheckUtils]: 229: Hoare triple {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:17:16,215 INFO L290 TraceCheckUtils]: 228: Hoare triple {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10574#(< (+ |ULTIMATE.start_main_~i~0#1| 1) ~N~0)} is VALID [2022-02-20 14:17:16,215 INFO L290 TraceCheckUtils]: 227: Hoare triple {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,215 INFO L290 TraceCheckUtils]: 226: Hoare triple {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,216 INFO L290 TraceCheckUtils]: 225: Hoare triple {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,216 INFO L290 TraceCheckUtils]: 224: Hoare triple {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,217 INFO L290 TraceCheckUtils]: 223: Hoare triple {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10590#(< (+ 2 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,217 INFO L290 TraceCheckUtils]: 222: Hoare triple {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,218 INFO L290 TraceCheckUtils]: 221: Hoare triple {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,218 INFO L290 TraceCheckUtils]: 220: Hoare triple {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,218 INFO L290 TraceCheckUtils]: 219: Hoare triple {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,219 INFO L290 TraceCheckUtils]: 218: Hoare triple {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10606#(< (+ 3 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,219 INFO L290 TraceCheckUtils]: 217: Hoare triple {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:17:16,220 INFO L290 TraceCheckUtils]: 216: Hoare triple {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:17:16,220 INFO L290 TraceCheckUtils]: 215: Hoare triple {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:17:16,220 INFO L290 TraceCheckUtils]: 214: Hoare triple {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:17:16,221 INFO L290 TraceCheckUtils]: 213: Hoare triple {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10622#(< (+ |ULTIMATE.start_main_~i~0#1| 4) ~N~0)} is VALID [2022-02-20 14:17:16,222 INFO L290 TraceCheckUtils]: 212: Hoare triple {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,222 INFO L290 TraceCheckUtils]: 211: Hoare triple {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,222 INFO L290 TraceCheckUtils]: 210: Hoare triple {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,223 INFO L290 TraceCheckUtils]: 209: Hoare triple {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,224 INFO L290 TraceCheckUtils]: 208: Hoare triple {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10638#(< (+ 5 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,224 INFO L290 TraceCheckUtils]: 207: Hoare triple {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,224 INFO L290 TraceCheckUtils]: 206: Hoare triple {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,225 INFO L290 TraceCheckUtils]: 205: Hoare triple {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,225 INFO L290 TraceCheckUtils]: 204: Hoare triple {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,226 INFO L290 TraceCheckUtils]: 203: Hoare triple {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10654#(< (+ 6 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,226 INFO L290 TraceCheckUtils]: 202: Hoare triple {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,227 INFO L290 TraceCheckUtils]: 201: Hoare triple {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,227 INFO L290 TraceCheckUtils]: 200: Hoare triple {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,227 INFO L290 TraceCheckUtils]: 199: Hoare triple {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,228 INFO L290 TraceCheckUtils]: 198: Hoare triple {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10670#(< (+ 7 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,229 INFO L290 TraceCheckUtils]: 197: Hoare triple {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:17:16,229 INFO L290 TraceCheckUtils]: 196: Hoare triple {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:17:16,229 INFO L290 TraceCheckUtils]: 195: Hoare triple {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:17:16,230 INFO L290 TraceCheckUtils]: 194: Hoare triple {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:17:16,231 INFO L290 TraceCheckUtils]: 193: Hoare triple {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10686#(< (+ |ULTIMATE.start_main_~i~0#1| 8) ~N~0)} is VALID [2022-02-20 14:17:16,231 INFO L290 TraceCheckUtils]: 192: Hoare triple {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,232 INFO L290 TraceCheckUtils]: 191: Hoare triple {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,232 INFO L290 TraceCheckUtils]: 190: Hoare triple {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,232 INFO L290 TraceCheckUtils]: 189: Hoare triple {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,233 INFO L290 TraceCheckUtils]: 188: Hoare triple {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10702#(< (+ 9 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,234 INFO L290 TraceCheckUtils]: 187: Hoare triple {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:17:16,234 INFO L290 TraceCheckUtils]: 186: Hoare triple {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:17:16,234 INFO L290 TraceCheckUtils]: 185: Hoare triple {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:17:16,234 INFO L290 TraceCheckUtils]: 184: Hoare triple {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:17:16,236 INFO L290 TraceCheckUtils]: 183: Hoare triple {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10718#(< (+ |ULTIMATE.start_main_~i~0#1| 10) ~N~0)} is VALID [2022-02-20 14:17:16,236 INFO L290 TraceCheckUtils]: 182: Hoare triple {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:17:16,236 INFO L290 TraceCheckUtils]: 181: Hoare triple {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:17:16,236 INFO L290 TraceCheckUtils]: 180: Hoare triple {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:17:16,237 INFO L290 TraceCheckUtils]: 179: Hoare triple {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:17:16,238 INFO L290 TraceCheckUtils]: 178: Hoare triple {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10734#(< (+ |ULTIMATE.start_main_~i~0#1| 11) ~N~0)} is VALID [2022-02-20 14:17:16,238 INFO L290 TraceCheckUtils]: 177: Hoare triple {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:17:16,239 INFO L290 TraceCheckUtils]: 176: Hoare triple {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:17:16,239 INFO L290 TraceCheckUtils]: 175: Hoare triple {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:17:16,239 INFO L290 TraceCheckUtils]: 174: Hoare triple {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:17:16,241 INFO L290 TraceCheckUtils]: 173: Hoare triple {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10750#(< (+ |ULTIMATE.start_main_~i~0#1| 12) ~N~0)} is VALID [2022-02-20 14:17:16,241 INFO L290 TraceCheckUtils]: 172: Hoare triple {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:17:16,241 INFO L290 TraceCheckUtils]: 171: Hoare triple {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:17:16,241 INFO L290 TraceCheckUtils]: 170: Hoare triple {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:17:16,242 INFO L290 TraceCheckUtils]: 169: Hoare triple {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:17:16,243 INFO L290 TraceCheckUtils]: 168: Hoare triple {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10766#(< (+ |ULTIMATE.start_main_~i~0#1| 13) ~N~0)} is VALID [2022-02-20 14:17:16,243 INFO L290 TraceCheckUtils]: 167: Hoare triple {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,243 INFO L290 TraceCheckUtils]: 166: Hoare triple {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,244 INFO L290 TraceCheckUtils]: 165: Hoare triple {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,244 INFO L290 TraceCheckUtils]: 164: Hoare triple {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,245 INFO L290 TraceCheckUtils]: 163: Hoare triple {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10782#(< (+ 14 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,245 INFO L290 TraceCheckUtils]: 162: Hoare triple {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:17:16,246 INFO L290 TraceCheckUtils]: 161: Hoare triple {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:17:16,246 INFO L290 TraceCheckUtils]: 160: Hoare triple {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:17:16,247 INFO L290 TraceCheckUtils]: 159: Hoare triple {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:17:16,248 INFO L290 TraceCheckUtils]: 158: Hoare triple {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10798#(< (+ |ULTIMATE.start_main_~i~0#1| 15) ~N~0)} is VALID [2022-02-20 14:17:16,248 INFO L290 TraceCheckUtils]: 157: Hoare triple {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,248 INFO L290 TraceCheckUtils]: 156: Hoare triple {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,249 INFO L290 TraceCheckUtils]: 155: Hoare triple {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,249 INFO L290 TraceCheckUtils]: 154: Hoare triple {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,250 INFO L290 TraceCheckUtils]: 153: Hoare triple {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10814#(< (+ 16 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,250 INFO L290 TraceCheckUtils]: 152: Hoare triple {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:17:16,251 INFO L290 TraceCheckUtils]: 151: Hoare triple {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:17:16,251 INFO L290 TraceCheckUtils]: 150: Hoare triple {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:17:16,251 INFO L290 TraceCheckUtils]: 149: Hoare triple {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:17:16,252 INFO L290 TraceCheckUtils]: 148: Hoare triple {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10830#(< (+ |ULTIMATE.start_main_~i~0#1| 17) ~N~0)} is VALID [2022-02-20 14:17:16,252 INFO L290 TraceCheckUtils]: 147: Hoare triple {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:17:16,253 INFO L290 TraceCheckUtils]: 146: Hoare triple {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:17:16,253 INFO L290 TraceCheckUtils]: 145: Hoare triple {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:17:16,253 INFO L290 TraceCheckUtils]: 144: Hoare triple {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:17:16,254 INFO L290 TraceCheckUtils]: 143: Hoare triple {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10846#(< (+ |ULTIMATE.start_main_~i~0#1| 18) ~N~0)} is VALID [2022-02-20 14:17:16,255 INFO L290 TraceCheckUtils]: 142: Hoare triple {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,255 INFO L290 TraceCheckUtils]: 141: Hoare triple {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,255 INFO L290 TraceCheckUtils]: 140: Hoare triple {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,256 INFO L290 TraceCheckUtils]: 139: Hoare triple {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,257 INFO L290 TraceCheckUtils]: 138: Hoare triple {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10862#(< (+ 19 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,257 INFO L290 TraceCheckUtils]: 137: Hoare triple {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:17:16,259 INFO L290 TraceCheckUtils]: 136: Hoare triple {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:17:16,265 INFO L290 TraceCheckUtils]: 135: Hoare triple {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:17:16,266 INFO L290 TraceCheckUtils]: 134: Hoare triple {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:17:16,268 INFO L290 TraceCheckUtils]: 133: Hoare triple {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10878#(< (+ |ULTIMATE.start_main_~i~0#1| 20) ~N~0)} is VALID [2022-02-20 14:17:16,268 INFO L290 TraceCheckUtils]: 132: Hoare triple {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,268 INFO L290 TraceCheckUtils]: 131: Hoare triple {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,269 INFO L290 TraceCheckUtils]: 130: Hoare triple {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,269 INFO L290 TraceCheckUtils]: 129: Hoare triple {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,270 INFO L290 TraceCheckUtils]: 128: Hoare triple {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10894#(< (+ 21 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,271 INFO L290 TraceCheckUtils]: 127: Hoare triple {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,271 INFO L290 TraceCheckUtils]: 126: Hoare triple {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,271 INFO L290 TraceCheckUtils]: 125: Hoare triple {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,272 INFO L290 TraceCheckUtils]: 124: Hoare triple {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,273 INFO L290 TraceCheckUtils]: 123: Hoare triple {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10910#(< (+ 22 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,273 INFO L290 TraceCheckUtils]: 122: Hoare triple {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,274 INFO L290 TraceCheckUtils]: 121: Hoare triple {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,274 INFO L290 TraceCheckUtils]: 120: Hoare triple {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1;call write~int((if (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 <= 2147483647 then (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 else (if main_~i~0#1 % 4294967296 < 0 && 0 != main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) + main_~R~0#1 % 4294967296 else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296) - main_~R~0#1 % 4294967296) else main_~i~0#1 % 4294967296 % (main_~R~0#1 % 4294967296)) % 4294967296 % 4294967296 - 4294967296), main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,274 INFO L290 TraceCheckUtils]: 119: Hoare triple {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,275 INFO L290 TraceCheckUtils]: 118: Hoare triple {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10926#(< (+ 23 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,276 INFO L290 TraceCheckUtils]: 117: Hoare triple {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} is VALID [2022-02-20 14:17:16,276 INFO L290 TraceCheckUtils]: 116: Hoare triple {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} is VALID [2022-02-20 14:17:16,276 INFO L290 TraceCheckUtils]: 115: Hoare triple {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} is VALID [2022-02-20 14:17:16,277 INFO L290 TraceCheckUtils]: 114: Hoare triple {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} is VALID [2022-02-20 14:17:16,278 INFO L290 TraceCheckUtils]: 113: Hoare triple {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10942#(< (+ |ULTIMATE.start_main_~i~0#1| 24) ~N~0)} is VALID [2022-02-20 14:17:16,278 INFO L290 TraceCheckUtils]: 112: Hoare triple {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} is VALID [2022-02-20 14:17:16,278 INFO L290 TraceCheckUtils]: 111: Hoare triple {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} is VALID [2022-02-20 14:17:16,278 INFO L290 TraceCheckUtils]: 110: Hoare triple {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} is VALID [2022-02-20 14:17:16,279 INFO L290 TraceCheckUtils]: 109: Hoare triple {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} is VALID [2022-02-20 14:17:16,280 INFO L290 TraceCheckUtils]: 108: Hoare triple {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10958#(< (+ |ULTIMATE.start_main_~i~0#1| 25) ~N~0)} is VALID [2022-02-20 14:17:16,280 INFO L290 TraceCheckUtils]: 107: Hoare triple {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} is VALID [2022-02-20 14:17:16,280 INFO L290 TraceCheckUtils]: 106: Hoare triple {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} is VALID [2022-02-20 14:17:16,281 INFO L290 TraceCheckUtils]: 105: Hoare triple {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} is VALID [2022-02-20 14:17:16,281 INFO L290 TraceCheckUtils]: 104: Hoare triple {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} is VALID [2022-02-20 14:17:16,282 INFO L290 TraceCheckUtils]: 103: Hoare triple {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10974#(< (+ |ULTIMATE.start_main_~i~0#1| 26) ~N~0)} is VALID [2022-02-20 14:17:16,282 INFO L290 TraceCheckUtils]: 102: Hoare triple {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} is VALID [2022-02-20 14:17:16,282 INFO L290 TraceCheckUtils]: 101: Hoare triple {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} is VALID [2022-02-20 14:17:16,283 INFO L290 TraceCheckUtils]: 100: Hoare triple {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} is VALID [2022-02-20 14:17:16,283 INFO L290 TraceCheckUtils]: 99: Hoare triple {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} is VALID [2022-02-20 14:17:16,284 INFO L290 TraceCheckUtils]: 98: Hoare triple {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {10990#(< (+ |ULTIMATE.start_main_~i~0#1| 27) ~N~0)} is VALID [2022-02-20 14:17:16,284 INFO L290 TraceCheckUtils]: 97: Hoare triple {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} is VALID [2022-02-20 14:17:16,285 INFO L290 TraceCheckUtils]: 96: Hoare triple {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} is VALID [2022-02-20 14:17:16,285 INFO L290 TraceCheckUtils]: 95: Hoare triple {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} is VALID [2022-02-20 14:17:16,285 INFO L290 TraceCheckUtils]: 94: Hoare triple {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} is VALID [2022-02-20 14:17:16,286 INFO L290 TraceCheckUtils]: 93: Hoare triple {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11006#(< (+ |ULTIMATE.start_main_~i~0#1| 28) ~N~0)} is VALID [2022-02-20 14:17:16,287 INFO L290 TraceCheckUtils]: 92: Hoare triple {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,287 INFO L290 TraceCheckUtils]: 91: Hoare triple {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,287 INFO L290 TraceCheckUtils]: 90: Hoare triple {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,287 INFO L290 TraceCheckUtils]: 89: Hoare triple {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,288 INFO L290 TraceCheckUtils]: 88: Hoare triple {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11022#(< (+ 29 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,289 INFO L290 TraceCheckUtils]: 87: Hoare triple {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,289 INFO L290 TraceCheckUtils]: 86: Hoare triple {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,289 INFO L290 TraceCheckUtils]: 85: Hoare triple {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,289 INFO L290 TraceCheckUtils]: 84: Hoare triple {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,291 INFO L290 TraceCheckUtils]: 83: Hoare triple {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11038#(< (+ 30 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,291 INFO L290 TraceCheckUtils]: 82: Hoare triple {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,291 INFO L290 TraceCheckUtils]: 81: Hoare triple {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,291 INFO L290 TraceCheckUtils]: 80: Hoare triple {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,292 INFO L290 TraceCheckUtils]: 79: Hoare triple {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,293 INFO L290 TraceCheckUtils]: 78: Hoare triple {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11054#(< (+ 31 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,293 INFO L290 TraceCheckUtils]: 77: Hoare triple {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,293 INFO L290 TraceCheckUtils]: 76: Hoare triple {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,293 INFO L290 TraceCheckUtils]: 75: Hoare triple {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,294 INFO L290 TraceCheckUtils]: 74: Hoare triple {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,295 INFO L290 TraceCheckUtils]: 73: Hoare triple {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11070#(< (+ 32 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,295 INFO L290 TraceCheckUtils]: 72: Hoare triple {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} is VALID [2022-02-20 14:17:16,296 INFO L290 TraceCheckUtils]: 71: Hoare triple {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} is VALID [2022-02-20 14:17:16,296 INFO L290 TraceCheckUtils]: 70: Hoare triple {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} is VALID [2022-02-20 14:17:16,296 INFO L290 TraceCheckUtils]: 69: Hoare triple {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} is VALID [2022-02-20 14:17:16,297 INFO L290 TraceCheckUtils]: 68: Hoare triple {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11086#(< (+ |ULTIMATE.start_main_~i~0#1| 33) ~N~0)} is VALID [2022-02-20 14:17:16,298 INFO L290 TraceCheckUtils]: 67: Hoare triple {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} is VALID [2022-02-20 14:17:16,298 INFO L290 TraceCheckUtils]: 66: Hoare triple {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} is VALID [2022-02-20 14:17:16,298 INFO L290 TraceCheckUtils]: 65: Hoare triple {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} is VALID [2022-02-20 14:17:16,299 INFO L290 TraceCheckUtils]: 64: Hoare triple {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} is VALID [2022-02-20 14:17:16,300 INFO L290 TraceCheckUtils]: 63: Hoare triple {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11102#(< (+ |ULTIMATE.start_main_~i~0#1| 34) ~N~0)} is VALID [2022-02-20 14:17:16,302 INFO L290 TraceCheckUtils]: 62: Hoare triple {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,302 INFO L290 TraceCheckUtils]: 61: Hoare triple {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,302 INFO L290 TraceCheckUtils]: 60: Hoare triple {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,302 INFO L290 TraceCheckUtils]: 59: Hoare triple {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,304 INFO L290 TraceCheckUtils]: 58: Hoare triple {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11118#(< (+ 35 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,304 INFO L290 TraceCheckUtils]: 57: Hoare triple {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} is VALID [2022-02-20 14:17:16,305 INFO L290 TraceCheckUtils]: 56: Hoare triple {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} is VALID [2022-02-20 14:17:16,305 INFO L290 TraceCheckUtils]: 55: Hoare triple {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} is VALID [2022-02-20 14:17:16,305 INFO L290 TraceCheckUtils]: 54: Hoare triple {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} is VALID [2022-02-20 14:17:16,306 INFO L290 TraceCheckUtils]: 53: Hoare triple {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11134#(< (+ |ULTIMATE.start_main_~i~0#1| 36) ~N~0)} is VALID [2022-02-20 14:17:16,307 INFO L290 TraceCheckUtils]: 52: Hoare triple {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} is VALID [2022-02-20 14:17:16,307 INFO L290 TraceCheckUtils]: 51: Hoare triple {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} is VALID [2022-02-20 14:17:16,307 INFO L290 TraceCheckUtils]: 50: Hoare triple {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} is VALID [2022-02-20 14:17:16,308 INFO L290 TraceCheckUtils]: 49: Hoare triple {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} is VALID [2022-02-20 14:17:16,309 INFO L290 TraceCheckUtils]: 48: Hoare triple {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11150#(< (+ |ULTIMATE.start_main_~i~0#1| 37) ~N~0)} is VALID [2022-02-20 14:17:16,309 INFO L290 TraceCheckUtils]: 47: Hoare triple {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} is VALID [2022-02-20 14:17:16,309 INFO L290 TraceCheckUtils]: 46: Hoare triple {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} is VALID [2022-02-20 14:17:16,309 INFO L290 TraceCheckUtils]: 45: Hoare triple {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} is VALID [2022-02-20 14:17:16,310 INFO L290 TraceCheckUtils]: 44: Hoare triple {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} is VALID [2022-02-20 14:17:16,311 INFO L290 TraceCheckUtils]: 43: Hoare triple {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11166#(< (+ |ULTIMATE.start_main_~i~0#1| 38) ~N~0)} is VALID [2022-02-20 14:17:16,311 INFO L290 TraceCheckUtils]: 42: Hoare triple {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} is VALID [2022-02-20 14:17:16,311 INFO L290 TraceCheckUtils]: 41: Hoare triple {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} is VALID [2022-02-20 14:17:16,312 INFO L290 TraceCheckUtils]: 40: Hoare triple {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} is VALID [2022-02-20 14:17:16,312 INFO L290 TraceCheckUtils]: 39: Hoare triple {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} is VALID [2022-02-20 14:17:16,313 INFO L290 TraceCheckUtils]: 38: Hoare triple {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11182#(< (+ |ULTIMATE.start_main_~i~0#1| 39) ~N~0)} is VALID [2022-02-20 14:17:16,314 INFO L290 TraceCheckUtils]: 37: Hoare triple {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,314 INFO L290 TraceCheckUtils]: 36: Hoare triple {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,314 INFO L290 TraceCheckUtils]: 35: Hoare triple {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,314 INFO L290 TraceCheckUtils]: 34: Hoare triple {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,315 INFO L290 TraceCheckUtils]: 33: Hoare triple {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11198#(< (+ 40 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,316 INFO L290 TraceCheckUtils]: 32: Hoare triple {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,316 INFO L290 TraceCheckUtils]: 31: Hoare triple {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,316 INFO L290 TraceCheckUtils]: 30: Hoare triple {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,316 INFO L290 TraceCheckUtils]: 29: Hoare triple {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,318 INFO L290 TraceCheckUtils]: 28: Hoare triple {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11214#(< (+ 41 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,318 INFO L290 TraceCheckUtils]: 27: Hoare triple {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,318 INFO L290 TraceCheckUtils]: 26: Hoare triple {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,318 INFO L290 TraceCheckUtils]: 25: Hoare triple {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,319 INFO L290 TraceCheckUtils]: 24: Hoare triple {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,334 INFO L290 TraceCheckUtils]: 23: Hoare triple {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11230#(< (+ 42 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,334 INFO L290 TraceCheckUtils]: 22: Hoare triple {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} is VALID [2022-02-20 14:17:16,334 INFO L290 TraceCheckUtils]: 21: Hoare triple {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} is VALID [2022-02-20 14:17:16,335 INFO L290 TraceCheckUtils]: 20: Hoare triple {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} is VALID [2022-02-20 14:17:16,335 INFO L290 TraceCheckUtils]: 19: Hoare triple {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} is VALID [2022-02-20 14:17:16,337 INFO L290 TraceCheckUtils]: 18: Hoare triple {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11246#(< (+ |ULTIMATE.start_main_~i~0#1| 43) ~N~0)} is VALID [2022-02-20 14:17:16,337 INFO L290 TraceCheckUtils]: 17: Hoare triple {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,337 INFO L290 TraceCheckUtils]: 16: Hoare triple {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,338 INFO L290 TraceCheckUtils]: 15: Hoare triple {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,338 INFO L290 TraceCheckUtils]: 14: Hoare triple {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,340 INFO L290 TraceCheckUtils]: 13: Hoare triple {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11262#(< (+ 44 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,340 INFO L290 TraceCheckUtils]: 12: Hoare triple {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} is VALID [2022-02-20 14:17:16,340 INFO L290 TraceCheckUtils]: 11: Hoare triple {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} is VALID [2022-02-20 14:17:16,341 INFO L290 TraceCheckUtils]: 10: Hoare triple {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} is VALID [2022-02-20 14:17:16,341 INFO L290 TraceCheckUtils]: 9: Hoare triple {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} is VALID [2022-02-20 14:17:16,344 INFO L290 TraceCheckUtils]: 8: Hoare triple {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} main_#t~post5#1 := main_~i~0#1;main_~i~0#1 := 1 + main_#t~post5#1;havoc main_#t~post5#1; {11278#(< (+ |ULTIMATE.start_main_~i~0#1| 45) ~N~0)} is VALID [2022-02-20 14:17:16,344 INFO L290 TraceCheckUtils]: 7: Hoare triple {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume 0 == main_#t~mem6#1;havoc main_#t~mem6#1;main_#t~post7#1 := main_~k~0#1;main_~k~0#1 := 1 + main_#t~post7#1;havoc main_#t~post7#1; {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,346 INFO L290 TraceCheckUtils]: 6: Hoare triple {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} call main_#t~mem6#1 := read~int(main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,346 INFO L290 TraceCheckUtils]: 5: Hoare triple {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !(main_~i~0#1 > (if ~N~0 < 0 && 0 != ~N~0 % 2 then 1 + ~N~0 / 2 else ~N~0 / 2) && main_~k~0#1 < main_~lim~0#1); {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,346 INFO L290 TraceCheckUtils]: 4: Hoare triple {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} assume !!(main_~i~0#1 < ~N~0);call write~int(1 + main_~i~0#1, main_~#a~0#1.base, main_~#a~0#1.offset + 4 * main_~i~0#1, 4); {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,347 INFO L290 TraceCheckUtils]: 3: Hoare triple {11310#(< 46 ~N~0)} assume { :end_inline_assume_abort_if_not } true;main_~i~0#1 := 0; {11294#(< (+ 46 |ULTIMATE.start_main_~i~0#1|) ~N~0)} is VALID [2022-02-20 14:17:16,347 INFO L290 TraceCheckUtils]: 2: Hoare triple {11310#(< 46 ~N~0)} assume !(0 == assume_abort_if_not_~cond#1); {11310#(< 46 ~N~0)} is VALID [2022-02-20 14:17:16,347 INFO L290 TraceCheckUtils]: 1: Hoare triple {11310#(< 46 ~N~0)} assume { :end_inline_ULTIMATE.init } true;assume { :begin_inline_main } true;havoc main_#res#1;havoc main_#t~nondet4#1, main_#t~mem6#1, main_#t~post7#1, main_#t~post5#1, main_#t~mem9#1, main_#t~post10#1, main_#t~post8#1, main_~i~0#1, main_~j~0#1, main_~k~0#1, main_~#a~0#1.base, main_~#a~0#1.offset, main_~lim~0#1, main_~R~0#1;havoc main_~i~0#1;main_~j~0#1 := 0;main_~k~0#1 := 0;call main_~#a~0#1.base, main_~#a~0#1.offset := #Ultimate.allocOnStack(4 * ~N~0);assume -2147483648 <= main_#t~nondet4#1 && main_#t~nondet4#1 <= 2147483647;main_~lim~0#1 := main_#t~nondet4#1;havoc main_#t~nondet4#1;main_~R~0#1 := 5;assume { :begin_inline_assume_abort_if_not } true;assume_abort_if_not_#in~cond#1 := (if 0 < main_~lim~0#1 && main_~lim~0#1 % 4294967296 < (if ~N~0 % 4294967296 < 0 && 0 != ~N~0 % 4294967296 % (main_~R~0#1 % 4294967296) then (if main_~R~0#1 % 4294967296 < 0 then ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296) - 1 else 1 + ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) else ~N~0 % 4294967296 / (main_~R~0#1 % 4294967296)) % 4294967296 then 1 else 0);havoc assume_abort_if_not_~cond#1;assume_abort_if_not_~cond#1 := assume_abort_if_not_#in~cond#1; {11310#(< 46 ~N~0)} is VALID [2022-02-20 14:17:16,348 INFO L290 TraceCheckUtils]: 0: Hoare triple {9743#true} assume { :begin_inline_ULTIMATE.init } 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(30, 2);call #Ultimate.allocInit(12, 3);~N~0 := 1000; {11310#(< 46 ~N~0)} is VALID [2022-02-20 14:17:16,350 INFO L134 CoverageAnalysis]: Checked inductivity of 5225 backedges. 0 proven. 5221 refuted. 0 times theorem prover too weak. 4 trivial. 0 not checked. [2022-02-20 14:17:16,350 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 14:17:16,350 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1866288453] [2022-02-20 14:17:16,351 WARN L317 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2022-02-20 14:17:16,351 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [721199631] [2022-02-20 14:17:16,351 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [721199631] provided 0 perfect and 2 imperfect interpolant sequences [2022-02-20 14:17:16,351 INFO L191 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2022-02-20 14:17:16,351 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [49, 49] total 97 [2022-02-20 14:17:16,351 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [695692810] [2022-02-20 14:17:16,351 INFO L85 oduleStraightlineAll]: Using 2 imperfect interpolants to construct interpolant automaton [2022-02-20 14:17:16,352 INFO L78 Accepts]: Start accepts. Automaton has has 98 states, 98 states have (on average 4.887755102040816) internal successors, (479), 97 states have internal predecessors, (479), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 247 [2022-02-20 14:17:16,353 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 14:17:16,353 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 98 states, 98 states have (on average 4.887755102040816) internal successors, (479), 97 states have internal predecessors, (479), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:16,893 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 479 edges. 479 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 14:17:16,893 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 98 states [2022-02-20 14:17:16,894 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 14:17:16,895 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 98 interpolants. [2022-02-20 14:17:16,896 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=4659, Invalid=4847, Unknown=0, NotChecked=0, Total=9506 [2022-02-20 14:17:16,897 INFO L87 Difference]: Start difference. First operand 256 states and 329 transitions. Second operand has 98 states, 98 states have (on average 4.887755102040816) internal successors, (479), 97 states have internal predecessors, (479), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:47,009 INFO L144 Difference]: Subtrahend was deterministic. Have not used determinization. [2022-02-20 14:17:47,010 INFO L93 Difference]: Finished difference Result 2482 states and 3024 transitions. [2022-02-20 14:17:47,010 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 97 states. [2022-02-20 14:17:47,010 INFO L78 Accepts]: Start accepts. Automaton has has 98 states, 98 states have (on average 4.887755102040816) internal successors, (479), 97 states have internal predecessors, (479), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 247 [2022-02-20 14:17:47,011 INFO L84 Accepts]: Finished accepts. some prefix is accepted. [2022-02-20 14:17:47,011 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 98 states, 98 states have (on average 4.887755102040816) internal successors, (479), 97 states have internal predecessors, (479), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:47,018 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 97 states to 97 states and 1553 transitions. [2022-02-20 14:17:47,019 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 98 states, 98 states have (on average 4.887755102040816) internal successors, (479), 97 states have internal predecessors, (479), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 14:17:47,027 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 97 states to 97 states and 1553 transitions. [2022-02-20 14:17:47,027 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with 97 states and 1553 transitions.