125.40/31.73 YES 125.40/31.73 property Termination 125.40/31.73 has value True 125.40/31.73 for SRS ( [b, b, b, a] -> [b, a, a, b], [b, a, b, a] -> [a, a, a, b], [a, a, b, b] -> [b, b, b, a]) 125.40/31.73 reason 125.40/31.73 remap for 3 rules 125.40/31.73 property Termination 125.40/31.73 has value True 125.40/31.73 for SRS ( [0, 0, 0, 1] -> [0, 1, 1, 0], [0, 1, 0, 1] -> [1, 1, 1, 0], [1, 1, 0, 0] -> [0, 0, 0, 1]) 125.40/31.73 reason 125.40/31.73 DP transform 125.40/31.73 property Termination 125.40/31.73 has value True 125.40/31.73 for SRS ( [0, 0, 0, 1] ->= [0, 1, 1, 0], [0, 1, 0, 1] ->= [1, 1, 1, 0], [1, 1, 0, 0] ->= [0, 0, 0, 1], [0#, 0, 0, 1] |-> [0#, 1, 1, 0], [0#, 0, 0, 1] |-> [1#, 1, 0], [0#, 0, 0, 1] |-> [1#, 0], [0#, 0, 0, 1] |-> [0#], [0#, 1, 0, 1] |-> [1#, 1, 1, 0], [0#, 1, 0, 1] |-> [1#, 1, 0], [0#, 1, 0, 1] |-> [1#, 0], [0#, 1, 0, 1] |-> [0#], [1#, 1, 0, 0] |-> [0#, 0, 0, 1], [1#, 1, 0, 0] |-> [0#, 0, 1], [1#, 1, 0, 0] |-> [0#, 1], [1#, 1, 0, 0] |-> [1#]) 125.40/31.73 reason 125.40/31.73 remap for 15 rules 125.40/31.73 property Termination 125.40/31.73 has value True 125.40/31.74 for SRS ( [0, 0, 0, 1] ->= [0, 1, 1, 0], [0, 1, 0, 1] ->= [1, 1, 1, 0], [1, 1, 0, 0] ->= [0, 0, 0, 1], [2, 0, 0, 1] |-> [2, 1, 1, 0], [2, 0, 0, 1] |-> [3, 1, 0], [2, 0, 0, 1] |-> [3, 0], [2, 0, 0, 1] |-> [2], [2, 1, 0, 1] |-> [3, 1, 1, 0], [2, 1, 0, 1] |-> [3, 1, 0], [2, 1, 0, 1] |-> [3, 0], [2, 1, 0, 1] |-> [2], [3, 1, 0, 0] |-> [2, 0, 0, 1], [3, 1, 0, 0] |-> [2, 0, 1], [3, 1, 0, 0] |-> [2, 1], [3, 1, 0, 0] |-> [3]) 125.40/31.74 reason 125.40/31.74 weights 125.40/31.74 Map [(0, 1/18), (1, 1/18)] 125.40/31.74 125.40/31.74 property Termination 125.40/31.74 has value True 125.40/31.74 for SRS ( [0, 0, 0, 1] ->= [0, 1, 1, 0], [0, 1, 0, 1] ->= [1, 1, 1, 0], [1, 1, 0, 0] ->= [0, 0, 0, 1], [2, 0, 0, 1] |-> [2, 1, 1, 0], [2, 1, 0, 1] |-> [3, 1, 1, 0], [3, 1, 0, 0] |-> [2, 0, 0, 1]) 125.40/31.74 reason 125.40/31.74 EDG has 1 SCCs 125.40/31.74 property Termination 125.40/31.74 has value True 125.40/31.74 for SRS ( [2, 0, 0, 1] |-> [2, 1, 1, 0], [2, 1, 0, 1] |-> [3, 1, 1, 0], [3, 1, 0, 0] |-> [2, 0, 0, 1], [0, 0, 0, 1] ->= [0, 1, 1, 0], [0, 1, 0, 1] ->= [1, 1, 1, 0], [1, 1, 0, 0] ->= [0, 0, 0, 1]) 125.40/31.74 reason 125.40/31.74 Matrix { monotone = Weak, domain = Natural, bits = 3, dim = 4, solver = Minisatapi, verbose = False, tracing = False} 125.40/31.74 interpretation 125.40/31.74 0 Wk / 0 1 1 1 \ 125.40/31.74 | 0 0 1 1 | 125.40/31.74 | 1 0 0 1 | 125.40/31.74 \ 0 0 0 1 / 125.40/31.74 1 Wk / 0 1 1 0 \ 125.40/31.74 | 0 0 1 0 | 125.40/31.74 | 1 0 0 0 | 125.40/31.74 \ 0 0 0 1 / 125.40/31.74 2 Wk / 1 0 0 2 \ 125.40/31.74 | 0 0 0 0 | 125.40/31.74 | 0 0 0 4 | 125.40/31.74 \ 0 0 0 1 / 125.40/31.74 3 Wk / 1 0 0 2 \ 125.40/31.74 | 0 0 0 0 | 125.40/31.74 | 0 0 0 4 | 125.40/31.74 \ 0 0 0 1 / 125.40/31.74 [2, 0, 0, 1] |-> [2, 1, 1, 0] 125.40/31.76 lhs rhs ge gt 125.40/31.76 Wk / 1 1 1 5 \ Wk / 1 1 1 4 \ True True 125.40/31.76 | 0 0 0 0 | | 0 0 0 0 | 125.40/31.76 | 0 0 0 4 | | 0 0 0 4 | 125.40/31.76 \ 0 0 0 1 / \ 0 0 0 1 / 125.40/31.76 [2, 1, 0, 1] |-> [3, 1, 1, 0] 125.40/31.76 lhs rhs ge gt 125.40/31.76 Wk / 1 1 1 4 \ Wk / 1 1 1 4 \ True False 125.40/31.76 | 0 0 0 0 | | 0 0 0 0 | 125.40/31.76 | 0 0 0 4 | | 0 0 0 4 | 125.40/31.76 \ 0 0 0 1 / \ 0 0 0 1 / 125.40/31.76 [3, 1, 0, 0] |-> [2, 0, 0, 1] 125.40/31.76 lhs rhs ge gt 125.40/31.76 Wk / 1 1 1 6 \ Wk / 1 1 1 5 \ True True 125.40/31.76 | 0 0 0 0 | | 0 0 0 0 | 125.75/31.78 | 0 0 0 4 | | 0 0 0 4 | 125.75/31.78 \ 0 0 0 1 / \ 0 0 0 1 / 125.75/31.78 [0, 0, 0, 1] ->= [0, 1, 1, 0] 125.75/31.78 lhs rhs ge gt 125.75/31.78 Wk / 1 1 2 5 \ Wk / 1 1 2 4 \ True True 125.75/31.78 | 1 0 1 3 | | 1 0 1 3 | 125.75/31.78 | 1 1 1 4 | | 1 1 1 3 | 125.75/31.78 \ 0 0 0 1 / \ 0 0 0 1 / 125.75/31.78 [0, 1, 0, 1] ->= [1, 1, 1, 0] 125.75/31.78 lhs rhs ge gt 125.75/31.78 Wk / 1 1 2 3 \ Wk / 1 1 2 3 \ True False 125.75/31.78 | 1 0 1 2 | | 1 0 1 2 | 125.75/31.78 | 1 1 1 3 | | 1 1 1 2 | 125.75/31.78 \ 0 0 0 1 / \ 0 0 0 1 / 125.75/31.78 [1, 1, 0, 0] ->= [0, 0, 0, 1] 125.78/31.79 lhs rhs ge gt 125.78/31.79 Wk / 1 1 2 5 \ Wk / 1 1 2 5 \ True False 125.78/31.79 | 1 0 1 3 | | 1 0 1 3 | 125.78/31.79 | 1 1 1 4 | | 1 1 1 4 | 125.78/31.79 \ 0 0 0 1 / \ 0 0 0 1 / 125.78/31.79 property Termination 125.78/31.79 has value True 125.78/31.79 for SRS ( [2, 1, 0, 1] |-> [3, 1, 1, 0], [0, 0, 0, 1] ->= [0, 1, 1, 0], [0, 1, 0, 1] ->= [1, 1, 1, 0], [1, 1, 0, 0] ->= [0, 0, 0, 1]) 125.78/31.79 reason 125.78/31.79 weights 125.78/31.79 Map [(2, 1/1)] 125.78/31.79 125.78/31.79 property Termination 125.78/31.79 has value True 125.78/31.79 for SRS ( [0, 0, 0, 1] ->= [0, 1, 1, 0], [0, 1, 0, 1] ->= [1, 1, 1, 0], [1, 1, 0, 0] ->= [0, 0, 0, 1]) 125.78/31.79 reason 125.78/31.79 EDG has 0 SCCs 125.78/31.79 125.78/31.79 ************************************************** 125.78/31.79 summary 125.78/31.79 ************************************************** 125.78/31.79 SRS with 3 rules on 2 letters Remap { tracing = False} 125.78/31.79 SRS with 3 rules on 2 letters DP transform 125.78/31.79 SRS with 15 rules on 4 letters Remap { tracing = False} 125.78/31.79 SRS with 15 rules on 4 letters weights 125.78/31.79 SRS with 6 rules on 4 letters EDG 125.78/31.79 SRS with 6 rules on 4 letters Matrix { monotone = Weak, domain = Natural, bits = 3, dim = 4, solver = Minisatapi, verbose = False, tracing = False} 125.78/31.79 SRS with 4 rules on 4 letters weights 125.78/31.79 SRS with 3 rules on 2 letters EDG 125.78/31.79 125.78/31.79 ************************************************** 125.78/31.79 (3, 2)\Deepee(15, 4)\Weight(6, 4)\Matrix{\Natural}{4}(4, 4)\Weight(3, 2)\EDG[] 125.78/31.79 ************************************************** 126.31/31.93 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]} 126.31/31.93 in Apply (Worker Remap) (First_Of ([ yeah] <> noh)) 126.98/32.14 EOF