261.54/66.04 YES 261.54/66.04 property Termination 261.54/66.04 has value True 261.54/66.04 for SRS ( [b, a, b, b] -> [b, b, b, a, b], [b, a, a, b, b] -> [b, a, b, b, a, a, b], [b, a, a, a, b, b] -> [b, a, a, b, b, a, a, a, b]) 261.54/66.04 reason 261.54/66.04 remap for 3 rules 261.54/66.04 property Termination 261.54/66.04 has value True 261.54/66.04 for SRS ( [0, 1, 0, 0] -> [0, 0, 0, 1, 0], [0, 1, 1, 0, 0] -> [0, 1, 0, 0, 1, 1, 0], [0, 1, 1, 1, 0, 0] -> [0, 1, 1, 0, 0, 1, 1, 1, 0]) 261.54/66.04 reason 261.54/66.04 reverse each lhs and rhs 261.54/66.04 property Termination 261.54/66.04 has value True 261.54/66.04 for SRS ( [0, 0, 1, 0] -> [0, 1, 0, 0, 0], [0, 0, 1, 1, 0] -> [0, 1, 1, 0, 0, 1, 0], [0, 0, 1, 1, 1, 0] -> [0, 1, 1, 1, 0, 0, 1, 1, 0]) 261.54/66.04 reason 261.54/66.04 DP transform 261.54/66.04 property Termination 261.54/66.04 has value True 261.54/66.05 for SRS ( [0, 0, 1, 0] ->= [0, 1, 0, 0, 0], [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0], [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0], [0#, 0, 1, 0] |-> [0#, 1, 0, 0, 0], [0#, 0, 1, 0] |-> [0#, 0, 0], [0#, 0, 1, 0] |-> [0#, 0], [0#, 0, 1, 1, 0] |-> [0#, 1, 1, 0, 0, 1, 0], [0#, 0, 1, 1, 0] |-> [0#, 0, 1, 0], [0#, 0, 1, 1, 0] |-> [0#, 1, 0], [0#, 0, 1, 1, 1, 0] |-> [0#, 1, 1, 1, 0, 0, 1, 1, 0], [0#, 0, 1, 1, 1, 0] |-> [0#, 0, 1, 1, 0], [0#, 0, 1, 1, 1, 0] |-> [0#, 1, 1, 0]) 261.54/66.05 reason 261.54/66.05 remap for 12 rules 261.54/66.05 property Termination 261.54/66.05 has value True 261.54/66.05 for SRS ( [0, 0, 1, 0] ->= [0, 1, 0, 0, 0], [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0], [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0], [2, 0, 1, 0] |-> [2, 1, 0, 0, 0], [2, 0, 1, 0] |-> [2, 0, 0], [2, 0, 1, 0] |-> [2, 0], [2, 0, 1, 1, 0] |-> [2, 1, 1, 0, 0, 1, 0], [2, 0, 1, 1, 0] |-> [2, 0, 1, 0], [2, 0, 1, 1, 0] |-> [2, 1, 0], [2, 0, 1, 1, 1, 0] |-> [2, 1, 1, 1, 0, 0, 1, 1, 0], [2, 0, 1, 1, 1, 0] |-> [2, 0, 1, 1, 0], [2, 0, 1, 1, 1, 0] |-> [2, 1, 1, 0]) 261.54/66.05 reason 261.54/66.05 EDG has 1 SCCs 261.54/66.05 property Termination 261.54/66.05 has value True 261.54/66.05 for SRS ( [2, 0, 1, 1, 0] |-> [2, 0, 1, 0], [2, 0, 1, 1, 1, 0] |-> [2, 0, 1, 1, 0], [2, 0, 1, 0] |-> [2, 0], [2, 0, 1, 0] |-> [2, 0, 0], [0, 0, 1, 0] ->= [0, 1, 0, 0, 0], [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0], [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0]) 261.54/66.05 reason 261.54/66.05 Matrix { monotone = Weak, domain = Arctic, bits = 4, dim = 3, solver = Minisatapi, verbose = False, tracing = True} 261.54/66.05 interpretation 261.54/66.05 0 / 0A 0A 0A \ 261.54/66.05 | -3A -3A -3A | 261.54/66.05 \ -3A -3A -3A / 261.54/66.05 1 / 0A 0A 3A \ 261.54/66.05 | 0A 0A 3A | 261.54/66.05 \ -3A 0A 0A / 261.54/66.05 2 / 17A 20A 20A \ 261.54/66.05 | 17A 20A 20A | 261.54/66.05 \ 17A 20A 20A / 261.54/66.05 [2, 0, 1, 1, 0] |-> [2, 0, 1, 0] 261.54/66.05 lhs rhs ge gt 261.54/66.05 / 17A 17A 17A \ / 17A 17A 17A \ True False 261.54/66.05 | 17A 17A 17A | | 17A 17A 17A | 261.54/66.05 \ 17A 17A 17A / \ 17A 17A 17A / 261.54/66.05 [2, 0, 1, 1, 1, 0] |-> [2, 0, 1, 1, 0] 261.54/66.05 lhs rhs ge gt 261.54/66.05 / 20A 20A 20A \ / 17A 17A 17A \ True True 261.54/66.05 | 20A 20A 20A | | 17A 17A 17A | 261.54/66.05 \ 20A 20A 20A / \ 17A 17A 17A / 261.54/66.05 [2, 0, 1, 0] |-> [2, 0] 261.54/66.05 lhs rhs ge gt 261.54/66.05 / 17A 17A 17A \ / 17A 17A 17A \ True False 261.54/66.05 | 17A 17A 17A | | 17A 17A 17A | 261.54/66.05 \ 17A 17A 17A / \ 17A 17A 17A / 261.54/66.05 [2, 0, 1, 0] |-> [2, 0, 0] 261.54/66.05 lhs rhs ge gt 261.54/66.05 / 17A 17A 17A \ / 17A 17A 17A \ True False 261.54/66.05 | 17A 17A 17A | | 17A 17A 17A | 261.54/66.05 \ 17A 17A 17A / \ 17A 17A 17A / 261.54/66.05 [0, 0, 1, 0] ->= [0, 1, 0, 0, 0] 261.54/66.05 lhs rhs ge gt 261.54/66.05 / 0A 0A 0A \ / 0A 0A 0A \ True False 261.54/66.05 | -3A -3A -3A | | -3A -3A -3A | 261.54/66.05 \ -3A -3A -3A / \ -3A -3A -3A / 261.54/66.05 [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0] 261.54/66.05 lhs rhs ge gt 261.54/66.05 / 0A 0A 0A \ / 0A 0A 0A \ True False 261.54/66.05 | -3A -3A -3A | | -3A -3A -3A | 261.54/66.05 \ -3A -3A -3A / \ -3A -3A -3A / 261.54/66.05 [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0] 261.54/66.05 lhs rhs ge gt 261.54/66.05 / 3A 3A 3A \ / 3A 3A 3A \ True False 261.54/66.05 | 0A 0A 0A | | 0A 0A 0A | 261.54/66.05 \ 0A 0A 0A / \ 0A 0A 0A / 261.54/66.05 property Termination 261.54/66.05 has value True 261.54/66.05 for SRS ( [2, 0, 1, 1, 0] |-> [2, 0, 1, 0], [2, 0, 1, 0] |-> [2, 0], [2, 0, 1, 0] |-> [2, 0, 0], [0, 0, 1, 0] ->= [0, 1, 0, 0, 0], [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0], [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0]) 261.54/66.05 reason 261.54/66.05 EDG has 1 SCCs 261.54/66.05 property Termination 261.54/66.05 has value True 261.54/66.05 for SRS ( [2, 0, 1, 1, 0] |-> [2, 0, 1, 0], [2, 0, 1, 0] |-> [2, 0, 0], [2, 0, 1, 0] |-> [2, 0], [0, 0, 1, 0] ->= [0, 1, 0, 0, 0], [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0], [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0]) 261.54/66.05 reason 261.54/66.05 Matrix { monotone = Weak, domain = Natural, bits = 3, dim = 4, solver = Minisatapi, verbose = False, tracing = False} 261.54/66.05 interpretation 261.54/66.06 0 Wk / 0 1 0 0 \ 261.54/66.06 | 0 1 0 0 | 261.54/66.06 | 0 0 0 0 | 261.54/66.06 \ 0 0 0 1 / 261.54/66.06 1 Wk / 0 0 0 1 \ 261.54/66.06 | 1 0 1 0 | 261.54/66.06 | 1 0 0 0 | 261.54/66.06 \ 0 0 0 1 / 261.54/66.06 2 Wk / 2 0 1 0 \ 261.54/66.06 | 0 0 0 0 | 261.54/66.06 | 0 0 0 4 | 261.54/66.06 \ 0 0 0 1 / 261.54/66.06 [2, 0, 1, 1, 0] |-> [2, 0, 1, 0] 261.54/66.06 lhs rhs ge gt 261.54/66.06 Wk / 0 2 0 2 \ Wk / 0 2 0 0 \ True True 261.54/66.06 | 0 0 0 0 | | 0 0 0 0 | 261.54/66.06 | 0 0 0 4 | | 0 0 0 4 | 261.54/66.06 \ 0 0 0 1 / \ 0 0 0 1 / 261.54/66.06 [2, 0, 1, 0] |-> [2, 0, 0] 261.54/66.06 lhs rhs ge gt 261.54/66.06 Wk / 0 2 0 0 \ Wk / 0 2 0 0 \ True False 261.54/66.06 | 0 0 0 0 | | 0 0 0 0 | 261.54/66.06 | 0 0 0 4 | | 0 0 0 4 | 261.54/66.06 \ 0 0 0 1 / \ 0 0 0 1 / 261.54/66.06 [2, 0, 1, 0] |-> [2, 0] 261.54/66.06 lhs rhs ge gt 261.54/66.06 Wk / 0 2 0 0 \ Wk / 0 2 0 0 \ True False 261.54/66.06 | 0 0 0 0 | | 0 0 0 0 | 261.54/66.06 | 0 0 0 4 | | 0 0 0 4 | 261.54/66.06 \ 0 0 0 1 / \ 0 0 0 1 / 261.54/66.06 [0, 0, 1, 0] ->= [0, 1, 0, 0, 0] 261.54/66.06 lhs rhs ge gt 261.54/66.06 Wk / 0 1 0 0 \ Wk / 0 1 0 0 \ True False 261.54/66.06 | 0 1 0 0 | | 0 1 0 0 | 261.54/66.06 | 0 0 0 0 | | 0 0 0 0 | 261.54/66.06 \ 0 0 0 1 / \ 0 0 0 1 / 261.54/66.06 [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0] 261.54/66.06 lhs rhs ge gt 261.54/66.06 Wk / 0 1 0 1 \ Wk / 0 1 0 1 \ True False 261.54/66.06 | 0 1 0 1 | | 0 1 0 1 | 261.54/66.06 | 0 0 0 0 | | 0 0 0 0 | 261.54/66.06 \ 0 0 0 1 / \ 0 0 0 1 / 261.54/66.06 [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0] 261.54/66.06 lhs rhs ge gt 261.54/66.06 Wk / 0 0 0 2 \ Wk / 0 0 0 2 \ True False 261.54/66.06 | 0 0 0 2 | | 0 0 0 2 | 261.54/66.06 | 0 0 0 0 | | 0 0 0 0 | 261.54/66.06 \ 0 0 0 1 / \ 0 0 0 1 / 261.54/66.06 property Termination 261.54/66.06 has value True 261.54/66.06 for SRS ( [2, 0, 1, 0] |-> [2, 0, 0], [2, 0, 1, 0] |-> [2, 0], [0, 0, 1, 0] ->= [0, 1, 0, 0, 0], [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0], [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0]) 261.54/66.06 reason 261.54/66.06 EDG has 1 SCCs 261.54/66.06 property Termination 261.54/66.06 has value True 261.54/66.06 for SRS ( [2, 0, 1, 0] |-> [2, 0, 0], [2, 0, 1, 0] |-> [2, 0], [0, 0, 1, 0] ->= [0, 1, 0, 0, 0], [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0], [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0]) 261.54/66.06 reason 261.54/66.06 Matrix { monotone = Weak, domain = Arctic, bits = 3, dim = 4, solver = Minisatapi, verbose = False, tracing = False} 261.54/66.06 interpretation 261.54/66.06 0 Wk / - - - 0A \ 261.54/66.06 | 3A 2A - 4A | 261.54/66.06 | 1A - 0A - | 261.54/66.06 \ - - - 0A / 261.54/66.06 1 Wk / - - 1A 2A \ 261.54/66.06 | 1A - 2A 3A | 261.54/66.06 | - - - 1A | 261.54/66.06 \ - - - 0A / 261.54/66.06 2 Wk / - - 4A 5A \ 261.54/66.06 | - - - - | 261.54/66.06 | - - - - | 261.54/66.06 \ - - - 0A / 261.54/66.06 [2, 0, 1, 0] |-> [2, 0, 0] 261.54/66.06 lhs rhs ge gt 261.54/66.06 Wk / 7A - 6A 7A \ Wk / 5A - 4A 5A \ True True 261.54/66.06 | - - - - | | - - - - | 261.54/66.06 | - - - - | | - - - - | 261.54/66.06 \ - - - 0A / \ - - - 0A / 261.54/66.06 [2, 0, 1, 0] |-> [2, 0] 261.54/66.06 lhs rhs ge gt 261.54/66.06 Wk / 7A - 6A 7A \ Wk / 5A - 4A 5A \ True True 261.54/66.06 | - - - - | | - - - - | 261.54/66.06 | - - - - | | - - - - | 261.54/66.06 \ - - - 0A / \ - - - 0A / 261.54/66.07 [0, 0, 1, 0] ->= [0, 1, 0, 0, 0] 261.54/66.07 lhs rhs ge gt 261.54/66.07 Wk / - - - 0A \ Wk / - - - 0A \ True False 261.54/66.07 | 7A - 6A 7A | | 5A - 4A 5A | 261.54/66.07 | 3A - 2A 3A | | 3A - 2A 3A | 261.54/66.07 \ - - - 0A / \ - - - 0A / 261.54/66.07 [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0] 261.54/66.07 lhs rhs ge gt 261.54/66.07 Wk / - - - 0A \ Wk / - - - 0A \ True False 261.54/66.07 | 7A - 6A 7A | | 7A - 6A 7A | 261.54/66.07 | - - - 3A | | - - - 3A | 261.54/66.07 \ - - - 0A / \ - - - 0A / 261.54/66.07 [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0] 261.54/66.07 lhs rhs ge gt 261.54/66.07 Wk / - - - 0A \ Wk / - - - 0A \ True False 261.54/66.07 | - - - 7A | | - - - 5A | 261.54/66.07 | - - - 3A | | - - - 3A | 261.54/66.07 \ - - - 0A / \ - - - 0A / 261.54/66.07 property Termination 261.54/66.07 has value True 261.54/66.07 for SRS ( [0, 0, 1, 0] ->= [0, 1, 0, 0, 0], [0, 0, 1, 1, 0] ->= [0, 1, 1, 0, 0, 1, 0], [0, 0, 1, 1, 1, 0] ->= [0, 1, 1, 1, 0, 0, 1, 1, 0]) 261.54/66.07 reason 261.54/66.07 EDG has 0 SCCs 261.54/66.07 261.54/66.07 ************************************************** 261.54/66.07 summary 261.54/66.07 ************************************************** 261.54/66.07 SRS with 3 rules on 2 letters Remap { tracing = False} 261.54/66.07 SRS with 3 rules on 2 letters reverse each lhs and rhs 261.54/66.07 SRS with 3 rules on 2 letters DP transform 261.54/66.07 SRS with 12 rules on 3 letters Remap { tracing = False} 261.54/66.07 SRS with 12 rules on 3 letters EDG 261.54/66.07 SRS with 7 rules on 3 letters Matrix { monotone = Weak, domain = Arctic, bits = 4, dim = 3, solver = Minisatapi, verbose = False, tracing = True} 261.54/66.07 SRS with 6 rules on 3 letters EDG 261.54/66.07 SRS with 6 rules on 3 letters Matrix { monotone = Weak, domain = Natural, bits = 3, dim = 4, solver = Minisatapi, verbose = False, tracing = False} 261.54/66.07 SRS with 5 rules on 3 letters EDG 261.54/66.07 SRS with 5 rules on 3 letters Matrix { monotone = Weak, domain = Arctic, bits = 3, dim = 4, solver = Minisatapi, verbose = False, tracing = False} 261.54/66.07 SRS with 3 rules on 2 letters EDG 261.54/66.07 261.54/66.07 ************************************************** 261.54/66.07 (3, 2)\Deepee(12, 3)\EDG(7, 3)\Matrix{\Arctic}{3}(6, 3)\Matrix{\Natural}{4}(5, 3)\Matrix{\Arctic}{4}(3, 2)\EDG[] 261.54/66.07 ************************************************** 261.54/66.09 let { done = Worker No_Strict_Rules;mo = Pre (Or_Else Count (IfSizeLeq 10000 GLPK Fail));wop = Or_Else (Worker (Weight { modus = mo})) Pass;weighted = \ m -> And_Then m wop;tiling = \ m w -> weighted (And_Then (Worker (Tiling { method = m,width = w})) (Worker Remap));when_small = \ m -> And_Then (Worker (SizeAtmost 100)) m;when_medium = \ m -> And_Then (Worker (SizeAtmost 10000)) m;solver = Minisatapi;qpi = \ dim bits -> weighted (when_small (Worker (QPI { tracing = True,dim = dim,bits = bits,solver = solver})));matrix = \ dom dim bits -> weighted (when_small (Worker (Matrix { monotone = Weak,domain = dom,dim = dim,bits = bits,tracing = False,solver = solver})));kbo = \ b -> weighted (when_small (Worker (KBO { bits = b,solver = solver})));mb = Worker (Matchbound { method = RFC,max_size = 100000});remove = First_Of ([ Worker (Weight { modus = mo})] <> ([ Seq [ qpi 2 4, qpi 3 4, qpi 4 4], Seq [ qpi 5 4, qpi 6 3, qpi 7 3]] <> ([ matrix Arctic 4 3, matrix Natural 4 3] <> [ kbo 1, And_Then (Worker Mirror) (kbo 1)])));remove_tile = Seq [ remove, tiling Overlap 3];dp = As_Transformer (Apply (And_Then (Worker (DP { tracing = False})) (Worker Remap)) (Apply wop (Branch (Worker (EDG { tracing = False})) remove_tile)));noh = [ Timeout 10 (Worker (Enumerate { closure = Forward})), Timeout 10 (Worker (Enumerate { closure = Backward}))];yeah = Tree_Search_Preemptive 0 done [ Worker (Weight { modus = mo}), mb, And_Then (Worker Mirror) mb, dp, And_Then (Worker Mirror) dp]} 261.54/66.09 in Apply (Worker Remap) (First_Of ([ yeah] <> noh)) 262.16/66.47 EOF