44.67/11.29 YES 44.67/11.29 property Termination 44.67/11.29 has value True 44.67/11.30 for SRS ( [a, a, a, b] -> [b, b], [b, b] -> [a, b, a, a]) 44.67/11.30 reason 44.67/11.30 remap for 2 rules 44.67/11.30 property Termination 44.67/11.30 has value True 44.67/11.30 for SRS ( [0, 0, 0, 1] -> [1, 1], [1, 1] -> [0, 1, 0, 0]) 44.67/11.30 reason 44.67/11.30 reverse each lhs and rhs 44.67/11.30 property Termination 44.67/11.30 has value True 44.67/11.30 for SRS ( [1, 0, 0, 0] -> [1, 1], [1, 1] -> [0, 0, 1, 0]) 44.67/11.30 reason 44.67/11.30 DP transform 44.67/11.30 property Termination 44.67/11.30 has value True 44.67/11.30 for SRS ( [1, 0, 0, 0] ->= [1, 1], [1, 1] ->= [0, 0, 1, 0], [1#, 0, 0, 0] |-> [1#, 1], [1#, 0, 0, 0] |-> [1#], [1#, 1] |-> [1#, 0]) 44.67/11.30 reason 44.67/11.30 remap for 5 rules 44.67/11.30 property Termination 44.67/11.30 has value True 44.67/11.30 for SRS ( [0, 1, 1, 1] ->= [0, 0], [0, 0] ->= [1, 1, 0, 1], [2, 1, 1, 1] |-> [2, 0], [2, 1, 1, 1] |-> [2], [2, 0] |-> [2, 1]) 44.67/11.30 reason 44.67/11.30 weights 44.67/11.30 Map [(0, 3/5), (1, 1/5)] 44.67/11.30 44.67/11.30 property Termination 44.67/11.30 has value True 44.67/11.30 for SRS ( [0, 1, 1, 1] ->= [0, 0], [0, 0] ->= [1, 1, 0, 1], [2, 1, 1, 1] |-> [2, 0]) 44.67/11.30 reason 44.67/11.30 EDG has 1 SCCs 44.67/11.30 property Termination 44.67/11.30 has value True 44.67/11.30 for SRS ( [2, 1, 1, 1] |-> [2, 0], [0, 1, 1, 1] ->= [0, 0], [0, 0] ->= [1, 1, 0, 1]) 44.67/11.30 reason 44.67/11.30 Matrix { monotone = Weak, domain = Arctic, bits = 3, dim = 4, solver = Minisatapi, verbose = False, tracing = False} 44.67/11.30 interpretation 44.67/11.30 0 Wk / 1A 6A 1A - \ 44.67/11.30 | 1A 0A 1A 0A | 44.67/11.30 | 0A 5A 0A - | 44.67/11.30 \ - - - 0A / 44.67/11.30 1 Wk / - - 2A 0A \ 44.67/11.30 | - - - - | 44.67/11.30 | 2A 2A - 1A | 44.67/11.30 \ - - - 0A / 44.67/11.32 2 Wk / 0A - 1A 4A \ 44.67/11.32 | - - - - | 44.67/11.32 | - - - - | 44.67/11.32 \ - - - 0A / 44.67/11.32 [2, 1, 1, 1] |-> [2, 0] 44.67/11.32 lhs rhs ge gt 44.67/11.32 Wk / 7A 7A 6A 6A \ Wk / 1A 6A 1A 4A \ True True 44.67/11.32 | - - - - | | - - - - | 44.67/11.32 | - - - - | | - - - - | 44.67/11.32 \ - - - 0A / \ - - - 0A / 44.67/11.32 [0, 1, 1, 1] ->= [0, 0] 44.67/11.32 lhs rhs ge gt 44.67/11.32 Wk / 7A 7A 7A 6A \ Wk / 7A 7A 7A 6A \ True False 44.67/11.32 | 7A 7A 7A 6A | | 2A 7A 2A 0A | 44.67/11.32 | 6A 6A 6A 5A | | 6A 6A 6A 5A | 44.67/11.32 \ - - - 0A / \ - - - 0A / 44.67/11.32 [0, 0] ->= [1, 1, 0, 1] 44.67/11.33 lhs rhs ge gt 44.67/11.33 Wk / 7A 7A 7A 6A \ Wk / 7A 7A 7A 6A \ True False 44.67/11.33 | 2A 7A 2A 0A | | - - - - | 44.67/11.33 | 6A 6A 6A 5A | | 6A 6A 6A 5A | 44.67/11.33 \ - - - 0A / \ - - - 0A / 44.67/11.33 property Termination 44.67/11.33 has value True 44.67/11.33 for SRS ( [0, 1, 1, 1] ->= [0, 0], [0, 0] ->= [1, 1, 0, 1]) 44.67/11.33 reason 44.67/11.33 EDG has 0 SCCs 44.67/11.33 44.67/11.33 ************************************************** 44.67/11.33 summary 44.67/11.33 ************************************************** 44.67/11.33 SRS with 2 rules on 2 letters Remap { tracing = False} 44.67/11.33 SRS with 2 rules on 2 letters reverse each lhs and rhs 44.67/11.33 SRS with 2 rules on 2 letters DP transform 44.67/11.33 SRS with 5 rules on 3 letters Remap { tracing = False} 44.67/11.33 SRS with 5 rules on 3 letters weights 44.67/11.33 SRS with 3 rules on 3 letters EDG 44.67/11.33 SRS with 3 rules on 3 letters Matrix { monotone = Weak, domain = Arctic, bits = 3, dim = 4, solver = Minisatapi, verbose = False, tracing = False} 44.67/11.33 SRS with 2 rules on 2 letters EDG 44.67/11.33 44.67/11.33 ************************************************** 44.67/11.33 (2, 2)\Deepee(5, 3)\Weight(3, 3)\Matrix{\Arctic}{4}(2, 2)\EDG[] 44.67/11.33 ************************************************** 45.18/11.44 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]} 45.18/11.44 in Apply (Worker Remap) (First_Of ([ yeah] <> noh)) 45.50/11.54 EOF