./Ultimate.py --spec ../sv-benchmarks/c/properties/unreach-call.prp --file ../sv-benchmarks/c/pthread-C-DAC/pthread-demo-datarace-1.i --full-output -ea --architecture 32bit -------------------------------------------------------------------------------- Checking for ERROR reachability Using default analysis Version 03d7b7b3 Calling Ultimate with: /usr/bin/java -Dosgi.configuration.area=/storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/config -Xmx15G -Xms4m -ea -jar /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/plugins/org.eclipse.equinox.launcher_1.5.800.v20200727-1323.jar -data @noDefault -ultimatedata /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data -tc /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/AutomizerReach.xml -i ../sv-benchmarks/c/pthread-C-DAC/pthread-demo-datarace-1.i -s /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/svcomp-Reach-32bit-Automizer_Default.epf --cacsl2boogietranslator.entry.function main --witnessprinter.witness.directory /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux --witnessprinter.witness.filename witness.graphml --witnessprinter.write.witness.besides.input.file false --witnessprinter.graph.data.specification CHECK( init(main()), LTL(G ! call(reach_error())) ) --witnessprinter.graph.data.producer Automizer --witnessprinter.graph.data.architecture 32bit --witnessprinter.graph.data.programhash 81147b3e42a82bd92b2fd1c17836bc41bf8598e66ad2317620561a8ac507fa9a --- Real Ultimate output --- This is Ultimate 0.2.2-dev-03d7b7b [2022-02-20 20:38:33,465 INFO L177 SettingsManager]: Resetting all preferences to default values... [2022-02-20 20:38:33,467 INFO L181 SettingsManager]: Resetting UltimateCore preferences to default values [2022-02-20 20:38:33,490 INFO L184 SettingsManager]: Ultimate Commandline Interface provides no preferences, ignoring... [2022-02-20 20:38:33,491 INFO L181 SettingsManager]: Resetting Boogie Preprocessor preferences to default values [2022-02-20 20:38:33,493 INFO L181 SettingsManager]: Resetting Boogie Procedure Inliner preferences to default values [2022-02-20 20:38:33,495 INFO L181 SettingsManager]: Resetting Abstract Interpretation preferences to default values [2022-02-20 20:38:33,498 INFO L181 SettingsManager]: Resetting LassoRanker preferences to default values [2022-02-20 20:38:33,499 INFO L181 SettingsManager]: Resetting Reaching Definitions preferences to default values [2022-02-20 20:38:33,504 INFO L181 SettingsManager]: Resetting SyntaxChecker preferences to default values [2022-02-20 20:38:33,505 INFO L181 SettingsManager]: Resetting Sifa preferences to default values [2022-02-20 20:38:33,506 INFO L184 SettingsManager]: Büchi Program Product provides no preferences, ignoring... [2022-02-20 20:38:33,506 INFO L181 SettingsManager]: Resetting LTL2Aut preferences to default values [2022-02-20 20:38:33,509 INFO L181 SettingsManager]: Resetting PEA to Boogie preferences to default values [2022-02-20 20:38:33,509 INFO L181 SettingsManager]: Resetting BlockEncodingV2 preferences to default values [2022-02-20 20:38:33,511 INFO L181 SettingsManager]: Resetting ChcToBoogie preferences to default values [2022-02-20 20:38:33,511 INFO L181 SettingsManager]: Resetting AutomataScriptInterpreter preferences to default values [2022-02-20 20:38:33,512 INFO L181 SettingsManager]: Resetting BuchiAutomizer preferences to default values [2022-02-20 20:38:33,516 INFO L181 SettingsManager]: Resetting CACSL2BoogieTranslator preferences to default values [2022-02-20 20:38:33,517 INFO L181 SettingsManager]: Resetting CodeCheck preferences to default values [2022-02-20 20:38:33,518 INFO L181 SettingsManager]: Resetting InvariantSynthesis preferences to default values [2022-02-20 20:38:33,519 INFO L181 SettingsManager]: Resetting RCFGBuilder preferences to default values [2022-02-20 20:38:33,519 INFO L181 SettingsManager]: Resetting Referee preferences to default values [2022-02-20 20:38:33,520 INFO L181 SettingsManager]: Resetting TraceAbstraction preferences to default values [2022-02-20 20:38:33,521 INFO L184 SettingsManager]: TraceAbstractionConcurrent provides no preferences, ignoring... [2022-02-20 20:38:33,522 INFO L184 SettingsManager]: TraceAbstractionWithAFAs provides no preferences, ignoring... [2022-02-20 20:38:33,522 INFO L181 SettingsManager]: Resetting TreeAutomizer preferences to default values [2022-02-20 20:38:33,522 INFO L181 SettingsManager]: Resetting IcfgToChc preferences to default values [2022-02-20 20:38:33,523 INFO L181 SettingsManager]: Resetting IcfgTransformer preferences to default values [2022-02-20 20:38:33,523 INFO L184 SettingsManager]: ReqToTest provides no preferences, ignoring... [2022-02-20 20:38:33,524 INFO L181 SettingsManager]: Resetting Boogie Printer preferences to default values [2022-02-20 20:38:33,524 INFO L181 SettingsManager]: Resetting ChcSmtPrinter preferences to default values [2022-02-20 20:38:33,525 INFO L181 SettingsManager]: Resetting ReqPrinter preferences to default values [2022-02-20 20:38:33,526 INFO L181 SettingsManager]: Resetting Witness Printer preferences to default values [2022-02-20 20:38:33,527 INFO L184 SettingsManager]: Boogie PL CUP Parser provides no preferences, ignoring... [2022-02-20 20:38:33,527 INFO L181 SettingsManager]: Resetting CDTParser preferences to default values [2022-02-20 20:38:33,527 INFO L184 SettingsManager]: AutomataScriptParser provides no preferences, ignoring... [2022-02-20 20:38:33,528 INFO L184 SettingsManager]: ReqParser provides no preferences, ignoring... [2022-02-20 20:38:33,528 INFO L181 SettingsManager]: Resetting SmtParser preferences to default values [2022-02-20 20:38:33,528 INFO L181 SettingsManager]: Resetting Witness Parser preferences to default values [2022-02-20 20:38:33,529 INFO L188 SettingsManager]: Finished resetting all preferences to default values... [2022-02-20 20:38:33,529 INFO L101 SettingsManager]: Beginning loading settings from /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/config/svcomp-Reach-32bit-Automizer_Default.epf [2022-02-20 20:38:33,546 INFO L113 SettingsManager]: Loading preferences was successful [2022-02-20 20:38:33,546 INFO L115 SettingsManager]: Preferences different from defaults after loading the file: [2022-02-20 20:38:33,547 INFO L136 SettingsManager]: Preferences of UltimateCore differ from their defaults: [2022-02-20 20:38:33,547 INFO L138 SettingsManager]: * Log level for class=de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=ERROR; [2022-02-20 20:38:33,548 INFO L136 SettingsManager]: Preferences of Boogie Procedure Inliner differ from their defaults: [2022-02-20 20:38:33,548 INFO L138 SettingsManager]: * Ignore calls to procedures called more than once=ONLY_FOR_SEQUENTIAL_PROGRAMS [2022-02-20 20:38:33,548 INFO L136 SettingsManager]: Preferences of BlockEncodingV2 differ from their defaults: [2022-02-20 20:38:33,548 INFO L138 SettingsManager]: * Create parallel compositions if possible=false [2022-02-20 20:38:33,548 INFO L138 SettingsManager]: * Use SBE=true [2022-02-20 20:38:33,549 INFO L136 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2022-02-20 20:38:33,549 INFO L138 SettingsManager]: * sizeof long=4 [2022-02-20 20:38:33,549 INFO L138 SettingsManager]: * Overapproximate operations on floating types=true [2022-02-20 20:38:33,550 INFO L138 SettingsManager]: * sizeof POINTER=4 [2022-02-20 20:38:33,550 INFO L138 SettingsManager]: * Check division by zero=IGNORE [2022-02-20 20:38:33,550 INFO L138 SettingsManager]: * Pointer to allocated memory at dereference=IGNORE [2022-02-20 20:38:33,550 INFO L138 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=IGNORE [2022-02-20 20:38:33,550 INFO L138 SettingsManager]: * Check array bounds for arrays that are off heap=IGNORE [2022-02-20 20:38:33,550 INFO L138 SettingsManager]: * sizeof long double=12 [2022-02-20 20:38:33,550 INFO L138 SettingsManager]: * Check if freed pointer was valid=false [2022-02-20 20:38:33,551 INFO L138 SettingsManager]: * Use constant arrays=true [2022-02-20 20:38:33,551 INFO L138 SettingsManager]: * Pointer base address is valid at dereference=IGNORE [2022-02-20 20:38:33,551 INFO L136 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2022-02-20 20:38:33,551 INFO L138 SettingsManager]: * Size of a code block=SequenceOfStatements [2022-02-20 20:38:33,551 INFO L138 SettingsManager]: * SMT solver=External_DefaultMode [2022-02-20 20:38:33,551 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 20:38:33,552 INFO L136 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2022-02-20 20:38:33,552 INFO L138 SettingsManager]: * Compute Interpolants along a Counterexample=FPandBP [2022-02-20 20:38:33,552 INFO L138 SettingsManager]: * Positions where we compute the Hoare Annotation=LoopsAndPotentialCycles [2022-02-20 20:38:33,552 INFO L138 SettingsManager]: * Trace refinement strategy=CAMEL [2022-02-20 20:38:33,552 INFO L138 SettingsManager]: * Command for external solver=z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in [2022-02-20 20:38:33,552 INFO L138 SettingsManager]: * Large block encoding in concurrent analysis=OFF [2022-02-20 20:38:33,552 INFO L138 SettingsManager]: * Automaton type used in concurrency analysis=PETRI_NET [2022-02-20 20:38:33,553 INFO L138 SettingsManager]: * Compute Hoare Annotation of negated interpolant automaton, abstraction and CFG=true [2022-02-20 20:38:33,553 INFO L138 SettingsManager]: * SMT solver=External_ModelsAndUnsatCoreMode WARNING: An illegal reflective access operation has occurred WARNING: Illegal reflective access by com.sun.xml.bind.v2.runtime.reflect.opt.Injector$1 (file:/storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/plugins/com.sun.xml.bind_2.2.0.v201505121915.jar) to method java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int) WARNING: Please consider reporting this to the maintainers of com.sun.xml.bind.v2.runtime.reflect.opt.Injector$1 WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations WARNING: All illegal access operations will be denied in a future release Applying setting for plugin de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator: Entry function -> main Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Witness directory -> /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Witness filename -> witness.graphml Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Write witness besides input file -> false Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data specification -> CHECK( init(main()), LTL(G ! call(reach_error())) ) Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data producer -> Automizer Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data architecture -> 32bit Applying setting for plugin de.uni_freiburg.informatik.ultimate.witnessprinter: Graph data programhash -> 81147b3e42a82bd92b2fd1c17836bc41bf8598e66ad2317620561a8ac507fa9a [2022-02-20 20:38:33,733 INFO L75 nceAwareModelManager]: Repository-Root is: /tmp [2022-02-20 20:38:33,748 INFO L261 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2022-02-20 20:38:33,750 INFO L217 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2022-02-20 20:38:33,750 INFO L271 PluginConnector]: Initializing CDTParser... [2022-02-20 20:38:33,751 INFO L275 PluginConnector]: CDTParser initialized [2022-02-20 20:38:33,752 INFO L432 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../sv-benchmarks/c/pthread-C-DAC/pthread-demo-datarace-1.i [2022-02-20 20:38:33,809 INFO L220 CDTParser]: Created temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/c06678cb5/decf6df286184463862ecb32fa0b177f/FLAGad82525ab [2022-02-20 20:38:34,258 INFO L306 CDTParser]: Found 1 translation units. [2022-02-20 20:38:34,259 INFO L160 CDTParser]: Scanning /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/pthread-C-DAC/pthread-demo-datarace-1.i [2022-02-20 20:38:34,277 INFO L349 CDTParser]: About to delete temporary CDT project at /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/c06678cb5/decf6df286184463862ecb32fa0b177f/FLAGad82525ab [2022-02-20 20:38:34,288 INFO L357 CDTParser]: Successfully deleted /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/data/c06678cb5/decf6df286184463862ecb32fa0b177f [2022-02-20 20:38:34,290 INFO L299 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2022-02-20 20:38:34,291 INFO L131 ToolchainWalker]: Walking toolchain with 6 elements. [2022-02-20 20:38:34,292 INFO L113 PluginConnector]: ------------------------CACSL2BoogieTranslator---------------------------- [2022-02-20 20:38:34,292 INFO L271 PluginConnector]: Initializing CACSL2BoogieTranslator... [2022-02-20 20:38:34,294 INFO L275 PluginConnector]: CACSL2BoogieTranslator initialized [2022-02-20 20:38:34,295 INFO L185 PluginConnector]: Executing the observer ACSLObjectContainerObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,295 INFO L205 PluginConnector]: Invalid model from CACSL2BoogieTranslator for observer de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator.ACSLObjectContainerObserver@79b94b80 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34, skipping insertion in model container [2022-02-20 20:38:34,296 INFO L185 PluginConnector]: Executing the observer CACSL2BoogieTranslatorObserver from plugin CACSL2BoogieTranslator for "CDTParser AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,300 INFO L145 MainTranslator]: Starting translation in SV-COMP mode [2022-02-20 20:38:34,339 INFO L178 MainTranslator]: Built tables and reachable declarations [2022-02-20 20:38:34,501 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/pthread-C-DAC/pthread-demo-datarace-1.i[820,833] [2022-02-20 20:38:34,680 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 20:38:34,686 INFO L203 MainTranslator]: Completed pre-run [2022-02-20 20:38:34,694 WARN L230 ndardFunctionHandler]: Function reach_error is already implemented but we override the implementation for the call at /storage/repos/ultimate/releaseScripts/default/sv-benchmarks/c/pthread-C-DAC/pthread-demo-datarace-1.i[820,833] [2022-02-20 20:38:34,716 INFO L210 PostProcessor]: Analyzing one entry point: main [2022-02-20 20:38:34,761 INFO L208 MainTranslator]: Completed translation [2022-02-20 20:38:34,762 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34 WrapperNode [2022-02-20 20:38:34,762 INFO L132 PluginConnector]: ------------------------ END CACSL2BoogieTranslator---------------------------- [2022-02-20 20:38:34,763 INFO L113 PluginConnector]: ------------------------Boogie Procedure Inliner---------------------------- [2022-02-20 20:38:34,763 INFO L271 PluginConnector]: Initializing Boogie Procedure Inliner... [2022-02-20 20:38:34,763 INFO L275 PluginConnector]: Boogie Procedure Inliner initialized [2022-02-20 20:38:34,773 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,785 INFO L185 PluginConnector]: Executing the observer Inliner from plugin Boogie Procedure Inliner for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,805 INFO L137 Inliner]: procedures = 364, calls = 25, calls flagged for inlining = 3, calls inlined = 3, statements flattened = 67 [2022-02-20 20:38:34,805 INFO L132 PluginConnector]: ------------------------ END Boogie Procedure Inliner---------------------------- [2022-02-20 20:38:34,806 INFO L113 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2022-02-20 20:38:34,806 INFO L271 PluginConnector]: Initializing Boogie Preprocessor... [2022-02-20 20:38:34,806 INFO L275 PluginConnector]: Boogie Preprocessor initialized [2022-02-20 20:38:34,812 INFO L185 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,812 INFO L185 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,814 INFO L185 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,814 INFO L185 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,818 INFO L185 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,820 INFO L185 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,821 INFO L185 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,823 INFO L132 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2022-02-20 20:38:34,823 INFO L113 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2022-02-20 20:38:34,823 INFO L271 PluginConnector]: Initializing RCFGBuilder... [2022-02-20 20:38:34,823 INFO L275 PluginConnector]: RCFGBuilder initialized [2022-02-20 20:38:34,824 INFO L185 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (1/1) ... [2022-02-20 20:38:34,828 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 [2022-02-20 20:38:34,837 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 20:38:34,846 INFO L229 MonitoredProcess]: Starting monitored process 1 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (exit command is (exit), workingDir is null) [2022-02-20 20:38:34,865 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:2024 -smt2 -in -t:2000 (1)] Waiting until timeout for monitored process [2022-02-20 20:38:34,870 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocOnStack [2022-02-20 20:38:34,870 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.dealloc [2022-02-20 20:38:34,871 INFO L130 BoogieDeclarations]: Found specification of procedure read~int [2022-02-20 20:38:34,871 INFO L130 BoogieDeclarations]: Found specification of procedure write~int [2022-02-20 20:38:34,871 INFO L130 BoogieDeclarations]: Found specification of procedure #PthreadsMutexLock [2022-02-20 20:38:34,871 INFO L130 BoogieDeclarations]: Found specification of procedure #Ultimate.allocInit [2022-02-20 20:38:34,871 INFO L130 BoogieDeclarations]: Found specification of procedure thread_function_mutex [2022-02-20 20:38:34,871 INFO L138 BoogieDeclarations]: Found implementation of procedure thread_function_mutex [2022-02-20 20:38:34,871 INFO L130 BoogieDeclarations]: Found specification of procedure write~init~int [2022-02-20 20:38:34,872 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2022-02-20 20:38:34,872 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2022-02-20 20:38:34,873 WARN L208 CfgBuilder]: User set CodeBlockSize to SequenceOfStatements but program contains fork statements. Overwriting the user preferences and setting CodeBlockSize to SingleStatement [2022-02-20 20:38:34,944 INFO L234 CfgBuilder]: Building ICFG [2022-02-20 20:38:34,945 INFO L260 CfgBuilder]: Building CFG for each procedure with an implementation [2022-02-20 20:38:35,086 INFO L275 CfgBuilder]: Performing block encoding [2022-02-20 20:38:35,092 INFO L294 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2022-02-20 20:38:35,092 INFO L299 CfgBuilder]: Removed 2 assume(true) statements. [2022-02-20 20:38:35,093 INFO L202 PluginConnector]: Adding new model de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 08:38:35 BoogieIcfgContainer [2022-02-20 20:38:35,093 INFO L132 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2022-02-20 20:38:35,095 INFO L113 PluginConnector]: ------------------------TraceAbstraction---------------------------- [2022-02-20 20:38:35,095 INFO L271 PluginConnector]: Initializing TraceAbstraction... [2022-02-20 20:38:35,097 INFO L275 PluginConnector]: TraceAbstraction initialized [2022-02-20 20:38:35,097 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "CDTParser AST 20.02 08:38:34" (1/3) ... [2022-02-20 20:38:35,098 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@5262f639 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 08:38:35, skipping insertion in model container [2022-02-20 20:38:35,098 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.cacsl2boogietranslator AST 20.02 08:38:34" (2/3) ... [2022-02-20 20:38:35,098 INFO L205 PluginConnector]: Invalid model from TraceAbstraction for observer de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction.TraceAbstractionObserver@5262f639 and model type de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction AST 20.02 08:38:35, skipping insertion in model container [2022-02-20 20:38:35,098 INFO L185 PluginConnector]: Executing the observer TraceAbstractionObserver from plugin TraceAbstraction for "de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 20.02 08:38:35" (3/3) ... [2022-02-20 20:38:35,099 INFO L111 eAbstractionObserver]: Analyzing ICFG pthread-demo-datarace-1.i [2022-02-20 20:38:35,105 WARN L150 ceAbstractionStarter]: Switching off computation of Hoare annotation because input is a concurrent program [2022-02-20 20:38:35,105 INFO L205 ceAbstractionStarter]: Automizer settings: Hoare:false NWA Interpolation:FPandBP Determinization: PREDICATE_ABSTRACTION [2022-02-20 20:38:35,105 INFO L164 ceAbstractionStarter]: Applying trace abstraction to program that has 1 error locations. [2022-02-20 20:38:35,105 INFO L534 ceAbstractionStarter]: Constructing petrified ICFG for 1 thread instances. [2022-02-20 20:38:35,147 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#in~arg.offset| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,147 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#in~arg.base| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,147 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~arg.offset not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,148 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~arg.base not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,148 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#in~arg.offset| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,148 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#in~arg.base| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,148 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~arg.offset not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,149 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~arg.base not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,149 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,149 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,149 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,149 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,150 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,150 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,150 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,152 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,153 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,154 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,155 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#res.base| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,155 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#res.offset| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,156 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#res.base| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,156 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#res.offset| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,156 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~nondet32| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,156 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~nondet32| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,157 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~nondet32| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,157 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~nondet32| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,157 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,157 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,158 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,158 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,158 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,158 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,159 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~nondet33| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,159 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~nondet33| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,159 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,159 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,160 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,160 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~post31| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,160 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,160 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~post31| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,160 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~post31| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,160 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,161 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~post31| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,161 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,161 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~post31| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,161 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~post31| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,164 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#res.offset| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,164 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~arg.base not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,165 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~j~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,165 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~post31| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,165 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~i~0 not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,165 WARN L322 ript$VariableManager]: TermVariabe thread_function_mutexThread1of1ForFork0_~arg.offset not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,165 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~nondet33| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,166 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#res.base| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,166 WARN L322 ript$VariableManager]: TermVariabe |thread_function_mutexThread1of1ForFork0_#t~nondet32| not constructed by VariableManager. Cannot ensure absence of name clashes. [2022-02-20 20:38:35,172 INFO L148 ThreadInstanceAdder]: Constructed 1 joinOtherThreadTransitions. [2022-02-20 20:38:35,203 INFO L338 AbstractCegarLoop]: ======== Iteration 0 == of CEGAR loop == AllErrorsAtOnce ======== [2022-02-20 20:38:35,207 INFO L339 AbstractCegarLoop]: Settings: SEPARATE_VIOLATION_CHECK=true, mInterprocedural=true, mMaxIterations=1000000, mWatchIteration=1000000, mArtifact=RCFG, mInterpolation=FPandBP, mInterpolantAutomaton=STRAIGHT_LINE, mDumpAutomata=false, mAutomataFormat=ATS_NUMERATE, mDumpPath=., mDeterminiation=PREDICATE_ABSTRACTION, mMinimize=MINIMIZE_SEVPA, mHoare=true, mAutomataTypeConcurrency=PETRI_NET, mHoareTripleChecks=INCREMENTAL, mHoareAnnotationPositions=LoopsAndPotentialCycles, mDumpOnlyReuseAutomata=false, mLimitTraceHistogram=0, mErrorLocTimeLimit=0, mLimitPathProgramCount=0, mCollectInterpolantStatistics=true, mHeuristicEmptinessCheck=false, mHeuristicEmptinessCheckAStarHeuristic=ZERO, mHeuristicEmptinessCheckAStarHeuristicRandomSeed=1337, mHeuristicEmptinessCheckSmtFeatureScoringMethod=DAGSIZE, mSMTFeatureExtraction=false, mSMTFeatureExtractionDumpPath=., mOverrideInterpolantAutomaton=false, mMcrInterpolantMethod=WP, mLoopAccelerationTechnique=FAST_UPR [2022-02-20 20:38:35,207 INFO L340 AbstractCegarLoop]: Starting to check reachability of 2 error locations. [2022-02-20 20:38:35,215 INFO L74 FinitePrefix]: Start finitePrefix. Operand has 94 places, 97 transitions, 202 flow [2022-02-20 20:38:35,246 INFO L129 PetriNetUnfolder]: 7/96 cut-off events. [2022-02-20 20:38:35,247 INFO L130 PetriNetUnfolder]: For 1/1 co-relation queries the response was YES. [2022-02-20 20:38:35,250 INFO L84 FinitePrefix]: Finished finitePrefix Result has 101 conditions, 96 events. 7/96 cut-off events. For 1/1 co-relation queries the response was YES. Maximal size of possible extension queue 4. Compared 82 event pairs, 0 based on Foata normal form. 0/88 useless extension candidates. Maximal degree in co-relation 38. Up to 2 conditions per place. [2022-02-20 20:38:35,250 INFO L82 GeneralOperation]: Start removeDead. Operand has 94 places, 97 transitions, 202 flow [2022-02-20 20:38:35,253 INFO L88 GeneralOperation]: Finished RemoveDead, result has has 84 places, 86 transitions, 178 flow [2022-02-20 20:38:35,267 INFO L129 PetriNetUnfolder]: 6/85 cut-off events. [2022-02-20 20:38:35,267 INFO L130 PetriNetUnfolder]: For 1/1 co-relation queries the response was YES. [2022-02-20 20:38:35,267 INFO L246 CegarLoopForPetriNet]: Found error trace [2022-02-20 20:38:35,268 INFO L254 CegarLoopForPetriNet]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 20:38:35,268 INFO L402 AbstractCegarLoop]: === Iteration 1 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATION] === [2022-02-20 20:38:35,272 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 20:38:35,272 INFO L85 PathProgramCache]: Analyzing trace with hash 730854198, now seen corresponding path program 1 times [2022-02-20 20:38:35,278 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 20:38:35,278 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1444346374] [2022-02-20 20:38:35,279 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 20:38:35,279 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 20:38:35,361 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:35,470 INFO L290 TraceCheckUtils]: 0: Hoare triple {97#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,470 INFO L290 TraceCheckUtils]: 1: Hoare triple {97#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {97#true} is VALID [2022-02-20 20:38:35,471 INFO L290 TraceCheckUtils]: 2: Hoare triple {97#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,471 INFO L290 TraceCheckUtils]: 3: Hoare triple {97#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,472 INFO L290 TraceCheckUtils]: 4: Hoare triple {97#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,472 INFO L290 TraceCheckUtils]: 5: Hoare triple {97#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,473 INFO L290 TraceCheckUtils]: 6: Hoare triple {97#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,473 INFO L290 TraceCheckUtils]: 7: Hoare triple {97#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,476 INFO L290 TraceCheckUtils]: 8: Hoare triple {97#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,476 INFO L290 TraceCheckUtils]: 9: Hoare triple {97#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,477 INFO L290 TraceCheckUtils]: 10: Hoare triple {97#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,478 INFO L290 TraceCheckUtils]: 11: Hoare triple {97#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,478 INFO L290 TraceCheckUtils]: 12: Hoare triple {97#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,479 INFO L290 TraceCheckUtils]: 13: Hoare triple {97#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {97#true} is VALID [2022-02-20 20:38:35,479 INFO L290 TraceCheckUtils]: 14: Hoare triple {97#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {97#true} is VALID [2022-02-20 20:38:35,479 INFO L290 TraceCheckUtils]: 15: Hoare triple {97#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,480 INFO L290 TraceCheckUtils]: 16: Hoare triple {97#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,484 INFO L290 TraceCheckUtils]: 17: Hoare triple {97#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,484 INFO L290 TraceCheckUtils]: 18: Hoare triple {97#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,485 INFO L290 TraceCheckUtils]: 19: Hoare triple {97#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,485 INFO L290 TraceCheckUtils]: 20: Hoare triple {97#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,485 INFO L290 TraceCheckUtils]: 21: Hoare triple {97#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,485 INFO L290 TraceCheckUtils]: 22: Hoare triple {97#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,486 INFO L290 TraceCheckUtils]: 23: Hoare triple {97#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {97#true} is VALID [2022-02-20 20:38:35,487 INFO L290 TraceCheckUtils]: 24: Hoare triple {97#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {97#true} is VALID [2022-02-20 20:38:35,487 INFO L290 TraceCheckUtils]: 25: Hoare triple {97#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {97#true} is VALID [2022-02-20 20:38:35,487 INFO L290 TraceCheckUtils]: 26: Hoare triple {97#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {97#true} is VALID [2022-02-20 20:38:35,488 INFO L290 TraceCheckUtils]: 27: Hoare triple {97#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {97#true} is VALID [2022-02-20 20:38:35,488 INFO L290 TraceCheckUtils]: 28: Hoare triple {97#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {97#true} is VALID [2022-02-20 20:38:35,488 INFO L290 TraceCheckUtils]: 29: Hoare triple {97#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {97#true} is VALID [2022-02-20 20:38:35,489 INFO L290 TraceCheckUtils]: 30: Hoare triple {97#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {97#true} is VALID [2022-02-20 20:38:35,489 INFO L290 TraceCheckUtils]: 31: Hoare triple {97#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {97#true} is VALID [2022-02-20 20:38:35,489 INFO L290 TraceCheckUtils]: 32: Hoare triple {97#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {97#true} is VALID [2022-02-20 20:38:35,489 INFO L290 TraceCheckUtils]: 33: Hoare triple {97#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {97#true} is VALID [2022-02-20 20:38:35,490 INFO L290 TraceCheckUtils]: 34: Hoare triple {97#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {97#true} is VALID [2022-02-20 20:38:35,490 INFO L290 TraceCheckUtils]: 35: Hoare triple {97#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {97#true} is VALID [2022-02-20 20:38:35,490 INFO L290 TraceCheckUtils]: 36: Hoare triple {97#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {97#true} is VALID [2022-02-20 20:38:35,490 INFO L290 TraceCheckUtils]: 37: Hoare triple {97#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {97#true} is VALID [2022-02-20 20:38:35,491 INFO L290 TraceCheckUtils]: 38: Hoare triple {97#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {97#true} is VALID [2022-02-20 20:38:35,491 INFO L290 TraceCheckUtils]: 39: Hoare triple {97#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {97#true} is VALID [2022-02-20 20:38:35,492 INFO L290 TraceCheckUtils]: 40: Hoare triple {97#true} [220] L1347-5-->L1347-6: Formula: false InVars {} OutVars{} AuxVars[] AssignedVars[] {98#false} is VALID [2022-02-20 20:38:35,492 INFO L290 TraceCheckUtils]: 41: Hoare triple {98#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {98#false} is VALID [2022-02-20 20:38:35,492 INFO L290 TraceCheckUtils]: 42: Hoare triple {98#false} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {98#false} is VALID [2022-02-20 20:38:35,492 INFO L290 TraceCheckUtils]: 43: Hoare triple {98#false} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {98#false} is VALID [2022-02-20 20:38:35,493 INFO L290 TraceCheckUtils]: 44: Hoare triple {98#false} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {98#false} is VALID [2022-02-20 20:38:35,493 INFO L290 TraceCheckUtils]: 45: Hoare triple {98#false} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {98#false} is VALID [2022-02-20 20:38:35,493 INFO L290 TraceCheckUtils]: 46: Hoare triple {98#false} [230] L1323-6-->L1323-7: Formula: false InVars {} OutVars{} AuxVars[] AssignedVars[] {98#false} is VALID [2022-02-20 20:38:35,494 INFO L290 TraceCheckUtils]: 47: Hoare triple {98#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {98#false} is VALID [2022-02-20 20:38:35,494 INFO L290 TraceCheckUtils]: 48: Hoare triple {98#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {98#false} is VALID [2022-02-20 20:38:35,494 INFO L290 TraceCheckUtils]: 49: Hoare triple {98#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {98#false} is VALID [2022-02-20 20:38:35,498 INFO L290 TraceCheckUtils]: 50: Hoare triple {98#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {98#false} is VALID [2022-02-20 20:38:35,498 INFO L290 TraceCheckUtils]: 51: Hoare triple {98#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {98#false} is VALID [2022-02-20 20:38:35,498 INFO L290 TraceCheckUtils]: 52: Hoare triple {98#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {98#false} is VALID [2022-02-20 20:38:35,499 INFO L290 TraceCheckUtils]: 53: Hoare triple {98#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {98#false} is VALID [2022-02-20 20:38:35,499 INFO L290 TraceCheckUtils]: 54: Hoare triple {98#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {98#false} is VALID [2022-02-20 20:38:35,500 INFO L290 TraceCheckUtils]: 55: Hoare triple {98#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {98#false} is VALID [2022-02-20 20:38:35,501 INFO L290 TraceCheckUtils]: 56: Hoare triple {98#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {98#false} is VALID [2022-02-20 20:38:35,502 INFO L290 TraceCheckUtils]: 57: Hoare triple {98#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {98#false} is VALID [2022-02-20 20:38:35,503 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 20:38:35,503 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 20:38:35,504 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1444346374] [2022-02-20 20:38:35,504 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1444346374] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 20:38:35,504 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 20:38:35,504 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [2] imperfect sequences [] total 2 [2022-02-20 20:38:35,507 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [329526841] [2022-02-20 20:38:35,507 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 20:38:35,518 INFO L78 Accepts]: Start accepts. Automaton has has 2 states, 2 states have (on average 29.0) internal successors, (58), 2 states have internal predecessors, (58), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 58 [2022-02-20 20:38:35,519 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 20:38:35,522 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 2 states, 2 states have (on average 29.0) internal successors, (58), 2 states have internal predecessors, (58), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,594 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 58 edges. 58 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 20:38:35,594 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 2 states [2022-02-20 20:38:35,594 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 20:38:35,635 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 2 interpolants. [2022-02-20 20:38:35,636 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=1, Invalid=1, Unknown=0, NotChecked=0, Total=2 [2022-02-20 20:38:35,637 INFO L499 CegarLoopForPetriNet]: Number of universal loopers: 87 out of 97 [2022-02-20 20:38:35,639 INFO L92 encePairwiseOnDemand]: Start differencePairwiseOnDemand. First operand has 84 places, 86 transitions, 178 flow. Second operand has 2 states, 2 states have (on average 89.0) internal successors, (178), 2 states have internal predecessors, (178), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,639 INFO L101 encePairwiseOnDemand]: Universal subtrahend loopers provided by user. [2022-02-20 20:38:35,639 INFO L102 encePairwiseOnDemand]: Number of universal subtrahend loopers: 87 of 97 [2022-02-20 20:38:35,640 INFO L74 FinitePrefix]: Start finitePrefix. Operand will be constructed on-demand [2022-02-20 20:38:35,683 INFO L129 PetriNetUnfolder]: 2/80 cut-off events. [2022-02-20 20:38:35,685 INFO L130 PetriNetUnfolder]: For 4/4 co-relation queries the response was YES. [2022-02-20 20:38:35,686 INFO L84 FinitePrefix]: Finished finitePrefix Result has 88 conditions, 80 events. 2/80 cut-off events. For 4/4 co-relation queries the response was YES. Maximal size of possible extension queue 4. Compared 68 event pairs, 0 based on Foata normal form. 4/81 useless extension candidates. Maximal degree in co-relation 35. Up to 3 conditions per place. [2022-02-20 20:38:35,687 INFO L132 encePairwiseOnDemand]: 93/97 looper letters, 2 selfloop transitions, 0 changer transitions 0/80 dead transitions. [2022-02-20 20:38:35,687 INFO L138 encePairwiseOnDemand]: Finished differencePairwiseOnDemand. Result has 83 places, 80 transitions, 170 flow [2022-02-20 20:38:35,687 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 2 states. [2022-02-20 20:38:35,689 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 2 states. [2022-02-20 20:38:35,703 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 2 states to 2 states and 180 transitions. [2022-02-20 20:38:35,705 INFO L544 CegarLoopForPetriNet]: DFA transition density 0.9278350515463918 [2022-02-20 20:38:35,705 INFO L72 ComplementDD]: Start complementDD. Operand 2 states and 180 transitions. [2022-02-20 20:38:35,706 INFO L73 IsDeterministic]: Start isDeterministic. Operand 2 states and 180 transitions. [2022-02-20 20:38:35,706 INFO L80 IsDeterministic]: Finished isDeterministic. Operand is deterministic. [2022-02-20 20:38:35,708 INFO L117 ReachableStatesCopy]: Start reachableStatesCopy. Operand 2 states and 180 transitions. [2022-02-20 20:38:35,711 INFO L343 DoubleDeckerVisitor]: Before removal of dead ends has 3 states, 2 states have (on average 90.0) internal successors, (180), 2 states have internal predecessors, (180), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,713 INFO L131 ReachableStatesCopy]: Finished reachableStatesCopy Result has 3 states, 3 states have (on average 97.0) internal successors, (291), 3 states have internal predecessors, (291), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,714 INFO L81 ComplementDD]: Finished complementDD. Result has 3 states, 3 states have (on average 97.0) internal successors, (291), 3 states have internal predecessors, (291), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,715 INFO L186 Difference]: Start difference. First operand has 84 places, 86 transitions, 178 flow. Second operand 2 states and 180 transitions. [2022-02-20 20:38:35,716 INFO L82 GeneralOperation]: Start removeRedundantFlow. Operand has 83 places, 80 transitions, 170 flow [2022-02-20 20:38:35,723 INFO L88 GeneralOperation]: Finished removeRedundantFlow, result has has 81 places, 80 transitions, 166 flow, removed 0 selfloop flow, removed 2 redundant places. [2022-02-20 20:38:35,726 INFO L242 Difference]: Finished difference. Result has 81 places, 80 transitions, 162 flow [2022-02-20 20:38:35,730 INFO L317 CegarLoopForPetriNet]: {PETRI_ALPHABET=97, PETRI_DIFFERENCE_MINUEND_FLOW=162, PETRI_DIFFERENCE_MINUEND_PLACES=80, PETRI_DIFFERENCE_MINUEND_TRANSITIONS=80, PETRI_DIFFERENCE_SUBTRAHEND_LETTERS_WITH_MORE_CHANGERS_THAN_LOOPERS=0, PETRI_DIFFERENCE_SUBTRAHEND_LOOPER_ONLY_LETTERS=80, PETRI_DIFFERENCE_SUBTRAHEND_STATES=2, PETRI_FLOW=162, PETRI_PLACES=81, PETRI_TRANSITIONS=80} [2022-02-20 20:38:35,734 INFO L334 CegarLoopForPetriNet]: 84 programPoint places, -3 predicate places. [2022-02-20 20:38:35,735 INFO L111 iNet2FiniteAutomaton]: Start petriNet2FiniteAutomaton. Operand has 81 places, 80 transitions, 162 flow [2022-02-20 20:38:35,756 INFO L133 iNet2FiniteAutomaton]: Finished petriNet2FiniteAutomaton. Result has 351 states, 349 states have (on average 1.8825214899713467) internal successors, (657), 350 states have internal predecessors, (657), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,758 INFO L78 Accepts]: Start accepts. Automaton has has 351 states, 349 states have (on average 1.8825214899713467) internal successors, (657), 350 states have internal predecessors, (657), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 58 [2022-02-20 20:38:35,759 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 20:38:35,759 INFO L470 AbstractCegarLoop]: Abstraction has has 81 places, 80 transitions, 162 flow [2022-02-20 20:38:35,759 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 2 states, 2 states have (on average 89.0) internal successors, (178), 2 states have internal predecessors, (178), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,759 INFO L246 CegarLoopForPetriNet]: Found error trace [2022-02-20 20:38:35,759 INFO L254 CegarLoopForPetriNet]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 20:38:35,760 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable0 [2022-02-20 20:38:35,760 INFO L402 AbstractCegarLoop]: === Iteration 2 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATION] === [2022-02-20 20:38:35,760 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 20:38:35,760 INFO L85 PathProgramCache]: Analyzing trace with hash -137135436, now seen corresponding path program 1 times [2022-02-20 20:38:35,761 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 20:38:35,761 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1246836928] [2022-02-20 20:38:35,761 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 20:38:35,761 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 20:38:35,788 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:35,823 INFO L290 TraceCheckUtils]: 0: Hoare triple {452#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,824 INFO L290 TraceCheckUtils]: 1: Hoare triple {452#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {452#true} is VALID [2022-02-20 20:38:35,824 INFO L290 TraceCheckUtils]: 2: Hoare triple {452#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,824 INFO L290 TraceCheckUtils]: 3: Hoare triple {452#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,824 INFO L290 TraceCheckUtils]: 4: Hoare triple {452#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,825 INFO L290 TraceCheckUtils]: 5: Hoare triple {452#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,825 INFO L290 TraceCheckUtils]: 6: Hoare triple {452#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,825 INFO L290 TraceCheckUtils]: 7: Hoare triple {452#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,825 INFO L290 TraceCheckUtils]: 8: Hoare triple {452#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,825 INFO L290 TraceCheckUtils]: 9: Hoare triple {452#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,825 INFO L290 TraceCheckUtils]: 10: Hoare triple {452#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,826 INFO L290 TraceCheckUtils]: 11: Hoare triple {452#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,826 INFO L290 TraceCheckUtils]: 12: Hoare triple {452#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,826 INFO L290 TraceCheckUtils]: 13: Hoare triple {452#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {452#true} is VALID [2022-02-20 20:38:35,826 INFO L290 TraceCheckUtils]: 14: Hoare triple {452#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {452#true} is VALID [2022-02-20 20:38:35,826 INFO L290 TraceCheckUtils]: 15: Hoare triple {452#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,827 INFO L290 TraceCheckUtils]: 16: Hoare triple {452#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,827 INFO L290 TraceCheckUtils]: 17: Hoare triple {452#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,827 INFO L290 TraceCheckUtils]: 18: Hoare triple {452#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,827 INFO L290 TraceCheckUtils]: 19: Hoare triple {452#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,827 INFO L290 TraceCheckUtils]: 20: Hoare triple {452#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,828 INFO L290 TraceCheckUtils]: 21: Hoare triple {452#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,828 INFO L290 TraceCheckUtils]: 22: Hoare triple {452#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,828 INFO L290 TraceCheckUtils]: 23: Hoare triple {452#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {452#true} is VALID [2022-02-20 20:38:35,828 INFO L290 TraceCheckUtils]: 24: Hoare triple {452#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {452#true} is VALID [2022-02-20 20:38:35,828 INFO L290 TraceCheckUtils]: 25: Hoare triple {452#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {452#true} is VALID [2022-02-20 20:38:35,829 INFO L290 TraceCheckUtils]: 26: Hoare triple {452#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {452#true} is VALID [2022-02-20 20:38:35,829 INFO L290 TraceCheckUtils]: 27: Hoare triple {452#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {452#true} is VALID [2022-02-20 20:38:35,829 INFO L290 TraceCheckUtils]: 28: Hoare triple {452#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {452#true} is VALID [2022-02-20 20:38:35,829 INFO L290 TraceCheckUtils]: 29: Hoare triple {452#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {452#true} is VALID [2022-02-20 20:38:35,829 INFO L290 TraceCheckUtils]: 30: Hoare triple {452#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {452#true} is VALID [2022-02-20 20:38:35,829 INFO L290 TraceCheckUtils]: 31: Hoare triple {452#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {452#true} is VALID [2022-02-20 20:38:35,830 INFO L290 TraceCheckUtils]: 32: Hoare triple {452#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {452#true} is VALID [2022-02-20 20:38:35,830 INFO L290 TraceCheckUtils]: 33: Hoare triple {452#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {452#true} is VALID [2022-02-20 20:38:35,830 INFO L290 TraceCheckUtils]: 34: Hoare triple {452#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {452#true} is VALID [2022-02-20 20:38:35,830 INFO L290 TraceCheckUtils]: 35: Hoare triple {452#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {452#true} is VALID [2022-02-20 20:38:35,830 INFO L290 TraceCheckUtils]: 36: Hoare triple {452#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {452#true} is VALID [2022-02-20 20:38:35,831 INFO L290 TraceCheckUtils]: 37: Hoare triple {452#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {452#true} is VALID [2022-02-20 20:38:35,831 INFO L290 TraceCheckUtils]: 38: Hoare triple {452#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {452#true} is VALID [2022-02-20 20:38:35,832 INFO L290 TraceCheckUtils]: 39: Hoare triple {452#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {454#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:35,832 INFO L290 TraceCheckUtils]: 40: Hoare triple {454#(= |ULTIMATE.start_main_~i~1#1| 0)} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {453#false} is VALID [2022-02-20 20:38:35,832 INFO L290 TraceCheckUtils]: 41: Hoare triple {453#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {453#false} is VALID [2022-02-20 20:38:35,832 INFO L290 TraceCheckUtils]: 42: Hoare triple {453#false} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {453#false} is VALID [2022-02-20 20:38:35,833 INFO L290 TraceCheckUtils]: 43: Hoare triple {453#false} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {453#false} is VALID [2022-02-20 20:38:35,833 INFO L290 TraceCheckUtils]: 44: Hoare triple {453#false} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {453#false} is VALID [2022-02-20 20:38:35,833 INFO L290 TraceCheckUtils]: 45: Hoare triple {453#false} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {453#false} is VALID [2022-02-20 20:38:35,833 INFO L290 TraceCheckUtils]: 46: Hoare triple {453#false} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {453#false} is VALID [2022-02-20 20:38:35,833 INFO L290 TraceCheckUtils]: 47: Hoare triple {453#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {453#false} is VALID [2022-02-20 20:38:35,834 INFO L290 TraceCheckUtils]: 48: Hoare triple {453#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {453#false} is VALID [2022-02-20 20:38:35,834 INFO L290 TraceCheckUtils]: 49: Hoare triple {453#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {453#false} is VALID [2022-02-20 20:38:35,834 INFO L290 TraceCheckUtils]: 50: Hoare triple {453#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {453#false} is VALID [2022-02-20 20:38:35,834 INFO L290 TraceCheckUtils]: 51: Hoare triple {453#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {453#false} is VALID [2022-02-20 20:38:35,834 INFO L290 TraceCheckUtils]: 52: Hoare triple {453#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {453#false} is VALID [2022-02-20 20:38:35,834 INFO L290 TraceCheckUtils]: 53: Hoare triple {453#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {453#false} is VALID [2022-02-20 20:38:35,835 INFO L290 TraceCheckUtils]: 54: Hoare triple {453#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {453#false} is VALID [2022-02-20 20:38:35,835 INFO L290 TraceCheckUtils]: 55: Hoare triple {453#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {453#false} is VALID [2022-02-20 20:38:35,835 INFO L290 TraceCheckUtils]: 56: Hoare triple {453#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {453#false} is VALID [2022-02-20 20:38:35,835 INFO L290 TraceCheckUtils]: 57: Hoare triple {453#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {453#false} is VALID [2022-02-20 20:38:35,836 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 20:38:35,836 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 20:38:35,836 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1246836928] [2022-02-20 20:38:35,836 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1246836928] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 20:38:35,836 INFO L191 FreeRefinementEngine]: Found 1 perfect and 0 imperfect interpolant sequences. [2022-02-20 20:38:35,836 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [] total 3 [2022-02-20 20:38:35,836 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [24051874] [2022-02-20 20:38:35,837 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 20:38:35,838 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 19.333333333333332) internal successors, (58), 3 states have internal predecessors, (58), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 58 [2022-02-20 20:38:35,838 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 20:38:35,838 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 3 states, 3 states have (on average 19.333333333333332) internal successors, (58), 3 states have internal predecessors, (58), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,874 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 58 edges. 58 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 20:38:35,874 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 3 states [2022-02-20 20:38:35,874 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 20:38:35,875 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 3 interpolants. [2022-02-20 20:38:35,875 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=3, Invalid=3, Unknown=0, NotChecked=0, Total=6 [2022-02-20 20:38:35,876 INFO L499 CegarLoopForPetriNet]: Number of universal loopers: 80 out of 97 [2022-02-20 20:38:35,877 INFO L92 encePairwiseOnDemand]: Start differencePairwiseOnDemand. First operand has 81 places, 80 transitions, 162 flow. Second operand has 3 states, 3 states have (on average 82.0) internal successors, (246), 3 states have internal predecessors, (246), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,877 INFO L101 encePairwiseOnDemand]: Universal subtrahend loopers provided by user. [2022-02-20 20:38:35,877 INFO L102 encePairwiseOnDemand]: Number of universal subtrahend loopers: 80 of 97 [2022-02-20 20:38:35,877 INFO L74 FinitePrefix]: Start finitePrefix. Operand will be constructed on-demand [2022-02-20 20:38:35,906 INFO L129 PetriNetUnfolder]: 2/87 cut-off events. [2022-02-20 20:38:35,906 INFO L130 PetriNetUnfolder]: For 1/1 co-relation queries the response was YES. [2022-02-20 20:38:35,907 INFO L84 FinitePrefix]: Finished finitePrefix Result has 103 conditions, 87 events. 2/87 cut-off events. For 1/1 co-relation queries the response was YES. Maximal size of possible extension queue 3. Compared 65 event pairs, 0 based on Foata normal form. 0/84 useless extension candidates. Maximal degree in co-relation 100. Up to 10 conditions per place. [2022-02-20 20:38:35,907 INFO L132 encePairwiseOnDemand]: 94/97 looper letters, 10 selfloop transitions, 2 changer transitions 0/83 dead transitions. [2022-02-20 20:38:35,907 INFO L138 encePairwiseOnDemand]: Finished differencePairwiseOnDemand. Result has 83 places, 83 transitions, 192 flow [2022-02-20 20:38:35,907 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 3 states. [2022-02-20 20:38:35,908 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 3 states. [2022-02-20 20:38:35,911 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 253 transitions. [2022-02-20 20:38:35,912 INFO L544 CegarLoopForPetriNet]: DFA transition density 0.8694158075601375 [2022-02-20 20:38:35,912 INFO L72 ComplementDD]: Start complementDD. Operand 3 states and 253 transitions. [2022-02-20 20:38:35,912 INFO L73 IsDeterministic]: Start isDeterministic. Operand 3 states and 253 transitions. [2022-02-20 20:38:35,912 INFO L80 IsDeterministic]: Finished isDeterministic. Operand is deterministic. [2022-02-20 20:38:35,912 INFO L117 ReachableStatesCopy]: Start reachableStatesCopy. Operand 3 states and 253 transitions. [2022-02-20 20:38:35,913 INFO L343 DoubleDeckerVisitor]: Before removal of dead ends has 4 states, 3 states have (on average 84.33333333333333) internal successors, (253), 3 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) [2022-02-20 20:38:35,914 INFO L131 ReachableStatesCopy]: Finished reachableStatesCopy Result has 4 states, 4 states have (on average 97.0) internal successors, (388), 4 states have internal predecessors, (388), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,914 INFO L81 ComplementDD]: Finished complementDD. Result has 4 states, 4 states have (on average 97.0) internal successors, (388), 4 states have internal predecessors, (388), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,915 INFO L186 Difference]: Start difference. First operand has 81 places, 80 transitions, 162 flow. Second operand 3 states and 253 transitions. [2022-02-20 20:38:35,915 INFO L82 GeneralOperation]: Start removeRedundantFlow. Operand has 83 places, 83 transitions, 192 flow [2022-02-20 20:38:35,915 INFO L88 GeneralOperation]: Finished removeRedundantFlow, result has has 83 places, 83 transitions, 192 flow, removed 0 selfloop flow, removed 0 redundant places. [2022-02-20 20:38:35,917 INFO L242 Difference]: Finished difference. Result has 84 places, 81 transitions, 174 flow [2022-02-20 20:38:35,917 INFO L317 CegarLoopForPetriNet]: {PETRI_ALPHABET=97, PETRI_DIFFERENCE_MINUEND_FLOW=162, PETRI_DIFFERENCE_MINUEND_PLACES=81, PETRI_DIFFERENCE_MINUEND_TRANSITIONS=80, PETRI_DIFFERENCE_SUBTRAHEND_LETTERS_WITH_MORE_CHANGERS_THAN_LOOPERS=1, PETRI_DIFFERENCE_SUBTRAHEND_LOOPER_ONLY_LETTERS=78, PETRI_DIFFERENCE_SUBTRAHEND_STATES=3, PETRI_FLOW=174, PETRI_PLACES=84, PETRI_TRANSITIONS=81} [2022-02-20 20:38:35,918 INFO L334 CegarLoopForPetriNet]: 84 programPoint places, 0 predicate places. [2022-02-20 20:38:35,918 INFO L111 iNet2FiniteAutomaton]: Start petriNet2FiniteAutomaton. Operand has 84 places, 81 transitions, 174 flow [2022-02-20 20:38:35,931 INFO L133 iNet2FiniteAutomaton]: Finished petriNet2FiniteAutomaton. Result has 477 states, 475 states have (on average 1.9136842105263159) internal successors, (909), 476 states have internal predecessors, (909), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,932 INFO L78 Accepts]: Start accepts. Automaton has has 477 states, 475 states have (on average 1.9136842105263159) internal successors, (909), 476 states have internal predecessors, (909), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 58 [2022-02-20 20:38:35,933 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 20:38:35,933 INFO L470 AbstractCegarLoop]: Abstraction has has 84 places, 81 transitions, 174 flow [2022-02-20 20:38:35,933 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 3 states, 3 states have (on average 82.0) internal successors, (246), 3 states have internal predecessors, (246), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:35,933 INFO L246 CegarLoopForPetriNet]: Found error trace [2022-02-20 20:38:35,934 INFO L254 CegarLoopForPetriNet]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 20:38:35,934 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable1 [2022-02-20 20:38:35,934 INFO L402 AbstractCegarLoop]: === Iteration 3 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATION] === [2022-02-20 20:38:35,934 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 20:38:35,934 INFO L85 PathProgramCache]: Analyzing trace with hash -1409393791, now seen corresponding path program 1 times [2022-02-20 20:38:35,935 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 20:38:35,935 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1844954999] [2022-02-20 20:38:35,935 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 20:38:35,935 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 20:38:35,961 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:36,030 INFO L290 TraceCheckUtils]: 0: Hoare triple {935#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,031 INFO L290 TraceCheckUtils]: 1: Hoare triple {935#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {935#true} is VALID [2022-02-20 20:38:36,032 INFO L290 TraceCheckUtils]: 2: Hoare triple {935#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,033 INFO L290 TraceCheckUtils]: 3: Hoare triple {935#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,039 INFO L290 TraceCheckUtils]: 4: Hoare triple {935#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,039 INFO L290 TraceCheckUtils]: 5: Hoare triple {935#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,039 INFO L290 TraceCheckUtils]: 6: Hoare triple {935#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,040 INFO L290 TraceCheckUtils]: 7: Hoare triple {935#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,040 INFO L290 TraceCheckUtils]: 8: Hoare triple {935#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,040 INFO L290 TraceCheckUtils]: 9: Hoare triple {935#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,040 INFO L290 TraceCheckUtils]: 10: Hoare triple {935#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,040 INFO L290 TraceCheckUtils]: 11: Hoare triple {935#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,040 INFO L290 TraceCheckUtils]: 12: Hoare triple {935#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,041 INFO L290 TraceCheckUtils]: 13: Hoare triple {935#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {935#true} is VALID [2022-02-20 20:38:36,041 INFO L290 TraceCheckUtils]: 14: Hoare triple {935#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {935#true} is VALID [2022-02-20 20:38:36,041 INFO L290 TraceCheckUtils]: 15: Hoare triple {935#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,041 INFO L290 TraceCheckUtils]: 16: Hoare triple {935#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,041 INFO L290 TraceCheckUtils]: 17: Hoare triple {935#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,042 INFO L290 TraceCheckUtils]: 18: Hoare triple {935#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,042 INFO L290 TraceCheckUtils]: 19: Hoare triple {935#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,042 INFO L290 TraceCheckUtils]: 20: Hoare triple {935#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,042 INFO L290 TraceCheckUtils]: 21: Hoare triple {935#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,042 INFO L290 TraceCheckUtils]: 22: Hoare triple {935#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,042 INFO L290 TraceCheckUtils]: 23: Hoare triple {935#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {935#true} is VALID [2022-02-20 20:38:36,043 INFO L290 TraceCheckUtils]: 24: Hoare triple {935#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {935#true} is VALID [2022-02-20 20:38:36,043 INFO L290 TraceCheckUtils]: 25: Hoare triple {935#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {935#true} is VALID [2022-02-20 20:38:36,043 INFO L290 TraceCheckUtils]: 26: Hoare triple {935#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {935#true} is VALID [2022-02-20 20:38:36,043 INFO L290 TraceCheckUtils]: 27: Hoare triple {935#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {935#true} is VALID [2022-02-20 20:38:36,043 INFO L290 TraceCheckUtils]: 28: Hoare triple {935#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {935#true} is VALID [2022-02-20 20:38:36,043 INFO L290 TraceCheckUtils]: 29: Hoare triple {935#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {935#true} is VALID [2022-02-20 20:38:36,044 INFO L290 TraceCheckUtils]: 30: Hoare triple {935#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {935#true} is VALID [2022-02-20 20:38:36,044 INFO L290 TraceCheckUtils]: 31: Hoare triple {935#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {935#true} is VALID [2022-02-20 20:38:36,044 INFO L290 TraceCheckUtils]: 32: Hoare triple {935#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {935#true} is VALID [2022-02-20 20:38:36,044 INFO L290 TraceCheckUtils]: 33: Hoare triple {935#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {935#true} is VALID [2022-02-20 20:38:36,044 INFO L290 TraceCheckUtils]: 34: Hoare triple {935#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {935#true} is VALID [2022-02-20 20:38:36,045 INFO L290 TraceCheckUtils]: 35: Hoare triple {935#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {935#true} is VALID [2022-02-20 20:38:36,045 INFO L290 TraceCheckUtils]: 36: Hoare triple {935#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,045 INFO L290 TraceCheckUtils]: 37: Hoare triple {935#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {935#true} is VALID [2022-02-20 20:38:36,045 INFO L290 TraceCheckUtils]: 38: Hoare triple {935#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {935#true} is VALID [2022-02-20 20:38:36,046 INFO L290 TraceCheckUtils]: 39: Hoare triple {935#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {937#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:36,046 INFO L290 TraceCheckUtils]: 40: Hoare triple {937#(= |ULTIMATE.start_main_~i~1#1| 0)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {937#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:36,051 INFO L290 TraceCheckUtils]: 41: Hoare triple {937#(= |ULTIMATE.start_main_~i~1#1| 0)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {937#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:36,051 INFO L290 TraceCheckUtils]: 42: Hoare triple {937#(= |ULTIMATE.start_main_~i~1#1| 0)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {937#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:36,052 INFO L290 TraceCheckUtils]: 43: Hoare triple {937#(= |ULTIMATE.start_main_~i~1#1| 0)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {937#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:36,052 INFO L290 TraceCheckUtils]: 44: Hoare triple {937#(= |ULTIMATE.start_main_~i~1#1| 0)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {937#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:36,053 INFO L290 TraceCheckUtils]: 45: Hoare triple {937#(= |ULTIMATE.start_main_~i~1#1| 0)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {938#(= 0 |ULTIMATE.start_main_#t~post40#1|)} is VALID [2022-02-20 20:38:36,053 INFO L290 TraceCheckUtils]: 46: Hoare triple {938#(= 0 |ULTIMATE.start_main_#t~post40#1|)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {939#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:36,054 INFO L290 TraceCheckUtils]: 47: Hoare triple {939#(<= |ULTIMATE.start_main_~i~1#1| 1)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {939#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:36,054 INFO L290 TraceCheckUtils]: 48: Hoare triple {939#(<= |ULTIMATE.start_main_~i~1#1| 1)} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,054 INFO L290 TraceCheckUtils]: 49: Hoare triple {936#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {936#false} is VALID [2022-02-20 20:38:36,054 INFO L290 TraceCheckUtils]: 50: Hoare triple {936#false} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {936#false} is VALID [2022-02-20 20:38:36,054 INFO L290 TraceCheckUtils]: 51: Hoare triple {936#false} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {936#false} is VALID [2022-02-20 20:38:36,055 INFO L290 TraceCheckUtils]: 52: Hoare triple {936#false} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {936#false} is VALID [2022-02-20 20:38:36,055 INFO L290 TraceCheckUtils]: 53: Hoare triple {936#false} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {936#false} is VALID [2022-02-20 20:38:36,055 INFO L290 TraceCheckUtils]: 54: Hoare triple {936#false} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,055 INFO L290 TraceCheckUtils]: 55: Hoare triple {936#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {936#false} is VALID [2022-02-20 20:38:36,055 INFO L290 TraceCheckUtils]: 56: Hoare triple {936#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,055 INFO L290 TraceCheckUtils]: 57: Hoare triple {936#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,056 INFO L290 TraceCheckUtils]: 58: Hoare triple {936#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,056 INFO L290 TraceCheckUtils]: 59: Hoare triple {936#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {936#false} is VALID [2022-02-20 20:38:36,056 INFO L290 TraceCheckUtils]: 60: Hoare triple {936#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,056 INFO L290 TraceCheckUtils]: 61: Hoare triple {936#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {936#false} is VALID [2022-02-20 20:38:36,056 INFO L290 TraceCheckUtils]: 62: Hoare triple {936#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {936#false} is VALID [2022-02-20 20:38:36,056 INFO L290 TraceCheckUtils]: 63: Hoare triple {936#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {936#false} is VALID [2022-02-20 20:38:36,057 INFO L290 TraceCheckUtils]: 64: Hoare triple {936#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,057 INFO L290 TraceCheckUtils]: 65: Hoare triple {936#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,057 INFO L134 CoverageAnalysis]: Checked inductivity of 1 backedges. 0 proven. 1 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2022-02-20 20:38:36,057 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 20:38:36,057 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1844954999] [2022-02-20 20:38:36,058 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1844954999] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 20:38:36,058 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [1484307826] [2022-02-20 20:38:36,058 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 20:38:36,058 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 20:38:36,058 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 20:38:36,060 INFO L229 MonitoredProcess]: Starting monitored process 2 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 20:38:36,061 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (2)] Waiting until timeout for monitored process [2022-02-20 20:38:36,135 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:36,136 INFO L263 TraceCheckSpWp]: Trace formula consists of 160 conjuncts, 2 conjunts are in the unsatisfiable core [2022-02-20 20:38:36,166 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:36,170 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 20:38:36,302 INFO L290 TraceCheckUtils]: 0: Hoare triple {935#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,302 INFO L290 TraceCheckUtils]: 1: Hoare triple {935#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {935#true} is VALID [2022-02-20 20:38:36,302 INFO L290 TraceCheckUtils]: 2: Hoare triple {935#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,302 INFO L290 TraceCheckUtils]: 3: Hoare triple {935#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,303 INFO L290 TraceCheckUtils]: 4: Hoare triple {935#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,303 INFO L290 TraceCheckUtils]: 5: Hoare triple {935#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,303 INFO L290 TraceCheckUtils]: 6: Hoare triple {935#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,303 INFO L290 TraceCheckUtils]: 7: Hoare triple {935#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,303 INFO L290 TraceCheckUtils]: 8: Hoare triple {935#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,303 INFO L290 TraceCheckUtils]: 9: Hoare triple {935#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,304 INFO L290 TraceCheckUtils]: 10: Hoare triple {935#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,304 INFO L290 TraceCheckUtils]: 11: Hoare triple {935#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,304 INFO L290 TraceCheckUtils]: 12: Hoare triple {935#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,304 INFO L290 TraceCheckUtils]: 13: Hoare triple {935#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {935#true} is VALID [2022-02-20 20:38:36,304 INFO L290 TraceCheckUtils]: 14: Hoare triple {935#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {935#true} is VALID [2022-02-20 20:38:36,304 INFO L290 TraceCheckUtils]: 15: Hoare triple {935#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,304 INFO L290 TraceCheckUtils]: 16: Hoare triple {935#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,305 INFO L290 TraceCheckUtils]: 17: Hoare triple {935#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,305 INFO L290 TraceCheckUtils]: 18: Hoare triple {935#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,305 INFO L290 TraceCheckUtils]: 19: Hoare triple {935#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,305 INFO L290 TraceCheckUtils]: 20: Hoare triple {935#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,305 INFO L290 TraceCheckUtils]: 21: Hoare triple {935#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,305 INFO L290 TraceCheckUtils]: 22: Hoare triple {935#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,305 INFO L290 TraceCheckUtils]: 23: Hoare triple {935#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {935#true} is VALID [2022-02-20 20:38:36,306 INFO L290 TraceCheckUtils]: 24: Hoare triple {935#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {935#true} is VALID [2022-02-20 20:38:36,306 INFO L290 TraceCheckUtils]: 25: Hoare triple {935#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {935#true} is VALID [2022-02-20 20:38:36,306 INFO L290 TraceCheckUtils]: 26: Hoare triple {935#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {935#true} is VALID [2022-02-20 20:38:36,306 INFO L290 TraceCheckUtils]: 27: Hoare triple {935#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {935#true} is VALID [2022-02-20 20:38:36,306 INFO L290 TraceCheckUtils]: 28: Hoare triple {935#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {935#true} is VALID [2022-02-20 20:38:36,306 INFO L290 TraceCheckUtils]: 29: Hoare triple {935#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {935#true} is VALID [2022-02-20 20:38:36,306 INFO L290 TraceCheckUtils]: 30: Hoare triple {935#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {935#true} is VALID [2022-02-20 20:38:36,307 INFO L290 TraceCheckUtils]: 31: Hoare triple {935#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {935#true} is VALID [2022-02-20 20:38:36,307 INFO L290 TraceCheckUtils]: 32: Hoare triple {935#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {935#true} is VALID [2022-02-20 20:38:36,307 INFO L290 TraceCheckUtils]: 33: Hoare triple {935#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {935#true} is VALID [2022-02-20 20:38:36,307 INFO L290 TraceCheckUtils]: 34: Hoare triple {935#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {935#true} is VALID [2022-02-20 20:38:36,307 INFO L290 TraceCheckUtils]: 35: Hoare triple {935#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {935#true} is VALID [2022-02-20 20:38:36,307 INFO L290 TraceCheckUtils]: 36: Hoare triple {935#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,308 INFO L290 TraceCheckUtils]: 37: Hoare triple {935#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {935#true} is VALID [2022-02-20 20:38:36,308 INFO L290 TraceCheckUtils]: 38: Hoare triple {935#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {935#true} is VALID [2022-02-20 20:38:36,308 INFO L290 TraceCheckUtils]: 39: Hoare triple {935#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {935#true} is VALID [2022-02-20 20:38:36,308 INFO L290 TraceCheckUtils]: 40: Hoare triple {935#true} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,308 INFO L290 TraceCheckUtils]: 41: Hoare triple {935#true} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {935#true} is VALID [2022-02-20 20:38:36,308 INFO L290 TraceCheckUtils]: 42: Hoare triple {935#true} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {935#true} is VALID [2022-02-20 20:38:36,309 INFO L290 TraceCheckUtils]: 43: Hoare triple {935#true} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {935#true} is VALID [2022-02-20 20:38:36,309 INFO L290 TraceCheckUtils]: 44: Hoare triple {935#true} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {935#true} is VALID [2022-02-20 20:38:36,309 INFO L290 TraceCheckUtils]: 45: Hoare triple {935#true} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {935#true} is VALID [2022-02-20 20:38:36,309 INFO L290 TraceCheckUtils]: 46: Hoare triple {935#true} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {935#true} is VALID [2022-02-20 20:38:36,309 INFO L290 TraceCheckUtils]: 47: Hoare triple {935#true} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {935#true} is VALID [2022-02-20 20:38:36,309 INFO L290 TraceCheckUtils]: 48: Hoare triple {935#true} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {935#true} is VALID [2022-02-20 20:38:36,309 INFO L290 TraceCheckUtils]: 49: Hoare triple {935#true} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {935#true} is VALID [2022-02-20 20:38:36,310 INFO L290 TraceCheckUtils]: 50: Hoare triple {935#true} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {935#true} is VALID [2022-02-20 20:38:36,310 INFO L290 TraceCheckUtils]: 51: Hoare triple {935#true} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {935#true} is VALID [2022-02-20 20:38:36,310 INFO L290 TraceCheckUtils]: 52: Hoare triple {935#true} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {935#true} is VALID [2022-02-20 20:38:36,310 INFO L290 TraceCheckUtils]: 53: Hoare triple {935#true} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {1102#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,311 INFO L290 TraceCheckUtils]: 54: Hoare triple {1102#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,311 INFO L290 TraceCheckUtils]: 55: Hoare triple {936#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {936#false} is VALID [2022-02-20 20:38:36,311 INFO L290 TraceCheckUtils]: 56: Hoare triple {936#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,311 INFO L290 TraceCheckUtils]: 57: Hoare triple {936#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,312 INFO L290 TraceCheckUtils]: 58: Hoare triple {936#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,312 INFO L290 TraceCheckUtils]: 59: Hoare triple {936#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {936#false} is VALID [2022-02-20 20:38:36,312 INFO L290 TraceCheckUtils]: 60: Hoare triple {936#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,312 INFO L290 TraceCheckUtils]: 61: Hoare triple {936#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {936#false} is VALID [2022-02-20 20:38:36,312 INFO L290 TraceCheckUtils]: 62: Hoare triple {936#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {936#false} is VALID [2022-02-20 20:38:36,312 INFO L290 TraceCheckUtils]: 63: Hoare triple {936#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {936#false} is VALID [2022-02-20 20:38:36,312 INFO L290 TraceCheckUtils]: 64: Hoare triple {936#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,313 INFO L290 TraceCheckUtils]: 65: Hoare triple {936#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {936#false} is VALID [2022-02-20 20:38:36,313 INFO L134 CoverageAnalysis]: Checked inductivity of 1 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 1 trivial. 0 not checked. [2022-02-20 20:38:36,313 INFO L324 TraceCheckSpWp]: Omiting computation of backward sequence because forward sequence was already perfect [2022-02-20 20:38:36,313 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [1484307826] provided 1 perfect and 0 imperfect interpolant sequences [2022-02-20 20:38:36,313 INFO L191 FreeRefinementEngine]: Found 1 perfect and 1 imperfect interpolant sequences. [2022-02-20 20:38:36,313 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [3] imperfect sequences [5] total 6 [2022-02-20 20:38:36,314 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [991139477] [2022-02-20 20:38:36,314 INFO L85 oduleStraightlineAll]: Using 1 perfect interpolants to construct interpolant automaton [2022-02-20 20:38:36,314 INFO L78 Accepts]: Start accepts. Automaton has has 3 states, 3 states have (on average 22.0) internal successors, (66), 3 states have internal predecessors, (66), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 66 [2022-02-20 20:38:36,315 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 20:38:36,315 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 3 states, 3 states have (on average 22.0) internal successors, (66), 3 states have internal predecessors, (66), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:36,351 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 66 edges. 66 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 20:38:36,351 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 3 states [2022-02-20 20:38:36,351 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 20:38:36,352 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 3 interpolants. [2022-02-20 20:38:36,352 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=10, Invalid=20, Unknown=0, NotChecked=0, Total=30 [2022-02-20 20:38:36,352 INFO L499 CegarLoopForPetriNet]: Number of universal loopers: 81 out of 97 [2022-02-20 20:38:36,353 INFO L92 encePairwiseOnDemand]: Start differencePairwiseOnDemand. First operand has 84 places, 81 transitions, 174 flow. Second operand has 3 states, 3 states have (on average 82.66666666666667) internal successors, (248), 3 states have internal predecessors, (248), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:36,353 INFO L101 encePairwiseOnDemand]: Universal subtrahend loopers provided by user. [2022-02-20 20:38:36,353 INFO L102 encePairwiseOnDemand]: Number of universal subtrahend loopers: 81 of 97 [2022-02-20 20:38:36,353 INFO L74 FinitePrefix]: Start finitePrefix. Operand will be constructed on-demand [2022-02-20 20:38:36,379 INFO L129 PetriNetUnfolder]: 2/97 cut-off events. [2022-02-20 20:38:36,379 INFO L130 PetriNetUnfolder]: For 2/2 co-relation queries the response was YES. [2022-02-20 20:38:36,380 INFO L84 FinitePrefix]: Finished finitePrefix Result has 119 conditions, 97 events. 2/97 cut-off events. For 2/2 co-relation queries the response was YES. Maximal size of possible extension queue 3. Compared 72 event pairs, 0 based on Foata normal form. 0/95 useless extension candidates. Maximal degree in co-relation 114. Up to 9 conditions per place. [2022-02-20 20:38:36,381 INFO L132 encePairwiseOnDemand]: 94/97 looper letters, 9 selfloop transitions, 2 changer transitions 0/84 dead transitions. [2022-02-20 20:38:36,381 INFO L138 encePairwiseOnDemand]: Finished differencePairwiseOnDemand. Result has 86 places, 84 transitions, 202 flow [2022-02-20 20:38:36,381 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 3 states. [2022-02-20 20:38:36,381 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 3 states. [2022-02-20 20:38:36,384 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 3 states to 3 states and 255 transitions. [2022-02-20 20:38:36,384 INFO L544 CegarLoopForPetriNet]: DFA transition density 0.8762886597938144 [2022-02-20 20:38:36,384 INFO L72 ComplementDD]: Start complementDD. Operand 3 states and 255 transitions. [2022-02-20 20:38:36,385 INFO L73 IsDeterministic]: Start isDeterministic. Operand 3 states and 255 transitions. [2022-02-20 20:38:36,385 INFO L80 IsDeterministic]: Finished isDeterministic. Operand is deterministic. [2022-02-20 20:38:36,385 INFO L117 ReachableStatesCopy]: Start reachableStatesCopy. Operand 3 states and 255 transitions. [2022-02-20 20:38:36,386 INFO L343 DoubleDeckerVisitor]: Before removal of dead ends has 4 states, 3 states have (on average 85.0) internal successors, (255), 3 states have internal predecessors, (255), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:36,386 INFO L131 ReachableStatesCopy]: Finished reachableStatesCopy Result has 4 states, 4 states have (on average 97.0) internal successors, (388), 4 states have internal predecessors, (388), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:36,387 INFO L81 ComplementDD]: Finished complementDD. Result has 4 states, 4 states have (on average 97.0) internal successors, (388), 4 states have internal predecessors, (388), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:36,387 INFO L186 Difference]: Start difference. First operand has 84 places, 81 transitions, 174 flow. Second operand 3 states and 255 transitions. [2022-02-20 20:38:36,387 INFO L82 GeneralOperation]: Start removeRedundantFlow. Operand has 86 places, 84 transitions, 202 flow [2022-02-20 20:38:36,388 INFO L88 GeneralOperation]: Finished removeRedundantFlow, result has has 85 places, 84 transitions, 200 flow, removed 0 selfloop flow, removed 1 redundant places. [2022-02-20 20:38:36,389 INFO L242 Difference]: Finished difference. Result has 86 places, 82 transitions, 184 flow [2022-02-20 20:38:36,389 INFO L317 CegarLoopForPetriNet]: {PETRI_ALPHABET=97, PETRI_DIFFERENCE_MINUEND_FLOW=172, PETRI_DIFFERENCE_MINUEND_PLACES=83, PETRI_DIFFERENCE_MINUEND_TRANSITIONS=81, PETRI_DIFFERENCE_SUBTRAHEND_LETTERS_WITH_MORE_CHANGERS_THAN_LOOPERS=1, PETRI_DIFFERENCE_SUBTRAHEND_LOOPER_ONLY_LETTERS=79, PETRI_DIFFERENCE_SUBTRAHEND_STATES=3, PETRI_FLOW=184, PETRI_PLACES=86, PETRI_TRANSITIONS=82} [2022-02-20 20:38:36,390 INFO L334 CegarLoopForPetriNet]: 84 programPoint places, 2 predicate places. [2022-02-20 20:38:36,390 INFO L111 iNet2FiniteAutomaton]: Start petriNet2FiniteAutomaton. Operand has 86 places, 82 transitions, 184 flow [2022-02-20 20:38:36,401 INFO L133 iNet2FiniteAutomaton]: Finished petriNet2FiniteAutomaton. Result has 717 states, 715 states have (on average 1.9426573426573426) internal successors, (1389), 716 states have internal predecessors, (1389), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:36,403 INFO L78 Accepts]: Start accepts. Automaton has has 717 states, 715 states have (on average 1.9426573426573426) internal successors, (1389), 716 states have internal predecessors, (1389), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 66 [2022-02-20 20:38:36,403 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 20:38:36,403 INFO L470 AbstractCegarLoop]: Abstraction has has 86 places, 82 transitions, 184 flow [2022-02-20 20:38:36,404 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 3 states, 3 states have (on average 82.66666666666667) internal successors, (248), 3 states have internal predecessors, (248), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:36,404 INFO L246 CegarLoopForPetriNet]: Found error trace [2022-02-20 20:38:36,404 INFO L254 CegarLoopForPetriNet]: trace histogram [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 20:38:36,436 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (2)] Forceful destruction successful, exit code 0 [2022-02-20 20:38:36,639 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable2,2 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 20:38:36,639 INFO L402 AbstractCegarLoop]: === Iteration 4 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATION] === [2022-02-20 20:38:36,640 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 20:38:36,640 INFO L85 PathProgramCache]: Analyzing trace with hash -293330369, now seen corresponding path program 1 times [2022-02-20 20:38:36,640 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 20:38:36,640 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [882468566] [2022-02-20 20:38:36,640 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 20:38:36,640 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 20:38:36,661 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:36,727 INFO L290 TraceCheckUtils]: 0: Hoare triple {1856#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,727 INFO L290 TraceCheckUtils]: 1: Hoare triple {1856#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {1856#true} is VALID [2022-02-20 20:38:36,727 INFO L290 TraceCheckUtils]: 2: Hoare triple {1856#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,727 INFO L290 TraceCheckUtils]: 3: Hoare triple {1856#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,727 INFO L290 TraceCheckUtils]: 4: Hoare triple {1856#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,728 INFO L290 TraceCheckUtils]: 5: Hoare triple {1856#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,728 INFO L290 TraceCheckUtils]: 6: Hoare triple {1856#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,728 INFO L290 TraceCheckUtils]: 7: Hoare triple {1856#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,728 INFO L290 TraceCheckUtils]: 8: Hoare triple {1856#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,728 INFO L290 TraceCheckUtils]: 9: Hoare triple {1856#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,728 INFO L290 TraceCheckUtils]: 10: Hoare triple {1856#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,728 INFO L290 TraceCheckUtils]: 11: Hoare triple {1856#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,729 INFO L290 TraceCheckUtils]: 12: Hoare triple {1856#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,729 INFO L290 TraceCheckUtils]: 13: Hoare triple {1856#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {1856#true} is VALID [2022-02-20 20:38:36,729 INFO L290 TraceCheckUtils]: 14: Hoare triple {1856#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {1856#true} is VALID [2022-02-20 20:38:36,729 INFO L290 TraceCheckUtils]: 15: Hoare triple {1856#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,729 INFO L290 TraceCheckUtils]: 16: Hoare triple {1856#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,729 INFO L290 TraceCheckUtils]: 17: Hoare triple {1856#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,729 INFO L290 TraceCheckUtils]: 18: Hoare triple {1856#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,730 INFO L290 TraceCheckUtils]: 19: Hoare triple {1856#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,730 INFO L290 TraceCheckUtils]: 20: Hoare triple {1856#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,730 INFO L290 TraceCheckUtils]: 21: Hoare triple {1856#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,730 INFO L290 TraceCheckUtils]: 22: Hoare triple {1856#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:36,730 INFO L290 TraceCheckUtils]: 23: Hoare triple {1856#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {1856#true} is VALID [2022-02-20 20:38:36,730 INFO L290 TraceCheckUtils]: 24: Hoare triple {1856#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {1856#true} is VALID [2022-02-20 20:38:36,730 INFO L290 TraceCheckUtils]: 25: Hoare triple {1856#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {1856#true} is VALID [2022-02-20 20:38:36,731 INFO L290 TraceCheckUtils]: 26: Hoare triple {1856#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {1856#true} is VALID [2022-02-20 20:38:36,731 INFO L290 TraceCheckUtils]: 27: Hoare triple {1856#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {1856#true} is VALID [2022-02-20 20:38:36,731 INFO L290 TraceCheckUtils]: 28: Hoare triple {1856#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {1856#true} is VALID [2022-02-20 20:38:36,731 INFO L290 TraceCheckUtils]: 29: Hoare triple {1856#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {1856#true} is VALID [2022-02-20 20:38:36,731 INFO L290 TraceCheckUtils]: 30: Hoare triple {1856#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {1856#true} is VALID [2022-02-20 20:38:36,731 INFO L290 TraceCheckUtils]: 31: Hoare triple {1856#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {1856#true} is VALID [2022-02-20 20:38:36,731 INFO L290 TraceCheckUtils]: 32: Hoare triple {1856#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {1856#true} is VALID [2022-02-20 20:38:36,732 INFO L290 TraceCheckUtils]: 33: Hoare triple {1856#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {1856#true} is VALID [2022-02-20 20:38:36,732 INFO L290 TraceCheckUtils]: 34: Hoare triple {1856#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {1856#true} is VALID [2022-02-20 20:38:36,732 INFO L290 TraceCheckUtils]: 35: Hoare triple {1856#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {1856#true} is VALID [2022-02-20 20:38:36,732 INFO L290 TraceCheckUtils]: 36: Hoare triple {1856#true} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {1856#true} is VALID [2022-02-20 20:38:36,732 INFO L290 TraceCheckUtils]: 37: Hoare triple {1856#true} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {1856#true} is VALID [2022-02-20 20:38:36,732 INFO L290 TraceCheckUtils]: 38: Hoare triple {1856#true} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {1856#true} is VALID [2022-02-20 20:38:36,733 INFO L290 TraceCheckUtils]: 39: Hoare triple {1856#true} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,733 INFO L290 TraceCheckUtils]: 40: Hoare triple {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,734 INFO L290 TraceCheckUtils]: 41: Hoare triple {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,734 INFO L290 TraceCheckUtils]: 42: Hoare triple {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,735 INFO L290 TraceCheckUtils]: 43: Hoare triple {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,738 INFO L290 TraceCheckUtils]: 44: Hoare triple {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,738 INFO L290 TraceCheckUtils]: 45: Hoare triple {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,739 INFO L290 TraceCheckUtils]: 46: Hoare triple {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,739 INFO L290 TraceCheckUtils]: 47: Hoare triple {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:36,740 INFO L290 TraceCheckUtils]: 48: Hoare triple {1858#(= thread_function_mutexThread1of1ForFork0_~i~0 0)} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {1859#(= |thread_function_mutexThread1of1ForFork0_#t~post31| 0)} is VALID [2022-02-20 20:38:36,740 INFO L290 TraceCheckUtils]: 49: Hoare triple {1859#(= |thread_function_mutexThread1of1ForFork0_#t~post31| 0)} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {1860#(<= thread_function_mutexThread1of1ForFork0_~i~0 1)} is VALID [2022-02-20 20:38:36,740 INFO L290 TraceCheckUtils]: 50: Hoare triple {1860#(<= thread_function_mutexThread1of1ForFork0_~i~0 1)} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {1860#(<= thread_function_mutexThread1of1ForFork0_~i~0 1)} is VALID [2022-02-20 20:38:36,741 INFO L290 TraceCheckUtils]: 51: Hoare triple {1860#(<= thread_function_mutexThread1of1ForFork0_~i~0 1)} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,741 INFO L290 TraceCheckUtils]: 52: Hoare triple {1857#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {1857#false} is VALID [2022-02-20 20:38:36,741 INFO L290 TraceCheckUtils]: 53: Hoare triple {1857#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,741 INFO L290 TraceCheckUtils]: 54: Hoare triple {1857#false} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,741 INFO L290 TraceCheckUtils]: 55: Hoare triple {1857#false} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {1857#false} is VALID [2022-02-20 20:38:36,742 INFO L290 TraceCheckUtils]: 56: Hoare triple {1857#false} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {1857#false} is VALID [2022-02-20 20:38:36,742 INFO L290 TraceCheckUtils]: 57: Hoare triple {1857#false} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {1857#false} is VALID [2022-02-20 20:38:36,743 INFO L290 TraceCheckUtils]: 58: Hoare triple {1857#false} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,743 INFO L290 TraceCheckUtils]: 59: Hoare triple {1857#false} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {1857#false} is VALID [2022-02-20 20:38:36,743 INFO L290 TraceCheckUtils]: 60: Hoare triple {1857#false} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {1857#false} is VALID [2022-02-20 20:38:36,743 INFO L290 TraceCheckUtils]: 61: Hoare triple {1857#false} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {1857#false} is VALID [2022-02-20 20:38:36,743 INFO L290 TraceCheckUtils]: 62: Hoare triple {1857#false} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {1857#false} is VALID [2022-02-20 20:38:36,744 INFO L290 TraceCheckUtils]: 63: Hoare triple {1857#false} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {1857#false} is VALID [2022-02-20 20:38:36,744 INFO L290 TraceCheckUtils]: 64: Hoare triple {1857#false} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {1857#false} is VALID [2022-02-20 20:38:36,744 INFO L290 TraceCheckUtils]: 65: Hoare triple {1857#false} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {1857#false} is VALID [2022-02-20 20:38:36,744 INFO L290 TraceCheckUtils]: 66: Hoare triple {1857#false} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,744 INFO L290 TraceCheckUtils]: 67: Hoare triple {1857#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {1857#false} is VALID [2022-02-20 20:38:36,744 INFO L290 TraceCheckUtils]: 68: Hoare triple {1857#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,744 INFO L290 TraceCheckUtils]: 69: Hoare triple {1857#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,745 INFO L290 TraceCheckUtils]: 70: Hoare triple {1857#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {1857#false} is VALID [2022-02-20 20:38:36,745 INFO L290 TraceCheckUtils]: 71: Hoare triple {1857#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,745 INFO L290 TraceCheckUtils]: 72: Hoare triple {1857#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {1857#false} is VALID [2022-02-20 20:38:36,745 INFO L290 TraceCheckUtils]: 73: Hoare triple {1857#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {1857#false} is VALID [2022-02-20 20:38:36,745 INFO L290 TraceCheckUtils]: 74: Hoare triple {1857#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {1857#false} is VALID [2022-02-20 20:38:36,745 INFO L290 TraceCheckUtils]: 75: Hoare triple {1857#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,745 INFO L290 TraceCheckUtils]: 76: Hoare triple {1857#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:36,746 INFO L134 CoverageAnalysis]: Checked inductivity of 2 backedges. 0 proven. 1 refuted. 0 times theorem prover too weak. 1 trivial. 0 not checked. [2022-02-20 20:38:36,747 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 20:38:36,747 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [882468566] [2022-02-20 20:38:36,747 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [882468566] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 20:38:36,748 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [256198319] [2022-02-20 20:38:36,748 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 20:38:36,748 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 20:38:36,748 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 20:38:36,764 INFO L229 MonitoredProcess]: Starting monitored process 3 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 20:38:36,765 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Waiting until timeout for monitored process [2022-02-20 20:38:36,851 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:36,852 INFO L263 TraceCheckSpWp]: Trace formula consists of 186 conjuncts, 4 conjunts are in the unsatisfiable core [2022-02-20 20:38:36,876 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:36,878 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 20:38:37,092 INFO L290 TraceCheckUtils]: 0: Hoare triple {1856#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,092 INFO L290 TraceCheckUtils]: 1: Hoare triple {1856#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {1856#true} is VALID [2022-02-20 20:38:37,092 INFO L290 TraceCheckUtils]: 2: Hoare triple {1856#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,093 INFO L290 TraceCheckUtils]: 3: Hoare triple {1856#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,093 INFO L290 TraceCheckUtils]: 4: Hoare triple {1856#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,093 INFO L290 TraceCheckUtils]: 5: Hoare triple {1856#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,093 INFO L290 TraceCheckUtils]: 6: Hoare triple {1856#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,093 INFO L290 TraceCheckUtils]: 7: Hoare triple {1856#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,093 INFO L290 TraceCheckUtils]: 8: Hoare triple {1856#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,094 INFO L290 TraceCheckUtils]: 9: Hoare triple {1856#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,094 INFO L290 TraceCheckUtils]: 10: Hoare triple {1856#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,094 INFO L290 TraceCheckUtils]: 11: Hoare triple {1856#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,094 INFO L290 TraceCheckUtils]: 12: Hoare triple {1856#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,094 INFO L290 TraceCheckUtils]: 13: Hoare triple {1856#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {1856#true} is VALID [2022-02-20 20:38:37,094 INFO L290 TraceCheckUtils]: 14: Hoare triple {1856#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {1856#true} is VALID [2022-02-20 20:38:37,095 INFO L290 TraceCheckUtils]: 15: Hoare triple {1856#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,095 INFO L290 TraceCheckUtils]: 16: Hoare triple {1856#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,095 INFO L290 TraceCheckUtils]: 17: Hoare triple {1856#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,095 INFO L290 TraceCheckUtils]: 18: Hoare triple {1856#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,095 INFO L290 TraceCheckUtils]: 19: Hoare triple {1856#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,097 INFO L290 TraceCheckUtils]: 20: Hoare triple {1856#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,097 INFO L290 TraceCheckUtils]: 21: Hoare triple {1856#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,097 INFO L290 TraceCheckUtils]: 22: Hoare triple {1856#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,097 INFO L290 TraceCheckUtils]: 23: Hoare triple {1856#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {1856#true} is VALID [2022-02-20 20:38:37,098 INFO L290 TraceCheckUtils]: 24: Hoare triple {1856#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {1856#true} is VALID [2022-02-20 20:38:37,098 INFO L290 TraceCheckUtils]: 25: Hoare triple {1856#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {1856#true} is VALID [2022-02-20 20:38:37,098 INFO L290 TraceCheckUtils]: 26: Hoare triple {1856#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {1856#true} is VALID [2022-02-20 20:38:37,098 INFO L290 TraceCheckUtils]: 27: Hoare triple {1856#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {1856#true} is VALID [2022-02-20 20:38:37,098 INFO L290 TraceCheckUtils]: 28: Hoare triple {1856#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {1856#true} is VALID [2022-02-20 20:38:37,098 INFO L290 TraceCheckUtils]: 29: Hoare triple {1856#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {1856#true} is VALID [2022-02-20 20:38:37,099 INFO L290 TraceCheckUtils]: 30: Hoare triple {1856#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {1856#true} is VALID [2022-02-20 20:38:37,099 INFO L290 TraceCheckUtils]: 31: Hoare triple {1856#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {1856#true} is VALID [2022-02-20 20:38:37,099 INFO L290 TraceCheckUtils]: 32: Hoare triple {1856#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {1856#true} is VALID [2022-02-20 20:38:37,099 INFO L290 TraceCheckUtils]: 33: Hoare triple {1856#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {1856#true} is VALID [2022-02-20 20:38:37,099 INFO L290 TraceCheckUtils]: 34: Hoare triple {1856#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {1856#true} is VALID [2022-02-20 20:38:37,099 INFO L290 TraceCheckUtils]: 35: Hoare triple {1856#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {1856#true} is VALID [2022-02-20 20:38:37,100 INFO L290 TraceCheckUtils]: 36: Hoare triple {1856#true} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {1856#true} is VALID [2022-02-20 20:38:37,100 INFO L290 TraceCheckUtils]: 37: Hoare triple {1856#true} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {1856#true} is VALID [2022-02-20 20:38:37,100 INFO L290 TraceCheckUtils]: 38: Hoare triple {1856#true} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {1856#true} is VALID [2022-02-20 20:38:37,101 INFO L290 TraceCheckUtils]: 39: Hoare triple {1856#true} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:37,101 INFO L290 TraceCheckUtils]: 40: Hoare triple {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:37,101 INFO L290 TraceCheckUtils]: 41: Hoare triple {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:37,102 INFO L290 TraceCheckUtils]: 42: Hoare triple {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:37,102 INFO L290 TraceCheckUtils]: 43: Hoare triple {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:37,102 INFO L290 TraceCheckUtils]: 44: Hoare triple {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:37,103 INFO L290 TraceCheckUtils]: 45: Hoare triple {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:37,103 INFO L290 TraceCheckUtils]: 46: Hoare triple {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:37,104 INFO L290 TraceCheckUtils]: 47: Hoare triple {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} is VALID [2022-02-20 20:38:37,105 INFO L290 TraceCheckUtils]: 48: Hoare triple {1981#(<= thread_function_mutexThread1of1ForFork0_~i~0 0)} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {2009#(<= |thread_function_mutexThread1of1ForFork0_#t~post31| 0)} is VALID [2022-02-20 20:38:37,108 INFO L290 TraceCheckUtils]: 49: Hoare triple {2009#(<= |thread_function_mutexThread1of1ForFork0_#t~post31| 0)} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {1860#(<= thread_function_mutexThread1of1ForFork0_~i~0 1)} is VALID [2022-02-20 20:38:37,111 INFO L290 TraceCheckUtils]: 50: Hoare triple {1860#(<= thread_function_mutexThread1of1ForFork0_~i~0 1)} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {1860#(<= thread_function_mutexThread1of1ForFork0_~i~0 1)} is VALID [2022-02-20 20:38:37,112 INFO L290 TraceCheckUtils]: 51: Hoare triple {1860#(<= thread_function_mutexThread1of1ForFork0_~i~0 1)} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,112 INFO L290 TraceCheckUtils]: 52: Hoare triple {1857#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {1857#false} is VALID [2022-02-20 20:38:37,112 INFO L290 TraceCheckUtils]: 53: Hoare triple {1857#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,113 INFO L290 TraceCheckUtils]: 54: Hoare triple {1857#false} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,114 INFO L290 TraceCheckUtils]: 55: Hoare triple {1857#false} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {1857#false} is VALID [2022-02-20 20:38:37,114 INFO L290 TraceCheckUtils]: 56: Hoare triple {1857#false} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {1857#false} is VALID [2022-02-20 20:38:37,114 INFO L290 TraceCheckUtils]: 57: Hoare triple {1857#false} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {1857#false} is VALID [2022-02-20 20:38:37,117 INFO L290 TraceCheckUtils]: 58: Hoare triple {1857#false} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,118 INFO L290 TraceCheckUtils]: 59: Hoare triple {1857#false} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {1857#false} is VALID [2022-02-20 20:38:37,118 INFO L290 TraceCheckUtils]: 60: Hoare triple {1857#false} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {1857#false} is VALID [2022-02-20 20:38:37,118 INFO L290 TraceCheckUtils]: 61: Hoare triple {1857#false} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {1857#false} is VALID [2022-02-20 20:38:37,118 INFO L290 TraceCheckUtils]: 62: Hoare triple {1857#false} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {1857#false} is VALID [2022-02-20 20:38:37,118 INFO L290 TraceCheckUtils]: 63: Hoare triple {1857#false} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {1857#false} is VALID [2022-02-20 20:38:37,118 INFO L290 TraceCheckUtils]: 64: Hoare triple {1857#false} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {1857#false} is VALID [2022-02-20 20:38:37,119 INFO L290 TraceCheckUtils]: 65: Hoare triple {1857#false} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {1857#false} is VALID [2022-02-20 20:38:37,119 INFO L290 TraceCheckUtils]: 66: Hoare triple {1857#false} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,119 INFO L290 TraceCheckUtils]: 67: Hoare triple {1857#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {1857#false} is VALID [2022-02-20 20:38:37,119 INFO L290 TraceCheckUtils]: 68: Hoare triple {1857#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,119 INFO L290 TraceCheckUtils]: 69: Hoare triple {1857#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,119 INFO L290 TraceCheckUtils]: 70: Hoare triple {1857#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {1857#false} is VALID [2022-02-20 20:38:37,120 INFO L290 TraceCheckUtils]: 71: Hoare triple {1857#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,120 INFO L290 TraceCheckUtils]: 72: Hoare triple {1857#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {1857#false} is VALID [2022-02-20 20:38:37,120 INFO L290 TraceCheckUtils]: 73: Hoare triple {1857#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {1857#false} is VALID [2022-02-20 20:38:37,120 INFO L290 TraceCheckUtils]: 74: Hoare triple {1857#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {1857#false} is VALID [2022-02-20 20:38:37,120 INFO L290 TraceCheckUtils]: 75: Hoare triple {1857#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,120 INFO L290 TraceCheckUtils]: 76: Hoare triple {1857#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,123 INFO L134 CoverageAnalysis]: Checked inductivity of 2 backedges. 0 proven. 1 refuted. 0 times theorem prover too weak. 1 trivial. 0 not checked. [2022-02-20 20:38:37,123 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-02-20 20:38:37,287 INFO L290 TraceCheckUtils]: 76: Hoare triple {1857#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,287 INFO L290 TraceCheckUtils]: 75: Hoare triple {1857#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,287 INFO L290 TraceCheckUtils]: 74: Hoare triple {1857#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {1857#false} is VALID [2022-02-20 20:38:37,287 INFO L290 TraceCheckUtils]: 73: Hoare triple {1857#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {1857#false} is VALID [2022-02-20 20:38:37,288 INFO L290 TraceCheckUtils]: 72: Hoare triple {1857#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {1857#false} is VALID [2022-02-20 20:38:37,288 INFO L290 TraceCheckUtils]: 71: Hoare triple {1857#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,288 INFO L290 TraceCheckUtils]: 70: Hoare triple {1857#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {1857#false} is VALID [2022-02-20 20:38:37,288 INFO L290 TraceCheckUtils]: 69: Hoare triple {1857#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,288 INFO L290 TraceCheckUtils]: 68: Hoare triple {1857#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,288 INFO L290 TraceCheckUtils]: 67: Hoare triple {1857#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {1857#false} is VALID [2022-02-20 20:38:37,289 INFO L290 TraceCheckUtils]: 66: Hoare triple {1857#false} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,289 INFO L290 TraceCheckUtils]: 65: Hoare triple {1857#false} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {1857#false} is VALID [2022-02-20 20:38:37,289 INFO L290 TraceCheckUtils]: 64: Hoare triple {1857#false} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {1857#false} is VALID [2022-02-20 20:38:37,289 INFO L290 TraceCheckUtils]: 63: Hoare triple {1857#false} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {1857#false} is VALID [2022-02-20 20:38:37,289 INFO L290 TraceCheckUtils]: 62: Hoare triple {1857#false} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {1857#false} is VALID [2022-02-20 20:38:37,289 INFO L290 TraceCheckUtils]: 61: Hoare triple {1857#false} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {1857#false} is VALID [2022-02-20 20:38:37,290 INFO L290 TraceCheckUtils]: 60: Hoare triple {1857#false} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {1857#false} is VALID [2022-02-20 20:38:37,290 INFO L290 TraceCheckUtils]: 59: Hoare triple {1857#false} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {1857#false} is VALID [2022-02-20 20:38:37,290 INFO L290 TraceCheckUtils]: 58: Hoare triple {1857#false} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,290 INFO L290 TraceCheckUtils]: 57: Hoare triple {1857#false} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {1857#false} is VALID [2022-02-20 20:38:37,290 INFO L290 TraceCheckUtils]: 56: Hoare triple {1857#false} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {1857#false} is VALID [2022-02-20 20:38:37,290 INFO L290 TraceCheckUtils]: 55: Hoare triple {1857#false} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {1857#false} is VALID [2022-02-20 20:38:37,290 INFO L290 TraceCheckUtils]: 54: Hoare triple {1857#false} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,291 INFO L290 TraceCheckUtils]: 53: Hoare triple {1857#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,291 INFO L290 TraceCheckUtils]: 52: Hoare triple {1857#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {1857#false} is VALID [2022-02-20 20:38:37,291 INFO L290 TraceCheckUtils]: 51: Hoare triple {2169#(< thread_function_mutexThread1of1ForFork0_~i~0 20)} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {1857#false} is VALID [2022-02-20 20:38:37,291 INFO L290 TraceCheckUtils]: 50: Hoare triple {2169#(< thread_function_mutexThread1of1ForFork0_~i~0 20)} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {2169#(< thread_function_mutexThread1of1ForFork0_~i~0 20)} is VALID [2022-02-20 20:38:37,292 INFO L290 TraceCheckUtils]: 49: Hoare triple {2176#(< |thread_function_mutexThread1of1ForFork0_#t~post31| 19)} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {2169#(< thread_function_mutexThread1of1ForFork0_~i~0 20)} is VALID [2022-02-20 20:38:37,292 INFO L290 TraceCheckUtils]: 48: Hoare triple {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {2176#(< |thread_function_mutexThread1of1ForFork0_#t~post31| 19)} is VALID [2022-02-20 20:38:37,293 INFO L290 TraceCheckUtils]: 47: Hoare triple {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} is VALID [2022-02-20 20:38:37,293 INFO L290 TraceCheckUtils]: 46: Hoare triple {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} is VALID [2022-02-20 20:38:37,293 INFO L290 TraceCheckUtils]: 45: Hoare triple {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} is VALID [2022-02-20 20:38:37,294 INFO L290 TraceCheckUtils]: 44: Hoare triple {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} is VALID [2022-02-20 20:38:37,294 INFO L290 TraceCheckUtils]: 43: Hoare triple {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} is VALID [2022-02-20 20:38:37,294 INFO L290 TraceCheckUtils]: 42: Hoare triple {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} is VALID [2022-02-20 20:38:37,295 INFO L290 TraceCheckUtils]: 41: Hoare triple {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} is VALID [2022-02-20 20:38:37,295 INFO L290 TraceCheckUtils]: 40: Hoare triple {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} is VALID [2022-02-20 20:38:37,295 INFO L290 TraceCheckUtils]: 39: Hoare triple {1856#true} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {2180#(< thread_function_mutexThread1of1ForFork0_~i~0 19)} is VALID [2022-02-20 20:38:37,296 INFO L290 TraceCheckUtils]: 38: Hoare triple {1856#true} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {1856#true} is VALID [2022-02-20 20:38:37,296 INFO L290 TraceCheckUtils]: 37: Hoare triple {1856#true} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {1856#true} is VALID [2022-02-20 20:38:37,296 INFO L290 TraceCheckUtils]: 36: Hoare triple {1856#true} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {1856#true} is VALID [2022-02-20 20:38:37,296 INFO L290 TraceCheckUtils]: 35: Hoare triple {1856#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {1856#true} is VALID [2022-02-20 20:38:37,296 INFO L290 TraceCheckUtils]: 34: Hoare triple {1856#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {1856#true} is VALID [2022-02-20 20:38:37,296 INFO L290 TraceCheckUtils]: 33: Hoare triple {1856#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {1856#true} is VALID [2022-02-20 20:38:37,297 INFO L290 TraceCheckUtils]: 32: Hoare triple {1856#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {1856#true} is VALID [2022-02-20 20:38:37,297 INFO L290 TraceCheckUtils]: 31: Hoare triple {1856#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {1856#true} is VALID [2022-02-20 20:38:37,297 INFO L290 TraceCheckUtils]: 30: Hoare triple {1856#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {1856#true} is VALID [2022-02-20 20:38:37,297 INFO L290 TraceCheckUtils]: 29: Hoare triple {1856#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {1856#true} is VALID [2022-02-20 20:38:37,297 INFO L290 TraceCheckUtils]: 28: Hoare triple {1856#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {1856#true} is VALID [2022-02-20 20:38:37,297 INFO L290 TraceCheckUtils]: 27: Hoare triple {1856#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {1856#true} is VALID [2022-02-20 20:38:37,297 INFO L290 TraceCheckUtils]: 26: Hoare triple {1856#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {1856#true} is VALID [2022-02-20 20:38:37,298 INFO L290 TraceCheckUtils]: 25: Hoare triple {1856#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {1856#true} is VALID [2022-02-20 20:38:37,298 INFO L290 TraceCheckUtils]: 24: Hoare triple {1856#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {1856#true} is VALID [2022-02-20 20:38:37,298 INFO L290 TraceCheckUtils]: 23: Hoare triple {1856#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {1856#true} is VALID [2022-02-20 20:38:37,298 INFO L290 TraceCheckUtils]: 22: Hoare triple {1856#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,298 INFO L290 TraceCheckUtils]: 21: Hoare triple {1856#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,298 INFO L290 TraceCheckUtils]: 20: Hoare triple {1856#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,298 INFO L290 TraceCheckUtils]: 19: Hoare triple {1856#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,298 INFO L290 TraceCheckUtils]: 18: Hoare triple {1856#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,299 INFO L290 TraceCheckUtils]: 17: Hoare triple {1856#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,299 INFO L290 TraceCheckUtils]: 16: Hoare triple {1856#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,299 INFO L290 TraceCheckUtils]: 15: Hoare triple {1856#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,299 INFO L290 TraceCheckUtils]: 14: Hoare triple {1856#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {1856#true} is VALID [2022-02-20 20:38:37,299 INFO L290 TraceCheckUtils]: 13: Hoare triple {1856#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {1856#true} is VALID [2022-02-20 20:38:37,299 INFO L290 TraceCheckUtils]: 12: Hoare triple {1856#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,299 INFO L290 TraceCheckUtils]: 11: Hoare triple {1856#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,299 INFO L290 TraceCheckUtils]: 10: Hoare triple {1856#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,300 INFO L290 TraceCheckUtils]: 9: Hoare triple {1856#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,300 INFO L290 TraceCheckUtils]: 8: Hoare triple {1856#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,300 INFO L290 TraceCheckUtils]: 7: Hoare triple {1856#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,300 INFO L290 TraceCheckUtils]: 6: Hoare triple {1856#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,300 INFO L290 TraceCheckUtils]: 5: Hoare triple {1856#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,300 INFO L290 TraceCheckUtils]: 4: Hoare triple {1856#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,300 INFO L290 TraceCheckUtils]: 3: Hoare triple {1856#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,300 INFO L290 TraceCheckUtils]: 2: Hoare triple {1856#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,301 INFO L290 TraceCheckUtils]: 1: Hoare triple {1856#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {1856#true} is VALID [2022-02-20 20:38:37,301 INFO L290 TraceCheckUtils]: 0: Hoare triple {1856#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {1856#true} is VALID [2022-02-20 20:38:37,301 INFO L134 CoverageAnalysis]: Checked inductivity of 2 backedges. 0 proven. 1 refuted. 0 times theorem prover too weak. 1 trivial. 0 not checked. [2022-02-20 20:38:37,301 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [256198319] provided 0 perfect and 2 imperfect interpolant sequences [2022-02-20 20:38:37,301 INFO L191 FreeRefinementEngine]: Found 0 perfect and 3 imperfect interpolant sequences. [2022-02-20 20:38:37,301 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [5, 5, 5] total 10 [2022-02-20 20:38:37,302 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1693622047] [2022-02-20 20:38:37,302 INFO L85 oduleStraightlineAll]: Using 3 imperfect interpolants to construct interpolant automaton [2022-02-20 20:38:37,302 INFO L78 Accepts]: Start accepts. Automaton has has 10 states, 10 states have (on average 10.1) internal successors, (101), 10 states have internal predecessors, (101), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 77 [2022-02-20 20:38:37,303 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 20:38:37,303 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 10 states, 10 states have (on average 10.1) internal successors, (101), 10 states have internal predecessors, (101), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:37,355 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 101 edges. 101 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 20:38:37,356 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 10 states [2022-02-20 20:38:37,356 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 20:38:37,356 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 10 interpolants. [2022-02-20 20:38:37,356 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=30, Invalid=60, Unknown=0, NotChecked=0, Total=90 [2022-02-20 20:38:37,357 INFO L499 CegarLoopForPetriNet]: Number of universal loopers: 80 out of 97 [2022-02-20 20:38:37,358 INFO L92 encePairwiseOnDemand]: Start differencePairwiseOnDemand. First operand has 86 places, 82 transitions, 184 flow. Second operand has 10 states, 10 states have (on average 81.9) internal successors, (819), 10 states have internal predecessors, (819), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:37,359 INFO L101 encePairwiseOnDemand]: Universal subtrahend loopers provided by user. [2022-02-20 20:38:37,359 INFO L102 encePairwiseOnDemand]: Number of universal subtrahend loopers: 80 of 97 [2022-02-20 20:38:37,359 INFO L74 FinitePrefix]: Start finitePrefix. Operand will be constructed on-demand [2022-02-20 20:38:37,440 INFO L129 PetriNetUnfolder]: 2/110 cut-off events. [2022-02-20 20:38:37,440 INFO L130 PetriNetUnfolder]: For 4/4 co-relation queries the response was YES. [2022-02-20 20:38:37,441 INFO L84 FinitePrefix]: Finished finitePrefix Result has 145 conditions, 110 events. 2/110 cut-off events. For 4/4 co-relation queries the response was YES. Maximal size of possible extension queue 3. Compared 55 event pairs, 0 based on Foata normal form. 2/111 useless extension candidates. Maximal degree in co-relation 139. Up to 7 conditions per place. [2022-02-20 20:38:37,441 INFO L132 encePairwiseOnDemand]: 91/97 looper letters, 9 selfloop transitions, 9 changer transitions 0/90 dead transitions. [2022-02-20 20:38:37,441 INFO L138 encePairwiseOnDemand]: Finished differencePairwiseOnDemand. Result has 94 places, 90 transitions, 238 flow [2022-02-20 20:38:37,441 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 9 states. [2022-02-20 20:38:37,441 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 9 states. [2022-02-20 20:38:37,448 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 740 transitions. [2022-02-20 20:38:37,449 INFO L544 CegarLoopForPetriNet]: DFA transition density 0.847651775486827 [2022-02-20 20:38:37,449 INFO L72 ComplementDD]: Start complementDD. Operand 9 states and 740 transitions. [2022-02-20 20:38:37,449 INFO L73 IsDeterministic]: Start isDeterministic. Operand 9 states and 740 transitions. [2022-02-20 20:38:37,449 INFO L80 IsDeterministic]: Finished isDeterministic. Operand is deterministic. [2022-02-20 20:38:37,449 INFO L117 ReachableStatesCopy]: Start reachableStatesCopy. Operand 9 states and 740 transitions. [2022-02-20 20:38:37,451 INFO L343 DoubleDeckerVisitor]: Before removal of dead ends has 10 states, 9 states have (on average 82.22222222222223) internal successors, (740), 9 states have internal predecessors, (740), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:37,452 INFO L131 ReachableStatesCopy]: Finished reachableStatesCopy Result has 10 states, 10 states have (on average 97.0) internal successors, (970), 10 states have internal predecessors, (970), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:37,453 INFO L81 ComplementDD]: Finished complementDD. Result has 10 states, 10 states have (on average 97.0) internal successors, (970), 10 states have internal predecessors, (970), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:37,453 INFO L186 Difference]: Start difference. First operand has 86 places, 82 transitions, 184 flow. Second operand 9 states and 740 transitions. [2022-02-20 20:38:37,453 INFO L82 GeneralOperation]: Start removeRedundantFlow. Operand has 94 places, 90 transitions, 238 flow [2022-02-20 20:38:37,454 INFO L88 GeneralOperation]: Finished removeRedundantFlow, result has has 93 places, 90 transitions, 236 flow, removed 0 selfloop flow, removed 1 redundant places. [2022-02-20 20:38:37,455 INFO L242 Difference]: Finished difference. Result has 96 places, 88 transitions, 232 flow [2022-02-20 20:38:37,455 INFO L317 CegarLoopForPetriNet]: {PETRI_ALPHABET=97, PETRI_DIFFERENCE_MINUEND_FLOW=182, PETRI_DIFFERENCE_MINUEND_PLACES=85, PETRI_DIFFERENCE_MINUEND_TRANSITIONS=82, PETRI_DIFFERENCE_SUBTRAHEND_LETTERS_WITH_MORE_CHANGERS_THAN_LOOPERS=5, PETRI_DIFFERENCE_SUBTRAHEND_LOOPER_ONLY_LETTERS=76, PETRI_DIFFERENCE_SUBTRAHEND_STATES=9, PETRI_FLOW=232, PETRI_PLACES=96, PETRI_TRANSITIONS=88} [2022-02-20 20:38:37,456 INFO L334 CegarLoopForPetriNet]: 84 programPoint places, 12 predicate places. [2022-02-20 20:38:37,456 INFO L111 iNet2FiniteAutomaton]: Start petriNet2FiniteAutomaton. Operand has 96 places, 88 transitions, 232 flow [2022-02-20 20:38:37,473 INFO L133 iNet2FiniteAutomaton]: Finished petriNet2FiniteAutomaton. Result has 1029 states, 1027 states have (on average 1.9600778967867576) internal successors, (2013), 1028 states have internal predecessors, (2013), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:37,475 INFO L78 Accepts]: Start accepts. Automaton has has 1029 states, 1027 states have (on average 1.9600778967867576) internal successors, (2013), 1028 states have internal predecessors, (2013), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 77 [2022-02-20 20:38:37,475 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 20:38:37,475 INFO L470 AbstractCegarLoop]: Abstraction has has 96 places, 88 transitions, 232 flow [2022-02-20 20:38:37,476 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 10 states, 10 states have (on average 81.9) internal successors, (819), 10 states have internal predecessors, (819), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:37,476 INFO L246 CegarLoopForPetriNet]: Found error trace [2022-02-20 20:38:37,476 INFO L254 CegarLoopForPetriNet]: trace histogram [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 20:38:37,518 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (3)] Forceful destruction successful, exit code 0 [2022-02-20 20:38:37,692 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: 3 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true,SelfDestructingSolverStorable3 [2022-02-20 20:38:37,692 INFO L402 AbstractCegarLoop]: === Iteration 5 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATION] === [2022-02-20 20:38:37,692 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 20:38:37,692 INFO L85 PathProgramCache]: Analyzing trace with hash -1717411201, now seen corresponding path program 2 times [2022-02-20 20:38:37,693 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 20:38:37,693 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [949142846] [2022-02-20 20:38:37,693 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 20:38:37,693 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 20:38:37,736 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:37,799 INFO L290 TraceCheckUtils]: 0: Hoare triple {3364#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,799 INFO L290 TraceCheckUtils]: 1: Hoare triple {3364#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {3364#true} is VALID [2022-02-20 20:38:37,799 INFO L290 TraceCheckUtils]: 2: Hoare triple {3364#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,799 INFO L290 TraceCheckUtils]: 3: Hoare triple {3364#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,799 INFO L290 TraceCheckUtils]: 4: Hoare triple {3364#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,800 INFO L290 TraceCheckUtils]: 5: Hoare triple {3364#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,800 INFO L290 TraceCheckUtils]: 6: Hoare triple {3364#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,800 INFO L290 TraceCheckUtils]: 7: Hoare triple {3364#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,800 INFO L290 TraceCheckUtils]: 8: Hoare triple {3364#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,800 INFO L290 TraceCheckUtils]: 9: Hoare triple {3364#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,800 INFO L290 TraceCheckUtils]: 10: Hoare triple {3364#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,800 INFO L290 TraceCheckUtils]: 11: Hoare triple {3364#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,800 INFO L290 TraceCheckUtils]: 12: Hoare triple {3364#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,801 INFO L290 TraceCheckUtils]: 13: Hoare triple {3364#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:37,801 INFO L290 TraceCheckUtils]: 14: Hoare triple {3364#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {3364#true} is VALID [2022-02-20 20:38:37,801 INFO L290 TraceCheckUtils]: 15: Hoare triple {3364#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,801 INFO L290 TraceCheckUtils]: 16: Hoare triple {3364#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,801 INFO L290 TraceCheckUtils]: 17: Hoare triple {3364#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,801 INFO L290 TraceCheckUtils]: 18: Hoare triple {3364#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,801 INFO L290 TraceCheckUtils]: 19: Hoare triple {3364#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,801 INFO L290 TraceCheckUtils]: 20: Hoare triple {3364#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,802 INFO L290 TraceCheckUtils]: 21: Hoare triple {3364#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,802 INFO L290 TraceCheckUtils]: 22: Hoare triple {3364#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,804 INFO L290 TraceCheckUtils]: 23: Hoare triple {3364#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {3364#true} is VALID [2022-02-20 20:38:37,804 INFO L290 TraceCheckUtils]: 24: Hoare triple {3364#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {3364#true} is VALID [2022-02-20 20:38:37,805 INFO L290 TraceCheckUtils]: 25: Hoare triple {3364#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {3364#true} is VALID [2022-02-20 20:38:37,805 INFO L290 TraceCheckUtils]: 26: Hoare triple {3364#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {3364#true} is VALID [2022-02-20 20:38:37,805 INFO L290 TraceCheckUtils]: 27: Hoare triple {3364#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {3364#true} is VALID [2022-02-20 20:38:37,805 INFO L290 TraceCheckUtils]: 28: Hoare triple {3364#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {3364#true} is VALID [2022-02-20 20:38:37,806 INFO L290 TraceCheckUtils]: 29: Hoare triple {3364#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {3364#true} is VALID [2022-02-20 20:38:37,806 INFO L290 TraceCheckUtils]: 30: Hoare triple {3364#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {3364#true} is VALID [2022-02-20 20:38:37,806 INFO L290 TraceCheckUtils]: 31: Hoare triple {3364#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:37,806 INFO L290 TraceCheckUtils]: 32: Hoare triple {3364#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {3364#true} is VALID [2022-02-20 20:38:37,806 INFO L290 TraceCheckUtils]: 33: Hoare triple {3364#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {3364#true} is VALID [2022-02-20 20:38:37,806 INFO L290 TraceCheckUtils]: 34: Hoare triple {3364#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {3364#true} is VALID [2022-02-20 20:38:37,806 INFO L290 TraceCheckUtils]: 35: Hoare triple {3364#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {3364#true} is VALID [2022-02-20 20:38:37,807 INFO L290 TraceCheckUtils]: 36: Hoare triple {3364#true} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {3364#true} is VALID [2022-02-20 20:38:37,807 INFO L290 TraceCheckUtils]: 37: Hoare triple {3364#true} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:37,807 INFO L290 TraceCheckUtils]: 38: Hoare triple {3364#true} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:37,807 INFO L290 TraceCheckUtils]: 39: Hoare triple {3364#true} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:37,807 INFO L290 TraceCheckUtils]: 40: Hoare triple {3364#true} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,807 INFO L290 TraceCheckUtils]: 41: Hoare triple {3364#true} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:37,807 INFO L290 TraceCheckUtils]: 42: Hoare triple {3364#true} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:37,807 INFO L290 TraceCheckUtils]: 43: Hoare triple {3364#true} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:37,808 INFO L290 TraceCheckUtils]: 44: Hoare triple {3364#true} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:37,808 INFO L290 TraceCheckUtils]: 45: Hoare triple {3364#true} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {3364#true} is VALID [2022-02-20 20:38:37,808 INFO L290 TraceCheckUtils]: 46: Hoare triple {3364#true} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:37,808 INFO L290 TraceCheckUtils]: 47: Hoare triple {3364#true} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {3364#true} is VALID [2022-02-20 20:38:37,808 INFO L290 TraceCheckUtils]: 48: Hoare triple {3364#true} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:37,808 INFO L290 TraceCheckUtils]: 49: Hoare triple {3364#true} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:37,808 INFO L290 TraceCheckUtils]: 50: Hoare triple {3364#true} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:37,808 INFO L290 TraceCheckUtils]: 51: Hoare triple {3364#true} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,809 INFO L290 TraceCheckUtils]: 52: Hoare triple {3364#true} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:37,809 INFO L290 TraceCheckUtils]: 53: Hoare triple {3364#true} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:37,809 INFO L290 TraceCheckUtils]: 54: Hoare triple {3364#true} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:37,809 INFO L290 TraceCheckUtils]: 55: Hoare triple {3364#true} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:37,809 INFO L290 TraceCheckUtils]: 56: Hoare triple {3364#true} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {3364#true} is VALID [2022-02-20 20:38:37,809 INFO L290 TraceCheckUtils]: 57: Hoare triple {3364#true} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:37,809 INFO L290 TraceCheckUtils]: 58: Hoare triple {3364#true} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {3364#true} is VALID [2022-02-20 20:38:37,809 INFO L290 TraceCheckUtils]: 59: Hoare triple {3364#true} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:37,809 INFO L290 TraceCheckUtils]: 60: Hoare triple {3364#true} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:37,810 INFO L290 TraceCheckUtils]: 61: Hoare triple {3364#true} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:37,810 INFO L290 TraceCheckUtils]: 62: Hoare triple {3364#true} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,810 INFO L290 TraceCheckUtils]: 63: Hoare triple {3364#true} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:37,810 INFO L290 TraceCheckUtils]: 64: Hoare triple {3364#true} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:37,810 INFO L290 TraceCheckUtils]: 65: Hoare triple {3364#true} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:37,810 INFO L290 TraceCheckUtils]: 66: Hoare triple {3364#true} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:37,810 INFO L290 TraceCheckUtils]: 67: Hoare triple {3364#true} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {3364#true} is VALID [2022-02-20 20:38:37,810 INFO L290 TraceCheckUtils]: 68: Hoare triple {3364#true} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:37,811 INFO L290 TraceCheckUtils]: 69: Hoare triple {3364#true} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {3364#true} is VALID [2022-02-20 20:38:37,811 INFO L290 TraceCheckUtils]: 70: Hoare triple {3364#true} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:37,811 INFO L290 TraceCheckUtils]: 71: Hoare triple {3364#true} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:37,811 INFO L290 TraceCheckUtils]: 72: Hoare triple {3364#true} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:37,811 INFO L290 TraceCheckUtils]: 73: Hoare triple {3364#true} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,811 INFO L290 TraceCheckUtils]: 74: Hoare triple {3364#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:37,811 INFO L290 TraceCheckUtils]: 75: Hoare triple {3364#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {3364#true} is VALID [2022-02-20 20:38:37,811 INFO L290 TraceCheckUtils]: 76: Hoare triple {3364#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {3364#true} is VALID [2022-02-20 20:38:37,812 INFO L290 TraceCheckUtils]: 77: Hoare triple {3364#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:37,812 INFO L290 TraceCheckUtils]: 78: Hoare triple {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:37,812 INFO L290 TraceCheckUtils]: 79: Hoare triple {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:37,813 INFO L290 TraceCheckUtils]: 80: Hoare triple {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:37,813 INFO L290 TraceCheckUtils]: 81: Hoare triple {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:37,813 INFO L290 TraceCheckUtils]: 82: Hoare triple {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:37,814 INFO L290 TraceCheckUtils]: 83: Hoare triple {3366#(= |ULTIMATE.start_main_~i~1#1| 0)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {3367#(= 0 |ULTIMATE.start_main_#t~post40#1|)} is VALID [2022-02-20 20:38:37,814 INFO L290 TraceCheckUtils]: 84: Hoare triple {3367#(= 0 |ULTIMATE.start_main_#t~post40#1|)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {3368#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:37,815 INFO L290 TraceCheckUtils]: 85: Hoare triple {3368#(<= |ULTIMATE.start_main_~i~1#1| 1)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {3368#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:37,815 INFO L290 TraceCheckUtils]: 86: Hoare triple {3368#(<= |ULTIMATE.start_main_~i~1#1| 1)} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:37,815 INFO L290 TraceCheckUtils]: 87: Hoare triple {3365#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {3365#false} is VALID [2022-02-20 20:38:37,815 INFO L290 TraceCheckUtils]: 88: Hoare triple {3365#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {3365#false} is VALID [2022-02-20 20:38:37,815 INFO L290 TraceCheckUtils]: 89: Hoare triple {3365#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:37,816 INFO L290 TraceCheckUtils]: 90: Hoare triple {3365#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:37,816 INFO L290 TraceCheckUtils]: 91: Hoare triple {3365#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:37,816 INFO L290 TraceCheckUtils]: 92: Hoare triple {3365#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {3365#false} is VALID [2022-02-20 20:38:37,816 INFO L290 TraceCheckUtils]: 93: Hoare triple {3365#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:37,816 INFO L290 TraceCheckUtils]: 94: Hoare triple {3365#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {3365#false} is VALID [2022-02-20 20:38:37,816 INFO L290 TraceCheckUtils]: 95: Hoare triple {3365#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {3365#false} is VALID [2022-02-20 20:38:37,816 INFO L290 TraceCheckUtils]: 96: Hoare triple {3365#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {3365#false} is VALID [2022-02-20 20:38:37,816 INFO L290 TraceCheckUtils]: 97: Hoare triple {3365#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:37,817 INFO L290 TraceCheckUtils]: 98: Hoare triple {3365#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:37,817 INFO L134 CoverageAnalysis]: Checked inductivity of 37 backedges. 0 proven. 1 refuted. 0 times theorem prover too weak. 36 trivial. 0 not checked. [2022-02-20 20:38:37,817 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 20:38:37,818 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [949142846] [2022-02-20 20:38:37,818 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [949142846] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 20:38:37,818 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [2027442439] [2022-02-20 20:38:37,818 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST1 [2022-02-20 20:38:37,818 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 20:38:37,819 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 20:38:37,823 INFO L229 MonitoredProcess]: Starting monitored process 4 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 20:38:37,824 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Waiting until timeout for monitored process [2022-02-20 20:38:37,905 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST1 issued 2 check-sat command(s) [2022-02-20 20:38:37,905 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-02-20 20:38:37,906 INFO L263 TraceCheckSpWp]: Trace formula consists of 238 conjuncts, 4 conjunts are in the unsatisfiable core [2022-02-20 20:38:37,927 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:37,929 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 20:38:38,118 INFO L290 TraceCheckUtils]: 0: Hoare triple {3364#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 1: Hoare triple {3364#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 2: Hoare triple {3364#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 3: Hoare triple {3364#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 4: Hoare triple {3364#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 5: Hoare triple {3364#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 6: Hoare triple {3364#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 7: Hoare triple {3364#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 8: Hoare triple {3364#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 9: Hoare triple {3364#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 10: Hoare triple {3364#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 11: Hoare triple {3364#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 12: Hoare triple {3364#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,119 INFO L290 TraceCheckUtils]: 13: Hoare triple {3364#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 14: Hoare triple {3364#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 15: Hoare triple {3364#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 16: Hoare triple {3364#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 17: Hoare triple {3364#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 18: Hoare triple {3364#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 19: Hoare triple {3364#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 20: Hoare triple {3364#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 21: Hoare triple {3364#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 22: Hoare triple {3364#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 23: Hoare triple {3364#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 24: Hoare triple {3364#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 25: Hoare triple {3364#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 26: Hoare triple {3364#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 27: Hoare triple {3364#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 28: Hoare triple {3364#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 29: Hoare triple {3364#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {3364#true} is VALID [2022-02-20 20:38:38,120 INFO L290 TraceCheckUtils]: 30: Hoare triple {3364#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 31: Hoare triple {3364#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 32: Hoare triple {3364#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 33: Hoare triple {3364#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 34: Hoare triple {3364#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 35: Hoare triple {3364#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 36: Hoare triple {3364#true} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 37: Hoare triple {3364#true} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 38: Hoare triple {3364#true} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 39: Hoare triple {3364#true} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 40: Hoare triple {3364#true} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 41: Hoare triple {3364#true} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 42: Hoare triple {3364#true} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 43: Hoare triple {3364#true} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 44: Hoare triple {3364#true} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 45: Hoare triple {3364#true} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 46: Hoare triple {3364#true} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,121 INFO L290 TraceCheckUtils]: 47: Hoare triple {3364#true} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 48: Hoare triple {3364#true} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 49: Hoare triple {3364#true} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 50: Hoare triple {3364#true} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 51: Hoare triple {3364#true} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 52: Hoare triple {3364#true} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 53: Hoare triple {3364#true} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 54: Hoare triple {3364#true} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 55: Hoare triple {3364#true} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 56: Hoare triple {3364#true} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 57: Hoare triple {3364#true} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 58: Hoare triple {3364#true} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 59: Hoare triple {3364#true} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 60: Hoare triple {3364#true} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 61: Hoare triple {3364#true} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 62: Hoare triple {3364#true} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 63: Hoare triple {3364#true} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,122 INFO L290 TraceCheckUtils]: 64: Hoare triple {3364#true} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 65: Hoare triple {3364#true} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 66: Hoare triple {3364#true} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 67: Hoare triple {3364#true} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 68: Hoare triple {3364#true} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 69: Hoare triple {3364#true} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 70: Hoare triple {3364#true} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 71: Hoare triple {3364#true} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 72: Hoare triple {3364#true} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 73: Hoare triple {3364#true} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 74: Hoare triple {3364#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 75: Hoare triple {3364#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 76: Hoare triple {3364#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {3364#true} is VALID [2022-02-20 20:38:38,123 INFO L290 TraceCheckUtils]: 77: Hoare triple {3364#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,124 INFO L290 TraceCheckUtils]: 78: Hoare triple {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,124 INFO L290 TraceCheckUtils]: 79: Hoare triple {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,124 INFO L290 TraceCheckUtils]: 80: Hoare triple {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,124 INFO L290 TraceCheckUtils]: 81: Hoare triple {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,125 INFO L290 TraceCheckUtils]: 82: Hoare triple {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,125 INFO L290 TraceCheckUtils]: 83: Hoare triple {3603#(<= |ULTIMATE.start_main_~i~1#1| 0)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {3622#(<= |ULTIMATE.start_main_#t~post40#1| 0)} is VALID [2022-02-20 20:38:38,125 INFO L290 TraceCheckUtils]: 84: Hoare triple {3622#(<= |ULTIMATE.start_main_#t~post40#1| 0)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {3368#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 85: Hoare triple {3368#(<= |ULTIMATE.start_main_~i~1#1| 1)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {3368#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 86: Hoare triple {3368#(<= |ULTIMATE.start_main_~i~1#1| 1)} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 87: Hoare triple {3365#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {3365#false} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 88: Hoare triple {3365#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {3365#false} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 89: Hoare triple {3365#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 90: Hoare triple {3365#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 91: Hoare triple {3365#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 92: Hoare triple {3365#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {3365#false} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 93: Hoare triple {3365#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,126 INFO L290 TraceCheckUtils]: 94: Hoare triple {3365#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {3365#false} is VALID [2022-02-20 20:38:38,127 INFO L290 TraceCheckUtils]: 95: Hoare triple {3365#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {3365#false} is VALID [2022-02-20 20:38:38,127 INFO L290 TraceCheckUtils]: 96: Hoare triple {3365#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {3365#false} is VALID [2022-02-20 20:38:38,127 INFO L290 TraceCheckUtils]: 97: Hoare triple {3365#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,127 INFO L290 TraceCheckUtils]: 98: Hoare triple {3365#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,127 INFO L134 CoverageAnalysis]: Checked inductivity of 37 backedges. 0 proven. 1 refuted. 0 times theorem prover too weak. 36 trivial. 0 not checked. [2022-02-20 20:38:38,127 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-02-20 20:38:38,300 INFO L290 TraceCheckUtils]: 98: Hoare triple {3365#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,300 INFO L290 TraceCheckUtils]: 97: Hoare triple {3365#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,300 INFO L290 TraceCheckUtils]: 96: Hoare triple {3365#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {3365#false} is VALID [2022-02-20 20:38:38,300 INFO L290 TraceCheckUtils]: 95: Hoare triple {3365#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {3365#false} is VALID [2022-02-20 20:38:38,300 INFO L290 TraceCheckUtils]: 94: Hoare triple {3365#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {3365#false} is VALID [2022-02-20 20:38:38,300 INFO L290 TraceCheckUtils]: 93: Hoare triple {3365#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,300 INFO L290 TraceCheckUtils]: 92: Hoare triple {3365#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {3365#false} is VALID [2022-02-20 20:38:38,300 INFO L290 TraceCheckUtils]: 91: Hoare triple {3365#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,301 INFO L290 TraceCheckUtils]: 90: Hoare triple {3365#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,301 INFO L290 TraceCheckUtils]: 89: Hoare triple {3365#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,301 INFO L290 TraceCheckUtils]: 88: Hoare triple {3365#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {3365#false} is VALID [2022-02-20 20:38:38,301 INFO L290 TraceCheckUtils]: 87: Hoare triple {3365#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {3365#false} is VALID [2022-02-20 20:38:38,301 INFO L290 TraceCheckUtils]: 86: Hoare triple {3704#(< |ULTIMATE.start_main_~i~1#1| 20)} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {3365#false} is VALID [2022-02-20 20:38:38,301 INFO L290 TraceCheckUtils]: 85: Hoare triple {3704#(< |ULTIMATE.start_main_~i~1#1| 20)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {3704#(< |ULTIMATE.start_main_~i~1#1| 20)} is VALID [2022-02-20 20:38:38,302 INFO L290 TraceCheckUtils]: 84: Hoare triple {3711#(< |ULTIMATE.start_main_#t~post40#1| 19)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {3704#(< |ULTIMATE.start_main_~i~1#1| 20)} is VALID [2022-02-20 20:38:38,302 INFO L290 TraceCheckUtils]: 83: Hoare triple {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {3711#(< |ULTIMATE.start_main_#t~post40#1| 19)} is VALID [2022-02-20 20:38:38,302 INFO L290 TraceCheckUtils]: 82: Hoare triple {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:38,303 INFO L290 TraceCheckUtils]: 81: Hoare triple {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:38,303 INFO L290 TraceCheckUtils]: 80: Hoare triple {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:38,303 INFO L290 TraceCheckUtils]: 79: Hoare triple {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:38,303 INFO L290 TraceCheckUtils]: 78: Hoare triple {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 77: Hoare triple {3364#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {3715#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 76: Hoare triple {3364#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 75: Hoare triple {3364#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 74: Hoare triple {3364#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 73: Hoare triple {3364#true} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 72: Hoare triple {3364#true} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 71: Hoare triple {3364#true} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 70: Hoare triple {3364#true} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 69: Hoare triple {3364#true} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 68: Hoare triple {3364#true} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 67: Hoare triple {3364#true} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 66: Hoare triple {3364#true} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 65: Hoare triple {3364#true} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,304 INFO L290 TraceCheckUtils]: 64: Hoare triple {3364#true} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 63: Hoare triple {3364#true} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 62: Hoare triple {3364#true} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 61: Hoare triple {3364#true} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 60: Hoare triple {3364#true} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 59: Hoare triple {3364#true} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 58: Hoare triple {3364#true} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 57: Hoare triple {3364#true} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 56: Hoare triple {3364#true} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 55: Hoare triple {3364#true} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,315 INFO L290 TraceCheckUtils]: 54: Hoare triple {3364#true} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 53: Hoare triple {3364#true} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 52: Hoare triple {3364#true} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 51: Hoare triple {3364#true} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 50: Hoare triple {3364#true} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 49: Hoare triple {3364#true} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 48: Hoare triple {3364#true} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 47: Hoare triple {3364#true} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 46: Hoare triple {3364#true} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 45: Hoare triple {3364#true} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 44: Hoare triple {3364#true} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 43: Hoare triple {3364#true} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 42: Hoare triple {3364#true} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 41: Hoare triple {3364#true} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 40: Hoare triple {3364#true} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 39: Hoare triple {3364#true} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 38: Hoare triple {3364#true} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 37: Hoare triple {3364#true} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {3364#true} is VALID [2022-02-20 20:38:38,316 INFO L290 TraceCheckUtils]: 36: Hoare triple {3364#true} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 35: Hoare triple {3364#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 34: Hoare triple {3364#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 33: Hoare triple {3364#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 32: Hoare triple {3364#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 31: Hoare triple {3364#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 30: Hoare triple {3364#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 29: Hoare triple {3364#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 28: Hoare triple {3364#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 27: Hoare triple {3364#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 26: Hoare triple {3364#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 25: Hoare triple {3364#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 24: Hoare triple {3364#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 23: Hoare triple {3364#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 22: Hoare triple {3364#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 21: Hoare triple {3364#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 20: Hoare triple {3364#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,317 INFO L290 TraceCheckUtils]: 19: Hoare triple {3364#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 18: Hoare triple {3364#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 17: Hoare triple {3364#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 16: Hoare triple {3364#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 15: Hoare triple {3364#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 14: Hoare triple {3364#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 13: Hoare triple {3364#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 12: Hoare triple {3364#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 11: Hoare triple {3364#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 10: Hoare triple {3364#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 9: Hoare triple {3364#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 8: Hoare triple {3364#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 7: Hoare triple {3364#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 6: Hoare triple {3364#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 5: Hoare triple {3364#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 4: Hoare triple {3364#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 3: Hoare triple {3364#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,318 INFO L290 TraceCheckUtils]: 2: Hoare triple {3364#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,319 INFO L290 TraceCheckUtils]: 1: Hoare triple {3364#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {3364#true} is VALID [2022-02-20 20:38:38,319 INFO L290 TraceCheckUtils]: 0: Hoare triple {3364#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {3364#true} is VALID [2022-02-20 20:38:38,319 INFO L134 CoverageAnalysis]: Checked inductivity of 37 backedges. 0 proven. 1 refuted. 0 times theorem prover too weak. 36 trivial. 0 not checked. [2022-02-20 20:38:38,319 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [2027442439] provided 0 perfect and 2 imperfect interpolant sequences [2022-02-20 20:38:38,319 INFO L191 FreeRefinementEngine]: Found 0 perfect and 3 imperfect interpolant sequences. [2022-02-20 20:38:38,319 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [5, 5, 5] total 10 [2022-02-20 20:38:38,319 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1536101572] [2022-02-20 20:38:38,319 INFO L85 oduleStraightlineAll]: Using 3 imperfect interpolants to construct interpolant automaton [2022-02-20 20:38:38,320 INFO L78 Accepts]: Start accepts. Automaton has has 10 states, 10 states have (on average 9.5) internal successors, (95), 10 states have internal predecessors, (95), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 99 [2022-02-20 20:38:38,320 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 20:38:38,320 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 10 states, 10 states have (on average 9.5) internal successors, (95), 10 states have internal predecessors, (95), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:38,372 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 95 edges. 95 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 20:38:38,372 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 10 states [2022-02-20 20:38:38,372 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 20:38:38,372 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 10 interpolants. [2022-02-20 20:38:38,372 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=30, Invalid=60, Unknown=0, NotChecked=0, Total=90 [2022-02-20 20:38:38,373 INFO L499 CegarLoopForPetriNet]: Number of universal loopers: 79 out of 97 [2022-02-20 20:38:38,374 INFO L92 encePairwiseOnDemand]: Start differencePairwiseOnDemand. First operand has 96 places, 88 transitions, 232 flow. Second operand has 10 states, 10 states have (on average 81.0) internal successors, (810), 10 states have internal predecessors, (810), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:38,374 INFO L101 encePairwiseOnDemand]: Universal subtrahend loopers provided by user. [2022-02-20 20:38:38,374 INFO L102 encePairwiseOnDemand]: Number of universal subtrahend loopers: 79 of 97 [2022-02-20 20:38:38,374 INFO L74 FinitePrefix]: Start finitePrefix. Operand will be constructed on-demand [2022-02-20 20:38:38,452 INFO L129 PetriNetUnfolder]: 2/120 cut-off events. [2022-02-20 20:38:38,452 INFO L130 PetriNetUnfolder]: For 7/21 co-relation queries the response was YES. [2022-02-20 20:38:38,453 INFO L84 FinitePrefix]: Finished finitePrefix Result has 178 conditions, 120 events. 2/120 cut-off events. For 7/21 co-relation queries the response was YES. Maximal size of possible extension queue 3. Compared 71 event pairs, 0 based on Foata normal form. 9/128 useless extension candidates. Maximal degree in co-relation 170. Up to 8 conditions per place. [2022-02-20 20:38:38,453 INFO L132 encePairwiseOnDemand]: 91/97 looper letters, 10 selfloop transitions, 9 changer transitions 0/96 dead transitions. [2022-02-20 20:38:38,453 INFO L138 encePairwiseOnDemand]: Finished differencePairwiseOnDemand. Result has 104 places, 96 transitions, 288 flow [2022-02-20 20:38:38,453 INFO L141 InterpolantAutomaton]: Switched to read-only mode: deterministic interpolant automaton has 9 states. [2022-02-20 20:38:38,453 INFO L82 GeneralOperation]: Start removeUnreachable. Operand 9 states. [2022-02-20 20:38:38,471 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 9 states to 9 states and 732 transitions. [2022-02-20 20:38:38,472 INFO L544 CegarLoopForPetriNet]: DFA transition density 0.8384879725085911 [2022-02-20 20:38:38,472 INFO L72 ComplementDD]: Start complementDD. Operand 9 states and 732 transitions. [2022-02-20 20:38:38,472 INFO L73 IsDeterministic]: Start isDeterministic. Operand 9 states and 732 transitions. [2022-02-20 20:38:38,472 INFO L80 IsDeterministic]: Finished isDeterministic. Operand is deterministic. [2022-02-20 20:38:38,472 INFO L117 ReachableStatesCopy]: Start reachableStatesCopy. Operand 9 states and 732 transitions. [2022-02-20 20:38:38,473 INFO L343 DoubleDeckerVisitor]: Before removal of dead ends has 10 states, 9 states have (on average 81.33333333333333) internal successors, (732), 9 states have internal predecessors, (732), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:38,475 INFO L131 ReachableStatesCopy]: Finished reachableStatesCopy Result has 10 states, 10 states have (on average 97.0) internal successors, (970), 10 states have internal predecessors, (970), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:38,475 INFO L81 ComplementDD]: Finished complementDD. Result has 10 states, 10 states have (on average 97.0) internal successors, (970), 10 states have internal predecessors, (970), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:38,475 INFO L186 Difference]: Start difference. First operand has 96 places, 88 transitions, 232 flow. Second operand 9 states and 732 transitions. [2022-02-20 20:38:38,475 INFO L82 GeneralOperation]: Start removeRedundantFlow. Operand has 104 places, 96 transitions, 288 flow [2022-02-20 20:38:38,478 INFO L88 GeneralOperation]: Finished removeRedundantFlow, result has has 103 places, 96 transitions, 282 flow, removed 2 selfloop flow, removed 1 redundant places. [2022-02-20 20:38:38,479 INFO L242 Difference]: Finished difference. Result has 106 places, 94 transitions, 276 flow [2022-02-20 20:38:38,480 INFO L317 CegarLoopForPetriNet]: {PETRI_ALPHABET=97, PETRI_DIFFERENCE_MINUEND_FLOW=226, PETRI_DIFFERENCE_MINUEND_PLACES=95, PETRI_DIFFERENCE_MINUEND_TRANSITIONS=88, PETRI_DIFFERENCE_SUBTRAHEND_LETTERS_WITH_MORE_CHANGERS_THAN_LOOPERS=5, PETRI_DIFFERENCE_SUBTRAHEND_LOOPER_ONLY_LETTERS=82, PETRI_DIFFERENCE_SUBTRAHEND_STATES=9, PETRI_FLOW=276, PETRI_PLACES=106, PETRI_TRANSITIONS=94} [2022-02-20 20:38:38,480 INFO L334 CegarLoopForPetriNet]: 84 programPoint places, 22 predicate places. [2022-02-20 20:38:38,480 INFO L111 iNet2FiniteAutomaton]: Start petriNet2FiniteAutomaton. Operand has 106 places, 94 transitions, 276 flow [2022-02-20 20:38:38,505 INFO L133 iNet2FiniteAutomaton]: Finished petriNet2FiniteAutomaton. Result has 1439 states, 1437 states have (on average 1.9714683368128045) internal successors, (2833), 1438 states have internal predecessors, (2833), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:38,507 INFO L78 Accepts]: Start accepts. Automaton has has 1439 states, 1437 states have (on average 1.9714683368128045) internal successors, (2833), 1438 states have internal predecessors, (2833), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 99 [2022-02-20 20:38:38,507 INFO L84 Accepts]: Finished accepts. word is rejected. [2022-02-20 20:38:38,508 INFO L470 AbstractCegarLoop]: Abstraction has has 106 places, 94 transitions, 276 flow [2022-02-20 20:38:38,508 INFO L471 AbstractCegarLoop]: INTERPOLANT automaton has has 10 states, 10 states have (on average 81.0) internal successors, (810), 10 states have internal predecessors, (810), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:38,508 INFO L246 CegarLoopForPetriNet]: Found error trace [2022-02-20 20:38:38,508 INFO L254 CegarLoopForPetriNet]: trace histogram [3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] [2022-02-20 20:38:38,525 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (4)] Ended with exit code 0 [2022-02-20 20:38:38,724 WARN L452 AbstractCegarLoop]: Destroyed unattended storables created during the last iteration: SelfDestructingSolverStorable4,4 /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 20:38:38,725 INFO L402 AbstractCegarLoop]: === Iteration 6 === Targeting ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION === [ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION, ULTIMATE.startErr0INUSE_VIOLATION] === [2022-02-20 20:38:38,725 INFO L144 PredicateUnifier]: Initialized classic predicate unifier [2022-02-20 20:38:38,725 INFO L85 PathProgramCache]: Analyzing trace with hash -1447238555, now seen corresponding path program 3 times [2022-02-20 20:38:38,726 INFO L126 FreeRefinementEngine]: Executing refinement strategy CAMEL [2022-02-20 20:38:38,726 INFO L338 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1785703638] [2022-02-20 20:38:38,726 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2022-02-20 20:38:38,726 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2022-02-20 20:38:38,748 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:38,798 INFO L290 TraceCheckUtils]: 0: Hoare triple {5414#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 1: Hoare triple {5414#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 2: Hoare triple {5414#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 3: Hoare triple {5414#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 4: Hoare triple {5414#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 5: Hoare triple {5414#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 6: Hoare triple {5414#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 7: Hoare triple {5414#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 8: Hoare triple {5414#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 9: Hoare triple {5414#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 10: Hoare triple {5414#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 11: Hoare triple {5414#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 12: Hoare triple {5414#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 13: Hoare triple {5414#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 14: Hoare triple {5414#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 15: Hoare triple {5414#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,799 INFO L290 TraceCheckUtils]: 16: Hoare triple {5414#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 17: Hoare triple {5414#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 18: Hoare triple {5414#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 19: Hoare triple {5414#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 20: Hoare triple {5414#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 21: Hoare triple {5414#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 22: Hoare triple {5414#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 23: Hoare triple {5414#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 24: Hoare triple {5414#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 25: Hoare triple {5414#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 26: Hoare triple {5414#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 27: Hoare triple {5414#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 28: Hoare triple {5414#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 29: Hoare triple {5414#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 30: Hoare triple {5414#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 31: Hoare triple {5414#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 32: Hoare triple {5414#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 33: Hoare triple {5414#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {5414#true} is VALID [2022-02-20 20:38:38,800 INFO L290 TraceCheckUtils]: 34: Hoare triple {5414#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {5414#true} is VALID [2022-02-20 20:38:38,801 INFO L290 TraceCheckUtils]: 35: Hoare triple {5414#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {5414#true} is VALID [2022-02-20 20:38:38,801 INFO L290 TraceCheckUtils]: 36: Hoare triple {5414#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:38,801 INFO L290 TraceCheckUtils]: 37: Hoare triple {5414#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {5414#true} is VALID [2022-02-20 20:38:38,801 INFO L290 TraceCheckUtils]: 38: Hoare triple {5414#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {5414#true} is VALID [2022-02-20 20:38:38,801 INFO L290 TraceCheckUtils]: 39: Hoare triple {5414#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,801 INFO L290 TraceCheckUtils]: 40: Hoare triple {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,801 INFO L290 TraceCheckUtils]: 41: Hoare triple {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,802 INFO L290 TraceCheckUtils]: 42: Hoare triple {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,802 INFO L290 TraceCheckUtils]: 43: Hoare triple {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,802 INFO L290 TraceCheckUtils]: 44: Hoare triple {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:38,803 INFO L290 TraceCheckUtils]: 45: Hoare triple {5416#(= |ULTIMATE.start_main_~i~1#1| 0)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5417#(= 0 |ULTIMATE.start_main_#t~post40#1|)} is VALID [2022-02-20 20:38:38,803 INFO L290 TraceCheckUtils]: 46: Hoare triple {5417#(= 0 |ULTIMATE.start_main_#t~post40#1|)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:38,803 INFO L290 TraceCheckUtils]: 47: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:38,803 INFO L290 TraceCheckUtils]: 48: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:38,804 INFO L290 TraceCheckUtils]: 49: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:38,804 INFO L290 TraceCheckUtils]: 50: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:38,804 INFO L290 TraceCheckUtils]: 51: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:38,804 INFO L290 TraceCheckUtils]: 52: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:38,805 INFO L290 TraceCheckUtils]: 53: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5419#(<= |ULTIMATE.start_main_#t~post40#1| 1)} is VALID [2022-02-20 20:38:38,805 INFO L290 TraceCheckUtils]: 54: Hoare triple {5419#(<= |ULTIMATE.start_main_#t~post40#1| 1)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:38,805 INFO L290 TraceCheckUtils]: 55: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:38,805 INFO L290 TraceCheckUtils]: 56: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:38,806 INFO L290 TraceCheckUtils]: 57: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:38,806 INFO L290 TraceCheckUtils]: 58: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:38,806 INFO L290 TraceCheckUtils]: 59: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:38,806 INFO L290 TraceCheckUtils]: 60: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:38,807 INFO L290 TraceCheckUtils]: 61: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5421#(<= |ULTIMATE.start_main_#t~post40#1| 2)} is VALID [2022-02-20 20:38:38,807 INFO L290 TraceCheckUtils]: 62: Hoare triple {5421#(<= |ULTIMATE.start_main_#t~post40#1| 2)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5422#(<= |ULTIMATE.start_main_~i~1#1| 3)} is VALID [2022-02-20 20:38:38,807 INFO L290 TraceCheckUtils]: 63: Hoare triple {5422#(<= |ULTIMATE.start_main_~i~1#1| 3)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5422#(<= |ULTIMATE.start_main_~i~1#1| 3)} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 64: Hoare triple {5422#(<= |ULTIMATE.start_main_~i~1#1| 3)} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 65: Hoare triple {5415#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 66: Hoare triple {5415#false} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 67: Hoare triple {5415#false} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 68: Hoare triple {5415#false} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 69: Hoare triple {5415#false} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 70: Hoare triple {5415#false} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 71: Hoare triple {5415#false} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 72: Hoare triple {5415#false} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 73: Hoare triple {5415#false} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 74: Hoare triple {5415#false} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 75: Hoare triple {5415#false} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 76: Hoare triple {5415#false} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 77: Hoare triple {5415#false} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 78: Hoare triple {5415#false} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:38,808 INFO L290 TraceCheckUtils]: 79: Hoare triple {5415#false} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 80: Hoare triple {5415#false} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 81: Hoare triple {5415#false} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 82: Hoare triple {5415#false} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 83: Hoare triple {5415#false} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 84: Hoare triple {5415#false} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 85: Hoare triple {5415#false} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 86: Hoare triple {5415#false} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 87: Hoare triple {5415#false} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 88: Hoare triple {5415#false} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 89: Hoare triple {5415#false} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 90: Hoare triple {5415#false} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 91: Hoare triple {5415#false} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 92: Hoare triple {5415#false} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 93: Hoare triple {5415#false} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 94: Hoare triple {5415#false} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 95: Hoare triple {5415#false} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 96: Hoare triple {5415#false} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:38,809 INFO L290 TraceCheckUtils]: 97: Hoare triple {5415#false} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 98: Hoare triple {5415#false} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 99: Hoare triple {5415#false} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 100: Hoare triple {5415#false} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 101: Hoare triple {5415#false} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 102: Hoare triple {5415#false} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 103: Hoare triple {5415#false} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 104: Hoare triple {5415#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 105: Hoare triple {5415#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 106: Hoare triple {5415#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 107: Hoare triple {5415#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 108: Hoare triple {5415#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 109: Hoare triple {5415#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 110: Hoare triple {5415#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 111: Hoare triple {5415#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 112: Hoare triple {5415#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 113: Hoare triple {5415#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,810 INFO L290 TraceCheckUtils]: 114: Hoare triple {5415#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:38,811 INFO L134 CoverageAnalysis]: Checked inductivity of 63 backedges. 0 proven. 27 refuted. 0 times theorem prover too weak. 36 trivial. 0 not checked. [2022-02-20 20:38:38,811 INFO L144 FreeRefinementEngine]: Strategy CAMEL found an infeasible trace [2022-02-20 20:38:38,811 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleSmtInterpolCraig [1785703638] [2022-02-20 20:38:38,811 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleSmtInterpolCraig [1785703638] provided 0 perfect and 1 imperfect interpolant sequences [2022-02-20 20:38:38,811 INFO L338 FreeRefinementEngine]: Using interpolant generator IpTcStrategyModuleZ3 [869706051] [2022-02-20 20:38:38,811 INFO L93 rtionOrderModulation]: Changing assertion order to OUTSIDE_LOOP_FIRST2 [2022-02-20 20:38:38,811 INFO L173 SolverBuilder]: Constructing external solver with command: z3 -smt2 -in SMTLIB2_COMPLIANT=true [2022-02-20 20:38:38,811 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2022-02-20 20:38:38,812 INFO L229 MonitoredProcess]: Starting monitored process 5 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (exit command is (exit), workingDir is null) [2022-02-20 20:38:38,813 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 -smt2 -in SMTLIB2_COMPLIANT=true (5)] Waiting until timeout for monitored process [2022-02-20 20:38:38,892 INFO L228 tOrderPrioritization]: Assert order OUTSIDE_LOOP_FIRST2 issued 4 check-sat command(s) [2022-02-20 20:38:38,892 INFO L229 tOrderPrioritization]: Conjunction of SSA is unsat [2022-02-20 20:38:38,893 INFO L263 TraceCheckSpWp]: Trace formula consists of 280 conjuncts, 8 conjunts are in the unsatisfiable core [2022-02-20 20:38:38,908 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2022-02-20 20:38:38,909 INFO L286 TraceCheckSpWp]: Computing forward predicates... [2022-02-20 20:38:39,195 INFO L290 TraceCheckUtils]: 0: Hoare triple {5414#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 1: Hoare triple {5414#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 2: Hoare triple {5414#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 3: Hoare triple {5414#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 4: Hoare triple {5414#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 5: Hoare triple {5414#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 6: Hoare triple {5414#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 7: Hoare triple {5414#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 8: Hoare triple {5414#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 9: Hoare triple {5414#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 10: Hoare triple {5414#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 11: Hoare triple {5414#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 12: Hoare triple {5414#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 13: Hoare triple {5414#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 14: Hoare triple {5414#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {5414#true} is VALID [2022-02-20 20:38:39,196 INFO L290 TraceCheckUtils]: 15: Hoare triple {5414#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 16: Hoare triple {5414#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 17: Hoare triple {5414#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 18: Hoare triple {5414#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 19: Hoare triple {5414#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 20: Hoare triple {5414#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 21: Hoare triple {5414#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 22: Hoare triple {5414#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 23: Hoare triple {5414#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 24: Hoare triple {5414#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 25: Hoare triple {5414#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 26: Hoare triple {5414#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 27: Hoare triple {5414#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 28: Hoare triple {5414#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 29: Hoare triple {5414#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 30: Hoare triple {5414#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 31: Hoare triple {5414#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {5414#true} is VALID [2022-02-20 20:38:39,197 INFO L290 TraceCheckUtils]: 32: Hoare triple {5414#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {5414#true} is VALID [2022-02-20 20:38:39,198 INFO L290 TraceCheckUtils]: 33: Hoare triple {5414#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {5414#true} is VALID [2022-02-20 20:38:39,198 INFO L290 TraceCheckUtils]: 34: Hoare triple {5414#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {5414#true} is VALID [2022-02-20 20:38:39,198 INFO L290 TraceCheckUtils]: 35: Hoare triple {5414#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {5414#true} is VALID [2022-02-20 20:38:39,198 INFO L290 TraceCheckUtils]: 36: Hoare triple {5414#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,198 INFO L290 TraceCheckUtils]: 37: Hoare triple {5414#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {5414#true} is VALID [2022-02-20 20:38:39,198 INFO L290 TraceCheckUtils]: 38: Hoare triple {5414#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {5414#true} is VALID [2022-02-20 20:38:39,198 INFO L290 TraceCheckUtils]: 39: Hoare triple {5414#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:39,199 INFO L290 TraceCheckUtils]: 40: Hoare triple {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:39,199 INFO L290 TraceCheckUtils]: 41: Hoare triple {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:39,199 INFO L290 TraceCheckUtils]: 42: Hoare triple {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:39,199 INFO L290 TraceCheckUtils]: 43: Hoare triple {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:39,200 INFO L290 TraceCheckUtils]: 44: Hoare triple {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} is VALID [2022-02-20 20:38:39,200 INFO L290 TraceCheckUtils]: 45: Hoare triple {5543#(<= |ULTIMATE.start_main_~i~1#1| 0)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5562#(<= |ULTIMATE.start_main_#t~post40#1| 0)} is VALID [2022-02-20 20:38:39,201 INFO L290 TraceCheckUtils]: 46: Hoare triple {5562#(<= |ULTIMATE.start_main_#t~post40#1| 0)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:39,201 INFO L290 TraceCheckUtils]: 47: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:39,201 INFO L290 TraceCheckUtils]: 48: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:39,201 INFO L290 TraceCheckUtils]: 49: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:39,202 INFO L290 TraceCheckUtils]: 50: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:39,202 INFO L290 TraceCheckUtils]: 51: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:39,202 INFO L290 TraceCheckUtils]: 52: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} is VALID [2022-02-20 20:38:39,203 INFO L290 TraceCheckUtils]: 53: Hoare triple {5418#(<= |ULTIMATE.start_main_~i~1#1| 1)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5419#(<= |ULTIMATE.start_main_#t~post40#1| 1)} is VALID [2022-02-20 20:38:39,203 INFO L290 TraceCheckUtils]: 54: Hoare triple {5419#(<= |ULTIMATE.start_main_#t~post40#1| 1)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:39,203 INFO L290 TraceCheckUtils]: 55: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:39,204 INFO L290 TraceCheckUtils]: 56: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:39,204 INFO L290 TraceCheckUtils]: 57: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:39,204 INFO L290 TraceCheckUtils]: 58: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:39,204 INFO L290 TraceCheckUtils]: 59: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:39,205 INFO L290 TraceCheckUtils]: 60: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} is VALID [2022-02-20 20:38:39,205 INFO L290 TraceCheckUtils]: 61: Hoare triple {5420#(<= |ULTIMATE.start_main_~i~1#1| 2)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5421#(<= |ULTIMATE.start_main_#t~post40#1| 2)} is VALID [2022-02-20 20:38:39,205 INFO L290 TraceCheckUtils]: 62: Hoare triple {5421#(<= |ULTIMATE.start_main_#t~post40#1| 2)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5422#(<= |ULTIMATE.start_main_~i~1#1| 3)} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 63: Hoare triple {5422#(<= |ULTIMATE.start_main_~i~1#1| 3)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5422#(<= |ULTIMATE.start_main_~i~1#1| 3)} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 64: Hoare triple {5422#(<= |ULTIMATE.start_main_~i~1#1| 3)} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 65: Hoare triple {5415#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {5415#false} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 66: Hoare triple {5415#false} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {5415#false} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 67: Hoare triple {5415#false} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 68: Hoare triple {5415#false} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 69: Hoare triple {5415#false} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 70: Hoare triple {5415#false} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 71: Hoare triple {5415#false} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,206 INFO L290 TraceCheckUtils]: 72: Hoare triple {5415#false} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 73: Hoare triple {5415#false} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 74: Hoare triple {5415#false} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 75: Hoare triple {5415#false} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 76: Hoare triple {5415#false} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 77: Hoare triple {5415#false} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 78: Hoare triple {5415#false} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 79: Hoare triple {5415#false} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 80: Hoare triple {5415#false} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 81: Hoare triple {5415#false} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 82: Hoare triple {5415#false} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 83: Hoare triple {5415#false} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 84: Hoare triple {5415#false} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 85: Hoare triple {5415#false} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 86: Hoare triple {5415#false} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 87: Hoare triple {5415#false} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 88: Hoare triple {5415#false} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {5415#false} is VALID [2022-02-20 20:38:39,207 INFO L290 TraceCheckUtils]: 89: Hoare triple {5415#false} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 90: Hoare triple {5415#false} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 91: Hoare triple {5415#false} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 92: Hoare triple {5415#false} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 93: Hoare triple {5415#false} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 94: Hoare triple {5415#false} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 95: Hoare triple {5415#false} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 96: Hoare triple {5415#false} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 97: Hoare triple {5415#false} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 98: Hoare triple {5415#false} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 99: Hoare triple {5415#false} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 100: Hoare triple {5415#false} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 101: Hoare triple {5415#false} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 102: Hoare triple {5415#false} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 103: Hoare triple {5415#false} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 104: Hoare triple {5415#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 105: Hoare triple {5415#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,208 INFO L290 TraceCheckUtils]: 106: Hoare triple {5415#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,209 INFO L290 TraceCheckUtils]: 107: Hoare triple {5415#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,209 INFO L290 TraceCheckUtils]: 108: Hoare triple {5415#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {5415#false} is VALID [2022-02-20 20:38:39,209 INFO L290 TraceCheckUtils]: 109: Hoare triple {5415#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,209 INFO L290 TraceCheckUtils]: 110: Hoare triple {5415#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {5415#false} is VALID [2022-02-20 20:38:39,209 INFO L290 TraceCheckUtils]: 111: Hoare triple {5415#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {5415#false} is VALID [2022-02-20 20:38:39,209 INFO L290 TraceCheckUtils]: 112: Hoare triple {5415#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {5415#false} is VALID [2022-02-20 20:38:39,209 INFO L290 TraceCheckUtils]: 113: Hoare triple {5415#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,209 INFO L290 TraceCheckUtils]: 114: Hoare triple {5415#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,209 INFO L134 CoverageAnalysis]: Checked inductivity of 63 backedges. 0 proven. 27 refuted. 0 times theorem prover too weak. 36 trivial. 0 not checked. [2022-02-20 20:38:39,209 INFO L328 TraceCheckSpWp]: Computing backward predicates... [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 114: Hoare triple {5415#false} [194] L13-2-->ULTIMATE.startErr0ASSERT_VIOLATIONERROR_FUNCTION: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 113: Hoare triple {5415#false} [142] L13-1-->L13-2: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_3| 0) InVars {ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_3|} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 112: Hoare triple {5415#false} [144] L13-->L13-1: Formula: (= |v_ULTIMATE.start___VERIFIER_assert_~cond#1_2| |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|) InVars {ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_2|, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_2|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 111: Hoare triple {5415#false} [130] L1357-1-->L13: Formula: true InVars {} OutVars{ULTIMATE.start___VERIFIER_assert_~cond#1=|v_ULTIMATE.start___VERIFIER_assert_~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_~cond#1] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 110: Hoare triple {5415#false} [185] L1357-->L1357-1: Formula: (= (ite (= 40 v_~myglobal~0_5) 1 0) |v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|) InVars {~myglobal~0=v_~myglobal~0_5} OutVars{~myglobal~0=v_~myglobal~0_5, ULTIMATE.start___VERIFIER_assert_#in~cond#1=|v_ULTIMATE.start___VERIFIER_assert_#in~cond#1_1|} AuxVars[] AssignedVars[ULTIMATE.start___VERIFIER_assert_#in~cond#1] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 109: Hoare triple {5415#false} [166] L1353-5-->L1357: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 108: Hoare triple {5415#false} [187] L1353-4-->L1353-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 107: Hoare triple {5415#false} [213] L1353-1-->L1353-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 106: Hoare triple {5415#false} [247] thread_function_mutexEXIT-->L1353-1: Formula: (and (= v_thread_function_mutexThread1of1ForFork0_thidvar1_4 0) (= (let ((.cse0 (mod |v_ULTIMATE.start_main_#t~mem42#1_6| 4294967296))) (ite (<= .cse0 2147483647) .cse0 (+ (- 4294967296) .cse0))) v_thread_function_mutexThread1of1ForFork0_thidvar0_4)) InVars {ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} OutVars{ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_6|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_4, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_4} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 105: Hoare triple {5415#false} [235] thread_function_mutexFINAL-->thread_function_mutexEXIT: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 104: Hoare triple {5415#false} [233] L1323-7-->thread_function_mutexFINAL: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#res.offset_1| 0) (= |v_thread_function_mutexThread1of1ForFork0_#res.base_1| 0)) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_1|, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_#res.base] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 103: Hoare triple {5415#false} [231] L1323-6-->L1323-7: Formula: (not (< v_thread_function_mutexThread1of1ForFork0_~i~0_5 20)) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_5} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,543 INFO L290 TraceCheckUtils]: 102: Hoare triple {5415#false} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 101: Hoare triple {5415#false} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 100: Hoare triple {5415#false} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 99: Hoare triple {5415#false} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 98: Hoare triple {5415#false} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 97: Hoare triple {5415#false} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 96: Hoare triple {5415#false} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 95: Hoare triple {5415#false} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 94: Hoare triple {5415#false} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 93: Hoare triple {5415#false} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 92: Hoare triple {5415#false} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 91: Hoare triple {5415#false} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 90: Hoare triple {5415#false} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 89: Hoare triple {5415#false} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 88: Hoare triple {5415#false} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 87: Hoare triple {5415#false} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 86: Hoare triple {5415#false} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 85: Hoare triple {5415#false} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,544 INFO L290 TraceCheckUtils]: 84: Hoare triple {5415#false} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 83: Hoare triple {5415#false} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 82: Hoare triple {5415#false} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 81: Hoare triple {5415#false} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 80: Hoare triple {5415#false} [244] L1323-5-->L1323-6: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_5|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 79: Hoare triple {5415#false} [243] L1323-4-->L1323-5: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_11 (+ |v_thread_function_mutexThread1of1ForFork0_#t~post31_3| 1)) InVars {thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_3|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_11} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 78: Hoare triple {5415#false} [242] L1323-3-->L1323-4: Formula: (= |v_thread_function_mutexThread1of1ForFork0_#t~post31_1| v_thread_function_mutexThread1of1ForFork0_~i~0_9) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} OutVars{thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_1|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_9} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~post31] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 77: Hoare triple {5415#false} [241] L1330-->L1323-3: Formula: (= |v_#pthreadsMutex_7| (store |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10| (store (select |v_#pthreadsMutex_8| |v_~#mymutex~0.base_10|) |v_~#mymutex~0.offset_10| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_8|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_10|, ~#mymutex~0.base=|v_~#mymutex~0.base_10|} AuxVars[] AssignedVars[#pthreadsMutex] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 76: Hoare triple {5415#false} [240] L1329-->L1330: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_9 v_~myglobal~0_7) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} OutVars{~myglobal~0=v_~myglobal~0_7, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_9} AuxVars[] AssignedVars[~myglobal~0] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 75: Hoare triple {5415#false} [239] L1328-->L1329: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet33] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 74: Hoare triple {5415#false} [238] L1327-->L1328: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_6 (+ v_thread_function_mutexThread1of1ForFork0_~j~0_5 1)) InVars {thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_5} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_6} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 73: Hoare triple {5415#false} [237] L1326-->L1327: Formula: (= v_thread_function_mutexThread1of1ForFork0_~j~0_3 v_~myglobal~0_6) InVars {~myglobal~0=v_~myglobal~0_6} OutVars{~myglobal~0=v_~myglobal~0_6, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 72: Hoare triple {5415#false} [236] L1325-1-->L1326: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_3|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 71: Hoare triple {5415#false} [234] L1325-->L1325-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9|))) (and (= |v_#pthreadsMutex_5| (store |v_#pthreadsMutex_6| |v_~#mymutex~0.base_9| (store .cse0 |v_~#mymutex~0.offset_9| 1))) (= (select .cse0 |v_~#mymutex~0.offset_9|) 0) (= |v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_9|, ~#mymutex~0.base=|v_~#mymutex~0.base_9|, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_1|} AuxVars[] AssignedVars[#pthreadsMutex, thread_function_mutexThread1of1ForFork0_#t~nondet32] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 70: Hoare triple {5415#false} [232] L1323-6-->L1325: Formula: (< v_thread_function_mutexThread1of1ForFork0_~i~0_7 20) InVars {thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_7} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 69: Hoare triple {5415#false} [229] L1323-->L1323-6: Formula: (= v_thread_function_mutexThread1of1ForFork0_~i~0_3 0) InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_3} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 68: Hoare triple {5415#false} [228] L1322-1-->L1323: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~j~0] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 67: Hoare triple {5415#false} [227] L1322-->L1322-1: Formula: true InVars {} OutVars{thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_1} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~i~0] {5415#false} is VALID [2022-02-20 20:38:39,545 INFO L290 TraceCheckUtils]: 66: Hoare triple {5415#false} [226] thread_function_mutexENTRY-->L1322: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1| v_thread_function_mutexThread1of1ForFork0_~arg.base_1) (= v_thread_function_mutexThread1of1ForFork0_~arg.offset_1 |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|)) InVars {thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_1|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_1, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_1, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_1|} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset] {5415#false} is VALID [2022-02-20 20:38:39,546 INFO L290 TraceCheckUtils]: 65: Hoare triple {5415#false} [179] L1347-6-->L1353: Formula: (= (select (select |v_#memory_int_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_4|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_4|) |v_ULTIMATE.start_main_#t~mem42#1_2|) InVars {#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} OutVars{#memory_int=|v_#memory_int_10|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_2|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_4|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~mem42#1] {5415#false} is VALID [2022-02-20 20:38:39,546 INFO L290 TraceCheckUtils]: 64: Hoare triple {5920#(< |ULTIMATE.start_main_~i~1#1| 20)} [221] L1347-5-->L1347-6: Formula: (not (< |v_ULTIMATE.start_main_~i~1#1_4| 20)) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_4|} AuxVars[] AssignedVars[] {5415#false} is VALID [2022-02-20 20:38:39,546 INFO L290 TraceCheckUtils]: 63: Hoare triple {5920#(< |ULTIMATE.start_main_~i~1#1| 20)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5920#(< |ULTIMATE.start_main_~i~1#1| 20)} is VALID [2022-02-20 20:38:39,547 INFO L290 TraceCheckUtils]: 62: Hoare triple {5927#(< |ULTIMATE.start_main_#t~post40#1| 19)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5920#(< |ULTIMATE.start_main_~i~1#1| 20)} is VALID [2022-02-20 20:38:39,547 INFO L290 TraceCheckUtils]: 61: Hoare triple {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5927#(< |ULTIMATE.start_main_#t~post40#1| 19)} is VALID [2022-02-20 20:38:39,547 INFO L290 TraceCheckUtils]: 60: Hoare triple {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:39,548 INFO L290 TraceCheckUtils]: 59: Hoare triple {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:39,548 INFO L290 TraceCheckUtils]: 58: Hoare triple {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:39,548 INFO L290 TraceCheckUtils]: 57: Hoare triple {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:39,548 INFO L290 TraceCheckUtils]: 56: Hoare triple {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:39,549 INFO L290 TraceCheckUtils]: 55: Hoare triple {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:39,549 INFO L290 TraceCheckUtils]: 54: Hoare triple {5953#(< |ULTIMATE.start_main_#t~post40#1| 18)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5931#(< |ULTIMATE.start_main_~i~1#1| 19)} is VALID [2022-02-20 20:38:39,549 INFO L290 TraceCheckUtils]: 53: Hoare triple {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5953#(< |ULTIMATE.start_main_#t~post40#1| 18)} is VALID [2022-02-20 20:38:39,550 INFO L290 TraceCheckUtils]: 52: Hoare triple {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} is VALID [2022-02-20 20:38:39,550 INFO L290 TraceCheckUtils]: 51: Hoare triple {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} is VALID [2022-02-20 20:38:39,550 INFO L290 TraceCheckUtils]: 50: Hoare triple {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} is VALID [2022-02-20 20:38:39,551 INFO L290 TraceCheckUtils]: 49: Hoare triple {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} is VALID [2022-02-20 20:38:39,551 INFO L290 TraceCheckUtils]: 48: Hoare triple {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} is VALID [2022-02-20 20:38:39,551 INFO L290 TraceCheckUtils]: 47: Hoare triple {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} [145] L1347-4-->L1347-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_4|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} is VALID [2022-02-20 20:38:39,551 INFO L290 TraceCheckUtils]: 46: Hoare triple {5979#(< |ULTIMATE.start_main_#t~post40#1| 17)} [178] L1347-3-->L1347-4: Formula: (= |v_ULTIMATE.start_main_~i~1#1_7| (+ |v_ULTIMATE.start_main_#t~post40#1_3| 1)) InVars {ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_7|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5957#(< |ULTIMATE.start_main_~i~1#1| 18)} is VALID [2022-02-20 20:38:39,552 INFO L290 TraceCheckUtils]: 45: Hoare triple {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} [196] L1347-2-->L1347-3: Formula: (= |v_ULTIMATE.start_main_~i~1#1_6| |v_ULTIMATE.start_main_#t~post40#1_2|) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_6|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~post40#1] {5979#(< |ULTIMATE.start_main_#t~post40#1| 17)} is VALID [2022-02-20 20:38:39,552 INFO L290 TraceCheckUtils]: 44: Hoare triple {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} [158] L1351-->L1347-2: Formula: (= |v_#pthreadsMutex_3| (store |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8| (store (select |v_#pthreadsMutex_4| |v_~#mymutex~0.base_8|) |v_~#mymutex~0.offset_8| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} OutVars{#pthreadsMutex=|v_#pthreadsMutex_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_8|, ~#mymutex~0.base=|v_~#mymutex~0.base_8|} AuxVars[] AssignedVars[#pthreadsMutex] {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} is VALID [2022-02-20 20:38:39,552 INFO L290 TraceCheckUtils]: 43: Hoare triple {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} [182] L1350-->L1351: Formula: (= v_~myglobal~0_3 (+ v_~myglobal~0_4 1)) InVars {~myglobal~0=v_~myglobal~0_4} OutVars{~myglobal~0=v_~myglobal~0_3} AuxVars[] AssignedVars[~myglobal~0] {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} is VALID [2022-02-20 20:38:39,552 INFO L290 TraceCheckUtils]: 42: Hoare triple {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} [211] L1349-1-->L1350: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1] {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} is VALID [2022-02-20 20:38:39,554 INFO L290 TraceCheckUtils]: 41: Hoare triple {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} [163] L1349-->L1349-1: Formula: (let ((.cse0 (select |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7|))) (and (= 0 (select .cse0 |v_~#mymutex~0.offset_7|)) (= |v_#pthreadsMutex_1| (store |v_#pthreadsMutex_2| |v_~#mymutex~0.base_7| (store .cse0 |v_~#mymutex~0.offset_7| 1))) (= |v_ULTIMATE.start_main_#t~nondet41#1_2| 0))) InVars {#pthreadsMutex=|v_#pthreadsMutex_2|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} OutVars{ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_2|, #pthreadsMutex=|v_#pthreadsMutex_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_7|, ~#mymutex~0.base=|v_~#mymutex~0.base_7|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet41#1, #pthreadsMutex] {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 40: Hoare triple {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} [222] L1347-5-->L1349: Formula: (< |v_ULTIMATE.start_main_~i~1#1_5| 20) InVars {ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_5|} AuxVars[] AssignedVars[] {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 39: Hoare triple {5414#true} [174] L1343-10-->L1347-5: Formula: (= |v_ULTIMATE.start_main_~i~1#1_3| 0) InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_3|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5983#(< |ULTIMATE.start_main_~i~1#1| 17)} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 38: Hoare triple {5414#true} [168] L1343-9-->L1343-10: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet39#1] {5414#true} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 37: Hoare triple {5414#true} [167] L1343-8-->L1343-9: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_5|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {5414#true} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 36: Hoare triple {5414#true} [138] L1343-4-->L1343-8: Formula: (= |v_ULTIMATE.start_main_#t~nondet39#1_4| 0) InVars {ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} OutVars{ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_4|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 35: Hoare triple {5414#true} [246] L1343-3-->thread_function_mutexENTRY: Formula: (and (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4| 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar1_2 0) (= v_thread_function_mutexThread1of1ForFork0_thidvar0_2 |v_ULTIMATE.start_main_#t~pre38#1_7|) (= |v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4| 0)) InVars {ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|} OutVars{thread_function_mutexThread1of1ForFork0_#in~arg.offset=|v_thread_function_mutexThread1of1ForFork0_#in~arg.offset_4|, thread_function_mutexThread1of1ForFork0_~i~0=v_thread_function_mutexThread1of1ForFork0_~i~0_14, thread_function_mutexThread1of1ForFork0_#in~arg.base=|v_thread_function_mutexThread1of1ForFork0_#in~arg.base_4|, thread_function_mutexThread1of1ForFork0_~arg.offset=v_thread_function_mutexThread1of1ForFork0_~arg.offset_4, thread_function_mutexThread1of1ForFork0_#res.offset=|v_thread_function_mutexThread1of1ForFork0_#res.offset_4|, thread_function_mutexThread1of1ForFork0_~arg.base=v_thread_function_mutexThread1of1ForFork0_~arg.base_4, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_7|, thread_function_mutexThread1of1ForFork0_~j~0=v_thread_function_mutexThread1of1ForFork0_~j~0_12, thread_function_mutexThread1of1ForFork0_#t~post31=|v_thread_function_mutexThread1of1ForFork0_#t~post31_8|, thread_function_mutexThread1of1ForFork0_#t~nondet33=|v_thread_function_mutexThread1of1ForFork0_#t~nondet33_4|, thread_function_mutexThread1of1ForFork0_#res.base=|v_thread_function_mutexThread1of1ForFork0_#res.base_4|, thread_function_mutexThread1of1ForFork0_thidvar1=v_thread_function_mutexThread1of1ForFork0_thidvar1_2, thread_function_mutexThread1of1ForFork0_#t~nondet32=|v_thread_function_mutexThread1of1ForFork0_#t~nondet32_6|, thread_function_mutexThread1of1ForFork0_thidvar0=v_thread_function_mutexThread1of1ForFork0_thidvar0_2} AuxVars[] AssignedVars[thread_function_mutexThread1of1ForFork0_#in~arg.offset, thread_function_mutexThread1of1ForFork0_~i~0, thread_function_mutexThread1of1ForFork0_#in~arg.base, thread_function_mutexThread1of1ForFork0_~arg.offset, thread_function_mutexThread1of1ForFork0_#res.offset, thread_function_mutexThread1of1ForFork0_~arg.base, thread_function_mutexThread1of1ForFork0_~j~0, thread_function_mutexThread1of1ForFork0_#t~post31, thread_function_mutexThread1of1ForFork0_#t~nondet33, thread_function_mutexThread1of1ForFork0_#res.base, thread_function_mutexThread1of1ForFork0_thidvar1, thread_function_mutexThread1of1ForFork0_#t~nondet32, thread_function_mutexThread1of1ForFork0_thidvar0] {5414#true} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 34: Hoare triple {5414#true} [141] L1343-2-->L1343-3: Formula: (= (store |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3| (store (select |v_#memory_int_9| |v_ULTIMATE.start_main_~#mythread~0#1.base_3|) |v_ULTIMATE.start_main_~#mythread~0#1.offset_3| |v_ULTIMATE.start_main_#t~pre38#1_3|)) |v_#memory_int_8|) InVars {#memory_int=|v_#memory_int_9|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} OutVars{#memory_int=|v_#memory_int_8|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_3|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_3|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_3|} AuxVars[] AssignedVars[#memory_int] {5414#true} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 33: Hoare triple {5414#true} [198] L1343-1-->L1343-2: Formula: (= (+ 1 |v_#pthreadsForks_3|) |v_#pthreadsForks_2|) InVars {#pthreadsForks=|v_#pthreadsForks_3|} OutVars{#pthreadsForks=|v_#pthreadsForks_2|} AuxVars[] AssignedVars[#pthreadsForks] {5414#true} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 32: Hoare triple {5414#true} [156] L1343-->L1343-1: Formula: (= |v_#pthreadsForks_1| |v_ULTIMATE.start_main_#t~pre38#1_2|) InVars {#pthreadsForks=|v_#pthreadsForks_1|} OutVars{ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_2|, #pthreadsForks=|v_#pthreadsForks_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~pre38#1] {5414#true} is VALID [2022-02-20 20:38:39,555 INFO L290 TraceCheckUtils]: 31: Hoare triple {5414#true} [207] L1342-->L1343: Formula: (= v_~myglobal~0_2 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_2} AuxVars[] AssignedVars[~myglobal~0] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 30: Hoare triple {5414#true} [140] L1341-1-->L1342: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet37#1] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 29: Hoare triple {5414#true} [134] L1340-1-->L1341-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet36#1] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 28: Hoare triple {5414#true} [180] L1339-1-->L1340-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet35#1] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 27: Hoare triple {5414#true} [160] L1338-1-->L1339-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_#t~nondet34#1] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 26: Hoare triple {5414#true} [132] L1336-1-->L1338-1: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_2|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 25: Hoare triple {5414#true} [146] L1336-->L1336-1: Formula: (and (= |v_ULTIMATE.start_main_~#mythread~0#1.offset_2| 0) (not (= |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 0)) (= (store |v_#length_10| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 4) |v_#length_9|) (= (store |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2| 1) |v_#valid_10|) (= (select |v_#valid_11| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|) 0) (< |v_#StackHeapBarrier_2| |v_ULTIMATE.start_main_~#mythread~0#1.base_2|)) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_10|, #valid=|v_#valid_11|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_2|, #length=|v_#length_9|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_2|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_2|, #valid=|v_#valid_10|} AuxVars[] AssignedVars[ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_~#mythread~0#1.base, #valid, #length] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 24: Hoare triple {5414#true} [153] L-1-5-->L1336: Formula: true InVars {} OutVars{ULTIMATE.start_main_~i~1#1=|v_ULTIMATE.start_main_~i~1#1_1|, ULTIMATE.start_main_#t~nondet39#1=|v_ULTIMATE.start_main_#t~nondet39#1_1|, ULTIMATE.start_main_#t~nondet36#1=|v_ULTIMATE.start_main_#t~nondet36#1_1|, ULTIMATE.start_main_~#mythread~0#1.offset=|v_ULTIMATE.start_main_~#mythread~0#1.offset_1|, ULTIMATE.start_main_#t~nondet34#1=|v_ULTIMATE.start_main_#t~nondet34#1_1|, ULTIMATE.start_main_#t~nondet41#1=|v_ULTIMATE.start_main_#t~nondet41#1_1|, ULTIMATE.start_main_#t~post40#1=|v_ULTIMATE.start_main_#t~post40#1_1|, ULTIMATE.start_main_#t~pre38#1=|v_ULTIMATE.start_main_#t~pre38#1_1|, ULTIMATE.start_main_#t~nondet35#1=|v_ULTIMATE.start_main_#t~nondet35#1_1|, ULTIMATE.start_main_#t~mem42#1=|v_ULTIMATE.start_main_#t~mem42#1_1|, ULTIMATE.start_main_~#mythread~0#1.base=|v_ULTIMATE.start_main_~#mythread~0#1.base_1|, ULTIMATE.start_main_#t~nondet37#1=|v_ULTIMATE.start_main_#t~nondet37#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_~i~1#1, ULTIMATE.start_main_#t~nondet41#1, ULTIMATE.start_main_#t~nondet39#1, ULTIMATE.start_main_#t~post40#1, ULTIMATE.start_main_#t~pre38#1, ULTIMATE.start_main_#t~nondet36#1, ULTIMATE.start_main_~#mythread~0#1.offset, ULTIMATE.start_main_#t~nondet35#1, ULTIMATE.start_main_#t~mem42#1, ULTIMATE.start_main_#t~nondet34#1, ULTIMATE.start_main_~#mythread~0#1.base, ULTIMATE.start_main_#t~nondet37#1] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 23: Hoare triple {5414#true} [191] L-1-4-->L-1-5: Formula: true InVars {} OutVars{ULTIMATE.start_main_#res#1=|v_ULTIMATE.start_main_#res#1_1|} AuxVars[] AssignedVars[ULTIMATE.start_main_#res#1] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 22: Hoare triple {5414#true} [217] L-1-3-->L-1-4: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 21: Hoare triple {5414#true} [173] L1319-7-->L-1-3: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 20: Hoare triple {5414#true} [131] L1319-6-->L1319-7: Formula: (= (select (select |v_#memory_int_7| |v_~#mymutex~0.base_6|) (+ 16 |v_~#mymutex~0.offset_6|)) 0) InVars {#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} OutVars{#memory_int=|v_#memory_int_7|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_6|, ~#mymutex~0.base=|v_~#mymutex~0.base_6|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 19: Hoare triple {5414#true} [165] L1319-5-->L1319-6: Formula: (= (select (select |v_#memory_int_6| |v_~#mymutex~0.base_5|) (+ 12 |v_~#mymutex~0.offset_5|)) 0) InVars {#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} OutVars{#memory_int=|v_#memory_int_6|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_5|, ~#mymutex~0.base=|v_~#mymutex~0.base_5|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 18: Hoare triple {5414#true} [184] L1319-4-->L1319-5: Formula: (= (select (select |v_#memory_int_5| |v_~#mymutex~0.base_4|) (+ 8 |v_~#mymutex~0.offset_4|)) 0) InVars {#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} OutVars{#memory_int=|v_#memory_int_5|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_4|, ~#mymutex~0.base=|v_~#mymutex~0.base_4|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 17: Hoare triple {5414#true} [136] L1319-3-->L1319-4: Formula: (= (select (select |v_#memory_int_4| |v_~#mymutex~0.base_3|) (+ 4 |v_~#mymutex~0.offset_3|)) 0) InVars {#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} OutVars{#memory_int=|v_#memory_int_4|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_3|, ~#mymutex~0.base=|v_~#mymutex~0.base_3|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 16: Hoare triple {5414#true} [170] L1319-2-->L1319-3: Formula: (= (select (select |v_#memory_int_3| |v_~#mymutex~0.base_2|) |v_~#mymutex~0.offset_2|) 0) InVars {#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} OutVars{#memory_int=|v_#memory_int_3|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_2|, ~#mymutex~0.base=|v_~#mymutex~0.base_2|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 15: Hoare triple {5414#true} [133] L1319-1-->L1319-2: Formula: (and (= (select |v_#valid_9| 8) 1) (= (select |v_#length_8| 8) 24)) InVars {#length=|v_#length_8|, #valid=|v_#valid_9|} OutVars{#length=|v_#length_8|, #valid=|v_#valid_9|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 14: Hoare triple {5414#true} [197] L1319-->L1319-1: Formula: (and (= |v_~#mymutex~0.base_1| 8) (= |v_~#mymutex~0.offset_1| 0)) InVars {} OutVars{~#mymutex~0.base=|v_~#mymutex~0.base_1|, ~#mymutex~0.offset=|v_~#mymutex~0.offset_1|} AuxVars[] AssignedVars[~#mymutex~0.base, ~#mymutex~0.offset] {5414#true} is VALID [2022-02-20 20:38:39,556 INFO L290 TraceCheckUtils]: 13: Hoare triple {5414#true} [224] L1341-->L1319: Formula: (= v_~myglobal~0_1 0) InVars {} OutVars{~myglobal~0=v_~myglobal~0_1} AuxVars[] AssignedVars[~myglobal~0] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 12: Hoare triple {5414#true} [210] L1340-->L1341: Formula: (and (= (select |v_#valid_8| 7) 1) (= (select |v_#length_7| 7) 79)) InVars {#length=|v_#length_7|, #valid=|v_#valid_8|} OutVars{#length=|v_#length_7|, #valid=|v_#valid_8|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 11: Hoare triple {5414#true} [162] L1339-->L1340: Formula: (and (= (select |v_#valid_7| 6) 1) (= (select |v_#length_6| 6) 27)) InVars {#length=|v_#length_6|, #valid=|v_#valid_7|} OutVars{#length=|v_#length_6|, #valid=|v_#valid_7|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 10: Hoare triple {5414#true} [214] L1338-->L1339: Formula: (and (= (select |v_#valid_6| 5) 1) (= 57 (select |v_#length_5| 5))) InVars {#length=|v_#length_5|, #valid=|v_#valid_6|} OutVars{#length=|v_#length_5|, #valid=|v_#valid_6|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 9: Hoare triple {5414#true} [157] L1328-->L1338: Formula: (and (= (select |v_#length_4| 4) 79) (= (select |v_#valid_5| 4) 1)) InVars {#length=|v_#length_4|, #valid=|v_#valid_5|} OutVars{#length=|v_#length_4|, #valid=|v_#valid_5|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 8: Hoare triple {5414#true} [193] L12-4-->L1328: Formula: (and (= 29 (select |v_#length_3| 3)) (= (select |v_#valid_4| 3) 1)) InVars {#length=|v_#length_3|, #valid=|v_#valid_4|} OutVars{#length=|v_#length_3|, #valid=|v_#valid_4|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 7: Hoare triple {5414#true} [204] L12-3-->L12-4: Formula: (and (= (select |v_#valid_3| 2) 1) (= (select |v_#length_2| 2) 26)) InVars {#length=|v_#length_2|, #valid=|v_#valid_3|} OutVars{#length=|v_#length_2|, #valid=|v_#valid_3|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 6: Hoare triple {5414#true} [175] L12-2-->L12-3: Formula: (= (select (select |v_#memory_int_2| 1) 1) 0) InVars {#memory_int=|v_#memory_int_2|} OutVars{#memory_int=|v_#memory_int_2|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 5: Hoare triple {5414#true} [176] L12-1-->L12-2: Formula: (= 48 (select (select |v_#memory_int_1| 1) 0)) InVars {#memory_int=|v_#memory_int_1|} OutVars{#memory_int=|v_#memory_int_1|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 4: Hoare triple {5414#true} [154] L12-->L12-1: Formula: (and (= (select |v_#valid_2| 1) 1) (= 2 (select |v_#length_1| 1))) InVars {#length=|v_#length_1|, #valid=|v_#valid_2|} OutVars{#length=|v_#length_1|, #valid=|v_#valid_2|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 3: Hoare triple {5414#true} [216] L-1-2-->L12: Formula: (< 0 |v_#StackHeapBarrier_1|) InVars {#StackHeapBarrier=|v_#StackHeapBarrier_1|} OutVars{#StackHeapBarrier=|v_#StackHeapBarrier_1|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 2: Hoare triple {5414#true} [215] L-1-1-->L-1-2: Formula: (= (select |v_#valid_1| 0) 0) InVars {#valid=|v_#valid_1|} OutVars{#valid=|v_#valid_1|} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 1: Hoare triple {5414#true} [181] L-1-->L-1-1: Formula: (and (= |v_#NULL.base_1| 0) (= |v_#NULL.offset_1| 0)) InVars {} OutVars{#NULL.offset=|v_#NULL.offset_1|, #NULL.base=|v_#NULL.base_1|} AuxVars[] AssignedVars[#NULL.offset, #NULL.base] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L290 TraceCheckUtils]: 0: Hoare triple {5414#true} [200] ULTIMATE.startENTRY-->L-1: Formula: true InVars {} OutVars{} AuxVars[] AssignedVars[] {5414#true} is VALID [2022-02-20 20:38:39,557 INFO L134 CoverageAnalysis]: Checked inductivity of 63 backedges. 0 proven. 27 refuted. 0 times theorem prover too weak. 36 trivial. 0 not checked. [2022-02-20 20:38:39,558 INFO L165 FreeRefinementEngine]: IpTcStrategyModuleZ3 [869706051] provided 0 perfect and 2 imperfect interpolant sequences [2022-02-20 20:38:39,558 INFO L191 FreeRefinementEngine]: Found 0 perfect and 3 imperfect interpolant sequences. [2022-02-20 20:38:39,558 INFO L204 FreeRefinementEngine]: Number of different interpolants: perfect sequences [] imperfect sequences [9, 9, 9] total 18 [2022-02-20 20:38:39,558 INFO L118 tionRefinementEngine]: Using interpolant automaton builder IpAbStrategyModuleStraightlineAll [1847636988] [2022-02-20 20:38:39,558 INFO L85 oduleStraightlineAll]: Using 3 imperfect interpolants to construct interpolant automaton [2022-02-20 20:38:39,558 INFO L78 Accepts]: Start accepts. Automaton has has 18 states, 18 states have (on average 7.055555555555555) internal successors, (127), 18 states have internal predecessors, (127), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) Word has length 115 [2022-02-20 20:38:39,559 INFO L84 Accepts]: Finished accepts. word is accepted. [2022-02-20 20:38:39,559 INFO L86 InductivityCheck]: Starting indutivity check of a Floyd-Hoare automaton with has 18 states, 18 states have (on average 7.055555555555555) internal successors, (127), 18 states have internal predecessors, (127), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:39,631 INFO L122 InductivityCheck]: Floyd-Hoare automaton has 127 edges. 127 inductive. 0 not inductive. 0 times theorem prover too weak to decide inductivity. [2022-02-20 20:38:39,631 INFO L546 AbstractCegarLoop]: INTERPOLANT automaton has 18 states [2022-02-20 20:38:39,631 INFO L108 FreeRefinementEngine]: Using predicate unifier PredicateUnifier provided by strategy CAMEL [2022-02-20 20:38:39,631 INFO L143 InterpolantAutomaton]: Constructing interpolant automaton starting with 18 interpolants. [2022-02-20 20:38:39,631 INFO L145 InterpolantAutomaton]: CoverageRelationStatistics Valid=90, Invalid=216, Unknown=0, NotChecked=0, Total=306 [2022-02-20 20:38:39,633 INFO L499 CegarLoopForPetriNet]: Number of universal loopers: 79 out of 97 [2022-02-20 20:38:39,634 INFO L92 encePairwiseOnDemand]: Start differencePairwiseOnDemand. First operand has 106 places, 94 transitions, 276 flow. Second operand has 18 states, 18 states have (on average 81.0) internal successors, (1458), 18 states have internal predecessors, (1458), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2022-02-20 20:38:39,634 INFO L101 encePairwiseOnDemand]: Universal subtrahend loopers provided by user. [2022-02-20 20:38:39,634 INFO L102 encePairwiseOnDemand]: Number of universal subtrahend loopers: 79 of 97 [2022-02-20 20:38:39,634 INFO L74 FinitePrefix]: Start finitePrefix. Operand will be constructed on-demand