/root/.sdkman/candidates/java/current/bin/java -Xmx8000000000 -Xss4m -jar ./plugins/org.eclipse.equinox.launcher_1.5.800.v20200727-1323.jar -data @noDefault -ultimatedata ./data -s ../../../trunk/examples/settings/default/automizer/svcomp-Termination-32bit-Automizer_Default.epf --buchiautomizer.automaton.type.for.concurrent.programs BUCHI_PETRI_NET -tc ../../../trunk/examples/toolchains/BuchiAutomizerBplInline.xml -i ../../../trunk/examples/concurrent/bpl/POPL2023/map-aggr-update3.bpl -------------------------------------------------------------------------------- This is Ultimate 0.2.3-?-9ecb849-m [2024-02-09 23:50:43,352 INFO L188 SettingsManager]: Resetting all preferences to default values... [2024-02-09 23:50:43,409 INFO L114 SettingsManager]: Loading settings from /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/settings/default/automizer/svcomp-Termination-32bit-Automizer_Default.epf [2024-02-09 23:50:43,414 WARN L101 SettingsManager]: Preference file contains the following unknown settings: [2024-02-09 23:50:43,415 WARN L103 SettingsManager]: * de.uni_freiburg.informatik.ultimate.core.Log level for class [2024-02-09 23:50:43,415 WARN L103 SettingsManager]: * de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder.Only consider context switches at boundaries of atomic blocks [2024-02-09 23:50:43,449 INFO L130 SettingsManager]: Preferences different from defaults after loading the file: [2024-02-09 23:50:43,450 INFO L151 SettingsManager]: Preferences of UltimateCore differ from their defaults: [2024-02-09 23:50:43,450 INFO L153 SettingsManager]: * Log level for class=de.uni_freiburg.informatik.ultimate.lib.smtlibutils.quantifier.QuantifierPusher=ERROR; [2024-02-09 23:50:43,453 INFO L151 SettingsManager]: Preferences of BlockEncodingV2 differ from their defaults: [2024-02-09 23:50:43,454 INFO L153 SettingsManager]: * Create parallel compositions if possible=false [2024-02-09 23:50:43,454 INFO L153 SettingsManager]: * Use SBE=true [2024-02-09 23:50:43,454 INFO L151 SettingsManager]: Preferences of BuchiAutomizer differ from their defaults: [2024-02-09 23:50:43,455 INFO L153 SettingsManager]: * NCSB implementation=INTSET_LAZY3 [2024-02-09 23:50:43,455 INFO L153 SettingsManager]: * Use old map elimination=false [2024-02-09 23:50:43,455 INFO L153 SettingsManager]: * Use external solver (rank synthesis)=false [2024-02-09 23:50:43,455 INFO L153 SettingsManager]: * Use only trivial implications for array writes=true [2024-02-09 23:50:43,456 INFO L153 SettingsManager]: * Rank analysis=LINEAR_WITH_GUESSES [2024-02-09 23:50:43,456 INFO L151 SettingsManager]: Preferences of CACSL2BoogieTranslator differ from their defaults: [2024-02-09 23:50:43,456 INFO L153 SettingsManager]: * Pointer base address is valid at dereference=ASSUME [2024-02-09 23:50:43,456 INFO L153 SettingsManager]: * sizeof long=4 [2024-02-09 23:50:43,457 INFO L153 SettingsManager]: * Overapproximate operations on floating types=true [2024-02-09 23:50:43,457 INFO L153 SettingsManager]: * sizeof POINTER=4 [2024-02-09 23:50:43,457 INFO L153 SettingsManager]: * Check division by zero=IGNORE [2024-02-09 23:50:43,457 INFO L153 SettingsManager]: * Pointer to allocated memory at dereference=ASSUME [2024-02-09 23:50:43,457 INFO L153 SettingsManager]: * If two pointers are subtracted or compared they have the same base address=ASSUME [2024-02-09 23:50:43,457 INFO L153 SettingsManager]: * Check array bounds for arrays that are off heap=ASSUME [2024-02-09 23:50:43,457 INFO L153 SettingsManager]: * Check unreachability of reach_error function=false [2024-02-09 23:50:43,458 INFO L153 SettingsManager]: * sizeof long double=12 [2024-02-09 23:50:43,458 INFO L153 SettingsManager]: * Check if freed pointer was valid=false [2024-02-09 23:50:43,459 INFO L153 SettingsManager]: * Assume nondeterminstic values are in range=false [2024-02-09 23:50:43,459 INFO L153 SettingsManager]: * Use constant arrays=true [2024-02-09 23:50:43,459 INFO L151 SettingsManager]: Preferences of RCFGBuilder differ from their defaults: [2024-02-09 23:50:43,459 INFO L153 SettingsManager]: * Size of a code block=SequenceOfStatements [2024-02-09 23:50:43,459 INFO L151 SettingsManager]: Preferences of TraceAbstraction differ from their defaults: [2024-02-09 23:50:43,459 INFO L153 SettingsManager]: * Trace refinement strategy=CAMEL [2024-02-09 23:50:43,459 INFO L153 SettingsManager]: * Apply one-shot large block encoding in concurrent analysis=false [2024-02-09 23:50:43,460 INFO L151 SettingsManager]: Preferences of IcfgTransformer differ from their defaults: [2024-02-09 23:50:43,460 INFO L153 SettingsManager]: * TransformationType=MODULO_NEIGHBOR 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.buchiautomizer: Automaton type for concurrent programs -> BUCHI_PETRI_NET [2024-02-09 23:50:43,735 INFO L75 nceAwareModelManager]: Repository-Root is: /tmp [2024-02-09 23:50:43,757 INFO L261 ainManager$Toolchain]: [Toolchain 1]: Applicable parser(s) successfully (re)initialized [2024-02-09 23:50:43,759 INFO L217 ainManager$Toolchain]: [Toolchain 1]: Toolchain selected. [2024-02-09 23:50:43,761 INFO L270 PluginConnector]: Initializing Boogie PL CUP Parser... [2024-02-09 23:50:43,762 INFO L274 PluginConnector]: Boogie PL CUP Parser initialized [2024-02-09 23:50:43,764 INFO L431 ainManager$Toolchain]: [Toolchain 1]: Parsing single file: /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/concurrent/bpl/POPL2023/map-aggr-update3.bpl [2024-02-09 23:50:43,765 INFO L110 BoogieParser]: Parsing: '/storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/../../../trunk/examples/concurrent/bpl/POPL2023/map-aggr-update3.bpl' [2024-02-09 23:50:43,801 INFO L299 ainManager$Toolchain]: ####################### [Toolchain 1] ####################### [2024-02-09 23:50:43,802 INFO L133 ToolchainWalker]: Walking toolchain with 4 elements. [2024-02-09 23:50:43,803 INFO L112 PluginConnector]: ------------------------Boogie Procedure Inliner---------------------------- [2024-02-09 23:50:43,803 INFO L270 PluginConnector]: Initializing Boogie Procedure Inliner... [2024-02-09 23:50:43,803 INFO L274 PluginConnector]: Boogie Procedure Inliner initialized [2024-02-09 23:50:43,812 INFO L184 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Procedure Inliner for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,830 INFO L184 PluginConnector]: Executing the observer Inliner from plugin Boogie Procedure Inliner for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,852 INFO L138 Inliner]: procedures = 4, calls = 3, calls flagged for inlining = 0, calls inlined = 0, statements flattened = 0 [2024-02-09 23:50:43,853 INFO L131 PluginConnector]: ------------------------ END Boogie Procedure Inliner---------------------------- [2024-02-09 23:50:43,854 INFO L112 PluginConnector]: ------------------------Boogie Preprocessor---------------------------- [2024-02-09 23:50:43,854 INFO L270 PluginConnector]: Initializing Boogie Preprocessor... [2024-02-09 23:50:43,854 INFO L274 PluginConnector]: Boogie Preprocessor initialized [2024-02-09 23:50:43,860 INFO L184 PluginConnector]: Executing the observer EnsureBoogieModelObserver from plugin Boogie Preprocessor for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,861 INFO L184 PluginConnector]: Executing the observer TypeChecker from plugin Boogie Preprocessor for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,861 INFO L184 PluginConnector]: Executing the observer ConstExpander from plugin Boogie Preprocessor for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,861 INFO L184 PluginConnector]: Executing the observer StructExpander from plugin Boogie Preprocessor for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,863 INFO L184 PluginConnector]: Executing the observer UnstructureCode from plugin Boogie Preprocessor for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,865 INFO L184 PluginConnector]: Executing the observer FunctionInliner from plugin Boogie Preprocessor for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,866 INFO L184 PluginConnector]: Executing the observer LTLStepAnnotator from plugin Boogie Preprocessor for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,867 INFO L184 PluginConnector]: Executing the observer BoogieSymbolTableConstructor from plugin Boogie Preprocessor for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,868 INFO L131 PluginConnector]: ------------------------ END Boogie Preprocessor---------------------------- [2024-02-09 23:50:43,868 INFO L112 PluginConnector]: ------------------------RCFGBuilder---------------------------- [2024-02-09 23:50:43,871 INFO L270 PluginConnector]: Initializing RCFGBuilder... [2024-02-09 23:50:43,871 INFO L274 PluginConnector]: RCFGBuilder initialized [2024-02-09 23:50:43,874 INFO L184 PluginConnector]: Executing the observer RCFGBuilderObserver from plugin RCFGBuilder for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/1) ... [2024-02-09 23:50:43,879 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 [2024-02-09 23:50:43,889 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2024-02-09 23:50:43,910 INFO L229 MonitoredProcess]: Starting monitored process 1 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (exit command is (exit), workingDir is null) [2024-02-09 23:50:43,914 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (1)] Waiting until timeout for monitored process [2024-02-09 23:50:43,950 INFO L124 BoogieDeclarations]: Specification and implementation of procedure thread1 given in one single declaration [2024-02-09 23:50:43,950 INFO L130 BoogieDeclarations]: Found specification of procedure thread1 [2024-02-09 23:50:43,950 INFO L138 BoogieDeclarations]: Found implementation of procedure thread1 [2024-02-09 23:50:43,950 INFO L124 BoogieDeclarations]: Specification and implementation of procedure thread2 given in one single declaration [2024-02-09 23:50:43,950 INFO L130 BoogieDeclarations]: Found specification of procedure thread2 [2024-02-09 23:50:43,951 INFO L138 BoogieDeclarations]: Found implementation of procedure thread2 [2024-02-09 23:50:43,951 INFO L124 BoogieDeclarations]: Specification and implementation of procedure thread3 given in one single declaration [2024-02-09 23:50:43,951 INFO L130 BoogieDeclarations]: Found specification of procedure thread3 [2024-02-09 23:50:43,951 INFO L138 BoogieDeclarations]: Found implementation of procedure thread3 [2024-02-09 23:50:43,951 INFO L124 BoogieDeclarations]: Specification and implementation of procedure ULTIMATE.start given in one single declaration [2024-02-09 23:50:43,951 INFO L130 BoogieDeclarations]: Found specification of procedure ULTIMATE.start [2024-02-09 23:50:43,951 INFO L138 BoogieDeclarations]: Found implementation of procedure ULTIMATE.start [2024-02-09 23:50:43,952 WARN L210 CfgBuilder]: User set CodeBlockSize to SequenceOfStatements but program contains fork statements. Overwriting the user preferences and setting CodeBlockSize to OneNontrivialStatement [2024-02-09 23:50:43,989 INFO L236 CfgBuilder]: Building ICFG [2024-02-09 23:50:43,991 INFO L262 CfgBuilder]: Building CFG for each procedure with an implementation [2024-02-09 23:50:44,131 INFO L277 CfgBuilder]: Performing block encoding [2024-02-09 23:50:44,138 INFO L297 CfgBuilder]: Using the 1 location(s) as analysis (start of procedure ULTIMATE.start) [2024-02-09 23:50:44,139 INFO L302 CfgBuilder]: Removed 0 assume(true) statements. [2024-02-09 23:50:44,140 INFO L201 PluginConnector]: Adding new model map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 09.02 11:50:44 BoogieIcfgContainer [2024-02-09 23:50:44,140 INFO L131 PluginConnector]: ------------------------ END RCFGBuilder---------------------------- [2024-02-09 23:50:44,141 INFO L112 PluginConnector]: ------------------------BuchiAutomizer---------------------------- [2024-02-09 23:50:44,141 INFO L270 PluginConnector]: Initializing BuchiAutomizer... [2024-02-09 23:50:44,147 INFO L274 PluginConnector]: BuchiAutomizer initialized [2024-02-09 23:50:44,148 INFO L99 BuchiAutomizer]: Safety of program was proven or not checked, starting termination analysis [2024-02-09 23:50:44,148 INFO L184 PluginConnector]: Executing the observer BuchiAutomizerObserver from plugin BuchiAutomizer for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.boogie.parser AST 09.02 11:50:43" (1/2) ... [2024-02-09 23:50:44,149 INFO L204 PluginConnector]: Invalid model from BuchiAutomizer for observer de.uni_freiburg.informatik.ultimate.plugins.generator.buchiautomizer.BuchiAutomizerObserver@657bdb4d and model type map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.plugins.generator.buchiautomizer AST 09.02 11:50:44, skipping insertion in model container [2024-02-09 23:50:44,150 INFO L99 BuchiAutomizer]: Safety of program was proven or not checked, starting termination analysis [2024-02-09 23:50:44,150 INFO L184 PluginConnector]: Executing the observer BuchiAutomizerObserver from plugin BuchiAutomizer for "map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.plugins.generator.rcfgbuilder CFG 09.02 11:50:44" (2/2) ... [2024-02-09 23:50:44,152 INFO L332 chiAutomizerObserver]: Analyzing ICFG map-aggr-update3.bpl [2024-02-09 23:50:44,268 INFO L144 ThreadInstanceAdder]: Constructed 3 joinOtherThreadTransitions. [2024-02-09 23:50:44,299 INFO L73 FinitePrefix]: Start finitePrefix. Operand has 42 places, 40 transitions, 101 flow [2024-02-09 23:50:44,338 INFO L124 PetriNetUnfolderBase]: 5/34 cut-off events. [2024-02-09 23:50:44,338 INFO L125 PetriNetUnfolderBase]: For 3/3 co-relation queries the response was YES. [2024-02-09 23:50:44,342 INFO L83 FinitePrefix]: Finished finitePrefix Result has 47 conditions, 34 events. 5/34 cut-off events. For 3/3 co-relation queries the response was YES. Maximal size of possible extension queue 6. Compared 75 event pairs, 0 based on Foata normal form. 0/28 useless extension candidates. Maximal degree in co-relation 30. Up to 2 conditions per place. [2024-02-09 23:50:44,342 INFO L82 GeneralOperation]: Start removeDead. Operand has 42 places, 40 transitions, 101 flow [2024-02-09 23:50:44,345 INFO L88 GeneralOperation]: Finished RemoveDead, result has has 39 places, 34 transitions, 86 flow [2024-02-09 23:50:44,351 INFO L303 stractBuchiCegarLoop]: Interprodecural is true [2024-02-09 23:50:44,351 INFO L304 stractBuchiCegarLoop]: Hoare is false [2024-02-09 23:50:44,352 INFO L305 stractBuchiCegarLoop]: Compute interpolants for ForwardPredicates [2024-02-09 23:50:44,352 INFO L306 stractBuchiCegarLoop]: Backedges is STRAIGHT_LINE [2024-02-09 23:50:44,352 INFO L307 stractBuchiCegarLoop]: Determinization is PREDICATE_ABSTRACTION [2024-02-09 23:50:44,352 INFO L308 stractBuchiCegarLoop]: Difference is false [2024-02-09 23:50:44,352 INFO L309 stractBuchiCegarLoop]: Minimize is MINIMIZE_SEVPA [2024-02-09 23:50:44,352 INFO L313 stractBuchiCegarLoop]: ======== Iteration 0 == of CEGAR loop == BuchiPetriNetCegarLoop ======== [2024-02-09 23:50:44,353 INFO L84 BuchiIsEmpty]: Start buchiIsEmpty. Operand has 39 places, 34 transitions, 86 flow [2024-02-09 23:50:44,357 INFO L185 PetriNetUnfolderBase]: Found word, exiting Unfolder. [2024-02-09 23:50:44,357 INFO L124 PetriNetUnfolderBase]: 0/10 cut-off events. [2024-02-09 23:50:44,357 INFO L125 PetriNetUnfolderBase]: For 1/1 co-relation queries the response was YES. [2024-02-09 23:50:44,357 INFO L88 BuchiIsEmpty]: Finished buchiIsEmpty language is not empty [2024-02-09 23:50:44,360 INFO L335 stractBuchiCegarLoop]: ======== Iteration 1 ============ [2024-02-09 23:50:44,360 INFO L84 BuchiIsEmpty]: Start buchiIsEmpty. Operand has 39 places, 34 transitions, 86 flow [2024-02-09 23:50:44,362 INFO L185 PetriNetUnfolderBase]: Found word, exiting Unfolder. [2024-02-09 23:50:44,362 INFO L124 PetriNetUnfolderBase]: 0/10 cut-off events. [2024-02-09 23:50:44,362 INFO L125 PetriNetUnfolderBase]: For 1/1 co-relation queries the response was YES. [2024-02-09 23:50:44,362 INFO L88 BuchiIsEmpty]: Finished buchiIsEmpty language is not empty [2024-02-09 23:50:44,366 INFO L748 eck$LassoCheckResult]: Stem: 46#[$Ultimate##0]true [83] $Ultimate##0-->L34: Formula: (and (< v_ULTIMATE.start_m_3 v_N_7) (<= 0 v_ULTIMATE.start_m_3)) InVars {ULTIMATE.start_m=v_ULTIMATE.start_m_3, N=v_N_7} OutVars{ULTIMATE.start_m=v_ULTIMATE.start_m_3, N=v_N_7} AuxVars[] AssignedVars[] 48#[L34]true [114] L34-->$Ultimate##0: Formula: (= v_thread1Thread1of1ForFork0_thidvar0_2 1) InVars {} OutVars{thread1Thread1of1ForFork0_thidvar0=v_thread1Thread1of1ForFork0_thidvar0_2, thread1Thread1of1ForFork0_i=v_thread1Thread1of1ForFork0_i_14} AuxVars[] AssignedVars[thread1Thread1of1ForFork0_thidvar0, thread1Thread1of1ForFork0_i] 50#[L34-1, $Ultimate##0]true [88] $Ultimate##0-->L51-1: Formula: (= v_thread1Thread1of1ForFork0_i_1 0) InVars {} OutVars{thread1Thread1of1ForFork0_i=v_thread1Thread1of1ForFork0_i_1} AuxVars[] AssignedVars[thread1Thread1of1ForFork0_i] 52#[L51-1, L34-1]true [2024-02-09 23:50:44,367 INFO L750 eck$LassoCheckResult]: Loop: 52#[L51-1, L34-1]true [90] L51-1-->L52: Formula: (< v_thread1Thread1of1ForFork0_i_5 v_N_1) InVars {thread1Thread1of1ForFork0_i=v_thread1Thread1of1ForFork0_i_5, N=v_N_1} OutVars{thread1Thread1of1ForFork0_i=v_thread1Thread1of1ForFork0_i_5, N=v_N_1} AuxVars[] AssignedVars[] 55#[L52, L34-1]true [92] L52-->L53: Formula: (= (store v_A_2 v_thread1Thread1of1ForFork0_i_7 (let ((.cse0 (select v_A_2 v_thread1Thread1of1ForFork0_i_7))) (ite (< .cse0 0) (- .cse0) .cse0))) v_A_1) InVars {A=v_A_2, thread1Thread1of1ForFork0_i=v_thread1Thread1of1ForFork0_i_7} OutVars{A=v_A_1, thread1Thread1of1ForFork0_i=v_thread1Thread1of1ForFork0_i_7} AuxVars[] AssignedVars[A] 57#[L34-1, L53]true [93] L53-->L51-1: Formula: (= v_thread1Thread1of1ForFork0_i_10 (+ v_thread1Thread1of1ForFork0_i_9 1)) InVars {thread1Thread1of1ForFork0_i=v_thread1Thread1of1ForFork0_i_9} OutVars{thread1Thread1of1ForFork0_i=v_thread1Thread1of1ForFork0_i_10} AuxVars[] AssignedVars[thread1Thread1of1ForFork0_i] 52#[L51-1, L34-1]true [2024-02-09 23:50:44,371 INFO L145 PredicateUnifier]: Initialized classic predicate unifier [2024-02-09 23:50:44,371 INFO L85 PathProgramCache]: Analyzing trace with hash 113176, now seen corresponding path program 1 times [2024-02-09 23:50:44,377 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-02-09 23:50:44,378 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1186172737] [2024-02-09 23:50:44,378 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-02-09 23:50:44,378 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-02-09 23:50:44,434 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:44,435 INFO L356 TraceCheck]: Trace is feasible, we will do another trace check, this time with branch encoders. [2024-02-09 23:50:44,440 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:44,452 INFO L130 FreeRefinementEngine]: Strategy CAMEL found a feasible trace [2024-02-09 23:50:44,454 INFO L145 PredicateUnifier]: Initialized classic predicate unifier [2024-02-09 23:50:44,454 INFO L85 PathProgramCache]: Analyzing trace with hash 119226, now seen corresponding path program 1 times [2024-02-09 23:50:44,454 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-02-09 23:50:44,454 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [882090502] [2024-02-09 23:50:44,455 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-02-09 23:50:44,455 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-02-09 23:50:44,465 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:44,465 INFO L356 TraceCheck]: Trace is feasible, we will do another trace check, this time with branch encoders. [2024-02-09 23:50:44,469 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:44,471 INFO L130 FreeRefinementEngine]: Strategy CAMEL found a feasible trace [2024-02-09 23:50:44,472 INFO L145 PredicateUnifier]: Initialized classic predicate unifier [2024-02-09 23:50:44,473 INFO L85 PathProgramCache]: Analyzing trace with hash -923251645, now seen corresponding path program 1 times [2024-02-09 23:50:44,473 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-02-09 23:50:44,473 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1100237199] [2024-02-09 23:50:44,473 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-02-09 23:50:44,473 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-02-09 23:50:44,480 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:44,481 INFO L356 TraceCheck]: Trace is feasible, we will do another trace check, this time with branch encoders. [2024-02-09 23:50:44,486 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:44,488 INFO L130 FreeRefinementEngine]: Strategy CAMEL found a feasible trace [2024-02-09 23:50:44,603 INFO L210 LassoAnalysis]: Preferences: [2024-02-09 23:50:44,603 INFO L126 ssoRankerPreferences]: Compute integeral hull: false [2024-02-09 23:50:44,603 INFO L127 ssoRankerPreferences]: Enable LassoPartitioneer: true [2024-02-09 23:50:44,603 INFO L128 ssoRankerPreferences]: Term annotations enabled: false [2024-02-09 23:50:44,604 INFO L129 ssoRankerPreferences]: Use exernal solver: false [2024-02-09 23:50:44,604 INFO L130 ssoRankerPreferences]: SMT solver command: z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 [2024-02-09 23:50:44,604 INFO L131 ssoRankerPreferences]: Dump SMT script to file: false [2024-02-09 23:50:44,604 INFO L132 ssoRankerPreferences]: Path of dumped script: [2024-02-09 23:50:44,604 INFO L133 ssoRankerPreferences]: Filename of dumped script: map-aggr-update3.bpl_BEv2_Iteration1_Lasso [2024-02-09 23:50:44,604 INFO L134 ssoRankerPreferences]: MapElimAlgo: Frank [2024-02-09 23:50:44,604 INFO L276 LassoAnalysis]: Starting lasso preprocessing... [2024-02-09 23:50:44,616 INFO L118 MapEliminator]: Using MapEliminator with SimplificationTechnique=SIMPLIFY_DDA XnfConversionTechnique=BOTTOM_UP_WITH_LOCAL_SIMPLIFICATION AddInequalities=false OnlyTrivialImplicationsArrayWrite=true OnlyTrivialImplicationsForModifiedArguments=true OnlyArgumentsInFormula=true [2024-02-09 23:50:44,643 INFO L118 MapEliminator]: Using MapEliminator with SimplificationTechnique=SIMPLIFY_DDA XnfConversionTechnique=BOTTOM_UP_WITH_LOCAL_SIMPLIFICATION AddInequalities=false OnlyTrivialImplicationsArrayWrite=true OnlyTrivialImplicationsForModifiedArguments=true OnlyArgumentsInFormula=true [2024-02-09 23:50:44,680 INFO L294 LassoAnalysis]: Preprocessing complete. [2024-02-09 23:50:44,683 INFO L490 LassoAnalysis]: Using template 'affine'. [2024-02-09 23:50:44,684 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 [2024-02-09 23:50:44,684 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2024-02-09 23:50:44,686 INFO L229 MonitoredProcess]: Starting monitored process 2 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (exit command is (exit), workingDir is null) [2024-02-09 23:50:44,721 INFO L120 nArgumentSynthesizer]: Termination Analysis Settings: Termination analysis: LINEAR_WITH_GUESSESNumber of strict supporting invariants: 0Number of non-strict supporting invariants: 1Consider only non-deceasing supporting invariants: trueSimplify termination arguments: trueSimplify supporting invariants: trueOverapproximate stem: false [2024-02-09 23:50:44,728 INFO L338 nArgumentSynthesizer]: Template has degree 0. [2024-02-09 23:50:44,729 INFO L351 nArgumentSynthesizer]: There is no stem transition; disabling supporting invariant generation. [2024-02-09 23:50:44,729 INFO L203 nArgumentSynthesizer]: 1 stem disjuncts [2024-02-09 23:50:44,729 INFO L204 nArgumentSynthesizer]: 1 loop disjuncts [2024-02-09 23:50:44,729 INFO L205 nArgumentSynthesizer]: 2 template conjuncts. [2024-02-09 23:50:44,731 INFO L401 nArgumentSynthesizer]: We have 2 Motzkin's Theorem applications. [2024-02-09 23:50:44,731 INFO L402 nArgumentSynthesizer]: A total of 0 supporting invariants were added. [2024-02-09 23:50:44,736 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (2)] Waiting until timeout for monitored process [2024-02-09 23:50:44,749 INFO L527 LassoAnalysis]: Proving termination failed for this template and these settings. [2024-02-09 23:50:44,753 INFO L552 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (2)] Ended with exit code 0 [2024-02-09 23:50:44,754 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 [2024-02-09 23:50:44,754 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2024-02-09 23:50:44,755 INFO L229 MonitoredProcess]: Starting monitored process 3 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (exit command is (exit), workingDir is null) [2024-02-09 23:50:44,757 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (3)] Waiting until timeout for monitored process [2024-02-09 23:50:44,759 INFO L120 nArgumentSynthesizer]: Termination Analysis Settings: Termination analysis: LINEAR_WITH_GUESSESNumber of strict supporting invariants: 0Number of non-strict supporting invariants: 1Consider only non-deceasing supporting invariants: trueSimplify termination arguments: trueSimplify supporting invariants: trueOverapproximate stem: false [2024-02-09 23:50:44,766 INFO L338 nArgumentSynthesizer]: Template has degree 0. [2024-02-09 23:50:44,767 INFO L203 nArgumentSynthesizer]: 1 stem disjuncts [2024-02-09 23:50:44,767 INFO L204 nArgumentSynthesizer]: 1 loop disjuncts [2024-02-09 23:50:44,767 INFO L205 nArgumentSynthesizer]: 2 template conjuncts. [2024-02-09 23:50:44,778 INFO L401 nArgumentSynthesizer]: We have 6 Motzkin's Theorem applications. [2024-02-09 23:50:44,778 INFO L402 nArgumentSynthesizer]: A total of 2 supporting invariants were added. [2024-02-09 23:50:44,800 INFO L420 nArgumentSynthesizer]: Found a termination argument, trying to simplify. [2024-02-09 23:50:44,822 INFO L443 ModelExtractionUtils]: Simplification made 7 calls to the SMT solver. [2024-02-09 23:50:44,822 INFO L444 ModelExtractionUtils]: 3 out of 13 variables were initially zero. Simplification set additionally 7 variables to zero. [2024-02-09 23:50:44,824 INFO L173 SolverBuilder]: Constructing external solver with command: z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 [2024-02-09 23:50:44,824 INFO L189 MonitoredProcess]: No working directory specified, using /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 [2024-02-09 23:50:44,880 INFO L229 MonitoredProcess]: Starting monitored process 4 with /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (exit command is (exit), workingDir is null) [2024-02-09 23:50:44,881 INFO L327 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (4)] Waiting until timeout for monitored process [2024-02-09 23:50:44,882 INFO L435 nArgumentSynthesizer]: Simplifying supporting invariants... [2024-02-09 23:50:44,891 INFO L438 nArgumentSynthesizer]: Removed 2 redundant supporting invariants from a total of 2. [2024-02-09 23:50:44,891 INFO L513 LassoAnalysis]: Proved termination. [2024-02-09 23:50:44,892 INFO L515 LassoAnalysis]: Termination argument consisting of: Ranking function f(thread1Thread1of1ForFork0_i, N) = -1*thread1Thread1of1ForFork0_i + 1*N Supporting invariants [] [2024-02-09 23:50:44,898 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (3)] Forceful destruction successful, exit code 0 [2024-02-09 23:50:44,903 INFO L156 tatePredicateManager]: 0 out of 0 supporting invariants were superfluous and have been removed [2024-02-09 23:50:44,924 INFO L145 PredicateUnifier]: Initialized classic predicate unifier [2024-02-09 23:50:44,936 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2024-02-09 23:50:44,939 INFO L262 TraceCheckSpWp]: Trace formula consists of 8 conjuncts, 2 conjunts are in the unsatisfiable core [2024-02-09 23:50:44,939 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-02-09 23:50:44,958 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is unsat [2024-02-09 23:50:44,959 WARN L260 TraceCheckSpWp]: Trace formula consists of 8 conjuncts, 4 conjunts are in the unsatisfiable core [2024-02-09 23:50:44,960 INFO L285 TraceCheckSpWp]: Computing forward predicates... [2024-02-09 23:50:44,989 INFO L134 CoverageAnalysis]: Checked inductivity of 0 backedges. 0 proven. 0 refuted. 0 times theorem prover too weak. 0 trivial. 0 not checked. [2024-02-09 23:50:45,036 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (4)] Forceful destruction successful, exit code 0 [2024-02-09 23:50:45,063 INFO L141 lantAutomatonBouncer]: Defining deterministic Buchi interpolant automaton with honda bouncer for stem and without honda bouncer for loop.1 stem predicates 2 loop predicates [2024-02-09 23:50:45,065 INFO L162 BuchiComplementFKV]: Start buchiComplementFKV with optimization HEIMAT2. Operand has 3 states, 3 states have (on average 2.0) internal successors, (6), 3 states have internal predecessors, (6), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2024-02-09 23:50:45,230 INFO L171 BuchiComplementFKV]: Finished buchiComplementFKV with optimization HEIMAT2. Operand has 3 states, 3 states have (on average 2.0) internal successors, (6), 3 states have internal predecessors, (6), 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) Result 9 states and 504 transitions.6 powerset states3 rank states. The highest rank that occured is 1 [2024-02-09 23:50:45,231 INFO L89 BuchiIntersect]: Starting Intersection [2024-02-09 23:50:45,231 INFO L72 uchiIntersectDefault]: Starting Basic Intersection [2024-02-09 23:50:45,237 INFO L85 uchiIntersectDefault]: Exiting Basic Intersection [2024-02-09 23:50:45,238 INFO L99 BuchiIntersect]: Exiting Intersection [2024-02-09 23:50:45,244 INFO L141 InterpolantAutomaton]: Switched to read-only mode: Buchi interpolant automaton has 5 states 1 stem states 2 non-accepting loop states 1 accepting loop states [2024-02-09 23:50:45,251 INFO L82 GeneralOperation]: Start removeUnreachable. Operand has 3 states, 3 states have (on average 2.0) internal successors, (6), 3 states have internal predecessors, (6), 0 states have call successors, (0), 0 states have call predecessors, (0), 0 states have return successors, (0), 0 states have call predecessors, (0), 0 states have call successors, (0) [2024-02-09 23:50:45,254 INFO L88 GeneralOperation]: Finished removeUnreachable. Reduced from 5 states to 5 states and 194 transitions. [2024-02-09 23:50:45,256 INFO L84 BuchiAccepts]: Start buchiAccepts Operand 5 states and 194 transitions. Stem has 3 letters. Loop has 3 letters. [2024-02-09 23:50:45,256 INFO L116 BuchiAccepts]: Finished buchiAccepts. [2024-02-09 23:50:45,256 INFO L84 BuchiAccepts]: Start buchiAccepts Operand 5 states and 194 transitions. Stem has 6 letters. Loop has 3 letters. [2024-02-09 23:50:45,256 INFO L116 BuchiAccepts]: Finished buchiAccepts. [2024-02-09 23:50:45,256 INFO L84 BuchiAccepts]: Start buchiAccepts Operand 5 states and 194 transitions. Stem has 3 letters. Loop has 6 letters. [2024-02-09 23:50:45,256 INFO L116 BuchiAccepts]: Finished buchiAccepts. [2024-02-09 23:50:45,256 INFO L428 stractBuchiCegarLoop]: Abstraction has has 57 places, 852 transitions, 3846 flow [2024-02-09 23:50:45,256 INFO L335 stractBuchiCegarLoop]: ======== Iteration 2 ============ [2024-02-09 23:50:45,257 INFO L84 BuchiIsEmpty]: Start buchiIsEmpty. Operand has 57 places, 852 transitions, 3846 flow [2024-02-09 23:50:45,347 INFO L185 PetriNetUnfolderBase]: Found word, exiting Unfolder. [2024-02-09 23:50:45,347 INFO L124 PetriNetUnfolderBase]: 444/614 cut-off events. [2024-02-09 23:50:45,347 INFO L125 PetriNetUnfolderBase]: For 75/75 co-relation queries the response was YES. [2024-02-09 23:50:45,348 INFO L88 BuchiIsEmpty]: Finished buchiIsEmpty language is not empty [2024-02-09 23:50:45,349 INFO L748 eck$LassoCheckResult]: Stem: 46#[$Ultimate##0]true [83] $Ultimate##0-->L34: Formula: (and (< v_ULTIMATE.start_m_3 v_N_7) (<= 0 v_ULTIMATE.start_m_3)) InVars {ULTIMATE.start_m=v_ULTIMATE.start_m_3, N=v_N_7} OutVars{ULTIMATE.start_m=v_ULTIMATE.start_m_3, N=v_N_7} AuxVars[] AssignedVars[] 48#[L34]true [114] L34-->$Ultimate##0: Formula: (= v_thread1Thread1of1ForFork0_thidvar0_2 1) InVars {} OutVars{thread1Thread1of1ForFork0_thidvar0=v_thread1Thread1of1ForFork0_thidvar0_2, thread1Thread1of1ForFork0_i=v_thread1Thread1of1ForFork0_i_14} AuxVars[] AssignedVars[thread1Thread1of1ForFork0_thidvar0, thread1Thread1of1ForFork0_i] 50#[L34-1, $Ultimate##0]true [117] L34-1-->$Ultimate##0: Formula: (and (= 2 v_thread2Thread1of1ForFork1_thidvar1_2) (= 2 v_thread2Thread1of1ForFork1_thidvar0_2)) InVars {} OutVars{thread2Thread1of1ForFork1_j=v_thread2Thread1of1ForFork1_j_20, thread2Thread1of1ForFork1_thidvar0=v_thread2Thread1of1ForFork1_thidvar0_2, thread2Thread1of1ForFork1_cnt=v_thread2Thread1of1ForFork1_cnt_12, thread2Thread1of1ForFork1_thidvar1=v_thread2Thread1of1ForFork1_thidvar1_2} AuxVars[] AssignedVars[thread2Thread1of1ForFork1_j, thread2Thread1of1ForFork1_thidvar0, thread2Thread1of1ForFork1_cnt, thread2Thread1of1ForFork1_thidvar1] 123#[$Ultimate##0, $Ultimate##0, L35]true [120] L35-->$Ultimate##0: Formula: (and (= 3 v_thread3Thread1of1ForFork2_thidvar0_2) (= 3 v_thread3Thread1of1ForFork2_thidvar1_2) (= 3 v_thread3Thread1of1ForFork2_thidvar2_2)) InVars {} OutVars{thread3Thread1of1ForFork2_thidvar2=v_thread3Thread1of1ForFork2_thidvar2_2, thread3Thread1of1ForFork2_thidvar1=v_thread3Thread1of1ForFork2_thidvar1_2, thread3Thread1of1ForFork2_thidvar0=v_thread3Thread1of1ForFork2_thidvar0_2, thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_12} AuxVars[] AssignedVars[thread3Thread1of1ForFork2_thidvar2, thread3Thread1of1ForFork2_thidvar1, thread3Thread1of1ForFork2_thidvar0, thread3Thread1of1ForFork2_k] 125#[$Ultimate##0, $Ultimate##0, L36, $Ultimate##0]true [106] $Ultimate##0-->L83-1: Formula: (= v_thread3Thread1of1ForFork2_k_1 0) InVars {} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_1} AuxVars[] AssignedVars[thread3Thread1of1ForFork2_k] 127#[$Ultimate##0, L83-1, $Ultimate##0, L36]true [108] L83-1-->L84: Formula: (< v_thread3Thread1of1ForFork2_k_5 v_N_5) InVars {thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_5, N=v_N_5} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_5, N=v_N_5} AuxVars[] AssignedVars[] 129#[$Ultimate##0, $Ultimate##0, L36, L84]true [110] L84-->L85: Formula: (= v_B_3 (store v_B_4 v_thread3Thread1of1ForFork2_k_7 v_thread3Thread1of1ForFork2_k_7)) InVars {thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_7, B=v_B_4} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_7, B=v_B_3} AuxVars[] AssignedVars[B] 131#[L85, $Ultimate##0, $Ultimate##0, L36]true [111] L85-->L83-1: Formula: (= v_thread3Thread1of1ForFork2_k_9 0) InVars {} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_9} AuxVars[] AssignedVars[thread3Thread1of1ForFork2_k] 127#[$Ultimate##0, L83-1, $Ultimate##0, L36]true [2024-02-09 23:50:45,349 INFO L750 eck$LassoCheckResult]: Loop: 127#[$Ultimate##0, L83-1, $Ultimate##0, L36]true [108] L83-1-->L84: Formula: (< v_thread3Thread1of1ForFork2_k_5 v_N_5) InVars {thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_5, N=v_N_5} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_5, N=v_N_5} AuxVars[] AssignedVars[] 129#[$Ultimate##0, $Ultimate##0, L36, L84]true [110] L84-->L85: Formula: (= v_B_3 (store v_B_4 v_thread3Thread1of1ForFork2_k_7 v_thread3Thread1of1ForFork2_k_7)) InVars {thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_7, B=v_B_4} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_7, B=v_B_3} AuxVars[] AssignedVars[B] 131#[L85, $Ultimate##0, $Ultimate##0, L36]true [111] L85-->L83-1: Formula: (= v_thread3Thread1of1ForFork2_k_9 0) InVars {} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_9} AuxVars[] AssignedVars[thread3Thread1of1ForFork2_k] 127#[$Ultimate##0, L83-1, $Ultimate##0, L36]true [108] L83-1-->L84: Formula: (< v_thread3Thread1of1ForFork2_k_5 v_N_5) InVars {thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_5, N=v_N_5} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_5, N=v_N_5} AuxVars[] AssignedVars[] 129#[$Ultimate##0, $Ultimate##0, L36, L84]true [110] L84-->L85: Formula: (= v_B_3 (store v_B_4 v_thread3Thread1of1ForFork2_k_7 v_thread3Thread1of1ForFork2_k_7)) InVars {thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_7, B=v_B_4} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_7, B=v_B_3} AuxVars[] AssignedVars[B] 131#[L85, $Ultimate##0, $Ultimate##0, L36]true [111] L85-->L83-1: Formula: (= v_thread3Thread1of1ForFork2_k_9 0) InVars {} OutVars{thread3Thread1of1ForFork2_k=v_thread3Thread1of1ForFork2_k_9} AuxVars[] AssignedVars[thread3Thread1of1ForFork2_k] 127#[$Ultimate##0, L83-1, $Ultimate##0, L36]true [2024-02-09 23:50:45,349 INFO L145 PredicateUnifier]: Initialized classic predicate unifier [2024-02-09 23:50:45,350 INFO L85 PathProgramCache]: Analyzing trace with hash -1623181850, now seen corresponding path program 1 times [2024-02-09 23:50:45,350 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-02-09 23:50:45,350 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [1335778463] [2024-02-09 23:50:45,351 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-02-09 23:50:45,351 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-02-09 23:50:45,364 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:45,367 INFO L356 TraceCheck]: Trace is feasible, we will do another trace check, this time with branch encoders. [2024-02-09 23:50:45,374 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:45,375 INFO L130 FreeRefinementEngine]: Strategy CAMEL found a feasible trace [2024-02-09 23:50:45,376 INFO L145 PredicateUnifier]: Initialized classic predicate unifier [2024-02-09 23:50:45,376 INFO L85 PathProgramCache]: Analyzing trace with hash -210513887, now seen corresponding path program 1 times [2024-02-09 23:50:45,376 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-02-09 23:50:45,376 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [140918955] [2024-02-09 23:50:45,376 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-02-09 23:50:45,376 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-02-09 23:50:45,391 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:45,391 INFO L356 TraceCheck]: Trace is feasible, we will do another trace check, this time with branch encoders. [2024-02-09 23:50:45,393 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:45,395 INFO L130 FreeRefinementEngine]: Strategy CAMEL found a feasible trace [2024-02-09 23:50:45,395 INFO L145 PredicateUnifier]: Initialized classic predicate unifier [2024-02-09 23:50:45,395 INFO L85 PathProgramCache]: Analyzing trace with hash 518735430, now seen corresponding path program 2 times [2024-02-09 23:50:45,395 INFO L118 FreeRefinementEngine]: Executing refinement strategy CAMEL [2024-02-09 23:50:45,395 INFO L334 FreeRefinementEngine]: Using trace check IpTcStrategyModuleSmtInterpolCraig [699716381] [2024-02-09 23:50:45,395 INFO L95 rtionOrderModulation]: Keeping assertion order NOT_INCREMENTALLY [2024-02-09 23:50:45,395 INFO L127 SolverBuilder]: Constructing new instance of SMTInterpol with explicit timeout -1 ms and remaining time -1 ms [2024-02-09 23:50:45,420 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:45,420 INFO L356 TraceCheck]: Trace is feasible, we will do another trace check, this time with branch encoders. [2024-02-09 23:50:45,425 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:45,427 INFO L130 FreeRefinementEngine]: Strategy CAMEL found a feasible trace [2024-02-09 23:50:45,559 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:45,559 INFO L356 TraceCheck]: Trace is feasible, we will do another trace check, this time with branch encoders. [2024-02-09 23:50:45,563 INFO L136 AnnotateAndAsserter]: Conjunction of SSA is sat [2024-02-09 23:50:45,587 INFO L201 PluginConnector]: Adding new model map-aggr-update3.bpl de.uni_freiburg.informatik.ultimate.plugins.generator.buchiautomizer CFG 09.02 11:50:45 BoogieIcfgContainer [2024-02-09 23:50:45,587 INFO L131 PluginConnector]: ------------------------ END BuchiAutomizer---------------------------- [2024-02-09 23:50:45,588 INFO L158 Benchmark]: Toolchain (without parser) took 1785.62ms. Allocated memory is still 168.8MB. Free memory was 115.8MB in the beginning and 101.2MB in the end (delta: 14.6MB). Peak memory consumption was 15.2MB. Max. memory is 8.0GB. [2024-02-09 23:50:45,589 INFO L158 Benchmark]: Boogie PL CUP Parser took 0.68ms. Allocated memory is still 168.8MB. Free memory is still 116.9MB. There was no memory consumed. Max. memory is 8.0GB. [2024-02-09 23:50:45,590 INFO L158 Benchmark]: Boogie Procedure Inliner took 50.19ms. Allocated memory is still 168.8MB. Free memory was 115.6MB in the beginning and 150.7MB in the end (delta: -35.0MB). Peak memory consumption was 8.8MB. Max. memory is 8.0GB. [2024-02-09 23:50:45,591 INFO L158 Benchmark]: Boogie Preprocessor took 14.03ms. Allocated memory is still 168.8MB. Free memory was 150.7MB in the beginning and 149.6MB in the end (delta: 1.1MB). There was no memory consumed. Max. memory is 8.0GB. [2024-02-09 23:50:45,594 INFO L158 Benchmark]: RCFGBuilder took 271.94ms. Allocated memory is still 168.8MB. Free memory was 149.6MB in the beginning and 139.5MB in the end (delta: 10.1MB). Peak memory consumption was 10.5MB. Max. memory is 8.0GB. [2024-02-09 23:50:45,595 INFO L158 Benchmark]: BuchiAutomizer took 1446.39ms. Allocated memory is still 168.8MB. Free memory was 139.4MB in the beginning and 101.2MB in the end (delta: 38.2MB). Peak memory consumption was 39.0MB. Max. memory is 8.0GB. [2024-02-09 23:50:45,597 INFO L338 ainManager$Toolchain]: ####################### End [Toolchain 1] ####################### --- Results --- * Results from de.uni_freiburg.informatik.ultimate.core: - StatisticsResult: Toolchain Benchmarks Benchmark results are: * Boogie PL CUP Parser took 0.68ms. Allocated memory is still 168.8MB. Free memory is still 116.9MB. There was no memory consumed. Max. memory is 8.0GB. * Boogie Procedure Inliner took 50.19ms. Allocated memory is still 168.8MB. Free memory was 115.6MB in the beginning and 150.7MB in the end (delta: -35.0MB). Peak memory consumption was 8.8MB. Max. memory is 8.0GB. * Boogie Preprocessor took 14.03ms. Allocated memory is still 168.8MB. Free memory was 150.7MB in the beginning and 149.6MB in the end (delta: 1.1MB). There was no memory consumed. Max. memory is 8.0GB. * RCFGBuilder took 271.94ms. Allocated memory is still 168.8MB. Free memory was 149.6MB in the beginning and 139.5MB in the end (delta: 10.1MB). Peak memory consumption was 10.5MB. Max. memory is 8.0GB. * BuchiAutomizer took 1446.39ms. Allocated memory is still 168.8MB. Free memory was 139.4MB in the beginning and 101.2MB in the end (delta: 38.2MB). Peak memory consumption was 39.0MB. Max. memory is 8.0GB. * Results from de.uni_freiburg.informatik.ultimate.plugins.generator.traceabstraction: - StatisticsResult: Constructed decomposition of program Your program was decomposed into 1 terminating modules (0 trivial, 1 deterministic, 0 nondeterministic) and one nonterminating remainder module.One deterministic module has affine ranking function -1 * i + N and consists of 5 locations. The remainder module has 3846 locations. - StatisticsResult: Timing statistics BüchiAutomizer plugin needed 1.2s and 2 iterations. TraceHistogramMax:0. Analysis of lassos took 0.7s. Construction of modules took 0.0s. Büchi inclusion checks took 0.2s. Highest rank in rank-based complementation 1. Minimization of det autom 0. Minimization of nondet autom 0. Automata minimization No data available. Non-live state removal took 0.0s Buchi closure took 0.0s. Biggest automaton had -1 states and ocurred in iteration -1. Nontrivial modules had stage [1, 0, 0, 0, 0]. InterpolantCoveringCapabilityFinite: 0/0 InterpolantCoveringCapabilityBuchi: 0/0 HoareTripleCheckerStatistics: 0 mSolverCounterUnknown, 112 SdHoareTripleChecker+Valid, 0.1s IncrementalHoareTripleChecker+Time, 0 mSdLazyCounter, 111 mSDsluCounter, 156 SdHoareTripleChecker+Invalid, 0.1s Time, 0 mProtectedAction, 0 SdHoareTripleChecker+Unchecked, 0 IncrementalHoareTripleChecker+Unchecked, 72 mSDsCounter, 4 IncrementalHoareTripleChecker+Valid, 0 mProtectedPredicate, 82 IncrementalHoareTripleChecker+Invalid, 86 SdHoareTripleChecker+Unknown, 0 mSolverCounterNotChecked, 4 mSolverCounterUnsat, 84 mSDtfsCounter, 82 mSolverCounterSat, 0.0s SdHoareTripleChecker+Time, 0 IncrementalHoareTripleChecker+Unknown LassoAnalysisResults: nont1 unkn0 SFLI0 SFLT0 conc0 concLT0 SILN0 SILU0 SILI0 SILT0 lasso1 LassoPreprocessingBenchmarks: Lassos: inital58 mio100 ax100 hnf100 lsp146 ukn27 mio100 lsp100 div100 bol100 ite100 ukn100 eq143 hnf93 smp100 dnf100 smp100 tf100 neg100 sie100 LassoTerminationAnalysisBenchmarks: ConstraintsSatisfiability: sat Degree: 0 Time: 137ms VariablesStem: 3 VariablesLoop: 3 DisjunctsStem: 1 DisjunctsLoop: 1 SupportingInvariants: 2 MotzkinApplications: 6 LassoTerminationAnalysisBenchmarks: LassoNonterminationAnalysisSatFixpoint: 0 LassoNonterminationAnalysisSatUnbounded: 0 LassoNonterminationAnalysisUnsat: 0 LassoNonterminationAnalysisUnknown: 0 LassoNonterminationAnalysisTime: 0.0s InitialAbstractionConstructionTime: 0.0s - TerminationAnalysisResult: Nontermination possible Buchi Automizer proved that your program is nonterminating for some inputs - LassoShapedNonTerminationArgument [Line: 83]: Nontermination argument in form of an infinite program execution. Nontermination argument in form of an infinite program execution. Stem: [L32] 0 assume 0 <= m && m < N; VAL [N=1, m=0] [L34] FORK 0 fork 1 thread1(); VAL [N=1, m=0] [L35] FORK 0 fork 2, 2 thread2(); VAL [N=1, m=0] [L36] FORK 0 fork 3, 3, 3 thread3(); VAL [N=1, m=0] [L82] 3 k := 0; VAL [N=1, k=0, m=0] [L83] COND TRUE 3 k < N VAL [N=1, k=0, m=0] [L84] 3 B[k] := k; VAL [N=1, k=0, m=0] [L85] 3 k := 0; VAL [N=1, k=0, m=0] Loop: [L83] COND TRUE k < N [L84] B[k] := k; [L85] k := 0; [L83] COND TRUE k < N [L84] B[k] := k; [L85] k := 0; End of lasso representation. - StatisticsResult: NonterminationArgumentStatistics Fixpoint - NonterminatingLassoResult [Line: 83]: Nonterminating execution Found a nonterminating execution for the following lasso shaped sequence of statements. Stem: [L32] 0 assume 0 <= m && m < N; VAL [N=1, m=0] [L34] FORK 0 fork 1 thread1(); VAL [N=1, m=0] [L35] FORK 0 fork 2, 2 thread2(); VAL [N=1, m=0] [L36] FORK 0 fork 3, 3, 3 thread3(); VAL [N=1, m=0] [L82] 3 k := 0; VAL [N=1, k=0, m=0] [L83] COND TRUE 3 k < N VAL [N=1, k=0, m=0] [L84] 3 B[k] := k; VAL [N=1, k=0, m=0] [L85] 3 k := 0; VAL [N=1, k=0, m=0] Loop: [L83] COND TRUE k < N [L84] B[k] := k; [L85] k := 0; [L83] COND TRUE k < N [L84] B[k] := k; [L85] k := 0; End of lasso representation. RESULT: Ultimate proved your program to be incorrect! [2024-02-09 23:50:45,642 INFO L540 MonitoredProcess]: [MP /storage/repos/ultimate/releaseScripts/default/UAutomizer-linux/z3 SMTLIB2_COMPLIANT=true -memory:1024 -smt2 -in -t:12000 (1)] Forceful destruction successful, exit code 0 Received shutdown request...