/root/.sdkman/candidates/java/current/bin/java -Xmx8000000000 -Xss4m -jar ./plugins/org.eclipse.equinox.launcher_1.5.800.v20200727-1323.jar -data @noDefault -ultimatedata ./data -s ../benchexec/../../../trunk/examples/settings/gemcutter/NewStatesSleep.epf --traceabstraction.dfs.order.used.in.por LOOP_LOCKSTEP --traceabstraction.additional.conditional.commutativity.checking DFS --traceabstraction.criterion.for.conditional.commutativity.checking RANDOM --traceabstraction.probability.for.random.criterion 20 --traceabstraction.seed.for.random.criterion 213 --traceabstraction.use.limited.checks.recommended.for.dfs true --traceabstraction.limit.for.limited.checks 10 -tc ../benchexec/../../../trunk/examples/toolchains/AutomizerCInline.xml -i ../../../trunk/examples/svcomp/weaver/loop-tiling-eq.wvr.c -------------------------------------------------------------------------------- This is Ultimate 0.2.4-wip.dk.conditional-comm-17da818-m [2024-05-07 09:58:43,041 INFO L188 SettingsManager]: Resetting all preferences to default values... [2024-05-07 09:58:43,093 INFO L114 SettingsManager]: Loading settings from /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/../benchexec/../../../trunk/examples/settings/gemcutter/NewStatesSleep.epf [2024-05-07 09:58:43,096 WARN L101 SettingsManager]: Preference file contains the following unknown settings: [2024-05-07 09:58:43,096 WARN L103 SettingsManager]: * de.uni_freiburg.informatik.ultimate.core.Log level for class [2024-05-07 09:58:43,110 INFO L130 SettingsManager]: Preferences different from defaults after loading the file: [2024-05-07 09:58:43,110 INFO L151 SettingsManager]: Preferences of UltimateCore differ from their defaults: [2024-05-07 09:58:43,110 INFO L153 SettingsManager]: * Log level for class=de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=ERROR; [2024-05-07 09:58:43,111 INFO L151 SettingsManager]: Preferences of Boogie Procedure Inliner differ from their defaults: [2024-05-07 09:58:43,111 INFO L153 SettingsManager]: * Ignore calls to procedures called more than once=ONLY_FOR_SEQUENTIAL_PROGRAMS [2024-05-07 09:58:43,111 INFO L151 SettingsManager]: Preferences of BlockEncodingV2 differ from their defaults: [2024-05-07 09:58:43,112 INFO L153 SettingsManager]: * Create parallel compositions if possible=false [2024-05-07 09:58:43,112 INFO L153 SettingsManager]: * Use SBE=true [2024-05-07 09:58:43,112 INFO L151 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2024-05-07 09:58:43,112 INFO L153 SettingsManager]: * Pointer base address is valid at dereference=IGNORE [2024-05-07 09:58:43,113 INFO L153 SettingsManager]: * sizeof long=4 [2024-05-07 09:58:43,113 INFO L153 SettingsManager]: * Overapproximate operations on floating types=true [2024-05-07 09:58:43,113 INFO L153 SettingsManager]: * sizeof POINTER=4 [2024-05-07 09:58:43,113 INFO L153 SettingsManager]: * Check division by zero=IGNORE [2024-05-07 09:58:43,113 INFO L153 SettingsManager]: * Pointer to allocated memory at dereference=IGNORE [2024-05-07 09:58:43,114 INFO L153 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=IGNORE [2024-05-07 09:58:43,114 INFO L153 SettingsManager]: * Check array bounds for arrays that are off heap=IGNORE [2024-05-07 09:58:43,114 INFO L153 SettingsManager]: * sizeof long double=12 [2024-05-07 09:58:43,114 INFO L153 SettingsManager]: * Check if freed pointer was valid=false [2024-05-07 09:58:43,114 INFO L153 SettingsManager]: * Use constant arrays=true [2024-05-07 09:58:43,115 INFO L151 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2024-05-07 09:58:43,115 INFO L153 SettingsManager]: * Size of a code block=SequenceOfStatements [2024-05-07 09:58:43,115 INFO L153 SettingsManager]: * To the following directory=./dump/ [2024-05-07 09:58:43,115 INFO L153 SettingsManager]: * SMT solver=External_DefaultMode [2024-05-07 09:58:43,115 INFO L153 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2024-05-07 09:58:43,116 INFO L151 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2024-05-07 09:58:43,116 INFO L153 SettingsManager]: * Compute Interpolants along a Counterexample=FPandBP [2024-05-07 09:58:43,116 INFO L153 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in [2024-05-07 09:58:43,116 INFO L153 SettingsManager]: * Apply one-shot large block encoding in concurrent analysis=false [2024-05-07 09:58:43,116 INFO L153 SettingsManager]: * Partial Order Reduction in concurrent analysis=SLEEP_NEW_STATES [2024-05-07 09:58:43,116 INFO L153 SettingsManager]: * Positions where we compute the Hoare Annotation=LoopHeads [2024-05-07 09:58:43,117 INFO L153 SettingsManager]: * Trace refinement strategy=CAMEL [2024-05-07 09:58:43,117 INFO L153 SettingsManager]: * Automaton type used in concurrency analysis=PARTIAL_ORDER_FA [2024-05-07 09:58:43,117 INFO L153 SettingsManager]: * Compute Hoare Annotation of negated interpolant automaton, abstraction and CFG=true [2024-05-07 09:58:43,117 INFO L153 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/UGemCutter-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.traceabstraction: DFS Order used in POR -> LOOP_LOCKSTEP Applying setting for plugin de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: Additional conditional commutativity checking -> DFS Applying setting for plugin de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: Criterion for conditional commutativity checking -> RANDOM Applying setting for plugin de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: probability for random criterion as percentage -> 20 Applying setting for plugin de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: seed for random criterion -> 213 Applying setting for plugin de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: use limited checks (recommended for DFS) -> true Applying setting for plugin de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: Limit for limited checks -> 10 [2024-05-07 09:58:43,357 INFO L75 nceAwareModelManager]: Repository-Root is: /tmp [2024-05-07 09:58:43,378 INFO L261 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2024-05-07 09:58:43,381 INFO L217 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2024-05-07 09:58:43,383 INFO L270 PluginConnector]: Initializing CDTParser... [2024-05-07 09:58:43,383 INFO L274 PluginConnector]: CDTParser initialized [2024-05-07 09:58:43,384 INFO L431 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/../../../trunk/examples/svcomp/weaver/loop-tiling-eq.wvr.c [2024-05-07 09:58:44,526 INFO L533 CDTParser]: Created temporary CDT project at NULL [2024-05-07 09:58:44,699 INFO L384 CDTParser]: Found 1 translation units. [2024-05-07 09:58:44,700 INFO L180 CDTParser]: Scanning /storage/repos/ultimate/trunk/examples/svcomp/weaver/loop-tiling-eq.wvr.c [2024-05-07 09:58:44,706 INFO L427 CDTParser]: About to delete temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/data/af889a35c/ff6cd9aab95448a0ba5c2d19b4271cac/FLAG2a42ee61d [2024-05-07 09:58:44,722 INFO L435 CDTParser]: Successfully deleted /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/data/af889a35c/ff6cd9aab95448a0ba5c2d19b4271cac [2024-05-07 09:58:44,725 INFO L299 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2024-05-07 09:58:44,726 INFO L133 ToolchainWalker]: Walking toolchain with 5 elements. [2024-05-07 09:58:44,726 INFO L112 PluginConnector]: ------------------------CACSL2BoogieTranslator---------------------------- [2024-05-07 09:58:44,726 INFO L270 PluginConnector]: Initializing CACSL2BoogieTranslator... [2024-05-07 09:58:44,730 INFO L274 PluginConnector]: CACSL2BoogieTranslator initialized [2024-05-07 09:58:44,730 INFO L184 PluginConnector]: Executing the observer ACSLObjectContainerObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,731 INFO L204 PluginConnector]: Invalid model from CACSL2BoogieTranslator for observer de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator.ACSLObjectContainerObserver@70c6b060 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44, skipping insertion in model container [2024-05-07 09:58:44,731 INFO L184 PluginConnector]: Executing the observer CACSL2BoogieTranslatorObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,754 INFO L177 MainTranslator]: Built tables and reachable declarations [2024-05-07 09:58:44,876 WARN L240 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/trunk/examples/svcomp/weaver/loop-tiling-eq.wvr.c[2618,2631] [2024-05-07 09:58:44,881 INFO L209 PostProcessor]: Analyzing one entry point: main [2024-05-07 09:58:44,888 INFO L202 MainTranslator]: Completed pre-run [2024-05-07 09:58:44,904 WARN L240 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/trunk/examples/svcomp/weaver/loop-tiling-eq.wvr.c[2618,2631] [2024-05-07 09:58:44,907 INFO L209 PostProcessor]: Analyzing one entry point: main [2024-05-07 09:58:44,917 INFO L206 MainTranslator]: Completed translation [2024-05-07 09:58:44,917 INFO L201 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44 WrapperNode [2024-05-07 09:58:44,918 INFO L131 PluginConnector]: ------------------------ END CACSL2BoogieTranslator---------------------------- [2024-05-07 09:58:44,918 INFO L112 PluginConnector]: ------------------------Boogie Procedure Inliner---------------------------- [2024-05-07 09:58:44,918 INFO L270 PluginConnector]: Initializing Boogie Procedure Inliner... [2024-05-07 09:58:44,918 INFO L274 PluginConnector]: Boogie Procedure Inliner initialized [2024-05-07 09:58:44,923 INFO L184 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,928 INFO L184 PluginConnector]: Executing the observer Inliner from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,947 INFO L138 Inliner]: procedures = 25, calls = 41, calls flagged for inlining = 13, calls inlined = 17, statements flattened = 196 [2024-05-07 09:58:44,947 INFO L131 PluginConnector]: ------------------------ END Boogie Procedure Inliner---------------------------- [2024-05-07 09:58:44,948 INFO L112 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2024-05-07 09:58:44,948 INFO L270 PluginConnector]: Initializing Boogie Preprocessor... [2024-05-07 09:58:44,948 INFO L274 PluginConnector]: Boogie Preprocessor initialized [2024-05-07 09:58:44,954 INFO L184 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,954 INFO L184 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,957 INFO L184 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,957 INFO L184 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,963 INFO L184 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,984 INFO L184 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,986 INFO L184 PluginConnector]: Executing the observer LTLStepAnnotator from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,987 INFO L184 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:44,989 INFO L131 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2024-05-07 09:58:44,996 INFO L112 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2024-05-07 09:58:44,997 INFO L270 PluginConnector]: Initializing RCFGBuilder... [2024-05-07 09:58:44,997 INFO L274 PluginConnector]: RCFGBuilder initialized [2024-05-07 09:58:44,998 INFO L184 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (1/1) ... [2024-05-07 09:58:45,016 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2024-05-07 09:58:45,027 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:45,057 INFO L229 MonitoredProcess]: Starting monitored process 1 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (exit command is (exit), workingDir is null) [2024-05-07 09:58:45,075 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1)] Waiting until timeout for monitored process [2024-05-07 09:58:45,100 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocInit [2024-05-07 09:58:45,100 INFO L130 BoogieDeclarations]: Found specification of procedure write~$Pointer$ [2024-05-07 09:58:45,101 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocOnStack [2024-05-07 09:58:45,101 INFO L130 BoogieDeclarations]: Found specification of procedure write~int [2024-05-07 09:58:45,101 INFO L130 BoogieDeclarations]: Found specification of procedure read~int [2024-05-07 09:58:45,101 INFO L130 BoogieDeclarations]: Found specification of procedure read~$Pointer$ [2024-05-07 09:58:45,101 INFO L130 BoogieDeclarations]: Found specification of procedure thread1 [2024-05-07 09:58:45,101 INFO L138 BoogieDeclarations]: Found implementation of procedure thread1 [2024-05-07 09:58:45,101 INFO L130 BoogieDeclarations]: Found specification of procedure thread2 [2024-05-07 09:58:45,102 INFO L138 BoogieDeclarations]: Found implementation of procedure thread2 [2024-05-07 09:58:45,102 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~int [2024-05-07 09:58:45,102 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocOnHeap [2024-05-07 09:58:45,102 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2024-05-07 09:58:45,103 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2024-05-07 09:58:45,103 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.dealloc [2024-05-07 09:58:45,105 WARN L213 CfgBuilder]: User set CodeBlockSize to SequenceOfStatements but program contains fork statements. Overwriting the user preferences and setting CodeBlockSize to OneNontrivialStatement [2024-05-07 09:58:45,219 INFO L241 CfgBuilder]: Building ICFG [2024-05-07 09:58:45,220 INFO L267 CfgBuilder]: Building CFG for each procedure with an implementation [2024-05-07 09:58:45,573 INFO L282 CfgBuilder]: Performing block encoding [2024-05-07 09:58:45,587 INFO L304 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2024-05-07 09:58:45,587 INFO L309 CfgBuilder]: Removed 7 assume(true) statements. [2024-05-07 09:58:45,589 INFO L201 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 07.05 09:58:45 BoogieIcfgContainer [2024-05-07 09:58:45,589 INFO L131 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2024-05-07 09:58:45,591 INFO L112 PluginConnector]: ------------------------TraceAbstraction---------------------------- [2024-05-07 09:58:45,591 INFO L270 PluginConnector]: Initializing TraceAbstraction... [2024-05-07 09:58:45,593 INFO L274 PluginConnector]: TraceAbstraction initialized [2024-05-07 09:58:45,593 INFO L184 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "CDTParser AST 07.05 09:58:44" (1/3) ... [2024-05-07 09:58:45,594 INFO L204 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@64d2f8f5 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 07.05 09:58:45, skipping insertion in model container [2024-05-07 09:58:45,594 INFO L184 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 07.05 09:58:44" (2/3) ... [2024-05-07 09:58:45,594 INFO L204 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@64d2f8f5 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 07.05 09:58:45, skipping insertion in model container [2024-05-07 09:58:45,594 INFO L184 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 07.05 09:58:45" (3/3) ... [2024-05-07 09:58:45,596 INFO L112 eAbstractionObserver]: Analyzing ICFG loop-tiling-eq.wvr.c [2024-05-07 09:58:45,603 WARN L145 ceAbstractionStarter]: Switching off computation of Hoare annotation because input is a concurrent program [2024-05-07 09:58:45,610 INFO L203 ceAbstractionStarter]: Automizer settings: Hoare:false NWA Interpolation:FPandBP Determinization: PREDICATE_ABSTRACTION [2024-05-07 09:58:45,611 INFO L162 ceAbstractionStarter]: Applying trace abstraction to program that has 1 error locations. [2024-05-07 09:58:45,611 INFO L514 ceAbstractionStarter]: Constructing petrified ICFG for 1 thread instances. [2024-05-07 09:58:45,665 INFO L144 ThreadInstanceAdder]: Constructed 2 joinOtherThreadTransitions. [2024-05-07 09:58:45,703 INFO L100 denceProviderFactory]: Independence Relation #1: [IndependenceType=SEMANTIC, AbstractionType=NONE, UseConditional=true, UseSemiCommutativity=true, Solver=Z3, SolverTimeout=1000ms] [2024-05-07 09:58:45,704 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true -t:1000 [2024-05-07 09:58:45,704 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:45,706 INFO L229 MonitoredProcess]: Starting monitored process 2 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true -t:1000 (exit command is (exit), workingDir is null) [2024-05-07 09:58:45,731 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true -t:1000 (2)] Waiting until timeout for monitored process [2024-05-07 09:58:45,742 INFO L188 artialOrderCegarLoop]: Running PartialOrderCegarLoop with 1 independence relations. [2024-05-07 09:58:45,750 INFO L160 PredicateUnifier]: Initialized classic predicate unifier [2024-05-07 09:58:45,752 INFO L356 AbstractCegarLoop]: ======== Iteration 0 == of CEGAR loop == AllErrorsAtOnce ======== [2024-05-07 09:58:45,757 INFO L357 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=PARTIAL_ORDER_FA, mHoareTripleChecks=INCREMENTAL, mHoareAnnotationPositions=LoopHeads, 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, mPorIndependenceSettings=[Lde.uni_freiburg.informatik.ultimate.lib.tracecheckerutils.partialorder.independence.IndependenceSettings;@3beee691, mLbeIndependenceSettings=[IndependenceType=SEMANTIC, AbstractionType=NONE, UseConditional=false, UseSemiCommutativity=true, Solver=Z3, SolverTimeout=1000ms], mConComChecker=DFS, mConComCheckerCriterion=RANDOM, mConComCheckerLimitedChecksCriterion=true, mConComCheckerCriterionLimit=10, mConComCheckerRandomProb=20, mConComCheckerRandomSeed=213, mConComCheckerConditionCriterion=false [2024-05-07 09:58:45,757 INFO L358 AbstractCegarLoop]: Starting to check reachability of 3 error locations. [2024-05-07 09:58:47,066 INFO L420 AbstractCegarLoop]: === Iteration 1 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES, ULTIMATE.startErr1INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES] === [2024-05-07 09:58:47,068 INFO L160 PredicateUnifier]: Initialized classic predicate unifier [2024-05-07 09:58:47,068 INFO L85 PathProgramCache]: Analyzing trace with hash -1610377654, now seen corresponding path program 1 times [2024-05-07 09:58:47,075 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-05-07 09:58:47,075 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1594457308] [2024-05-07 09:58:47,076 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:47,076 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:47,198 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2024-05-07 09:58:47,245 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2024-05-07 09:58:47,245 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1594457308] [2024-05-07 09:58:47,245 WARN L311 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: Unsupported non-linear arithmetic [2024-05-07 09:58:47,246 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1066736171] [2024-05-07 09:58:47,246 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:47,246 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:47,246 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:47,275 INFO L229 MonitoredProcess]: Starting monitored process 3 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2024-05-07 09:58:47,304 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Waiting until timeout for monitored process [2024-05-07 09:58:47,493 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2024-05-07 09:58:47,497 INFO L262 TraceCheckSpWp]: Trace formula consists of 487 conjuncts, 1 conjunts are in the unsatisfiable core [2024-05-07 09:58:47,508 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-05-07 09:58:47,534 INFO L134 CoverageAnalysis]: Checked inductivity of 26 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 26 trivial. 0 not checked. [2024-05-07 09:58:47,534 INFO L323 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2024-05-07 09:58:47,535 INFO L158 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1066736171] provided 1 perfect and 0 imperfect interpolant sequences [2024-05-07 09:58:47,535 INFO L185 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2024-05-07 09:58:47,535 INFO L198 FreeRefinementEngine]: Number of different interpolants: perfect sequences [2] imperfect sequences [] total 2 [2024-05-07 09:58:47,537 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [907172832] [2024-05-07 09:58:47,537 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2024-05-07 09:58:47,542 INFO L571 AbstractCegarLoop]: INTERPOLANT automaton has 2 states [2024-05-07 09:58:47,542 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2024-05-07 09:58:47,557 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 2 interpolants. [2024-05-07 09:58:47,558 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=1, Invalid=1, Unknown=0, NotChecked=0, Total=2 [2024-05-07 09:58:47,558 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:47,560 INFO L495 AbstractCegarLoop]: Abstraction has currently 0 states, but on-demand construction may add more states [2024-05-07 09:58:47,561 INFO L496 AbstractCegarLoop]: INTERPOLANT automaton has has 2 states, 2 states have (on average 100.5) internal successors, (201), 2 states have internal predecessors, (201), 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) [2024-05-07 09:58:47,561 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:47,692 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 0 stores, 1 select indices, 1 select index equivalence classes, 0 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 31 treesize of output 27 [2024-05-07 09:58:47,809 INFO L85 PathProgramCache]: Analyzing trace with hash 1409066055, now seen corresponding path program 1 times [2024-05-07 09:58:47,810 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:47,810 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:47,838 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:47,847 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Forceful destruction successful, exit code 0 [2024-05-07 09:58:48,044 WARN L477 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 3 /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable1,SelfDestructingSolverStorable0 [2024-05-07 09:58:48,045 INFO L420 AbstractCegarLoop]: === Iteration 2 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES, ULTIMATE.startErr1INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES] === [2024-05-07 09:58:48,045 INFO L160 PredicateUnifier]: Initialized classic predicate unifier [2024-05-07 09:58:48,045 INFO L85 PathProgramCache]: Analyzing trace with hash 1426262776, now seen corresponding path program 1 times [2024-05-07 09:58:48,046 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-05-07 09:58:48,046 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [635951946] [2024-05-07 09:58:48,046 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:48,046 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:48,096 ERROR L246 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2024-05-07 09:58:48,096 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [359785889] [2024-05-07 09:58:48,096 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:48,097 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:48,097 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:48,100 INFO L229 MonitoredProcess]: Starting monitored process 4 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2024-05-07 09:58:48,123 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Waiting until timeout for monitored process [2024-05-07 09:58:48,228 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2024-05-07 09:58:48,230 INFO L262 TraceCheckSpWp]: Trace formula consists of 467 conjuncts, 6 conjunts are in the unsatisfiable core [2024-05-07 09:58:48,246 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-05-07 09:58:48,419 INFO L134 CoverageAnalysis]: Checked inductivity of 26 backedges. 3 proven. 0 refuted. 0 times theorem prover too weak. 23 trivial. 0 not checked. [2024-05-07 09:58:48,420 INFO L323 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2024-05-07 09:58:48,420 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2024-05-07 09:58:48,420 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [635951946] [2024-05-07 09:58:48,420 WARN L311 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2024-05-07 09:58:48,420 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [359785889] [2024-05-07 09:58:48,421 INFO L158 FreeRefinementEngine]: IpTcStrategyModuleZ3 [359785889] provided 1 perfect and 0 imperfect interpolant sequences [2024-05-07 09:58:48,421 INFO L185 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2024-05-07 09:58:48,421 INFO L198 FreeRefinementEngine]: Number of different interpolants: perfect sequences [7] imperfect sequences [] total 7 [2024-05-07 09:58:48,421 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1777949351] [2024-05-07 09:58:48,421 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2024-05-07 09:58:48,424 INFO L571 AbstractCegarLoop]: INTERPOLANT automaton has 7 states [2024-05-07 09:58:48,424 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2024-05-07 09:58:48,425 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 7 interpolants. [2024-05-07 09:58:48,428 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=13, Invalid=29, Unknown=0, NotChecked=0, Total=42 [2024-05-07 09:58:48,428 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:48,429 INFO L495 AbstractCegarLoop]: Abstraction has currently 0 states, but on-demand construction may add more states [2024-05-07 09:58:48,430 INFO L496 AbstractCegarLoop]: INTERPOLANT automaton has has 7 states, 7 states have (on average 27.428571428571427) internal successors, (192), 7 states have internal predecessors, (192), 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) [2024-05-07 09:58:48,430 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:48,430 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:48,570 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:48,570 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:48,578 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Forceful destruction successful, exit code 0 [2024-05-07 09:58:48,778 WARN L477 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable2,4 /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:48,778 INFO L420 AbstractCegarLoop]: === Iteration 3 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES, ULTIMATE.startErr1INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES] === [2024-05-07 09:58:48,779 INFO L160 PredicateUnifier]: Initialized classic predicate unifier [2024-05-07 09:58:48,779 INFO L85 PathProgramCache]: Analyzing trace with hash -590941296, now seen corresponding path program 1 times [2024-05-07 09:58:48,779 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-05-07 09:58:48,779 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [794939526] [2024-05-07 09:58:48,779 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:48,780 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:48,801 ERROR L246 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2024-05-07 09:58:48,801 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1226039192] [2024-05-07 09:58:48,801 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:48,801 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:48,802 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:48,803 INFO L229 MonitoredProcess]: Starting monitored process 5 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2024-05-07 09:58:48,832 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (5)] Waiting until timeout for monitored process [2024-05-07 09:58:48,958 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2024-05-07 09:58:48,960 INFO L262 TraceCheckSpWp]: Trace formula consists of 511 conjuncts, 4 conjunts are in the unsatisfiable core [2024-05-07 09:58:48,963 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-05-07 09:58:49,056 INFO L134 CoverageAnalysis]: Checked inductivity of 28 backedges. 16 proven. 0 refuted. 0 times theorem prover too weak. 12 trivial. 0 not checked. [2024-05-07 09:58:49,057 INFO L323 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2024-05-07 09:58:49,057 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2024-05-07 09:58:49,057 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [794939526] [2024-05-07 09:58:49,057 WARN L311 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2024-05-07 09:58:49,057 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1226039192] [2024-05-07 09:58:49,057 INFO L158 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1226039192] provided 1 perfect and 0 imperfect interpolant sequences [2024-05-07 09:58:49,057 INFO L185 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2024-05-07 09:58:49,058 INFO L198 FreeRefinementEngine]: Number of different interpolants: perfect sequences [5] imperfect sequences [] total 5 [2024-05-07 09:58:49,058 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1742523145] [2024-05-07 09:58:49,058 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2024-05-07 09:58:49,058 INFO L571 AbstractCegarLoop]: INTERPOLANT automaton has 5 states [2024-05-07 09:58:49,058 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2024-05-07 09:58:49,059 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 5 interpolants. [2024-05-07 09:58:49,059 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=8, Invalid=12, Unknown=0, NotChecked=0, Total=20 [2024-05-07 09:58:49,059 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:49,059 INFO L495 AbstractCegarLoop]: Abstraction has currently 0 states, but on-demand construction may add more states [2024-05-07 09:58:49,059 INFO L496 AbstractCegarLoop]: INTERPOLANT automaton has has 5 states, 5 states have (on average 42.8) internal successors, (214), 5 states have internal predecessors, (214), 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) [2024-05-07 09:58:49,059 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:49,060 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:49,060 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:49,105 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:49,105 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:49,105 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2024-05-07 09:58:49,111 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (5)] Ended with exit code 0 [2024-05-07 09:58:49,311 WARN L477 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable3,5 /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:49,311 INFO L420 AbstractCegarLoop]: === Iteration 4 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES, ULTIMATE.startErr1INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES] === [2024-05-07 09:58:49,312 INFO L160 PredicateUnifier]: Initialized classic predicate unifier [2024-05-07 09:58:49,312 INFO L85 PathProgramCache]: Analyzing trace with hash -65961908, now seen corresponding path program 1 times [2024-05-07 09:58:49,312 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-05-07 09:58:49,312 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1916968527] [2024-05-07 09:58:49,312 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:49,312 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:49,363 ERROR L246 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2024-05-07 09:58:49,364 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [922352562] [2024-05-07 09:58:49,364 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:49,364 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:49,364 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:49,367 INFO L229 MonitoredProcess]: Starting monitored process 6 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2024-05-07 09:58:49,412 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (6)] Waiting until timeout for monitored process [2024-05-07 09:58:49,533 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2024-05-07 09:58:49,535 INFO L262 TraceCheckSpWp]: Trace formula consists of 583 conjuncts, 10 conjunts are in the unsatisfiable core [2024-05-07 09:58:49,538 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-05-07 09:58:49,755 INFO L134 CoverageAnalysis]: Checked inductivity of 29 backedges. 18 proven. 1 refuted. 0 times theorem prover too weak. 10 trivial. 0 not checked. [2024-05-07 09:58:49,755 INFO L327 TraceCheckSpWp]: Computing backward predicates... [2024-05-07 09:58:49,996 INFO L134 CoverageAnalysis]: Checked inductivity of 29 backedges. 18 proven. 1 refuted. 0 times theorem prover too weak. 10 trivial. 0 not checked. [2024-05-07 09:58:49,996 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2024-05-07 09:58:49,996 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1916968527] [2024-05-07 09:58:49,996 WARN L311 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2024-05-07 09:58:49,996 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [922352562] [2024-05-07 09:58:49,996 INFO L158 FreeRefinementEngine]: IpTcStrategyModuleZ3 [922352562] provided 0 perfect and 2 imperfect interpolant sequences [2024-05-07 09:58:49,997 INFO L185 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2024-05-07 09:58:49,997 INFO L198 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [11, 11] total 19 [2024-05-07 09:58:49,997 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [230404831] [2024-05-07 09:58:49,997 INFO L85 oduleStraightlineAll]: Using 2 imperfect interpolants to construct interpolant automaton [2024-05-07 09:58:49,997 INFO L571 AbstractCegarLoop]: INTERPOLANT automaton has 19 states [2024-05-07 09:58:49,997 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2024-05-07 09:58:49,998 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 19 interpolants. [2024-05-07 09:58:49,998 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=78, Invalid=264, Unknown=0, NotChecked=0, Total=342 [2024-05-07 09:58:49,998 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:49,999 INFO L495 AbstractCegarLoop]: Abstraction has currently 0 states, but on-demand construction may add more states [2024-05-07 09:58:49,999 INFO L496 AbstractCegarLoop]: INTERPOLANT automaton has has 19 states, 19 states have (on average 15.631578947368421) internal successors, (297), 19 states have internal predecessors, (297), 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) [2024-05-07 09:58:49,999 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:49,999 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:49,999 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 5 states. [2024-05-07 09:58:49,999 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:50,288 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:50,288 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:50,288 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2024-05-07 09:58:50,288 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2024-05-07 09:58:50,305 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (6)] Ended with exit code 0 [2024-05-07 09:58:50,494 WARN L477 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable4,6 /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:50,495 INFO L420 AbstractCegarLoop]: === Iteration 5 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES, ULTIMATE.startErr1INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES] === [2024-05-07 09:58:50,495 INFO L160 PredicateUnifier]: Initialized classic predicate unifier [2024-05-07 09:58:50,495 INFO L85 PathProgramCache]: Analyzing trace with hash -1840211228, now seen corresponding path program 2 times [2024-05-07 09:58:50,495 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-05-07 09:58:50,496 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [797096162] [2024-05-07 09:58:50,497 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:50,497 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:50,521 ERROR L246 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2024-05-07 09:58:50,521 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [2014475093] [2024-05-07 09:58:50,521 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2024-05-07 09:58:50,521 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:50,522 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:50,542 INFO L229 MonitoredProcess]: Starting monitored process 7 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2024-05-07 09:58:50,552 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (7)] Waiting until timeout for monitored process [2024-05-07 09:58:50,724 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2024-05-07 09:58:50,725 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2024-05-07 09:58:50,728 INFO L262 TraceCheckSpWp]: Trace formula consists of 627 conjuncts, 6 conjunts are in the unsatisfiable core [2024-05-07 09:58:50,732 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-05-07 09:58:50,825 INFO L134 CoverageAnalysis]: Checked inductivity of 47 backedges. 26 proven. 0 refuted. 0 times theorem prover too weak. 21 trivial. 0 not checked. [2024-05-07 09:58:50,825 INFO L323 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2024-05-07 09:58:50,826 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2024-05-07 09:58:50,826 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [797096162] [2024-05-07 09:58:50,826 WARN L311 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2024-05-07 09:58:50,826 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [2014475093] [2024-05-07 09:58:50,826 INFO L158 FreeRefinementEngine]: IpTcStrategyModuleZ3 [2014475093] provided 1 perfect and 0 imperfect interpolant sequences [2024-05-07 09:58:50,826 INFO L185 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2024-05-07 09:58:50,826 INFO L198 FreeRefinementEngine]: Number of different interpolants: perfect sequences [7] imperfect sequences [] total 7 [2024-05-07 09:58:50,826 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1595528328] [2024-05-07 09:58:50,827 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2024-05-07 09:58:50,827 INFO L571 AbstractCegarLoop]: INTERPOLANT automaton has 7 states [2024-05-07 09:58:50,827 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2024-05-07 09:58:50,828 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 7 interpolants. [2024-05-07 09:58:50,828 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=13, Invalid=29, Unknown=0, NotChecked=0, Total=42 [2024-05-07 09:58:50,828 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:50,828 INFO L495 AbstractCegarLoop]: Abstraction has currently 0 states, but on-demand construction may add more states [2024-05-07 09:58:50,828 INFO L496 AbstractCegarLoop]: INTERPOLANT automaton has has 7 states, 7 states have (on average 36.142857142857146) internal successors, (253), 7 states have internal predecessors, (253), 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) [2024-05-07 09:58:50,828 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:50,828 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:50,828 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 5 states. [2024-05-07 09:58:50,829 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 14 states. [2024-05-07 09:58:50,829 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:50,969 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:50,969 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:50,969 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2024-05-07 09:58:50,970 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2024-05-07 09:58:50,970 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 10 states. [2024-05-07 09:58:50,992 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (7)] Forceful destruction successful, exit code 0 [2024-05-07 09:58:51,176 WARN L477 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable5,7 /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:51,177 INFO L420 AbstractCegarLoop]: === Iteration 6 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES, ULTIMATE.startErr1INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES] === [2024-05-07 09:58:51,177 INFO L160 PredicateUnifier]: Initialized classic predicate unifier [2024-05-07 09:58:51,177 INFO L85 PathProgramCache]: Analyzing trace with hash 173938187, now seen corresponding path program 1 times [2024-05-07 09:58:51,177 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-05-07 09:58:51,177 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1042609169] [2024-05-07 09:58:51,177 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:51,178 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:51,198 ERROR L246 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2024-05-07 09:58:51,198 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1205727666] [2024-05-07 09:58:51,198 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:51,198 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:51,198 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:51,199 INFO L229 MonitoredProcess]: Starting monitored process 8 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2024-05-07 09:58:51,229 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (8)] Waiting until timeout for monitored process [2024-05-07 09:58:51,367 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2024-05-07 09:58:51,370 INFO L262 TraceCheckSpWp]: Trace formula consists of 653 conjuncts, 8 conjunts are in the unsatisfiable core [2024-05-07 09:58:51,374 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-05-07 09:58:51,457 INFO L134 CoverageAnalysis]: Checked inductivity of 58 backedges. 14 proven. 22 refuted. 0 times theorem prover too weak. 22 trivial. 0 not checked. [2024-05-07 09:58:51,458 INFO L327 TraceCheckSpWp]: Computing backward predicates... [2024-05-07 09:58:51,576 INFO L134 CoverageAnalysis]: Checked inductivity of 58 backedges. 15 proven. 21 refuted. 0 times theorem prover too weak. 22 trivial. 0 not checked. [2024-05-07 09:58:51,577 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2024-05-07 09:58:51,577 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1042609169] [2024-05-07 09:58:51,577 WARN L311 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2024-05-07 09:58:51,577 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1205727666] [2024-05-07 09:58:51,577 INFO L158 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1205727666] provided 0 perfect and 2 imperfect interpolant sequences [2024-05-07 09:58:51,577 INFO L185 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2024-05-07 09:58:51,577 INFO L198 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [9, 9] total 13 [2024-05-07 09:58:51,577 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [205760046] [2024-05-07 09:58:51,577 INFO L85 oduleStraightlineAll]: Using 2 imperfect interpolants to construct interpolant automaton [2024-05-07 09:58:51,578 INFO L571 AbstractCegarLoop]: INTERPOLANT automaton has 13 states [2024-05-07 09:58:51,578 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2024-05-07 09:58:51,579 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 13 interpolants. [2024-05-07 09:58:51,579 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=33, Invalid=123, Unknown=0, NotChecked=0, Total=156 [2024-05-07 09:58:51,579 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:51,579 INFO L495 AbstractCegarLoop]: Abstraction has currently 0 states, but on-demand construction may add more states [2024-05-07 09:58:51,579 INFO L496 AbstractCegarLoop]: INTERPOLANT automaton has has 13 states, 13 states have (on average 22.53846153846154) internal successors, (293), 13 states have internal predecessors, (293), 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) [2024-05-07 09:58:51,579 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:51,579 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:51,579 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 5 states. [2024-05-07 09:58:51,579 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 14 states. [2024-05-07 09:58:51,580 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 10 states. [2024-05-07 09:58:51,580 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:51,892 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:51,892 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:51,893 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2024-05-07 09:58:51,893 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2024-05-07 09:58:51,893 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 10 states. [2024-05-07 09:58:51,893 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 18 states. [2024-05-07 09:58:51,911 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (8)] Forceful destruction successful, exit code 0 [2024-05-07 09:58:52,099 WARN L477 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 8 /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable6 [2024-05-07 09:58:52,099 INFO L420 AbstractCegarLoop]: === Iteration 7 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES, ULTIMATE.startErr1INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES] === [2024-05-07 09:58:52,099 INFO L160 PredicateUnifier]: Initialized classic predicate unifier [2024-05-07 09:58:52,100 INFO L85 PathProgramCache]: Analyzing trace with hash -771055893, now seen corresponding path program 1 times [2024-05-07 09:58:52,100 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-05-07 09:58:52,100 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [671993248] [2024-05-07 09:58:52,100 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:52,100 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:52,120 ERROR L246 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2024-05-07 09:58:52,121 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [623326072] [2024-05-07 09:58:52,121 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:52,121 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:52,121 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:52,138 INFO L229 MonitoredProcess]: Starting monitored process 9 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2024-05-07 09:58:52,162 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (9)] Waiting until timeout for monitored process [2024-05-07 09:58:52,306 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2024-05-07 09:58:52,309 INFO L262 TraceCheckSpWp]: Trace formula consists of 649 conjuncts, 14 conjunts are in the unsatisfiable core [2024-05-07 09:58:52,313 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-05-07 09:58:52,588 INFO L134 CoverageAnalysis]: Checked inductivity of 48 backedges. 26 proven. 10 refuted. 0 times theorem prover too weak. 12 trivial. 0 not checked. [2024-05-07 09:58:52,588 INFO L327 TraceCheckSpWp]: Computing backward predicates... [2024-05-07 09:58:52,879 INFO L134 CoverageAnalysis]: Checked inductivity of 48 backedges. 26 proven. 10 refuted. 0 times theorem prover too weak. 12 trivial. 0 not checked. [2024-05-07 09:58:52,879 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2024-05-07 09:58:52,879 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [671993248] [2024-05-07 09:58:52,879 WARN L311 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2024-05-07 09:58:52,879 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [623326072] [2024-05-07 09:58:52,879 INFO L158 FreeRefinementEngine]: IpTcStrategyModuleZ3 [623326072] provided 0 perfect and 2 imperfect interpolant sequences [2024-05-07 09:58:52,879 INFO L185 FreeRefinementEngine]: Found 0 perfect and 2 imperfect interpolant sequences. [2024-05-07 09:58:52,879 INFO L198 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [15, 15] total 27 [2024-05-07 09:58:52,880 INFO L121 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1221347168] [2024-05-07 09:58:52,880 INFO L85 oduleStraightlineAll]: Using 2 imperfect interpolants to construct interpolant automaton [2024-05-07 09:58:52,880 INFO L571 AbstractCegarLoop]: INTERPOLANT automaton has 27 states [2024-05-07 09:58:52,880 INFO L100 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2024-05-07 09:58:52,881 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 27 interpolants. [2024-05-07 09:58:52,881 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=144, Invalid=558, Unknown=0, NotChecked=0, Total=702 [2024-05-07 09:58:52,881 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:52,881 INFO L495 AbstractCegarLoop]: Abstraction has currently 0 states, but on-demand construction may add more states [2024-05-07 09:58:52,882 INFO L496 AbstractCegarLoop]: INTERPOLANT automaton has has 27 states, 27 states have (on average 12.481481481481481) internal successors, (337), 27 states have internal predecessors, (337), 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) [2024-05-07 09:58:52,882 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:52,882 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:52,882 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 5 states. [2024-05-07 09:58:52,882 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 14 states. [2024-05-07 09:58:52,882 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 10 states. [2024-05-07 09:58:52,882 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 18 states. [2024-05-07 09:58:52,882 INFO L154 InterpolantAutomaton]: Switched to On-DemandConstruction mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:53,499 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 0 stores, 1 select indices, 1 select index equivalence classes, 0 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 1802 treesize of output 1706 [2024-05-07 09:58:55,807 INFO L85 PathProgramCache]: Analyzing trace with hash -1061625025, now seen corresponding path program 1 times [2024-05-07 09:58:55,807 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:55,808 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:55,837 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2024-05-07 09:58:55,838 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 7 states. [2024-05-07 09:58:55,838 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 5 states. [2024-05-07 09:58:55,838 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 14 states. [2024-05-07 09:58:55,838 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 10 states. [2024-05-07 09:58:55,838 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 18 states. [2024-05-07 09:58:55,838 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 18 states. [2024-05-07 09:58:55,844 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (9)] Ended with exit code 0 [2024-05-07 09:58:56,043 WARN L477 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable8,SelfDestructingSolverStorable7,9 /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:56,044 INFO L420 AbstractCegarLoop]: === Iteration 8 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES, ULTIMATE.startErr1INUSE_VIOLATIONSUFFICIENT_THREAD_INSTANCES] === [2024-05-07 09:58:56,044 INFO L160 PredicateUnifier]: Initialized classic predicate unifier [2024-05-07 09:58:56,045 INFO L85 PathProgramCache]: Analyzing trace with hash 2134717315, now seen corresponding path program 2 times [2024-05-07 09:58:56,045 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-05-07 09:58:56,045 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [337362457] [2024-05-07 09:58:56,045 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-05-07 09:58:56,045 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-05-07 09:58:56,071 ERROR L246 FreeRefinementEngine]: Caught known exception: Unsupported non-linear arithmetic [2024-05-07 09:58:56,071 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleZ3 [1016032093] [2024-05-07 09:58:56,071 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2024-05-07 09:58:56,071 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2024-05-07 09:58:56,071 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 [2024-05-07 09:58:56,072 INFO L229 MonitoredProcess]: Starting monitored process 10 with /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2024-05-07 09:58:56,075 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (10)] Waiting until timeout for monitored process [2024-05-07 09:58:56,572 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2024-05-07 09:58:56,572 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2024-05-07 09:58:56,577 INFO L262 TraceCheckSpWp]: Trace formula consists of 693 conjuncts, 124 conjunts are in the unsatisfiable core [2024-05-07 09:58:56,584 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-05-07 09:58:56,715 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 1, 1 stores, 0 select indices, 0 select index equivalence classes, 0 disjoint index pairs (out of 0 index pairs), introduced 0 new quantified variables, introduced 0 case distinctions, treesize of input 6 treesize of output 5 [2024-05-07 09:58:57,002 INFO L349 Elim1Store]: treesize reduction 18, result has 35.7 percent of original size [2024-05-07 09:58:57,002 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 1, 1 stores, 2 select indices, 2 select index equivalence classes, 0 disjoint index pairs (out of 1 index pairs), introduced 2 new quantified variables, introduced 2 case distinctions, treesize of input 17 treesize of output 21 [2024-05-07 09:58:57,553 INFO L349 Elim1Store]: treesize reduction 36, result has 34.5 percent of original size [2024-05-07 09:58:57,553 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 1, 1 stores, 3 select indices, 3 select index equivalence classes, 1 disjoint index pairs (out of 3 index pairs), introduced 3 new quantified variables, introduced 4 case distinctions, treesize of input 22 treesize of output 33 [2024-05-07 09:58:58,112 INFO L349 Elim1Store]: treesize reduction 12, result has 52.0 percent of original size [2024-05-07 09:58:58,112 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 1, 0 stores, 4 select indices, 4 select index equivalence classes, 3 disjoint index pairs (out of 6 index pairs), introduced 4 new quantified variables, introduced 3 case distinctions, treesize of input 21 treesize of output 25 [2024-05-07 09:58:58,597 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 0 select indices, 0 select index equivalence classes, 5 disjoint index pairs (out of 0 index pairs), introduced 0 new quantified variables, introduced 0 case distinctions, treesize of input 15 treesize of output 1 [2024-05-07 09:58:58,822 INFO L190 IndexEqualityManager]: detected not equals via solver [2024-05-07 09:58:58,822 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 1 select indices, 1 select index equivalence classes, 3 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 33 treesize of output 24 [2024-05-07 09:58:59,008 INFO L190 IndexEqualityManager]: detected not equals via solver [2024-05-07 09:58:59,009 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 1 select indices, 1 select index equivalence classes, 3 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 33 treesize of output 24 [2024-05-07 09:58:59,244 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 1 select indices, 1 select index equivalence classes, 3 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 15 treesize of output 15 [2024-05-07 09:58:59,253 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 1 select indices, 1 select index equivalence classes, 3 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 33 treesize of output 24 [2024-05-07 09:58:59,594 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 2 select indices, 2 select index equivalence classes, 3 disjoint index pairs (out of 1 index pairs), introduced 2 new quantified variables, introduced 0 case distinctions, treesize of input 31 treesize of output 18 [2024-05-07 09:58:59,608 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 1 select indices, 1 select index equivalence classes, 3 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 33 treesize of output 24 [2024-05-07 09:59:00,093 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 1 select indices, 1 select index equivalence classes, 1 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 16 treesize of output 11 [2024-05-07 09:59:00,108 INFO L349 Elim1Store]: treesize reduction 25, result has 21.9 percent of original size [2024-05-07 09:59:00,109 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 2 select indices, 2 select index equivalence classes, 5 disjoint index pairs (out of 1 index pairs), introduced 2 new quantified variables, introduced 1 case distinctions, treesize of input 42 treesize of output 21 [2024-05-07 09:59:00,117 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 1 select indices, 1 select index equivalence classes, 3 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 40 treesize of output 29 [2024-05-07 09:59:00,595 INFO L349 Elim1Store]: treesize reduction 19, result has 20.8 percent of original size [2024-05-07 09:59:00,596 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 1 select indices, 1 select index equivalence classes, 2 disjoint index pairs (out of 0 index pairs), introduced 2 new quantified variables, introduced 1 case distinctions, treesize of input 84 treesize of output 73 [2024-05-07 09:59:00,612 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 2 select indices, 2 select index equivalence classes, 6 disjoint index pairs (out of 1 index pairs), introduced 2 new quantified variables, introduced 0 case distinctions, treesize of input 39 treesize of output 33 [2024-05-07 09:59:00,624 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 1 stores, 1 select indices, 1 select index equivalence classes, 3 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 36 treesize of output 23 [2024-05-07 09:59:02,165 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 0 stores, 1 select indices, 1 select index equivalence classes, 2 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 51 treesize of output 31 [2024-05-07 09:59:02,169 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 0 stores, 1 select indices, 1 select index equivalence classes, 3 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 23 treesize of output 15 [2024-05-07 09:59:02,253 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 0 stores, 3 select indices, 3 select index equivalence classes, 3 disjoint index pairs (out of 3 index pairs), introduced 3 new quantified variables, introduced 0 case distinctions, treesize of input 37 treesize of output 13 [2024-05-07 09:59:02,408 INFO L134 CoverageAnalysis]: Checked inductivity of 82 backedges. 0 proven. 27 refuted. 0 times theorem prover too weak. 55 trivial. 0 not checked. [2024-05-07 09:59:02,408 INFO L327 TraceCheckSpWp]: Computing backward predicates... [2024-05-07 09:59:07,288 INFO L349 Elim1Store]: treesize reduction 0, result has 100.0 percent of original size [2024-05-07 09:59:07,288 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 0 stores, 2 select indices, 2 select index equivalence classes, 0 disjoint index pairs (out of 1 index pairs), introduced 2 new quantified variables, introduced 1 case distinctions, treesize of input 856 treesize of output 792 [2024-05-07 09:59:07,295 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 1, 0 stores, 1 select indices, 1 select index equivalence classes, 0 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 784 treesize of output 772 [2024-05-07 09:59:07,303 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 1, 0 stores, 1 select indices, 1 select index equivalence classes, 0 disjoint index pairs (out of 0 index pairs), introduced 1 new quantified variables, introduced 0 case distinctions, treesize of input 388 treesize of output 382 [2024-05-07 09:59:10,941 WARN L876 $PredicateComparison]: unable to prove that (let ((.cse4 (select (select |c_#memory_$Pointer$.base| c_~B~0.base) (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset)))) (let ((.cse14 (= .cse4 c_~B~0.base)) (.cse25 (= c_~B~0.base c_~A~0.base))) (let ((.cse15 (not .cse25)) (.cse19 (not .cse14)) (.cse7 (select |c_#memory_int| c_~F~0.base)) (.cse6 (* c_thread2Thread1of1ForFork1_~j~0 4)) (.cse8 (select |c_#memory_int| c_~A~0.base)) (.cse9 (+ c_~A~0.offset (* c_thread1Thread1of1ForFork0_~i~0 4))) (.cse10 (+ c_thread2Thread1of1ForFork1_~j~0 1))) (and (or (and (forall ((~M~0 Int)) (or (forall ((~b~0 Int)) (or (< ~b~0 0) (< ~M~0 (+ ~b~0 1)) (forall ((~a~0 Int)) (or (< ~a~0 0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse1 (* ~b~0 4)) (.cse3 (let ((.cse5 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse5 .cse4 (store (select .cse5 .cse4) (+ .cse6 v_arrayElimCell_33) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (let ((.cse0 (select .cse3 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse2 (select (select .cse3 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse1)))) (or (forall ((v_arrayElimCell_34 Int)) (= (select .cse0 (+ .cse1 v_arrayElimCell_34)) .cse2)) (= (select .cse0 (+ .cse1 v_arrayElimCell_35)) .cse2))))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0))))) (< .cse10 ~M~0))) (or (forall ((~a~0 Int) (~b~0 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< .cse10 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (let ((.cse11 (let ((.cse13 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse13 .cse4 (store (select .cse13 .cse4) (+ .cse6 v_arrayElimCell_33) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse12 (* ~b~0 4))) (= (select (select .cse11 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse12 v_arrayElimCell_35)) (select (select .cse11 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse12)))))) .cse14)) .cse15) (or (forall ((~a~0 Int) (~b~0 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< .cse10 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (let ((.cse16 (let ((.cse18 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse18 .cse4 (store (select .cse18 .cse4) (+ .cse6 v_arrayElimCell_33) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse17 (* ~b~0 4))) (= (select (select .cse16 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse17 v_arrayElimCell_34)) (select (select .cse16 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse17)))))) .cse19) (or (forall ((~a~0 Int) (~b~0 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse21 (* ~b~0 4)) (.cse23 (let ((.cse24 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse24 .cse4 (store (select .cse24 .cse4) (+ .cse6 v_arrayElimCell_33) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (let ((.cse20 (select .cse23 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse22 (select (select .cse23 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse21)))) (or (< ~b~0 0) (< ~a~0 0) (< .cse10 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= (select .cse20 (+ .cse21 v_arrayElimCell_35)) .cse22) (= (select .cse20 (+ .cse21 v_arrayElimCell_34)) .cse22))))) .cse19) (or (and (or .cse25 (forall ((~a~0 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< .cse10 ~M~0) (let ((.cse26 (let ((.cse28 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse28 .cse4 (store (select .cse28 .cse4) (+ .cse6 v_arrayElimCell_32) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse27 (* ~b~0 4))) (= (select (select .cse26 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse27)) (select (select .cse26 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse27 v_arrayElimCell_33)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))) (forall ((~M~0 Int)) (or (forall ((~b~0 Int)) (or (< ~b~0 0) (forall ((~a~0 Int)) (or (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse32 (let ((.cse33 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse33 .cse4 (store (select .cse33 .cse4) (+ .cse6 v_arrayElimCell_32) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse31 (* ~b~0 4))) (let ((.cse29 (select (select .cse32 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse31))) (.cse30 (select .cse32 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (= .cse29 (select .cse30 (+ .cse31 v_arrayElimCell_33))) (forall ((v_arrayElimCell_35 Int)) (= .cse29 (select .cse30 (+ .cse31 v_arrayElimCell_35)))))))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) (< ~M~0 (+ ~b~0 1)))) (< .cse10 ~M~0)))) .cse14) (or (and (or .cse14 (forall ((~a~0 Int) (~b~0 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (let ((.cse34 (let ((.cse36 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse36 .cse4 (store (select .cse36 .cse4) (+ .cse6 v_arrayElimCell_32) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse35 (* ~b~0 4))) (= (select (select .cse34 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse35)) (select (select .cse34 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse35 v_arrayElimCell_35)))) (< ~a~0 0) (< .cse10 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))) (forall ((~M~0 Int)) (or (< .cse10 ~M~0) (forall ((~b~0 Int)) (or (forall ((~a~0 Int)) (or (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int)) (let ((.cse40 (let ((.cse41 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse41 .cse4 (store (select .cse41 .cse4) (+ .cse6 v_arrayElimCell_32) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse39 (* ~b~0 4))) (let ((.cse37 (select (select .cse40 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse39))) (.cse38 (select .cse40 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (= .cse37 (select .cse38 (+ .cse39 v_arrayElimCell_35))) (forall ((v_arrayElimCell_34 Int)) (= .cse37 (select .cse38 (+ .cse39 v_arrayElimCell_34)))))))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) (< ~b~0 0) (< ~M~0 (+ ~b~0 1))))))) .cse15) (or (forall ((~a~0 Int) (~b~0 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse45 (let ((.cse46 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse46 .cse4 (store (select .cse46 .cse4) (+ .cse6 v_arrayElimCell_32) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse44 (* ~b~0 4))) (let ((.cse42 (select (select .cse45 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse44))) (.cse43 (select .cse45 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= .cse42 (select .cse43 (+ .cse44 v_arrayElimCell_35))) (< ~a~0 0) (< .cse10 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse42 (select .cse43 (+ .cse44 v_arrayElimCell_34))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))))) .cse19) (forall ((~M~0 Int)) (or (< .cse10 ~M~0) (forall ((~b~0 Int)) (or (< ~b~0 0) (< ~M~0 (+ ~b~0 1)) (forall ((~a~0 Int)) (or (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse48 (* ~b~0 4)) (.cse50 (let ((.cse51 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse51 .cse4 (store (select .cse51 .cse4) (+ .cse6 v_arrayElimCell_33) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (let ((.cse47 (select .cse50 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse49 (select (select .cse50 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse48)))) (or (= (select .cse47 (+ .cse48 v_arrayElimCell_33)) .cse49) (= (select .cse47 (+ .cse48 v_arrayElimCell_35)) .cse49) (= (select .cse47 (+ .cse48 v_arrayElimCell_34)) .cse49))))))))))) (or .cse14 (and (or .cse25 (forall ((~a~0 Int) (~b~0 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse52 (let ((.cse54 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse54 .cse4 (store (select .cse54 .cse4) (+ .cse6 v_arrayElimCell_33) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse53 (* ~b~0 4))) (= (select (select .cse52 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse53 v_arrayElimCell_33)) (select (select .cse52 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse53)))) (< ~a~0 0) (< .cse10 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1))))) (forall ((~M~0 Int)) (or (< .cse10 ~M~0) (forall ((~b~0 Int)) (or (< ~b~0 0) (< ~M~0 (+ ~b~0 1)) (forall ((~a~0 Int)) (or (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse56 (* ~b~0 4)) (.cse58 (let ((.cse59 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse59 .cse4 (store (select .cse59 .cse4) (+ .cse6 v_arrayElimCell_33) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (let ((.cse55 (select .cse58 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse57 (select (select .cse58 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse56)))) (or (= (select .cse55 (+ .cse56 v_arrayElimCell_33)) .cse57) (forall ((v_arrayElimCell_35 Int)) (= (select .cse55 (+ .cse56 v_arrayElimCell_35)) .cse57)))))))))))))) (or .cse19 (forall ((~a~0 Int) (~b~0 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (< ~a~0 0) (< .cse10 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse60 (let ((.cse62 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse62 .cse4 (store (select .cse62 .cse4) (+ .cse6 v_arrayElimCell_32) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse61 (* ~b~0 4))) (= (select (select .cse60 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse61)) (select (select .cse60 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse61 v_arrayElimCell_34)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))) (forall ((~M~0 Int)) (or (forall ((~b~0 Int)) (or (< ~b~0 0) (forall ((~a~0 Int)) (or (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse66 (let ((.cse67 (store |c_#memory_int| c_~A~0.base (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse67 .cse4 (store (select .cse67 .cse4) (+ .cse6 v_arrayElimCell_32) (select .cse7 (+ .cse6 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse65 (* ~b~0 4))) (let ((.cse63 (select (select .cse66 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse65))) (.cse64 (select .cse66 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse4 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (= .cse63 (select .cse64 (+ .cse65 v_arrayElimCell_35))) (= .cse63 (select .cse64 (+ .cse65 v_arrayElimCell_33))) (= .cse63 (select .cse64 (+ .cse65 v_arrayElimCell_34))))))))) (< ~M~0 (+ ~b~0 1)))) (< .cse10 ~M~0))))))) is different from true [2024-05-07 09:59:15,311 WARN L876 $PredicateComparison]: unable to prove that (let ((.cse6 (select (select |c_#memory_$Pointer$.base| c_~B~0.base) (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset)))) (let ((.cse34 (= .cse6 c_~B~0.base)) (.cse25 (= c_~B~0.base c_~A~0.base))) (let ((.cse43 (not .cse25)) (.cse0 (+ c_thread2Thread1of1ForFork1_~j~0 1)) (.cse4 (+ |c_thread1Thread1of1ForFork0_#t~post1| 1)) (.cse9 (select |c_#memory_int| c_~F~0.base)) (.cse8 (* c_thread2Thread1of1ForFork1_~j~0 4)) (.cse10 (select |c_#memory_int| c_~A~0.base)) (.cse11 (not .cse34))) (and (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse5 (let ((.cse7 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse7 .cse6 (store (select .cse7 .cse6) (+ .cse8 v_arrayElimCell_33) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse3 (* ~b~0 4))) (let ((.cse1 (select (select .cse5 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse3))) (.cse2 (select .cse5 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< ~a~0 0) (< .cse0 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse1 (select .cse2 (+ .cse3 v_arrayElimCell_35))) (= .cse1 (select .cse2 (+ .cse3 v_arrayElimCell_34))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4))))) .cse11) (forall ((v_thread1Thread1of1ForFork0_~i~0_40 Int)) (or (forall ((~M~0 Int)) (or (< .cse0 ~M~0) (forall ((~b~0 Int)) (or (< ~b~0 0) (forall ((~a~0 Int)) (or (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse15 (let ((.cse16 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse16 .cse6 (store (select .cse16 .cse6) (+ .cse8 v_arrayElimCell_33) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse14 (* ~b~0 4))) (let ((.cse12 (select (select .cse15 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse14))) (.cse13 (select .cse15 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (= .cse12 (select .cse13 (+ .cse14 v_arrayElimCell_35))) (= .cse12 (select .cse13 (+ .cse14 v_arrayElimCell_34))) (= .cse12 (select .cse13 (+ .cse14 v_arrayElimCell_33))))))))) (< ~M~0 (+ ~b~0 1)))))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4))) (or .cse11 (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< .cse0 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse17 (let ((.cse19 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse19 .cse6 (store (select .cse19 .cse6) (+ .cse8 v_arrayElimCell_33) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse18 (* ~b~0 4))) (= (select (select .cse17 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse18)) (select (select .cse17 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse18 v_arrayElimCell_34)))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4)))) (forall ((v_thread1Thread1of1ForFork0_~i~0_40 Int)) (or (forall ((~M~0 Int)) (or (< .cse0 ~M~0) (forall ((~b~0 Int)) (or (< ~b~0 0) (forall ((~a~0 Int)) (or (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse23 (let ((.cse24 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse24 .cse6 (store (select .cse24 .cse6) (+ .cse8 v_arrayElimCell_32) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse22 (* ~b~0 4))) (let ((.cse20 (select (select .cse23 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse22))) (.cse21 (select .cse23 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (= .cse20 (select .cse21 (+ .cse22 v_arrayElimCell_34))) (= (select .cse21 (+ .cse22 v_arrayElimCell_35)) .cse20) (= .cse20 (select .cse21 (+ .cse22 v_arrayElimCell_33))))))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) (< ~M~0 (+ ~b~0 1)))))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4))) (or (and (or .cse25 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< .cse0 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (let ((.cse26 (let ((.cse28 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse28 .cse6 (store (select .cse28 .cse6) (+ .cse8 v_arrayElimCell_32) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse27 (* ~b~0 4))) (= (select (select .cse26 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse27)) (select (select .cse26 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse27 v_arrayElimCell_33)))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))) (forall ((v_thread1Thread1of1ForFork0_~i~0_40 Int)) (or (forall ((~M~0 Int)) (or (< .cse0 ~M~0) (forall ((~b~0 Int)) (or (< ~b~0 0) (< ~M~0 (+ ~b~0 1)) (forall ((~a~0 Int)) (or (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse32 (let ((.cse33 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse33 .cse6 (store (select .cse33 .cse6) (+ .cse8 v_arrayElimCell_32) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse30 (* ~b~0 4))) (let ((.cse31 (select (select .cse32 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse30))) (.cse29 (select .cse32 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (forall ((v_arrayElimCell_35 Int)) (= (select .cse29 (+ .cse30 v_arrayElimCell_35)) .cse31)) (= .cse31 (select .cse29 (+ .cse30 v_arrayElimCell_33))))))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))))))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4)))) .cse34) (or (and (forall ((v_thread1Thread1of1ForFork0_~i~0_40 Int)) (or (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (forall ((~M~0 Int)) (or (< .cse0 ~M~0) (forall ((~b~0 Int)) (or (< ~b~0 0) (forall ((~a~0 Int)) (or (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int)) (let ((.cse37 (* ~b~0 4)) (.cse38 (let ((.cse39 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse39 .cse6 (store (select .cse39 .cse6) (+ .cse8 v_arrayElimCell_32) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (let ((.cse36 (select .cse38 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse35 (select (select .cse38 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse37)))) (or (forall ((v_arrayElimCell_34 Int)) (= .cse35 (select .cse36 (+ .cse37 v_arrayElimCell_34)))) (= (select .cse36 (+ .cse37 v_arrayElimCell_35)) .cse35))))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) (< ~M~0 (+ ~b~0 1)))))))) (or (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< ~a~0 0) (< .cse0 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse40 (let ((.cse42 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse42 .cse6 (store (select .cse42 .cse6) (+ .cse8 v_arrayElimCell_32) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse41 (* ~b~0 4))) (= (select (select .cse40 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse41 v_arrayElimCell_35)) (select (select .cse40 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse41)))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) .cse34)) .cse43) (or (and (forall ((v_thread1Thread1of1ForFork0_~i~0_40 Int)) (or (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (forall ((~M~0 Int)) (or (< .cse0 ~M~0) (forall ((~b~0 Int)) (or (< ~b~0 0) (< ~M~0 (+ ~b~0 1)) (forall ((~a~0 Int)) (or (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse47 (let ((.cse48 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse48 .cse6 (store (select .cse48 .cse6) (+ .cse8 v_arrayElimCell_33) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse46 (* ~b~0 4))) (let ((.cse44 (select (select .cse47 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse46))) (.cse45 (select .cse47 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (= .cse44 (select .cse45 (+ .cse46 v_arrayElimCell_35))) (forall ((v_arrayElimCell_34 Int)) (= .cse44 (select .cse45 (+ .cse46 v_arrayElimCell_34)))))))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0))))))))) (or (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< .cse0 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse49 (let ((.cse51 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse51 .cse6 (store (select .cse51 .cse6) (+ .cse8 v_arrayElimCell_33) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse50 (* ~b~0 4))) (= (select (select .cse49 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse50)) (select (select .cse49 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse50 v_arrayElimCell_35)))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4))) .cse34)) .cse43) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (let ((.cse52 (let ((.cse54 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse54 .cse6 (store (select .cse54 .cse6) (+ .cse8 v_arrayElimCell_32) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse53 (* ~b~0 4))) (= (select (select .cse52 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse53)) (select (select .cse52 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse53 v_arrayElimCell_34)))) (< ~b~0 0) (< ~a~0 0) (< .cse0 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) .cse11) (or (and (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< .cse0 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (let ((.cse55 (let ((.cse57 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse57 .cse6 (store (select .cse57 .cse6) (+ .cse8 v_arrayElimCell_33) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse56 (* ~b~0 4))) (= (select (select .cse55 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse56)) (select (select .cse55 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse56 v_arrayElimCell_33)))))) .cse25) (forall ((v_thread1Thread1of1ForFork0_~i~0_40 Int)) (or (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (forall ((~M~0 Int)) (or (forall ((~b~0 Int)) (or (< ~b~0 0) (forall ((~a~0 Int)) (or (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse61 (let ((.cse62 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse62 .cse6 (store (select .cse62 .cse6) (+ .cse8 v_arrayElimCell_33) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse60 (* ~b~0 4))) (let ((.cse58 (select (select .cse61 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse60))) (.cse59 (select .cse61 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (forall ((v_arrayElimCell_35 Int)) (= .cse58 (select .cse59 (+ .cse60 v_arrayElimCell_35)))) (= .cse58 (select .cse59 (+ .cse60 v_arrayElimCell_33))))))))) (< ~M~0 (+ ~b~0 1)))) (< .cse0 ~M~0)))))) .cse34) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse65 (* ~b~0 4)) (.cse66 (let ((.cse67 (store |c_#memory_int| c_~A~0.base (store .cse10 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse67 .cse6 (store (select .cse67 .cse6) (+ .cse8 v_arrayElimCell_32) (select .cse9 (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (let ((.cse64 (select .cse66 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse63 (select (select .cse66 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse65)))) (or (= .cse63 (select .cse64 (+ .cse65 v_arrayElimCell_34))) (< ~b~0 0) (< ~a~0 0) (< .cse0 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse64 (+ .cse65 v_arrayElimCell_35)) .cse63) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))))) .cse11))))) is different from true [2024-05-07 09:59:18,374 WARN L876 $PredicateComparison]: unable to prove that (let ((.cse8 (select (select |c_#memory_$Pointer$.base| c_~B~0.base) (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset)))) (let ((.cse16 (= c_~B~0.base c_~A~0.base)) (.cse17 (= .cse8 c_~B~0.base)) (.cse2 (+ c_thread1Thread1of1ForFork0_~i~0 1)) (.cse3 (+ c_thread2Thread1of1ForFork1_~j~0 1)) (.cse11 (select |c_#memory_int| c_~F~0.base)) (.cse10 (* c_thread2Thread1of1ForFork1_~j~0 4)) (.cse12 (select |c_#memory_int| c_~A~0.base))) (let ((.cse0 (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse58 (let ((.cse59 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse59 .cse8 (store (select .cse59 .cse8) (+ .cse10 v_arrayElimCell_33) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse57 (* ~b~0 4))) (let ((.cse55 (select (select .cse58 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse57))) (.cse56 (select .cse58 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse55 (select .cse56 (+ .cse57 v_arrayElimCell_35))) (= .cse55 (select .cse56 (+ .cse57 v_arrayElimCell_34))) (< ~M~0 (+ ~b~0 1))))))) (.cse1 (not .cse17)) (.cse26 (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse52 (* ~b~0 4)) (.cse53 (let ((.cse54 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse54 .cse8 (store (select .cse54 .cse8) (+ .cse10 v_arrayElimCell_32) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (let ((.cse51 (select .cse53 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse50 (select (select .cse53 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse52)))) (or (= .cse50 (select .cse51 (+ .cse52 v_arrayElimCell_34))) (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse51 (+ .cse52 v_arrayElimCell_35)) .cse50) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))))) (.cse35 (not .cse16))) (and (or .cse0 .cse1) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse7 (let ((.cse9 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse9 .cse8 (store (select .cse9 .cse8) (+ .cse10 v_arrayElimCell_32) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse5 (* ~b~0 4))) (let ((.cse6 (select (select .cse7 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse5))) (.cse4 (select .cse7 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse4 (+ .cse5 v_arrayElimCell_35)) .cse6) (< ~M~0 (+ ~b~0 1)) (= .cse6 (select .cse4 (+ .cse5 v_arrayElimCell_33))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (let ((.cse13 (let ((.cse15 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse15 .cse8 (store (select .cse15 .cse8) (+ .cse10 v_arrayElimCell_32) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse14 (* ~b~0 4))) (= (select (select .cse13 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse14)) (select (select .cse13 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse14 v_arrayElimCell_33)))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) .cse16)) .cse17) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse21 (let ((.cse22 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse22 .cse8 (store (select .cse22 .cse8) (+ .cse10 v_arrayElimCell_33) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse20 (* ~b~0 4))) (let ((.cse18 (select (select .cse21 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse20))) (.cse19 (select .cse21 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse18 (select .cse19 (+ .cse20 v_arrayElimCell_35))) (= .cse18 (select .cse19 (+ .cse20 v_arrayElimCell_34))) (< ~M~0 (+ ~b~0 1)) (= .cse18 (select .cse19 (+ .cse20 v_arrayElimCell_33))))))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (let ((.cse23 (let ((.cse25 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse25 .cse8 (store (select .cse25 .cse8) (+ .cse10 v_arrayElimCell_32) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse24 (* ~b~0 4))) (= (select (select .cse23 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse24)) (select (select .cse23 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse24 v_arrayElimCell_34)))) (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) .cse1) (or .cse26 .cse1) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse30 (let ((.cse31 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse31 .cse8 (store (select .cse31 .cse8) (+ .cse10 v_arrayElimCell_32) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse29 (* ~b~0 4))) (let ((.cse27 (select (select .cse30 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse29))) (.cse28 (select .cse30 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (= .cse27 (select .cse28 (+ .cse29 v_arrayElimCell_34))) (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse28 (+ .cse29 v_arrayElimCell_35)) .cse27) (< ~M~0 (+ ~b~0 1)) (= .cse27 (select .cse28 (+ .cse29 v_arrayElimCell_33))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))))) (or (and (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse32 (let ((.cse34 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse34 .cse8 (store (select .cse34 .cse8) (+ .cse10 v_arrayElimCell_33) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse33 (* ~b~0 4))) (= (select (select .cse32 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse33)) (select (select .cse32 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse33 v_arrayElimCell_35)))) (< ~M~0 (+ ~b~0 1)))) .cse17) .cse0) .cse35) (or (and (or .cse16 (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (let ((.cse36 (let ((.cse38 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse38 .cse8 (store (select .cse38 .cse8) (+ .cse10 v_arrayElimCell_33) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse37 (* ~b~0 4))) (= (select (select .cse36 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse37)) (select (select .cse36 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse37 v_arrayElimCell_33))))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse42 (let ((.cse43 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse43 .cse8 (store (select .cse43 .cse8) (+ .cse10 v_arrayElimCell_33) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse41 (* ~b~0 4))) (let ((.cse39 (select (select .cse42 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse41))) (.cse40 (select .cse42 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse39 (select .cse40 (+ .cse41 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (= .cse39 (select .cse40 (+ .cse41 v_arrayElimCell_33)))))))) .cse17) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse44 (let ((.cse46 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse46 .cse8 (store (select .cse46 .cse8) (+ .cse10 v_arrayElimCell_33) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse45 (* ~b~0 4))) (= (select (select .cse44 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse45)) (select (select .cse44 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse45 v_arrayElimCell_34)))) (< ~M~0 (+ ~b~0 1)))) .cse1) (or (and .cse26 (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse2) (< ~a~0 0) (< .cse3 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse47 (let ((.cse49 (store |c_#memory_int| c_~A~0.base (store .cse12 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) |thread1Thread1of1ForFork0_#t~mem2|)))) (store .cse49 .cse8 (store (select .cse49 .cse8) (+ .cse10 v_arrayElimCell_32) (select .cse11 (+ .cse10 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))) (.cse48 (* ~b~0 4))) (= (select (select .cse47 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse8 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse48 v_arrayElimCell_35)) (select (select .cse47 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse48)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) .cse17)) .cse35))))) is different from true [2024-05-07 09:59:20,867 WARN L854 $PredicateComparison]: unable to prove that (let ((.cse18 (= c_~B~0.base c_~A~0.base))) (let ((.cse43 (not .cse18)) (.cse0 (+ c_thread1Thread1of1ForFork0_~i~0 1)) (.cse1 (+ c_thread2Thread1of1ForFork1_~j~0 1)) (.cse8 (* c_thread2Thread1of1ForFork1_~j~0 4)) (.cse10 (select |c_#memory_int| c_~A~0.base)) (.cse11 (+ c_~A~0.offset (* c_thread1Thread1of1ForFork0_~i~0 4))) (.cse12 (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset))) (and (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse6 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_5 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse3 (* ~b~0 4)) (.cse5 (let ((.cse9 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse7 (store |c_#memory_int| c_~A~0.base (store .cse9 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_5)))) (store .cse7 .cse6 (store (select .cse7 .cse6) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse9) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse2 (select .cse5 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse4 (select (select .cse5 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse3)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse2 (+ .cse3 v_arrayElimCell_35)) .cse4) (< ~M~0 (+ ~b~0 1)) (= (select .cse2 (+ .cse3 v_arrayElimCell_33)) .cse4))))) (= c_~B~0.base .cse6)))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse15 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_subst_8 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse13 (let ((.cse17 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse16 (store |c_#memory_int| c_~A~0.base (store .cse17 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_8)))) (store .cse16 .cse15 (store (select .cse16 .cse15) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse17) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse14 (* ~b~0 4))) (= (select (select .cse13 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse14)) (select (select .cse13 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse15 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse14 v_arrayElimCell_34)))) (< ~M~0 (+ ~b~0 1)))) (not (= c_~B~0.base .cse15))))) (or .cse18 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_6 Int) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse19 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse19) (< ~M~0 (+ ~b~0 1)) (let ((.cse20 (let ((.cse23 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse22 (store |c_#memory_int| c_~A~0.base (store .cse23 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_6)))) (store .cse22 .cse19 (store (select .cse22 .cse19) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse23) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse21 (* ~b~0 4))) (= (select (select .cse20 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse19 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse21 v_arrayElimCell_33)) (select (select .cse20 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse21)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse24 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (not (= c_~B~0.base .cse24)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_subst_1 Int) (v_arrayElimCell_34 Int)) (let ((.cse28 (let ((.cse30 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse29 (store |c_#memory_int| c_~A~0.base (store .cse30 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse29 .cse24 (store (select .cse29 .cse24) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse30) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse27 (* ~b~0 4))) (let ((.cse25 (select (select .cse28 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse27))) (.cse26 (select .cse28 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse24 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (= .cse25 (select .cse26 (+ .cse27 v_arrayElimCell_34))) (< .cse1 ~M~0) (= .cse25 (select .cse26 (+ .cse27 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))))))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_1 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse35 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (let ((.cse34 (let ((.cse37 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse36 (store |c_#memory_int| c_~A~0.base (store .cse37 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse36 .cse35 (store (select .cse36 .cse35) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse37) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse33 (* ~b~0 4))) (let ((.cse31 (select (select .cse34 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse33))) (.cse32 (select .cse34 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse35 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (= .cse31 (select .cse32 (+ .cse33 v_arrayElimCell_34))) (< .cse1 ~M~0) (= .cse31 (select .cse32 (+ .cse33 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse39 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_2 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (let ((.cse38 (let ((.cse42 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse41 (store |c_#memory_int| c_~A~0.base (store .cse42 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_2)))) (store .cse41 .cse39 (store (select .cse41 .cse39) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse42) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse40 (* ~b~0 4))) (= (select (select .cse38 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse39 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse40 v_arrayElimCell_35)) (select (select .cse38 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse40)))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) (= c_~B~0.base .cse39))))) .cse43) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_10 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse48 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (let ((.cse47 (let ((.cse50 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse49 (store |c_#memory_int| c_~A~0.base (store .cse50 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_10)))) (store .cse49 .cse48 (store (select .cse49 .cse48) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse50) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse46 (* ~b~0 4))) (let ((.cse44 (select (select .cse47 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse46))) (.cse45 (select .cse47 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse48 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= .cse44 (select .cse45 (+ .cse46 v_arrayElimCell_34))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (= .cse44 (select .cse45 (+ .cse46 v_arrayElimCell_35))) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= .cse44 (select .cse45 (+ .cse46 v_arrayElimCell_33))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_subst_9 Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse55 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (let ((.cse52 (* ~b~0 4)) (.cse54 (let ((.cse57 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse56 (store |c_#memory_int| c_~A~0.base (store .cse57 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_9)))) (store .cse56 .cse55 (store (select .cse56 .cse55) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse57) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse51 (select .cse54 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse55 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse53 (select (select .cse54 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse52)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (= (select .cse51 (+ .cse52 v_arrayElimCell_33)) .cse53) (= .cse53 (select .cse51 (+ .cse52 v_arrayElimCell_34))) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse51 (+ .cse52 v_arrayElimCell_35)) .cse53) (< ~M~0 (+ ~b~0 1))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse62 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_3 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse61 (let ((.cse64 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse63 (store |c_#memory_int| c_~A~0.base (store .cse64 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse63 .cse62 (store (select .cse63 .cse62) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse64) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse59 (* ~b~0 4))) (let ((.cse60 (select (select .cse61 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse59))) (.cse58 (select .cse61 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse62 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse58 (+ .cse59 v_arrayElimCell_35)) .cse60) (< ~M~0 (+ ~b~0 1)) (= .cse60 (select .cse58 (+ .cse59 v_arrayElimCell_34))))))) (not (= c_~B~0.base .cse62))))) (or (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_11 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse65 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse65) (let ((.cse66 (let ((.cse69 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse68 (store |c_#memory_int| c_~A~0.base (store .cse69 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_11)))) (store .cse68 .cse65 (store (select .cse68 .cse65) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse69) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse67 (* ~b~0 4))) (= (select (select .cse66 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse67)) (select (select .cse66 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse65 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse67 v_arrayElimCell_33)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))) .cse18) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse74 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_12 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse72 (* ~b~0 4)) (.cse73 (let ((.cse76 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse75 (store |c_#memory_int| c_~A~0.base (store .cse76 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_12)))) (store .cse75 .cse74 (store (select .cse75 .cse74) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse76) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse71 (select .cse73 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse74 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse70 (select (select .cse73 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse72)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= .cse70 (select .cse71 (+ .cse72 v_arrayElimCell_35))) (= (select .cse71 (+ .cse72 v_arrayElimCell_33)) .cse70) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))))) (= c_~B~0.base .cse74)))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_3 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse81 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (let ((.cse80 (let ((.cse83 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse82 (store |c_#memory_int| c_~A~0.base (store .cse83 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse82 .cse81 (store (select .cse82 .cse81) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse83) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse78 (* ~b~0 4))) (let ((.cse79 (select (select .cse80 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse78))) (.cse77 (select .cse80 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse81 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse77 (+ .cse78 v_arrayElimCell_35)) .cse79) (< ~M~0 (+ ~b~0 1)) (= .cse79 (select .cse77 (+ .cse78 v_arrayElimCell_34)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse85 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_7 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse84 (let ((.cse88 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse87 (store |c_#memory_int| c_~A~0.base (store .cse88 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_7)))) (store .cse87 .cse85 (store (select .cse87 .cse85) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse88) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse86 (* ~b~0 4))) (= (select (select .cse84 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse85 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse86 v_arrayElimCell_35)) (select (select .cse84 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse86)))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)))) (= c_~B~0.base .cse85))))) .cse43) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse90 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_subst_4 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse89 (let ((.cse93 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse92 (store |c_#memory_int| c_~A~0.base (store .cse93 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_4)))) (store .cse92 .cse90 (store (select .cse92 .cse90) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse93) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse91 (* ~b~0 4))) (= (select (select .cse89 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse90 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse91 v_arrayElimCell_34)) (select (select .cse89 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse91)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) (not (= c_~B~0.base .cse90)))))))) is different from false [2024-05-07 09:59:22,914 WARN L876 $PredicateComparison]: unable to prove that (let ((.cse18 (= c_~B~0.base c_~A~0.base))) (let ((.cse43 (not .cse18)) (.cse0 (+ c_thread1Thread1of1ForFork0_~i~0 1)) (.cse1 (+ c_thread2Thread1of1ForFork1_~j~0 1)) (.cse8 (* c_thread2Thread1of1ForFork1_~j~0 4)) (.cse10 (select |c_#memory_int| c_~A~0.base)) (.cse11 (+ c_~A~0.offset (* c_thread1Thread1of1ForFork0_~i~0 4))) (.cse12 (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset))) (and (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse6 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_5 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse3 (* ~b~0 4)) (.cse5 (let ((.cse9 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse7 (store |c_#memory_int| c_~A~0.base (store .cse9 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_5)))) (store .cse7 .cse6 (store (select .cse7 .cse6) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse9) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse2 (select .cse5 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse6 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse4 (select (select .cse5 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse3)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse2 (+ .cse3 v_arrayElimCell_35)) .cse4) (< ~M~0 (+ ~b~0 1)) (= (select .cse2 (+ .cse3 v_arrayElimCell_33)) .cse4))))) (= c_~B~0.base .cse6)))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse15 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_subst_8 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse13 (let ((.cse17 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse16 (store |c_#memory_int| c_~A~0.base (store .cse17 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_8)))) (store .cse16 .cse15 (store (select .cse16 .cse15) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse17) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse14 (* ~b~0 4))) (= (select (select .cse13 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse14)) (select (select .cse13 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse15 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse14 v_arrayElimCell_34)))) (< ~M~0 (+ ~b~0 1)))) (not (= c_~B~0.base .cse15))))) (or .cse18 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_6 Int) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse19 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse19) (< ~M~0 (+ ~b~0 1)) (let ((.cse20 (let ((.cse23 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse22 (store |c_#memory_int| c_~A~0.base (store .cse23 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_6)))) (store .cse22 .cse19 (store (select .cse22 .cse19) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse23) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse21 (* ~b~0 4))) (= (select (select .cse20 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse19 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse21 v_arrayElimCell_33)) (select (select .cse20 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse21)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse24 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (not (= c_~B~0.base .cse24)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_subst_1 Int) (v_arrayElimCell_34 Int)) (let ((.cse28 (let ((.cse30 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse29 (store |c_#memory_int| c_~A~0.base (store .cse30 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse29 .cse24 (store (select .cse29 .cse24) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse30) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse27 (* ~b~0 4))) (let ((.cse25 (select (select .cse28 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse27))) (.cse26 (select .cse28 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse24 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (= .cse25 (select .cse26 (+ .cse27 v_arrayElimCell_34))) (< .cse1 ~M~0) (= .cse25 (select .cse26 (+ .cse27 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))))))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_1 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse35 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (let ((.cse34 (let ((.cse37 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse36 (store |c_#memory_int| c_~A~0.base (store .cse37 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse36 .cse35 (store (select .cse36 .cse35) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse37) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse33 (* ~b~0 4))) (let ((.cse31 (select (select .cse34 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse33))) (.cse32 (select .cse34 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse35 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (= .cse31 (select .cse32 (+ .cse33 v_arrayElimCell_34))) (< .cse1 ~M~0) (= .cse31 (select .cse32 (+ .cse33 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse39 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_2 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (let ((.cse38 (let ((.cse42 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse41 (store |c_#memory_int| c_~A~0.base (store .cse42 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_2)))) (store .cse41 .cse39 (store (select .cse41 .cse39) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse42) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse40 (* ~b~0 4))) (= (select (select .cse38 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse39 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse40 v_arrayElimCell_35)) (select (select .cse38 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse40)))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) (= c_~B~0.base .cse39))))) .cse43) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_10 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse48 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (let ((.cse47 (let ((.cse50 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse49 (store |c_#memory_int| c_~A~0.base (store .cse50 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_10)))) (store .cse49 .cse48 (store (select .cse49 .cse48) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse50) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse46 (* ~b~0 4))) (let ((.cse44 (select (select .cse47 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse46))) (.cse45 (select .cse47 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse48 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= .cse44 (select .cse45 (+ .cse46 v_arrayElimCell_34))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (= .cse44 (select .cse45 (+ .cse46 v_arrayElimCell_35))) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= .cse44 (select .cse45 (+ .cse46 v_arrayElimCell_33))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_subst_9 Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse55 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (let ((.cse52 (* ~b~0 4)) (.cse54 (let ((.cse57 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse56 (store |c_#memory_int| c_~A~0.base (store .cse57 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_9)))) (store .cse56 .cse55 (store (select .cse56 .cse55) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse57) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse51 (select .cse54 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse55 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse53 (select (select .cse54 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse52)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (= (select .cse51 (+ .cse52 v_arrayElimCell_33)) .cse53) (= .cse53 (select .cse51 (+ .cse52 v_arrayElimCell_34))) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse51 (+ .cse52 v_arrayElimCell_35)) .cse53) (< ~M~0 (+ ~b~0 1))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse62 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_3 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse61 (let ((.cse64 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse63 (store |c_#memory_int| c_~A~0.base (store .cse64 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse63 .cse62 (store (select .cse63 .cse62) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse64) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse59 (* ~b~0 4))) (let ((.cse60 (select (select .cse61 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse59))) (.cse58 (select .cse61 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse62 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse58 (+ .cse59 v_arrayElimCell_35)) .cse60) (< ~M~0 (+ ~b~0 1)) (= .cse60 (select .cse58 (+ .cse59 v_arrayElimCell_34))))))) (not (= c_~B~0.base .cse62))))) (or (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_11 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse65 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse65) (let ((.cse66 (let ((.cse69 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse68 (store |c_#memory_int| c_~A~0.base (store .cse69 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_11)))) (store .cse68 .cse65 (store (select .cse68 .cse65) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse69) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse67 (* ~b~0 4))) (= (select (select .cse66 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse67)) (select (select .cse66 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse65 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse67 v_arrayElimCell_33)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0)))) .cse18) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse74 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_12 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse72 (* ~b~0 4)) (.cse73 (let ((.cse76 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse75 (store |c_#memory_int| c_~A~0.base (store .cse76 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_12)))) (store .cse75 .cse74 (store (select .cse75 .cse74) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse76) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse71 (select .cse73 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse74 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse70 (select (select .cse73 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse72)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= .cse70 (select .cse71 (+ .cse72 v_arrayElimCell_35))) (= (select .cse71 (+ .cse72 v_arrayElimCell_33)) .cse70) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))))) (= c_~B~0.base .cse74)))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_3 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse81 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (let ((.cse80 (let ((.cse83 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse82 (store |c_#memory_int| c_~A~0.base (store .cse83 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse82 .cse81 (store (select .cse82 .cse81) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse83) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse78 (* ~b~0 4))) (let ((.cse79 (select (select .cse80 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse78))) (.cse77 (select .cse80 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse81 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse77 (+ .cse78 v_arrayElimCell_35)) .cse79) (< ~M~0 (+ ~b~0 1)) (= .cse79 (select .cse77 (+ .cse78 v_arrayElimCell_34)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse85 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_7 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse84 (let ((.cse88 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse87 (store |c_#memory_int| c_~A~0.base (store .cse88 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_7)))) (store .cse87 .cse85 (store (select .cse87 .cse85) (+ .cse8 v_arrayElimCell_33) (select (select (store |c_#memory_int| c_~A~0.base .cse88) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse86 (* ~b~0 4))) (= (select (select .cse84 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse85 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse86 v_arrayElimCell_35)) (select (select .cse84 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse86)))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)))) (= c_~B~0.base .cse85))))) .cse43) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse90 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse12))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_subst_4 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< ~a~0 0) (< .cse1 ~M~0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse89 (let ((.cse93 (store .cse10 .cse11 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse92 (store |c_#memory_int| c_~A~0.base (store .cse93 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_4)))) (store .cse92 .cse90 (store (select .cse92 .cse90) (+ .cse8 v_arrayElimCell_32) (select (select (store |c_#memory_int| c_~A~0.base .cse93) c_~F~0.base) (+ .cse8 c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse91 (* ~b~0 4))) (= (select (select .cse89 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse90 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse91 v_arrayElimCell_34)) (select (select .cse89 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse91)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0))) (not (= c_~B~0.base .cse90)))))))) is different from true [2024-05-07 09:59:27,050 WARN L854 $PredicateComparison]: unable to prove that (let ((.cse16 (= c_~B~0.base c_~A~0.base))) (let ((.cse36 (not .cse16)) (.cse3 (+ c_thread1Thread1of1ForFork0_~i~0 1)) (.cse8 (select |c_#memory_int| c_~A~0.base)) (.cse9 (+ c_~A~0.offset (* c_thread1Thread1of1ForFork0_~i~0 4))) (.cse10 (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset))) (and (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse5 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_subst_1 Int) (v_arrayElimCell_34 Int)) (let ((.cse2 (* ~b~0 4)) (.cse4 (let ((.cse7 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse6 (store |c_#memory_int| c_~A~0.base (store .cse7 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse6 .cse5 (store (select .cse6 .cse5) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse7) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse1 (select .cse4 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse5 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse0 (select (select .cse4 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse2)))) (or (< ~b~0 0) (= .cse0 (select .cse1 (+ .cse2 v_arrayElimCell_35))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (= (select .cse1 (+ .cse2 v_arrayElimCell_34)) .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (not (= c_~B~0.base .cse5))))) (or (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_11 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse13 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (let ((.cse11 (let ((.cse15 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse14 (store |c_#memory_int| c_~A~0.base (store .cse15 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_11)))) (store .cse14 .cse13 (store (select .cse14 .cse13) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse15) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse12 (* ~b~0 4))) (= (select (select .cse11 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse12)) (select (select .cse11 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse13 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse12 v_arrayElimCell_33)))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse13) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))) .cse16) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_10 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse21 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse19 (* ~b~0 4)) (.cse20 (let ((.cse23 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse22 (store |c_#memory_int| c_~A~0.base (store .cse23 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_10)))) (store .cse22 .cse21 (store (select .cse22 .cse21) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse23) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse18 (select .cse20 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse21 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse17 (select (select .cse20 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse19)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (= .cse17 (select .cse18 (+ .cse19 v_arrayElimCell_33))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse18 (+ .cse19 v_arrayElimCell_34)) .cse17) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0) (= (select .cse18 (+ .cse19 v_arrayElimCell_35)) .cse17)))))) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse24 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse24) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_5 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse28 (let ((.cse30 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse29 (store |c_#memory_int| c_~A~0.base (store .cse30 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_5)))) (store .cse29 .cse24 (store (select .cse29 .cse24) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse30) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse26 (* ~b~0 4))) (let ((.cse27 (select (select .cse28 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse26))) (.cse25 (select .cse28 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse24 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (= (select .cse25 (+ .cse26 v_arrayElimCell_33)) .cse27) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse27 (select .cse25 (+ .cse26 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse32 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_subst_8 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse31 (let ((.cse35 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse34 (store |c_#memory_int| c_~A~0.base (store .cse35 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_8)))) (store .cse34 .cse32 (store (select .cse34 .cse32) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse35) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse33 (* ~b~0 4))) (= (select (select .cse31 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse32 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse33 v_arrayElimCell_34)) (select (select .cse31 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse33)))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0))) (not (= c_~B~0.base .cse32))))) (or .cse36 (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_3 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse41 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse40 (let ((.cse43 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse42 (store |c_#memory_int| c_~A~0.base (store .cse43 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse42 .cse41 (store (select .cse42 .cse41) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse43) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse39 (* ~b~0 4))) (let ((.cse37 (select (select .cse40 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse39))) (.cse38 (select .cse40 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse41 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse37 (select .cse38 (+ .cse39 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (= .cse37 (select .cse38 (+ .cse39 v_arrayElimCell_34))) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse44 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse44) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_7 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse45 (let ((.cse48 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse47 (store |c_#memory_int| c_~A~0.base (store .cse48 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_7)))) (store .cse47 .cse44 (store (select .cse47 .cse44) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse48) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse46 (* ~b~0 4))) (= (select (select .cse45 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse44 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse46 v_arrayElimCell_35)) (select (select .cse45 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse46)))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_subst_9 Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse53 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse50 (* ~b~0 4)) (.cse52 (let ((.cse55 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse54 (store |c_#memory_int| c_~A~0.base (store .cse55 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_9)))) (store .cse54 .cse53 (store (select .cse54 .cse53) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse55) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse49 (select .cse52 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse53 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse51 (select (select .cse52 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse50)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (= (select .cse49 (+ .cse50 v_arrayElimCell_33)) .cse51) (< ~a~0 0) (= (select .cse49 (+ .cse50 v_arrayElimCell_35)) .cse51) (= (select .cse49 (+ .cse50 v_arrayElimCell_34)) .cse51) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_1 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse60 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse58 (* ~b~0 4)) (.cse59 (let ((.cse62 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse61 (store |c_#memory_int| c_~A~0.base (store .cse62 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse61 .cse60 (store (select .cse61 .cse60) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse62) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse57 (select .cse59 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse60 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse56 (select (select .cse59 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse58)))) (or (< ~b~0 0) (= .cse56 (select .cse57 (+ .cse58 v_arrayElimCell_35))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (= (select .cse57 (+ .cse58 v_arrayElimCell_34)) .cse56) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse64 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_2 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse63 (let ((.cse67 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse66 (store |c_#memory_int| c_~A~0.base (store .cse67 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_2)))) (store .cse66 .cse64 (store (select .cse66 .cse64) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse67) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse65 (* ~b~0 4))) (= (select (select .cse63 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse64 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse65 v_arrayElimCell_35)) (select (select .cse63 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse65)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))) (= c_~B~0.base .cse64))))) .cse36) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse68 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse68)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_3 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse72 (let ((.cse74 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse73 (store |c_#memory_int| c_~A~0.base (store .cse74 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse73 .cse68 (store (select .cse73 .cse68) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse74) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse71 (* ~b~0 4))) (let ((.cse69 (select (select .cse72 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse71))) (.cse70 (select .cse72 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse68 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse69 (select .cse70 (+ .cse71 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (= .cse69 (select .cse70 (+ .cse71 v_arrayElimCell_34))) (< 1 ~M~0)))))))) (or .cse16 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_6 Int) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse76 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (let ((.cse75 (let ((.cse79 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse78 (store |c_#memory_int| c_~A~0.base (store .cse79 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_6)))) (store .cse78 .cse76 (store (select .cse78 .cse76) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse79) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse77 (* ~b~0 4))) (= (select (select .cse75 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse76 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse77 v_arrayElimCell_33)) (select (select .cse75 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse77)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse76) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0))))) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse80 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse80) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_12 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse82 (* ~b~0 4)) (.cse84 (let ((.cse86 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse85 (store |c_#memory_int| c_~A~0.base (store .cse86 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_12)))) (store .cse85 .cse80 (store (select .cse85 .cse80) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse86) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse81 (select .cse84 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse80 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse83 (select (select .cse84 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse82)))) (or (< ~b~0 0) (= (select .cse81 (+ .cse82 v_arrayElimCell_35)) .cse83) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= (select .cse81 (+ .cse82 v_arrayElimCell_33)) .cse83) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse89 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_subst_4 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (let ((.cse87 (let ((.cse91 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse90 (store |c_#memory_int| c_~A~0.base (store .cse91 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_4)))) (store .cse90 .cse89 (store (select .cse90 .cse89) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse91) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse88 (* ~b~0 4))) (= (select (select .cse87 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse88)) (select (select .cse87 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse89 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse88 v_arrayElimCell_34)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))) (not (= c_~B~0.base .cse89)))))))) is different from false [2024-05-07 09:59:29,062 WARN L876 $PredicateComparison]: unable to prove that (let ((.cse16 (= c_~B~0.base c_~A~0.base))) (let ((.cse36 (not .cse16)) (.cse3 (+ c_thread1Thread1of1ForFork0_~i~0 1)) (.cse8 (select |c_#memory_int| c_~A~0.base)) (.cse9 (+ c_~A~0.offset (* c_thread1Thread1of1ForFork0_~i~0 4))) (.cse10 (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset))) (and (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse5 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_subst_1 Int) (v_arrayElimCell_34 Int)) (let ((.cse2 (* ~b~0 4)) (.cse4 (let ((.cse7 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse6 (store |c_#memory_int| c_~A~0.base (store .cse7 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse6 .cse5 (store (select .cse6 .cse5) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse7) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse1 (select .cse4 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse5 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse0 (select (select .cse4 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse2)))) (or (< ~b~0 0) (= .cse0 (select .cse1 (+ .cse2 v_arrayElimCell_35))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (= (select .cse1 (+ .cse2 v_arrayElimCell_34)) .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (not (= c_~B~0.base .cse5))))) (or (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_11 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse13 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (let ((.cse11 (let ((.cse15 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse14 (store |c_#memory_int| c_~A~0.base (store .cse15 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_11)))) (store .cse14 .cse13 (store (select .cse14 .cse13) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse15) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse12 (* ~b~0 4))) (= (select (select .cse11 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse12)) (select (select .cse11 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse13 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse12 v_arrayElimCell_33)))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse13) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))) .cse16) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_10 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse21 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse19 (* ~b~0 4)) (.cse20 (let ((.cse23 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse22 (store |c_#memory_int| c_~A~0.base (store .cse23 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_10)))) (store .cse22 .cse21 (store (select .cse22 .cse21) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse23) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse18 (select .cse20 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse21 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse17 (select (select .cse20 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse19)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (= .cse17 (select .cse18 (+ .cse19 v_arrayElimCell_33))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse18 (+ .cse19 v_arrayElimCell_34)) .cse17) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0) (= (select .cse18 (+ .cse19 v_arrayElimCell_35)) .cse17)))))) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse24 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse24) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_5 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse28 (let ((.cse30 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse29 (store |c_#memory_int| c_~A~0.base (store .cse30 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_5)))) (store .cse29 .cse24 (store (select .cse29 .cse24) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse30) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse26 (* ~b~0 4))) (let ((.cse27 (select (select .cse28 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse26))) (.cse25 (select .cse28 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse24 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (= (select .cse25 (+ .cse26 v_arrayElimCell_33)) .cse27) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse27 (select .cse25 (+ .cse26 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse32 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_subst_8 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse31 (let ((.cse35 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse34 (store |c_#memory_int| c_~A~0.base (store .cse35 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_8)))) (store .cse34 .cse32 (store (select .cse34 .cse32) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse35) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse33 (* ~b~0 4))) (= (select (select .cse31 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse32 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse33 v_arrayElimCell_34)) (select (select .cse31 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse33)))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0))) (not (= c_~B~0.base .cse32))))) (or .cse36 (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_3 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse41 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse40 (let ((.cse43 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse42 (store |c_#memory_int| c_~A~0.base (store .cse43 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse42 .cse41 (store (select .cse42 .cse41) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse43) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse39 (* ~b~0 4))) (let ((.cse37 (select (select .cse40 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse39))) (.cse38 (select .cse40 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse41 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse37 (select .cse38 (+ .cse39 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (= .cse37 (select .cse38 (+ .cse39 v_arrayElimCell_34))) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse44 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse44) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_7 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse45 (let ((.cse48 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse47 (store |c_#memory_int| c_~A~0.base (store .cse48 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_7)))) (store .cse47 .cse44 (store (select .cse47 .cse44) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse48) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse46 (* ~b~0 4))) (= (select (select .cse45 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse44 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse46 v_arrayElimCell_35)) (select (select .cse45 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse46)))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_subst_9 Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse53 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse50 (* ~b~0 4)) (.cse52 (let ((.cse55 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse54 (store |c_#memory_int| c_~A~0.base (store .cse55 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_9)))) (store .cse54 .cse53 (store (select .cse54 .cse53) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse55) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse49 (select .cse52 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse53 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse51 (select (select .cse52 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse50)))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (= (select .cse49 (+ .cse50 v_arrayElimCell_33)) .cse51) (< ~a~0 0) (= (select .cse49 (+ .cse50 v_arrayElimCell_35)) .cse51) (= (select .cse49 (+ .cse50 v_arrayElimCell_34)) .cse51) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_1 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse60 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse58 (* ~b~0 4)) (.cse59 (let ((.cse62 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse61 (store |c_#memory_int| c_~A~0.base (store .cse62 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse61 .cse60 (store (select .cse61 .cse60) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse62) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse57 (select .cse59 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse60 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse56 (select (select .cse59 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse58)))) (or (< ~b~0 0) (= .cse56 (select .cse57 (+ .cse58 v_arrayElimCell_35))) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (= (select .cse57 (+ .cse58 v_arrayElimCell_34)) .cse56) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse64 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_2 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse63 (let ((.cse67 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse66 (store |c_#memory_int| c_~A~0.base (store .cse67 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_2)))) (store .cse66 .cse64 (store (select .cse66 .cse64) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse67) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse65 (* ~b~0 4))) (= (select (select .cse63 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse64 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse65 v_arrayElimCell_35)) (select (select .cse63 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse65)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))) (= c_~B~0.base .cse64))))) .cse36) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse68 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse68)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_3 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse72 (let ((.cse74 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse73 (store |c_#memory_int| c_~A~0.base (store .cse74 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse73 .cse68 (store (select .cse73 .cse68) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse74) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse71 (* ~b~0 4))) (let ((.cse69 (select (select .cse72 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse71))) (.cse70 (select .cse72 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse68 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse69 (select .cse70 (+ .cse71 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (= .cse69 (select .cse70 (+ .cse71 v_arrayElimCell_34))) (< 1 ~M~0)))))))) (or .cse16 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_6 Int) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse76 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (let ((.cse75 (let ((.cse79 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse78 (store |c_#memory_int| c_~A~0.base (store .cse79 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_6)))) (store .cse78 .cse76 (store (select .cse78 .cse76) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse79) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse77 (* ~b~0 4))) (= (select (select .cse75 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse76 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse77 v_arrayElimCell_33)) (select (select .cse75 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse77)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse76) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0))))) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse80 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse80) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_12 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse82 (* ~b~0 4)) (.cse84 (let ((.cse86 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse85 (store |c_#memory_int| c_~A~0.base (store .cse86 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_12)))) (store .cse85 .cse80 (store (select .cse85 .cse80) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse86) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse81 (select .cse84 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse80 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse83 (select (select .cse84 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse82)))) (or (< ~b~0 0) (= (select .cse81 (+ .cse82 v_arrayElimCell_35)) .cse83) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= (select .cse81 (+ .cse82 v_arrayElimCell_33)) .cse83) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse89 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_subst_4 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse3) (let ((.cse87 (let ((.cse91 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse90 (store |c_#memory_int| c_~A~0.base (store .cse91 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_4)))) (store .cse90 .cse89 (store (select .cse90 .cse89) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse91) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse88 (* ~b~0 4))) (= (select (select .cse87 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse88)) (select (select .cse87 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse89 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse88 v_arrayElimCell_34)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))) (not (= c_~B~0.base .cse89)))))))) is different from true [2024-05-07 09:59:32,450 WARN L854 $PredicateComparison]: unable to prove that (let ((.cse55 (= c_~B~0.base c_~A~0.base))) (let ((.cse49 (not .cse55)) (.cse8 (select |c_#memory_int| c_~A~0.base)) (.cse9 (+ c_~A~0.offset 4 (* |c_thread1Thread1of1ForFork0_#t~post1| 4))) (.cse0 (+ |c_thread1Thread1of1ForFork0_#t~post1| 2)) (.cse10 (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset))) (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_subst_9 Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse5 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse3 (* ~b~0 4)) (.cse4 (let ((.cse7 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse6 (store |c_#memory_int| c_~A~0.base (store .cse7 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_9)))) (store .cse6 .cse5 (store (select .cse6 .cse5) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse7) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse2 (select .cse4 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse5 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse1 (select (select .cse4 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse3)))) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (= .cse1 (select .cse2 (+ .cse3 v_arrayElimCell_34))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse2 (+ .cse3 v_arrayElimCell_33)) .cse1) (< ~M~0 (+ ~b~0 1)) (= (select .cse2 (+ .cse3 v_arrayElimCell_35)) .cse1) (< 1 ~M~0)))))) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse15 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_12 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse12 (* ~b~0 4)) (.cse14 (let ((.cse17 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse16 (store |c_#memory_int| c_~A~0.base (store .cse17 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_12)))) (store .cse16 .cse15 (store (select .cse16 .cse15) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse17) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse11 (select .cse14 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse15 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse13 (select (select .cse14 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse12)))) (or (< ~b~0 0) (= (select .cse11 (+ .cse12 v_arrayElimCell_35)) .cse13) (= (select .cse11 (+ .cse12 v_arrayElimCell_33)) .cse13) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (= c_~B~0.base .cse15)))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_10 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse22 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse19 (* ~b~0 4)) (.cse21 (let ((.cse24 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse23 (store |c_#memory_int| c_~A~0.base (store .cse24 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_10)))) (store .cse23 .cse22 (store (select .cse23 .cse22) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse24) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse18 (select .cse21 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse22 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse20 (select (select .cse21 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse19)))) (or (< ~b~0 0) (= (select .cse18 (+ .cse19 v_arrayElimCell_35)) .cse20) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse18 (+ .cse19 v_arrayElimCell_34)) .cse20) (< ~M~0 (+ ~b~0 1)) (= (select .cse18 (+ .cse19 v_arrayElimCell_33)) .cse20) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse27 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_subst_8 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse25 (let ((.cse29 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse28 (store |c_#memory_int| c_~A~0.base (store .cse29 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_8)))) (store .cse28 .cse27 (store (select .cse28 .cse27) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse29) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse26 (* ~b~0 4))) (= (select (select .cse25 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse26)) (select (select .cse25 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse27 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse26 v_arrayElimCell_34)))) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0))) (not (= c_~B~0.base .cse27))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse30 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse30)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_subst_1 Int) (v_arrayElimCell_34 Int)) (let ((.cse33 (* ~b~0 4)) (.cse34 (let ((.cse36 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse35 (store |c_#memory_int| c_~A~0.base (store .cse36 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse35 .cse30 (store (select .cse35 .cse30) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse36) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse32 (select .cse34 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse30 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse31 (select (select .cse34 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse33)))) (or (< ~b~0 0) (= .cse31 (select .cse32 (+ .cse33 v_arrayElimCell_35))) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse32 (+ .cse33 v_arrayElimCell_34)) .cse31) (< 1 ~M~0)))))))) (or (and (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse37 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse37) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_2 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (let ((.cse38 (let ((.cse41 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse40 (store |c_#memory_int| c_~A~0.base (store .cse41 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_2)))) (store .cse40 .cse37 (store (select .cse40 .cse37) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse41) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse39 (* ~b~0 4))) (= (select (select .cse38 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse37 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse39 v_arrayElimCell_35)) (select (select .cse38 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse39)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_1 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse46 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse44 (* ~b~0 4)) (.cse45 (let ((.cse48 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse47 (store |c_#memory_int| c_~A~0.base (store .cse48 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse47 .cse46 (store (select .cse47 .cse46) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse48) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse43 (select .cse45 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse46 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse42 (select (select .cse45 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse44)))) (or (< ~b~0 0) (= .cse42 (select .cse43 (+ .cse44 v_arrayElimCell_35))) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse43 (+ .cse44 v_arrayElimCell_34)) .cse42) (< 1 ~M~0))))))) .cse49) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse52 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_subst_4 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse50 (let ((.cse54 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse53 (store |c_#memory_int| c_~A~0.base (store .cse54 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_4)))) (store .cse53 .cse52 (store (select .cse53 .cse52) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse54) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse51 (* ~b~0 4))) (= (select (select .cse50 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse51)) (select (select .cse50 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse52 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse51 v_arrayElimCell_34)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))) (not (= c_~B~0.base .cse52))))) (or .cse55 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_11 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse58 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (let ((.cse56 (let ((.cse60 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse59 (store |c_#memory_int| c_~A~0.base (store .cse60 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_11)))) (store .cse59 .cse58 (store (select .cse59 .cse58) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse60) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse57 (* ~b~0 4))) (= (select (select .cse56 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse57)) (select (select .cse56 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse58 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse57 v_arrayElimCell_33)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse58) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse61 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse61)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_3 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse65 (let ((.cse67 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse66 (store |c_#memory_int| c_~A~0.base (store .cse67 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse66 .cse61 (store (select .cse66 .cse61) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse67) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse63 (* ~b~0 4))) (let ((.cse64 (select (select .cse65 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse63))) (.cse62 (select .cse65 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse61 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse62 (+ .cse63 v_arrayElimCell_34)) .cse64) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse64 (select .cse62 (+ .cse63 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_3 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse72 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse71 (let ((.cse74 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse73 (store |c_#memory_int| c_~A~0.base (store .cse74 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse73 .cse72 (store (select .cse73 .cse72) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse74) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse69 (* ~b~0 4))) (let ((.cse70 (select (select .cse71 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse69))) (.cse68 (select .cse71 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse72 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse68 (+ .cse69 v_arrayElimCell_34)) .cse70) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse70 (select .cse68 (+ .cse69 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse77 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_7 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse75 (let ((.cse79 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse78 (store |c_#memory_int| c_~A~0.base (store .cse79 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_7)))) (store .cse78 .cse77 (store (select .cse78 .cse77) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse79) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse76 (* ~b~0 4))) (= (select (select .cse75 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse76)) (select (select .cse75 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse77 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse76 v_arrayElimCell_35)))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0))) (= c_~B~0.base .cse77))))) .cse49) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse80 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse80) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_5 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse82 (* ~b~0 4)) (.cse84 (let ((.cse86 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse85 (store |c_#memory_int| c_~A~0.base (store .cse86 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_5)))) (store .cse85 .cse80 (store (select .cse85 .cse80) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse86) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse81 (select .cse84 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse80 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse83 (select (select .cse84 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse82)))) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= (select .cse81 (+ .cse82 v_arrayElimCell_35)) .cse83) (= (select .cse81 (+ .cse82 v_arrayElimCell_33)) .cse83) (< 1 ~M~0)))))))) (or .cse55 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_6 Int) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse88 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (let ((.cse87 (let ((.cse91 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse90 (store |c_#memory_int| c_~A~0.base (store .cse91 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_6)))) (store .cse90 .cse88 (store (select .cse90 .cse88) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse91) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse89 (* ~b~0 4))) (= (select (select .cse87 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse88 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse89 v_arrayElimCell_33)) (select (select .cse87 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse89)))) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse88) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))))) is different from false [2024-05-07 09:59:34,462 WARN L876 $PredicateComparison]: unable to prove that (let ((.cse55 (= c_~B~0.base c_~A~0.base))) (let ((.cse49 (not .cse55)) (.cse8 (select |c_#memory_int| c_~A~0.base)) (.cse9 (+ c_~A~0.offset 4 (* |c_thread1Thread1of1ForFork0_#t~post1| 4))) (.cse0 (+ |c_thread1Thread1of1ForFork0_#t~post1| 2)) (.cse10 (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset))) (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_subst_9 Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse5 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse3 (* ~b~0 4)) (.cse4 (let ((.cse7 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse6 (store |c_#memory_int| c_~A~0.base (store .cse7 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_9)))) (store .cse6 .cse5 (store (select .cse6 .cse5) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse7) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse2 (select .cse4 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse5 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse1 (select (select .cse4 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse3)))) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (= .cse1 (select .cse2 (+ .cse3 v_arrayElimCell_34))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse2 (+ .cse3 v_arrayElimCell_33)) .cse1) (< ~M~0 (+ ~b~0 1)) (= (select .cse2 (+ .cse3 v_arrayElimCell_35)) .cse1) (< 1 ~M~0)))))) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse15 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_12 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse12 (* ~b~0 4)) (.cse14 (let ((.cse17 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse16 (store |c_#memory_int| c_~A~0.base (store .cse17 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_12)))) (store .cse16 .cse15 (store (select .cse16 .cse15) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse17) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse11 (select .cse14 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse15 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse13 (select (select .cse14 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse12)))) (or (< ~b~0 0) (= (select .cse11 (+ .cse12 v_arrayElimCell_35)) .cse13) (= (select .cse11 (+ .cse12 v_arrayElimCell_33)) .cse13) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (= c_~B~0.base .cse15)))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_10 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse22 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse19 (* ~b~0 4)) (.cse21 (let ((.cse24 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse23 (store |c_#memory_int| c_~A~0.base (store .cse24 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_10)))) (store .cse23 .cse22 (store (select .cse23 .cse22) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse24) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse18 (select .cse21 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse22 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse20 (select (select .cse21 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse19)))) (or (< ~b~0 0) (= (select .cse18 (+ .cse19 v_arrayElimCell_35)) .cse20) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse18 (+ .cse19 v_arrayElimCell_34)) .cse20) (< ~M~0 (+ ~b~0 1)) (= (select .cse18 (+ .cse19 v_arrayElimCell_33)) .cse20) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse27 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_subst_8 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse25 (let ((.cse29 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse28 (store |c_#memory_int| c_~A~0.base (store .cse29 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_8)))) (store .cse28 .cse27 (store (select .cse28 .cse27) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse29) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse26 (* ~b~0 4))) (= (select (select .cse25 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse26)) (select (select .cse25 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse27 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse26 v_arrayElimCell_34)))) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0))) (not (= c_~B~0.base .cse27))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse30 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse30)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_subst_1 Int) (v_arrayElimCell_34 Int)) (let ((.cse33 (* ~b~0 4)) (.cse34 (let ((.cse36 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse35 (store |c_#memory_int| c_~A~0.base (store .cse36 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse35 .cse30 (store (select .cse35 .cse30) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse36) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse32 (select .cse34 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse30 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse31 (select (select .cse34 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse33)))) (or (< ~b~0 0) (= .cse31 (select .cse32 (+ .cse33 v_arrayElimCell_35))) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse32 (+ .cse33 v_arrayElimCell_34)) .cse31) (< 1 ~M~0)))))))) (or (and (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse37 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse37) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_2 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (let ((.cse38 (let ((.cse41 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse40 (store |c_#memory_int| c_~A~0.base (store .cse41 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_2)))) (store .cse40 .cse37 (store (select .cse40 .cse37) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse41) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse39 (* ~b~0 4))) (= (select (select .cse38 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse37 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse39 v_arrayElimCell_35)) (select (select .cse38 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse39)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_1 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse46 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse44 (* ~b~0 4)) (.cse45 (let ((.cse48 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse47 (store |c_#memory_int| c_~A~0.base (store .cse48 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse47 .cse46 (store (select .cse47 .cse46) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse48) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse43 (select .cse45 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse46 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse42 (select (select .cse45 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse44)))) (or (< ~b~0 0) (= .cse42 (select .cse43 (+ .cse44 v_arrayElimCell_35))) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse43 (+ .cse44 v_arrayElimCell_34)) .cse42) (< 1 ~M~0))))))) .cse49) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse52 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_subst_4 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse50 (let ((.cse54 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse53 (store |c_#memory_int| c_~A~0.base (store .cse54 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_4)))) (store .cse53 .cse52 (store (select .cse53 .cse52) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse54) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse51 (* ~b~0 4))) (= (select (select .cse50 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse51)) (select (select .cse50 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse52 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse51 v_arrayElimCell_34)))) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))) (not (= c_~B~0.base .cse52))))) (or .cse55 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_11 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse58 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (let ((.cse56 (let ((.cse60 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse59 (store |c_#memory_int| c_~A~0.base (store .cse60 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_11)))) (store .cse59 .cse58 (store (select .cse59 .cse58) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse60) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse57 (* ~b~0 4))) (= (select (select .cse56 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse57)) (select (select .cse56 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse58 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse57 v_arrayElimCell_33)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse58) (< ~M~0 (+ ~b~0 1)) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse61 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse61)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_3 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse65 (let ((.cse67 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse66 (store |c_#memory_int| c_~A~0.base (store .cse67 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse66 .cse61 (store (select .cse66 .cse61) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse67) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse63 (* ~b~0 4))) (let ((.cse64 (select (select .cse65 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse63))) (.cse62 (select .cse65 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse61 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse62 (+ .cse63 v_arrayElimCell_34)) .cse64) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse64 (select .cse62 (+ .cse63 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_3 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse72 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse71 (let ((.cse74 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse73 (store |c_#memory_int| c_~A~0.base (store .cse74 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse73 .cse72 (store (select .cse73 .cse72) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse74) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse69 (* ~b~0 4))) (let ((.cse70 (select (select .cse71 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse69))) (.cse68 (select .cse71 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse72 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse68 (+ .cse69 v_arrayElimCell_34)) .cse70) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse70 (select .cse68 (+ .cse69 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse77 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_7 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse75 (let ((.cse79 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse78 (store |c_#memory_int| c_~A~0.base (store .cse79 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_7)))) (store .cse78 .cse77 (store (select .cse78 .cse77) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse79) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse76 (* ~b~0 4))) (= (select (select .cse75 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse76)) (select (select .cse75 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse77 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse76 v_arrayElimCell_35)))) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0))) (= c_~B~0.base .cse77))))) .cse49) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse80 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse80) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_5 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse82 (* ~b~0 4)) (.cse84 (let ((.cse86 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse85 (store |c_#memory_int| c_~A~0.base (store .cse86 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_5)))) (store .cse85 .cse80 (store (select .cse85 .cse80) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse86) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse81 (select .cse84 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse80 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse83 (select (select .cse84 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse82)))) (or (< ~b~0 0) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= (select .cse81 (+ .cse82 v_arrayElimCell_35)) .cse83) (= (select .cse81 (+ .cse82 v_arrayElimCell_33)) .cse83) (< 1 ~M~0)))))))) (or .cse55 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_6 Int) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse88 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (let ((.cse87 (let ((.cse91 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse90 (store |c_#memory_int| c_~A~0.base (store .cse91 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_6)))) (store .cse90 .cse88 (store (select .cse90 .cse88) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse91) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse89 (* ~b~0 4))) (= (select (select .cse87 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse88 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse89 v_arrayElimCell_33)) (select (select .cse87 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse89)))) (< ~a~0 0) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse88) (< ~M~0 (+ ~b~0 1)) (< 1 ~M~0)))))))) is different from true [2024-05-07 09:59:35,876 WARN L854 $PredicateComparison]: unable to prove that (let ((.cse11 (= c_~B~0.base c_~A~0.base))) (let ((.cse22 (not .cse11)) (.cse4 (+ 2 c_thread1Thread1of1ForFork0_~i~0)) (.cse8 (select |c_#memory_int| c_~A~0.base)) (.cse9 (+ c_~A~0.offset 4 (* c_thread1Thread1of1ForFork0_~i~0 4))) (.cse10 (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset))) (and (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse0 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse0) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_12 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse3 (* ~b~0 4)) (.cse5 (let ((.cse7 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse6 (store |c_#memory_int| c_~A~0.base (store .cse7 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_12)))) (store .cse6 .cse0 (store (select .cse6 .cse0) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse7) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse2 (select .cse5 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse0 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse1 (select (select .cse5 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse3)))) (or (< ~b~0 0) (< ~a~0 0) (= .cse1 (select .cse2 (+ .cse3 v_arrayElimCell_33))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= (select .cse2 (+ .cse3 v_arrayElimCell_35)) .cse1) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))))) (or .cse11 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_11 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse12 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse12) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (let ((.cse13 (let ((.cse16 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse15 (store |c_#memory_int| c_~A~0.base (store .cse16 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_11)))) (store .cse15 .cse12 (store (select .cse15 .cse12) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse16) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse14 (* ~b~0 4))) (= (select (select .cse13 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse14)) (select (select .cse13 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse12 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse14 v_arrayElimCell_33)))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse19 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_subst_4 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (let ((.cse17 (let ((.cse21 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse20 (store |c_#memory_int| c_~A~0.base (store .cse21 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_4)))) (store .cse20 .cse19 (store (select .cse20 .cse19) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse21) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse18 (* ~b~0 4))) (= (select (select .cse17 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse18)) (select (select .cse17 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse19 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse18 v_arrayElimCell_34)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))) (not (= c_~B~0.base .cse19))))) (or .cse22 (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_3 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse27 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse26 (let ((.cse29 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse28 (store |c_#memory_int| c_~A~0.base (store .cse29 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse28 .cse27 (store (select .cse28 .cse27) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse29) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse24 (* ~b~0 4))) (let ((.cse25 (select (select .cse26 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse24))) (.cse23 (select .cse26 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse27 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse23 (+ .cse24 v_arrayElimCell_35)) .cse25) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0) (= .cse25 (select .cse23 (+ .cse24 v_arrayElimCell_34)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse31 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_7 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse30 (let ((.cse34 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse33 (store |c_#memory_int| c_~A~0.base (store .cse34 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_7)))) (store .cse33 .cse31 (store (select .cse33 .cse31) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse34) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse32 (* ~b~0 4))) (= (select (select .cse30 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse31 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse32 v_arrayElimCell_35)) (select (select .cse30 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse32)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0))) (= c_~B~0.base .cse31)))))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_1 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse39 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse38 (let ((.cse41 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse40 (store |c_#memory_int| c_~A~0.base (store .cse41 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse40 .cse39 (store (select .cse40 .cse39) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse41) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse37 (* ~b~0 4))) (let ((.cse35 (select (select .cse38 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse37))) (.cse36 (select .cse38 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse39 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< ~a~0 0) (= .cse35 (select .cse36 (+ .cse37 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse35 (select .cse36 (+ .cse37 v_arrayElimCell_34))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse42 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse42) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_2 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< ~a~0 0) (let ((.cse43 (let ((.cse46 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse45 (store |c_#memory_int| c_~A~0.base (store .cse46 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_2)))) (store .cse45 .cse42 (store (select .cse45 .cse42) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse46) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse44 (* ~b~0 4))) (= (select (select .cse43 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse42 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse44 v_arrayElimCell_35)) (select (select .cse43 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse44)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))))) .cse22) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse47 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse47) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_5 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse49 (* ~b~0 4)) (.cse51 (let ((.cse53 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse52 (store |c_#memory_int| c_~A~0.base (store .cse53 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_5)))) (store .cse52 .cse47 (store (select .cse52 .cse47) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse53) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse48 (select .cse51 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse47 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse50 (select (select .cse51 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse49)))) (or (< ~b~0 0) (< ~a~0 0) (= (select .cse48 (+ .cse49 v_arrayElimCell_35)) .cse50) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= (select .cse48 (+ .cse49 v_arrayElimCell_33)) .cse50) (< 1 ~M~0)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse54 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse54)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_3 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse58 (let ((.cse60 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse59 (store |c_#memory_int| c_~A~0.base (store .cse60 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse59 .cse54 (store (select .cse59 .cse54) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse60) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse56 (* ~b~0 4))) (let ((.cse57 (select (select .cse58 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse56))) (.cse55 (select .cse58 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse54 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse55 (+ .cse56 v_arrayElimCell_35)) .cse57) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0) (= .cse57 (select .cse55 (+ .cse56 v_arrayElimCell_34)))))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse61 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse61)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_subst_1 Int) (v_arrayElimCell_34 Int)) (let ((.cse65 (let ((.cse67 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse66 (store |c_#memory_int| c_~A~0.base (store .cse67 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse66 .cse61 (store (select .cse66 .cse61) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse67) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse64 (* ~b~0 4))) (let ((.cse62 (select (select .cse65 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse64))) (.cse63 (select .cse65 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse61 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< ~a~0 0) (= .cse62 (select .cse63 (+ .cse64 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse62 (select .cse63 (+ .cse64 v_arrayElimCell_34))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_10 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse72 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse71 (let ((.cse74 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse73 (store |c_#memory_int| c_~A~0.base (store .cse74 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_10)))) (store .cse73 .cse72 (store (select .cse73 .cse72) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse74) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse70 (* ~b~0 4))) (let ((.cse68 (select (select .cse71 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse70))) (.cse69 (select .cse71 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse72 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< ~a~0 0) (= .cse68 (select .cse69 (+ .cse70 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= .cse68 (select .cse69 (+ .cse70 v_arrayElimCell_33))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0) (= .cse68 (select .cse69 (+ .cse70 v_arrayElimCell_34)))))))) (or (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_6 Int) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse76 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (< ~a~0 0) (let ((.cse75 (let ((.cse79 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse78 (store |c_#memory_int| c_~A~0.base (store .cse79 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_6)))) (store .cse78 .cse76 (store (select .cse78 .cse76) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse79) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse77 (* ~b~0 4))) (= (select (select .cse75 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse76 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse77 v_arrayElimCell_33)) (select (select .cse75 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse77)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse76) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0)))) .cse11) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse80 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse80)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_subst_8 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse81 (let ((.cse84 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse83 (store |c_#memory_int| c_~A~0.base (store .cse84 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_8)))) (store .cse83 .cse80 (store (select .cse83 .cse80) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse84) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse82 (* ~b~0 4))) (= (select (select .cse81 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse80 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse82 v_arrayElimCell_34)) (select (select .cse81 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse82)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0)))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_subst_9 Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse89 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse86 (* ~b~0 4)) (.cse88 (let ((.cse91 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse90 (store |c_#memory_int| c_~A~0.base (store .cse91 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_9)))) (store .cse90 .cse89 (store (select .cse90 .cse89) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse91) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse85 (select .cse88 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse89 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse87 (select (select .cse88 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse86)))) (or (< ~b~0 0) (= (select .cse85 (+ .cse86 v_arrayElimCell_35)) .cse87) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= (select .cse85 (+ .cse86 v_arrayElimCell_34)) .cse87) (= (select .cse85 (+ .cse86 v_arrayElimCell_33)) .cse87) (< 1 ~M~0))))))))) is different from false [2024-05-07 09:59:37,891 WARN L876 $PredicateComparison]: unable to prove that (let ((.cse11 (= c_~B~0.base c_~A~0.base))) (let ((.cse22 (not .cse11)) (.cse4 (+ 2 c_thread1Thread1of1ForFork0_~i~0)) (.cse8 (select |c_#memory_int| c_~A~0.base)) (.cse9 (+ c_~A~0.offset 4 (* c_thread1Thread1of1ForFork0_~i~0 4))) (.cse10 (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset))) (and (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse0 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse0) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_12 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse3 (* ~b~0 4)) (.cse5 (let ((.cse7 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse6 (store |c_#memory_int| c_~A~0.base (store .cse7 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_12)))) (store .cse6 .cse0 (store (select .cse6 .cse0) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse7) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse2 (select .cse5 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse0 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse1 (select (select .cse5 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse3)))) (or (< ~b~0 0) (< ~a~0 0) (= .cse1 (select .cse2 (+ .cse3 v_arrayElimCell_33))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (= (select .cse2 (+ .cse3 v_arrayElimCell_35)) .cse1) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))))) (or .cse11 (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_11 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse12 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse12) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (let ((.cse13 (let ((.cse16 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse15 (store |c_#memory_int| c_~A~0.base (store .cse16 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_11)))) (store .cse15 .cse12 (store (select .cse15 .cse12) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse16) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse14 (* ~b~0 4))) (= (select (select .cse13 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse14)) (select (select .cse13 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse12 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse14 v_arrayElimCell_33)))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse19 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_subst_4 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (let ((.cse17 (let ((.cse21 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse20 (store |c_#memory_int| c_~A~0.base (store .cse21 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_4)))) (store .cse20 .cse19 (store (select .cse20 .cse19) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse21) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse18 (* ~b~0 4))) (= (select (select .cse17 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse18)) (select (select .cse17 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse19 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse18 v_arrayElimCell_34)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))) (not (= c_~B~0.base .cse19))))) (or .cse22 (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_3 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse27 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse26 (let ((.cse29 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse28 (store |c_#memory_int| c_~A~0.base (store .cse29 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse28 .cse27 (store (select .cse28 .cse27) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse29) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse24 (* ~b~0 4))) (let ((.cse25 (select (select .cse26 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse24))) (.cse23 (select .cse26 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse27 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse23 (+ .cse24 v_arrayElimCell_35)) .cse25) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0) (= .cse25 (select .cse23 (+ .cse24 v_arrayElimCell_34)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse31 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_7 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse30 (let ((.cse34 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse33 (store |c_#memory_int| c_~A~0.base (store .cse34 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_7)))) (store .cse33 .cse31 (store (select .cse33 .cse31) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse34) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse32 (* ~b~0 4))) (= (select (select .cse30 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse31 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse32 v_arrayElimCell_35)) (select (select .cse30 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse32)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0))) (= c_~B~0.base .cse31)))))) (or (and (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_1 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse39 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse38 (let ((.cse41 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse40 (store |c_#memory_int| c_~A~0.base (store .cse41 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse40 .cse39 (store (select .cse40 .cse39) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse41) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse37 (* ~b~0 4))) (let ((.cse35 (select (select .cse38 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse37))) (.cse36 (select .cse38 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse39 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< ~a~0 0) (= .cse35 (select .cse36 (+ .cse37 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse35 (select .cse36 (+ .cse37 v_arrayElimCell_34))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse42 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse42) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_2 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< ~a~0 0) (let ((.cse43 (let ((.cse46 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse45 (store |c_#memory_int| c_~A~0.base (store .cse46 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_2)))) (store .cse45 .cse42 (store (select .cse45 .cse42) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse46) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse44 (* ~b~0 4))) (= (select (select .cse43 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse42 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse44 v_arrayElimCell_35)) (select (select .cse43 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse44)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))))) .cse22) (forall ((v_ArrVal_1230 (Array Int Int))) (let ((.cse47 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (= c_~B~0.base .cse47) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_5 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse49 (* ~b~0 4)) (.cse51 (let ((.cse53 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse52 (store |c_#memory_int| c_~A~0.base (store .cse53 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_5)))) (store .cse52 .cse47 (store (select .cse52 .cse47) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse53) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse48 (select .cse51 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse47 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse50 (select (select .cse51 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse49)))) (or (< ~b~0 0) (< ~a~0 0) (= (select .cse48 (+ .cse49 v_arrayElimCell_35)) .cse50) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= (select .cse48 (+ .cse49 v_arrayElimCell_33)) .cse50) (< 1 ~M~0)))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse54 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse54)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_3 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse58 (let ((.cse60 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse59 (store |c_#memory_int| c_~A~0.base (store .cse60 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse59 .cse54 (store (select .cse59 .cse54) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse60) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse56 (* ~b~0 4))) (let ((.cse57 (select (select .cse58 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse56))) (.cse55 (select .cse58 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse54 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse55 (+ .cse56 v_arrayElimCell_35)) .cse57) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0) (= .cse57 (select .cse55 (+ .cse56 v_arrayElimCell_34)))))))))) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse61 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse61)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_subst_1 Int) (v_arrayElimCell_34 Int)) (let ((.cse65 (let ((.cse67 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse66 (store |c_#memory_int| c_~A~0.base (store .cse67 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse66 .cse61 (store (select .cse66 .cse61) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse67) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse64 (* ~b~0 4))) (let ((.cse62 (select (select .cse65 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse64))) (.cse63 (select .cse65 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse61 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< ~a~0 0) (= .cse62 (select .cse63 (+ .cse64 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse62 (select .cse63 (+ .cse64 v_arrayElimCell_34))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_10 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse72 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse71 (let ((.cse74 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse73 (store |c_#memory_int| c_~A~0.base (store .cse74 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_10)))) (store .cse73 .cse72 (store (select .cse73 .cse72) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse74) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse70 (* ~b~0 4))) (let ((.cse68 (select (select .cse71 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse70))) (.cse69 (select .cse71 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse72 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< ~a~0 0) (= .cse68 (select .cse69 (+ .cse70 v_arrayElimCell_35))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= .cse68 (select .cse69 (+ .cse70 v_arrayElimCell_33))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0) (= .cse68 (select .cse69 (+ .cse70 v_arrayElimCell_34)))))))) (or (forall ((~a~0 Int) (~b~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~M~0 Int) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_6 Int) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_arrayElimCell_33 Int)) (let ((.cse76 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (< ~b~0 0) (< ~a~0 0) (let ((.cse75 (let ((.cse79 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse78 (store |c_#memory_int| c_~A~0.base (store .cse79 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_6)))) (store .cse78 .cse76 (store (select .cse78 .cse76) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse79) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse77 (* ~b~0 4))) (= (select (select .cse75 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse76 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse77 v_arrayElimCell_33)) (select (select .cse75 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse77)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse76) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0)))) .cse11) (forall ((|thread1Thread1of1ForFork0_#t~mem2| Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse80 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (or (not (= c_~B~0.base .cse80)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_subst_8 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (let ((.cse81 (let ((.cse84 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse83 (store |c_#memory_int| c_~A~0.base (store .cse84 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_8)))) (store .cse83 .cse80 (store (select .cse83 .cse80) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse84) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse82 (* ~b~0 4))) (= (select (select .cse81 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse80 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse82 v_arrayElimCell_34)) (select (select .cse81 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse82)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (< 1 ~M~0)))))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (|thread1Thread1of1ForFork0_#t~mem2| Int) (v_subst_9 Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse89 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse10))) (let ((.cse86 (* ~b~0 4)) (.cse88 (let ((.cse91 (store .cse8 .cse9 |thread1Thread1of1ForFork0_#t~mem2|))) (let ((.cse90 (store |c_#memory_int| c_~A~0.base (store .cse91 (+ c_~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_9)))) (store .cse90 .cse89 (store (select .cse90 .cse89) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse91) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse85 (select .cse88 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse89 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse87 (select (select .cse88 c_~A~0.base) (+ c_~A~0.offset (* (* ~M~0 ~a~0) 4) .cse86)))) (or (< ~b~0 0) (= (select .cse85 (+ .cse86 v_arrayElimCell_35)) .cse87) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse4) (= (select .cse85 (+ .cse86 v_arrayElimCell_34)) .cse87) (= (select .cse85 (+ .cse86 v_arrayElimCell_33)) .cse87) (< 1 ~M~0))))))))) is different from true [2024-05-07 09:59:42,454 WARN L876 $PredicateComparison]: unable to prove that (let ((.cse0 (= c_~B~0.base c_~A~0.base))) (let ((.cse43 (not .cse0)) (.cse6 (select |c_#memory_int| c_~A~0.base)) (.cse7 (* c_thread1Thread1of1ForFork0_~i~0 4)) (.cse8 (+ 2 c_thread1Thread1of1ForFork0_~i~0)) (.cse9 (+ (* c_thread2Thread1of1ForFork1_~i~1 4) c_~B~0.offset))) (and (or .cse0 (forall ((~A~0.offset Int) (~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_6 Int) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_21 Int) (v_arrayElimCell_33 Int)) (let ((.cse2 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (< ~b~0 0) (< ~a~0 0) (let ((.cse1 (let ((.cse5 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_21))) (let ((.cse4 (store |c_#memory_int| c_~A~0.base (store .cse5 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_6)))) (store .cse4 .cse2 (store (select .cse4 .cse2) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse5) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse3 (* ~b~0 4))) (= (select (select .cse1 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse2 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse3 v_arrayElimCell_33)) (select (select .cse1 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse3)))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse2) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (< 1 ~M~0))))) (forall ((~A~0.offset Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse10 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (= c_~B~0.base .cse10) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_23 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_5 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (let ((.cse14 (let ((.cse16 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_23))) (let ((.cse15 (store |c_#memory_int| c_~A~0.base (store .cse16 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_5)))) (store .cse15 .cse10 (store (select .cse15 .cse10) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse16) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse12 (* ~b~0 4))) (let ((.cse13 (select (select .cse14 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse12))) (.cse11 (select .cse14 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse10 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse11 (+ .cse12 v_arrayElimCell_35)) .cse13) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (< 1 ~M~0) (= .cse13 (select .cse11 (+ .cse12 v_arrayElimCell_33)))))))))) (forall ((~A~0.offset Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse21 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_12 Int) (v_subst_19 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse20 (let ((.cse23 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_19))) (let ((.cse22 (store |c_#memory_int| c_~A~0.base (store .cse23 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_12)))) (store .cse22 .cse21 (store (select .cse22 .cse21) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse23) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse19 (* ~b~0 4))) (let ((.cse17 (select (select .cse20 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse19))) (.cse18 (select .cse20 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse21 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< ~a~0 0) (= .cse17 (select .cse18 (+ .cse19 v_arrayElimCell_35))) (= .cse17 (select .cse18 (+ .cse19 v_arrayElimCell_33))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (= c_~B~0.base .cse21)))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_22 Int) (v_subst_10 Int) (~A~0.offset Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse28 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (let ((.cse26 (* ~b~0 4)) (.cse27 (let ((.cse30 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_22))) (let ((.cse29 (store |c_#memory_int| c_~A~0.base (store .cse30 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_10)))) (store .cse29 .cse28 (store (select .cse29 .cse28) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse30) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse25 (select .cse27 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse28 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse24 (select (select .cse27 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse26)))) (or (< ~b~0 0) (= .cse24 (select .cse25 (+ .cse26 v_arrayElimCell_34))) (= (select .cse25 (+ .cse26 v_arrayElimCell_33)) .cse24) (= (select .cse25 (+ .cse26 v_arrayElimCell_35)) .cse24) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (or (and (forall ((~A~0.offset Int) (v_subst_14 Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse33 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_subst_7 Int) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse31 (let ((.cse35 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_14))) (let ((.cse34 (store |c_#memory_int| c_~A~0.base (store .cse35 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_7)))) (store .cse34 .cse33 (store (select .cse34 .cse33) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse35) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse32 (* ~b~0 4))) (= (select (select .cse31 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse32)) (select (select .cse31 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse33 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse32 v_arrayElimCell_35)))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (< 1 ~M~0))) (= c_~B~0.base .cse33)))) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_13 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_3 Int) (~A~0.offset Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse40 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (let ((.cse39 (let ((.cse42 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_13))) (let ((.cse41 (store |c_#memory_int| c_~A~0.base (store .cse42 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse41 .cse40 (store (select .cse41 .cse40) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse42) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse37 (* ~b~0 4))) (let ((.cse38 (select (select .cse39 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse37))) (.cse36 (select .cse39 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse40 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= (select .cse36 (+ .cse37 v_arrayElimCell_35)) .cse38) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (< 1 ~M~0) (= .cse38 (select .cse36 (+ .cse37 v_arrayElimCell_34))))))))) .cse43) (or .cse0 (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_subst_18 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_11 Int) (~A~0.offset Int) (~M~0 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_33 Int)) (let ((.cse45 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (< ~b~0 0) (let ((.cse44 (let ((.cse48 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_18))) (let ((.cse47 (store |c_#memory_int| c_~A~0.base (store .cse48 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_11)))) (store .cse47 .cse45 (store (select .cse47 .cse45) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse48) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse46 (* ~b~0 4))) (= (select (select .cse44 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse45 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse46 v_arrayElimCell_33)) (select (select .cse44 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse46)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= c_~B~0.base .cse45) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (forall ((~A~0.offset Int) (v_subst_17 Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse53 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_subst_1 Int) (v_arrayElimCell_34 Int)) (let ((.cse52 (let ((.cse55 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_17))) (let ((.cse54 (store |c_#memory_int| c_~A~0.base (store .cse55 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse54 .cse53 (store (select .cse54 .cse53) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse55) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse51 (* ~b~0 4))) (let ((.cse49 (select (select .cse52 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse51))) (.cse50 (select .cse52 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse53 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (= .cse49 (select .cse50 (+ .cse51 v_arrayElimCell_34))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (= .cse49 (select .cse50 (+ .cse51 v_arrayElimCell_35))) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))) (not (= c_~B~0.base .cse53))))) (forall ((~a~0 Int) (v_subst_25 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (~A~0.offset Int) (v_subst_9 Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse60 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (let ((.cse57 (* ~b~0 4)) (.cse59 (let ((.cse62 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_25))) (let ((.cse61 (store |c_#memory_int| c_~A~0.base (store .cse62 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_9)))) (store .cse61 .cse60 (store (select .cse61 .cse60) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse62) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse56 (select .cse59 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse60 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse58 (select (select .cse59 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse57)))) (or (< ~b~0 0) (= (select .cse56 (+ .cse57 v_arrayElimCell_35)) .cse58) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse56 (+ .cse57 v_arrayElimCell_34)) .cse58) (< ~M~0 (+ ~b~0 1)) (= (select .cse56 (+ .cse57 v_arrayElimCell_33)) .cse58) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (< 1 ~M~0)))))) (forall ((~A~0.offset Int) (v_ArrVal_1230 (Array Int Int)) (v_subst_20 Int)) (let ((.cse63 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (not (= c_~B~0.base .cse63)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_subst_8 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (or (< ~b~0 0) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse64 (let ((.cse67 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_20))) (let ((.cse66 (store |c_#memory_int| c_~A~0.base (store .cse67 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_8)))) (store .cse66 .cse63 (store (select .cse66 .cse63) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse67) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse65 (* ~b~0 4))) (= (select (select .cse64 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse63 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse65 v_arrayElimCell_34)) (select (select .cse64 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse65)))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (< 1 ~M~0)))))) (or .cse43 (and (forall ((v_subst_15 Int) (~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_ArrVal_1230 (Array Int Int)) (v_subst_1 Int) (~A~0.offset Int) (~M~0 Int) (v_arrayElimCell_35 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (let ((.cse72 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (let ((.cse71 (let ((.cse74 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_15))) (let ((.cse73 (store |c_#memory_int| c_~A~0.base (store .cse74 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_1)))) (store .cse73 .cse72 (store (select .cse73 .cse72) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse74) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse70 (* ~b~0 4))) (let ((.cse68 (select (select .cse71 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse70))) (.cse69 (select .cse71 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse72 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))))) (or (< ~b~0 0) (< ~a~0 0) (= .cse68 (select .cse69 (+ .cse70 v_arrayElimCell_34))) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= .cse68 (select .cse69 (+ .cse70 v_arrayElimCell_35))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0)))))) (forall ((~A~0.offset Int) (v_subst_16 Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse76 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_2 Int) (v_arrayElimCell_32 Int)) (or (< ~b~0 0) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (let ((.cse75 (let ((.cse79 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_16))) (let ((.cse78 (store |c_#memory_int| c_~A~0.base (store .cse79 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_2)))) (store .cse78 .cse76 (store (select .cse78 .cse76) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse79) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse77 (* ~b~0 4))) (= (select (select .cse75 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse76 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse77 v_arrayElimCell_35)) (select (select .cse75 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse77)))) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))) (= c_~B~0.base .cse76)))))) (forall ((~A~0.offset Int) (v_subst_26 Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse84 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_arrayElimCell_35 Int) (v_subst_3 Int) (v_arrayElimCell_34 Int) (v_arrayElimCell_33 Int)) (let ((.cse82 (* ~b~0 4)) (.cse83 (let ((.cse86 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_26))) (let ((.cse85 (store |c_#memory_int| c_~A~0.base (store .cse86 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_3)))) (store .cse85 .cse84 (store (select .cse85 .cse84) v_arrayElimCell_33 (select (select (store |c_#memory_int| c_~A~0.base .cse86) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4))))))))) (let ((.cse81 (select .cse83 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse84 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset)))) (.cse80 (select (select .cse83 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse82)))) (or (< ~b~0 0) (= .cse80 (select .cse81 (+ .cse82 v_arrayElimCell_34))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (= (select .cse81 (+ .cse82 v_arrayElimCell_35)) .cse80) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (< 1 ~M~0))))) (not (= c_~B~0.base .cse84))))) (forall ((~A~0.offset Int) (v_subst_24 Int) (v_ArrVal_1230 (Array Int Int))) (let ((.cse87 (select (select (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1230) c_~B~0.base) .cse9))) (or (not (= c_~B~0.base .cse87)) (forall ((~a~0 Int) (v_thread1Thread1of1ForFork0_~i~0_40 Int) (~b~0 Int) (~M~0 Int) (v_ArrVal_1235 (Array Int Int)) (v_ArrVal_1232 (Array Int Int)) (v_subst_4 Int) (v_arrayElimCell_32 Int) (v_arrayElimCell_34 Int)) (or (< ~b~0 0) (let ((.cse88 (let ((.cse91 (store (store .cse6 (+ ~A~0.offset .cse7) |c_thread1Thread1of1ForFork0_#t~mem2|) (+ ~A~0.offset 4 .cse7) v_subst_24))) (let ((.cse90 (store |c_#memory_int| c_~A~0.base (store .cse91 (+ ~A~0.offset (* v_thread1Thread1of1ForFork0_~i~0_40 4)) v_subst_4)))) (store .cse90 .cse87 (store (select .cse90 .cse87) v_arrayElimCell_32 (select (select (store |c_#memory_int| c_~A~0.base .cse91) c_~F~0.base) (+ c_~F~0.offset (* (* c_thread2Thread1of1ForFork1_~i~1 ~M~0) 4)))))))) (.cse89 (* ~b~0 4))) (= (select (select .cse88 (select (select (store (store |c_#memory_$Pointer$.base| c_~A~0.base v_ArrVal_1232) .cse87 v_ArrVal_1235) c_~B~0.base) (+ (* ~a~0 4) c_~B~0.offset))) (+ .cse89 v_arrayElimCell_34)) (select (select .cse88 c_~A~0.base) (+ (* (* ~M~0 ~a~0) 4) ~A~0.offset .cse89)))) (< ~a~0 0) (< c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< ~M~0 (+ ~b~0 1)) (< v_thread1Thread1of1ForFork0_~i~0_40 .cse8) (= c_thread2Thread1of1ForFork1_~i~1 ~a~0) (< 1 ~M~0))))))))) is different from true [2024-05-07 09:59:42,621 INFO L173 IndexEqualityManager]: detected equality via solver [2024-05-07 09:59:42,857 INFO L349 Elim1Store]: treesize reduction 4, result has 97.9 percent of original size [2024-05-07 09:59:42,858 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 0 stores, 4 select indices, 4 select index equivalence classes, 0 disjoint index pairs (out of 6 index pairs), introduced 4 new quantified variables, introduced 6 case distinctions, treesize of input 534926 treesize of output 473162 [2024-05-07 10:01:28,642 INFO L349 Elim1Store]: treesize reduction 8, result has 97.6 percent of original size [2024-05-07 10:01:28,645 INFO L378 Elim1Store]: Elim1 eliminated variable of array dimension 2, 0 stores, 5 select indices, 5 select index equivalence classes, 0 disjoint index pairs (out of 10 index pairs), introduced 5 new quantified variables, introduced 10 case distinctions, treesize of input 11820411 treesize of output 10571199 [2024-05-07 10:02:01,089 WARN L293 SmtUtils]: Spent 32.44s on a formula simplification. DAG size of input: 2607 DAG size of output: 950 (called from [L 731] de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher.simplify) [2024-05-07 10:02:08,545 WARN L293 SmtUtils]: Spent 6.50s on a formula simplification. DAG size of input: 463 DAG size of output: 500 (called from [L 731] de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher.simplify) [2024-05-07 10:02:42,107 WARN L293 SmtUtils]: Spent 5.92s on a formula simplification. DAG size of input: 459 DAG size of output: 490 (called from [L 731] de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher.simplify) [2024-05-07 10:06:39,056 WARN L249 Executor]: External (MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1) with exit command (exit)) stderr output: (error "out of memory") [2024-05-07 10:06:39,057 INFO L136 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2024-05-07 10:06:39,057 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [337362457] [2024-05-07 10:06:39,057 WARN L311 FreeRefinementEngine]: Interpolation failed due to KNOWN_IGNORE: SMT_SOLVER_CANNOT_INTERPOLATE_INPUT [2024-05-07 10:06:39,057 INFO L334 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1016032093] [2024-05-07 10:06:39,057 WARN L320 FreeRefinementEngine]: Global settings require throwing the following exception [2024-05-07 10:06:39,066 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1)] Forceful destruction successful, exit code 101 [2024-05-07 10:06:39,066 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (10)] Forceful destruction successful, exit code 0 [2024-05-07 10:06:39,257 WARN L477 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 10 /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable9 [2024-05-07 10:06:39,258 FATAL L? ?]: An unrecoverable error occured during an interaction with an SMT solver: de.uni_freiburg.informatik.ultimate.logic.SMTLIBException: External (MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1) with exit command (exit)) Received EOF on stdin. stderr output: (error "out of memory") at de.uni_freiburg.informatik.ultimate.smtsolver.external.Executor.parse(Executor.java:262) at de.uni_freiburg.informatik.ultimate.smtsolver.external.Executor.parseSuccess(Executor.java:277) at de.uni_freiburg.informatik.ultimate.smtsolver.external.Scriptor.push(Scriptor.java:133) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.arrays.DiffWrapperScript.push(DiffWrapperScript.java:90) at de.uni_freiburg.informatik.ultimate.logic.WrapperScript.push(WrapperScript.java:148) at de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.smt.scripttransfer.HistoryRecordingScript.push(HistoryRecordingScript.java:107) at de.uni_freiburg.informatik.ultimate.logic.Util.checkSat(Util.java:48) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.SimplifyDDA2.checkRedundancy(SimplifyDDA2.java:268) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.SimplifyDDA2.convertForPreprocessedInputTerms(SimplifyDDA2.java:410) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.SimplifyDDA2.convert(SimplifyDDA2.java:394) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.SimplifyDDA2.convert(SimplifyDDA2.java:1) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.TermContextTransformationEngine.transform(TermContextTransformationEngine.java:88) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.TermContextTransformationEngine.transform(TermContextTransformationEngine.java:84) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.SimplifyDDA2.simplify(SimplifyDDA2.java:500) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.SmtUtils.simplify(SmtUtils.java:252) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.SmtUtils.simplifyWithStatistics(SmtUtils.java:324) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher.simplify(QuantifierPusher.java:731) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPushTermWalker.convert(QuantifierPushTermWalker.java:140) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPushTermWalker.convert(QuantifierPushTermWalker.java:1) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.TermContextTransformationEngine$ApplicationTermTask.doStep(TermContextTransformationEngine.java:209) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.TermContextTransformationEngine.transform(TermContextTransformationEngine.java:100) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.TermContextTransformationEngine.transform(TermContextTransformationEngine.java:84) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPushTermWalker.eliminate(QuantifierPushTermWalker.java:297) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPushUtilsForSubsetPush.pushMinionEliminatees(QuantifierPushUtilsForSubsetPush.java:255) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPushUtilsForSubsetPush.sequentialSubsetPush(QuantifierPushUtilsForSubsetPush.java:151) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher.tryToPushOverDualFiniteConnective(QuantifierPusher.java:338) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPushTermWalker.convert(QuantifierPushTermWalker.java:189) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPushTermWalker.convert(QuantifierPushTermWalker.java:1) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.TermContextTransformationEngine$ApplicationTermTask.doStep(TermContextTransformationEngine.java:209) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.TermContextTransformationEngine.transform(TermContextTransformationEngine.java:100) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.TermContextTransformationEngine.transform(TermContextTransformationEngine.java:84) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPushTermWalker.eliminate(QuantifierPushTermWalker.java:297) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPushTermWalker.eliminate(QuantifierPushTermWalker.java:283) at de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.PartialQuantifierElimination.eliminate(PartialQuantifierElimination.java:51) at de.uni_freiburg.informatik.ultimate.lib.tracecheckerutils.predicates.IterativePredicateTransformer$QuantifierEliminationPostprocessor.postprocess(IterativePredicateTransformer.java:238) at de.uni_freiburg.informatik.ultimate.lib.tracecheckerutils.predicates.IterativePredicateTransformer.applyPostprocessors(IterativePredicateTransformer.java:420) at de.uni_freiburg.informatik.ultimate.lib.tracecheckerutils.predicates.IterativePredicateTransformer.computeBackwardSequence(IterativePredicateTransformer.java:399) at de.uni_freiburg.informatik.ultimate.lib.tracecheckerutils.predicates.IterativePredicateTransformer.computeWeakestPreconditionSequence(IterativePredicateTransformer.java:271) at de.uni_freiburg.informatik.ultimate.lib.tracecheckerutils.singletracecheck.TraceCheckSpWp.computeInterpolantsUsingUnsatCore(TraceCheckSpWp.java:341) at de.uni_freiburg.informatik.ultimate.lib.tracecheckerutils.singletracecheck.TraceCheckSpWp.computeInterpolants(TraceCheckSpWp.java:184) at de.uni_freiburg.informatik.ultimate.lib.tracecheckerutils.singletracecheck.TraceCheckSpWp.(TraceCheckSpWp.java:162) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.tracehandling.IpTcStrategyModuleSpWp.construct(IpTcStrategyModuleSpWp.java:110) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.tracehandling.IpTcStrategyModuleSpWp.construct(IpTcStrategyModuleSpWp.java:1) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.tracehandling.IpTcStrategyModuleBase.getOrConstruct(IpTcStrategyModuleBase.java:101) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.tracehandling.IpTcStrategyModuleBase.isCorrect(IpTcStrategyModuleBase.java:57) at de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.tracehandling.AutomatonFreeRefinementEngine.checkFeasibility(AutomatonFreeRefinementEngine.java:210) at de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.tracehandling.AutomatonFreeRefinementEngine.executeStrategy(AutomatonFreeRefinementEngine.java:121) at de.uni_freiburg.informatik.ultimate.lib.modelcheckerutils.tracehandling.AutomatonFreeRefinementEngine.(AutomatonFreeRefinementEngine.java:85) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.tracehandling.TraceAbstractionRefinementEngine.(TraceAbstractionRefinementEngine.java:82) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.BasicCegarLoop.isCounterexampleFeasible(BasicCegarLoop.java:340) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.AbstractCegarLoop.iterate(AbstractCegarLoop.java:431) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.AbstractCegarLoop.startCegar(AbstractCegarLoop.java:366) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.AbstractCegarLoop.runCegar(AbstractCegarLoop.java:348) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionStarter.executeCegarLoop(TraceAbstractionStarter.java:415) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionStarter.analyseProgram(TraceAbstractionStarter.java:302) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionStarter.analyseConcurrentProgram(TraceAbstractionStarter.java:225) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionStarter.runCegarLoops(TraceAbstractionStarter.java:173) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionStarter.(TraceAbstractionStarter.java:154) at de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver.finish(TraceAbstractionObserver.java:124) at de.uni_freiburg.informatik.ultimate.core.coreplugin.PluginConnector.runObserver(PluginConnector.java:167) at de.uni_freiburg.informatik.ultimate.core.coreplugin.PluginConnector.runTool(PluginConnector.java:150) at de.uni_freiburg.informatik.ultimate.core.coreplugin.PluginConnector.run(PluginConnector.java:127) at de.uni_freiburg.informatik.ultimate.core.coreplugin.ToolchainWalker.executePluginConnector(ToolchainWalker.java:233) at de.uni_freiburg.informatik.ultimate.core.coreplugin.ToolchainWalker.processPlugin(ToolchainWalker.java:227) at de.uni_freiburg.informatik.ultimate.core.coreplugin.ToolchainWalker.walkUnprotected(ToolchainWalker.java:144) at de.uni_freiburg.informatik.ultimate.core.coreplugin.ToolchainWalker.walk(ToolchainWalker.java:106) at de.uni_freiburg.informatik.ultimate.core.coreplugin.ToolchainManager$Toolchain.processToolchain(ToolchainManager.java:319) at de.uni_freiburg.informatik.ultimate.core.coreplugin.toolchain.DefaultToolchainJob.run(DefaultToolchainJob.java:145) at org.eclipse.core.internal.jobs.Worker.run(Worker.java:63) Caused by: de.uni_freiburg.informatik.ultimate.logic.SMTLIBException: EOF at de.uni_freiburg.informatik.ultimate.smtsolver.external.Parser$Action$.CUP$do_action(Parser.java:1518) at de.uni_freiburg.informatik.ultimate.smtsolver.external.Parser.do_action(Parser.java:701) at com.github.jhoenicke.javacup.runtime.LRParser.parse(LRParser.java:383) at de.uni_freiburg.informatik.ultimate.smtsolver.external.Executor.parse(Executor.java:258) ... 68 more [2024-05-07 10:06:39,262 INFO L158 Benchmark]: Toolchain (without parser) took 474536.03ms. Allocated memory was 270.5MB in the beginning and 1.0GB in the end (delta: 744.5MB). Free memory was 199.1MB in the beginning and 745.9MB in the end (delta: -546.8MB). Peak memory consumption was 595.5MB. Max. memory is 8.0GB. [2024-05-07 10:06:39,262 INFO L158 Benchmark]: CDTParser took 0.10ms. Allocated memory is still 166.7MB. Free memory is still 97.6MB. There was no memory consumed. Max. memory is 8.0GB. [2024-05-07 10:06:39,262 INFO L158 Benchmark]: CACSL2BoogieTranslator took 191.34ms. Allocated memory is still 270.5MB. Free memory was 199.0MB in the beginning and 186.9MB in the end (delta: 12.1MB). Peak memory consumption was 11.5MB. Max. memory is 8.0GB. [2024-05-07 10:06:39,262 INFO L158 Benchmark]: Boogie Procedure Inliner took 28.88ms. Allocated memory is still 270.5MB. Free memory was 186.9MB in the beginning and 184.6MB in the end (delta: 2.3MB). Peak memory consumption was 3.1MB. Max. memory is 8.0GB. [2024-05-07 10:06:39,262 INFO L158 Benchmark]: Boogie Preprocessor took 41.73ms. Allocated memory is still 270.5MB. Free memory was 184.6MB in the beginning and 182.7MB in the end (delta: 1.9MB). Peak memory consumption was 1.0MB. Max. memory is 8.0GB. [2024-05-07 10:06:39,262 INFO L158 Benchmark]: RCFGBuilder took 592.61ms. Allocated memory is still 270.5MB. Free memory was 182.5MB in the beginning and 233.3MB in the end (delta: -50.8MB). Peak memory consumption was 25.2MB. Max. memory is 8.0GB. [2024-05-07 10:06:39,263 INFO L158 Benchmark]: TraceAbstraction took 473670.63ms. Allocated memory was 270.5MB in the beginning and 1.0GB in the end (delta: 744.5MB). Free memory was 232.3MB in the beginning and 745.9MB in the end (delta: -513.6MB). Peak memory consumption was 628.8MB. Max. memory is 8.0GB. [2024-05-07 10:06:39,264 INFO L338 ainManager$Toolchain]: ####################### End [Toolchain 1] ####################### --- Results --- * Results from de.uni_freiburg.informatik.ultimate.core: - StatisticsResult: Toolchain Benchmarks Benchmark results are: * CDTParser took 0.10ms. Allocated memory is still 166.7MB. Free memory is still 97.6MB. There was no memory consumed. Max. memory is 8.0GB. * CACSL2BoogieTranslator took 191.34ms. Allocated memory is still 270.5MB. Free memory was 199.0MB in the beginning and 186.9MB in the end (delta: 12.1MB). Peak memory consumption was 11.5MB. Max. memory is 8.0GB. * Boogie Procedure Inliner took 28.88ms. Allocated memory is still 270.5MB. Free memory was 186.9MB in the beginning and 184.6MB in the end (delta: 2.3MB). Peak memory consumption was 3.1MB. Max. memory is 8.0GB. * Boogie Preprocessor took 41.73ms. Allocated memory is still 270.5MB. Free memory was 184.6MB in the beginning and 182.7MB in the end (delta: 1.9MB). Peak memory consumption was 1.0MB. Max. memory is 8.0GB. * RCFGBuilder took 592.61ms. Allocated memory is still 270.5MB. Free memory was 182.5MB in the beginning and 233.3MB in the end (delta: -50.8MB). Peak memory consumption was 25.2MB. Max. memory is 8.0GB. * TraceAbstraction took 473670.63ms. Allocated memory was 270.5MB in the beginning and 1.0GB in the end (delta: 744.5MB). Free memory was 232.3MB in the beginning and 745.9MB in the end (delta: -513.6MB). Peak memory consumption was 628.8MB. Max. memory is 8.0GB. * Results from de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: - ExceptionOrErrorResult: SMTLIBException: External (MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1) with exit command (exit)) Received EOF on stdin. stderr output: (error "out of memory") de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: SMTLIBException: External (MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1) with exit command (exit)) Received EOF on stdin. stderr output: (error "out of memory") : de.uni_freiburg.informatik.ultimate.smtsolver.external.Executor.parse(Executor.java:262) RESULT: Ultimate could not prove your program: Toolchain returned no result. [2024-05-07 10:06:39,288 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UGemCutter-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true -t:1000 (2)] Ended with exit code 0 Received shutdown request...