YES Problem: g(A()) -> A() g(B()) -> A() g(B()) -> B() g(C()) -> A() g(C()) -> B() g(C()) -> C() foldB(t,0()) -> t foldB(t,s(n)) -> f(foldB(t,n),B()) foldC(t,0()) -> t foldC(t,s(n)) -> f(foldC(t,n),C()) f(t,x) -> f'(t,g(x)) f'(triple(a,b,c),C()) -> triple(a,b,s(c)) f'(triple(a,b,c),B()) -> f(triple(a,b,c),A()) f'(triple(a,b,c),A()) -> f''(foldB(triple(s(a),0(),c),b)) f''(triple(a,b,c)) -> foldC(triple(a,b,0()),c) Proof: DP Processor: DPs: foldB#(t,s(n)) -> foldB#(t,n) foldB#(t,s(n)) -> f#(foldB(t,n),B()) foldC#(t,s(n)) -> foldC#(t,n) foldC#(t,s(n)) -> f#(foldC(t,n),C()) f#(t,x) -> g#(x) f#(t,x) -> f'#(t,g(x)) f'#(triple(a,b,c),B()) -> f#(triple(a,b,c),A()) f'#(triple(a,b,c),A()) -> foldB#(triple(s(a),0(),c),b) f'#(triple(a,b,c),A()) -> f''#(foldB(triple(s(a),0(),c),b)) f''#(triple(a,b,c)) -> foldC#(triple(a,b,0()),c) TRS: g(A()) -> A() g(B()) -> A() g(B()) -> B() g(C()) -> A() g(C()) -> B() g(C()) -> C() foldB(t,0()) -> t foldB(t,s(n)) -> f(foldB(t,n),B()) foldC(t,0()) -> t foldC(t,s(n)) -> f(foldC(t,n),C()) f(t,x) -> f'(t,g(x)) f'(triple(a,b,c),C()) -> triple(a,b,s(c)) f'(triple(a,b,c),B()) -> f(triple(a,b,c),A()) f'(triple(a,b,c),A()) -> f''(foldB(triple(s(a),0(),c),b)) f''(triple(a,b,c)) -> foldC(triple(a,b,0()),c) Matrix Interpretation Processor: dim=1 interpretation: [f''#](x0) = 1/2x0 + 2, [f'#](x0, x1) = 1/2x0 + 1/2x1 + 2, [foldC#](x0, x1) = 1/2x0 + x1 + 3/2, [f#](x0, x1) = 1/2x0 + 1/2x1 + 5/2, [foldB#](x0, x1) = 1/2x0 + x1 + 3/2, [g#](x0) = 1/2x0, [f''](x0) = x0, [triple](x0, x1, x2) = 2x1 + 2x2 + 2, [f'](x0, x1) = x0 + 3/2x1 + 3/2, [foldC](x0, x1) = x0 + 2x1, [f](x0, x1) = x0 + 3/2x1 + 3/2, [s](x0) = x0 + 3, [foldB](x0, x1) = x0 + 2x1, [0] = 0, [C] = 3, [B] = 3, [g](x0) = x0, [A] = 1 orientation: foldB#(t,s(n)) = n + 1/2t + 9/2 >= n + 1/2t + 3/2 = foldB#(t,n) foldB#(t,s(n)) = n + 1/2t + 9/2 >= n + 1/2t + 4 = f#(foldB(t,n),B()) foldC#(t,s(n)) = n + 1/2t + 9/2 >= n + 1/2t + 3/2 = foldC#(t,n) foldC#(t,s(n)) = n + 1/2t + 9/2 >= n + 1/2t + 4 = f#(foldC(t,n),C()) f#(t,x) = 1/2t + 1/2x + 5/2 >= 1/2x = g#(x) f#(t,x) = 1/2t + 1/2x + 5/2 >= 1/2t + 1/2x + 2 = f'#(t,g(x)) f'#(triple(a,b,c),B()) = b + c + 9/2 >= b + c + 4 = f#(triple(a,b,c),A()) f'#(triple(a,b,c),A()) = b + c + 7/2 >= b + c + 5/2 = foldB#(triple(s(a),0(),c),b) f'#(triple(a,b,c),A()) = b + c + 7/2 >= b + c + 3 = f''#(foldB(triple(s(a),0(),c),b)) f''#(triple(a,b,c)) = b + c + 3 >= b + c + 5/2 = foldC#(triple(a,b,0()),c) g(A()) = 1 >= 1 = A() g(B()) = 3 >= 1 = A() g(B()) = 3 >= 3 = B() g(C()) = 3 >= 1 = A() g(C()) = 3 >= 3 = B() g(C()) = 3 >= 3 = C() foldB(t,0()) = t >= t = t foldB(t,s(n)) = 2n + t + 6 >= 2n + t + 6 = f(foldB(t,n),B()) foldC(t,0()) = t >= t = t foldC(t,s(n)) = 2n + t + 6 >= 2n + t + 6 = f(foldC(t,n),C()) f(t,x) = t + 3/2x + 3/2 >= t + 3/2x + 3/2 = f'(t,g(x)) f'(triple(a,b,c),C()) = 2b + 2c + 8 >= 2b + 2c + 8 = triple(a,b,s(c)) f'(triple(a,b,c),B()) = 2b + 2c + 8 >= 2b + 2c + 5 = f(triple(a,b,c),A()) f'(triple(a,b,c),A()) = 2b + 2c + 5 >= 2b + 2c + 2 = f''(foldB(triple(s(a),0(),c),b)) f''(triple(a,b,c)) = 2b + 2c + 2 >= 2b + 2c + 2 = foldC(triple(a,b,0()),c) problem: DPs: TRS: g(A()) -> A() g(B()) -> A() g(B()) -> B() g(C()) -> A() g(C()) -> B() g(C()) -> C() foldB(t,0()) -> t foldB(t,s(n)) -> f(foldB(t,n),B()) foldC(t,0()) -> t foldC(t,s(n)) -> f(foldC(t,n),C()) f(t,x) -> f'(t,g(x)) f'(triple(a,b,c),C()) -> triple(a,b,s(c)) f'(triple(a,b,c),B()) -> f(triple(a,b,c),A()) f'(triple(a,b,c),A()) -> f''(foldB(triple(s(a),0(),c),b)) f''(triple(a,b,c)) -> foldC(triple(a,b,0()),c) Qed