YES Problem: minus(x,0()) -> x minus(s(x),s(y)) -> minus(x,y) f(0()) -> s(0()) f(s(x)) -> minus(s(x),g(f(x))) g(0()) -> 0() g(s(x)) -> minus(s(x),f(g(x))) Proof: DP Processor: DPs: minus#(s(x),s(y)) -> minus#(x,y) f#(s(x)) -> f#(x) f#(s(x)) -> g#(f(x)) f#(s(x)) -> minus#(s(x),g(f(x))) g#(s(x)) -> g#(x) g#(s(x)) -> f#(g(x)) g#(s(x)) -> minus#(s(x),f(g(x))) TRS: minus(x,0()) -> x minus(s(x),s(y)) -> minus(x,y) f(0()) -> s(0()) f(s(x)) -> minus(s(x),g(f(x))) g(0()) -> 0() g(s(x)) -> minus(s(x),f(g(x))) EDG Processor: DPs: minus#(s(x),s(y)) -> minus#(x,y) f#(s(x)) -> f#(x) f#(s(x)) -> g#(f(x)) f#(s(x)) -> minus#(s(x),g(f(x))) g#(s(x)) -> g#(x) g#(s(x)) -> f#(g(x)) g#(s(x)) -> minus#(s(x),f(g(x))) TRS: minus(x,0()) -> x minus(s(x),s(y)) -> minus(x,y) f(0()) -> s(0()) f(s(x)) -> minus(s(x),g(f(x))) g(0()) -> 0() g(s(x)) -> minus(s(x),f(g(x))) graph: g#(s(x)) -> g#(x) -> g#(s(x)) -> g#(x) g#(s(x)) -> g#(x) -> g#(s(x)) -> f#(g(x)) g#(s(x)) -> g#(x) -> g#(s(x)) -> minus#(s(x),f(g(x))) g#(s(x)) -> f#(g(x)) -> f#(s(x)) -> f#(x) g#(s(x)) -> f#(g(x)) -> f#(s(x)) -> g#(f(x)) g#(s(x)) -> f#(g(x)) -> f#(s(x)) -> minus#(s(x),g(f(x))) g#(s(x)) -> minus#(s(x),f(g(x))) -> minus#(s(x),s(y)) -> minus#(x,y) f#(s(x)) -> g#(f(x)) -> g#(s(x)) -> g#(x) f#(s(x)) -> g#(f(x)) -> g#(s(x)) -> f#(g(x)) f#(s(x)) -> g#(f(x)) -> g#(s(x)) -> minus#(s(x),f(g(x))) f#(s(x)) -> f#(x) -> f#(s(x)) -> f#(x) f#(s(x)) -> f#(x) -> f#(s(x)) -> g#(f(x)) f#(s(x)) -> f#(x) -> f#(s(x)) -> minus#(s(x),g(f(x))) f#(s(x)) -> minus#(s(x),g(f(x))) -> minus#(s(x),s(y)) -> minus#(x,y) minus#(s(x),s(y)) -> minus#(x,y) -> minus#(s(x),s(y)) -> minus#(x,y) SCC Processor: #sccs: 2 #rules: 5 #arcs: 15/49 DPs: g#(s(x)) -> g#(x) g#(s(x)) -> f#(g(x)) f#(s(x)) -> g#(f(x)) f#(s(x)) -> f#(x) TRS: minus(x,0()) -> x minus(s(x),s(y)) -> minus(x,y) f(0()) -> s(0()) f(s(x)) -> minus(s(x),g(f(x))) g(0()) -> 0() g(s(x)) -> minus(s(x),f(g(x))) Matrix Interpretation Processor: dimension: 1 interpretation: [g#](x0) = x0 + 1, [f#](x0) = x0 + 1, [g](x0) = x0, [f](x0) = x0 + 1, [s](x0) = x0 + 1, [minus](x0, x1) = x0, [0] = 0 orientation: g#(s(x)) = x + 2 >= x + 1 = g#(x) g#(s(x)) = x + 2 >= x + 1 = f#(g(x)) f#(s(x)) = x + 2 >= x + 2 = g#(f(x)) f#(s(x)) = x + 2 >= x + 1 = f#(x) minus(x,0()) = x >= x = x minus(s(x),s(y)) = x + 1 >= x = minus(x,y) f(0()) = 1 >= 1 = s(0()) f(s(x)) = x + 2 >= x + 1 = minus(s(x),g(f(x))) g(0()) = 0 >= 0 = 0() g(s(x)) = x + 1 >= x + 1 = minus(s(x),f(g(x))) problem: DPs: f#(s(x)) -> g#(f(x)) TRS: minus(x,0()) -> x minus(s(x),s(y)) -> minus(x,y) f(0()) -> s(0()) f(s(x)) -> minus(s(x),g(f(x))) g(0()) -> 0() g(s(x)) -> minus(s(x),f(g(x))) Matrix Interpretation Processor: dimension: 1 interpretation: [g#](x0) = 0, [f#](x0) = 1, [g](x0) = x0, [f](x0) = x0, [s](x0) = x0, [minus](x0, x1) = x0, [0] = 0 orientation: f#(s(x)) = 1 >= 0 = g#(f(x)) minus(x,0()) = x >= x = x minus(s(x),s(y)) = x >= x = minus(x,y) f(0()) = 0 >= 0 = s(0()) f(s(x)) = x >= x = minus(s(x),g(f(x))) g(0()) = 0 >= 0 = 0() g(s(x)) = x >= x = minus(s(x),f(g(x))) problem: DPs: TRS: minus(x,0()) -> x minus(s(x),s(y)) -> minus(x,y) f(0()) -> s(0()) f(s(x)) -> minus(s(x),g(f(x))) g(0()) -> 0() g(s(x)) -> minus(s(x),f(g(x))) Qed DPs: minus#(s(x),s(y)) -> minus#(x,y) TRS: minus(x,0()) -> x minus(s(x),s(y)) -> minus(x,y) f(0()) -> s(0()) f(s(x)) -> minus(s(x),g(f(x))) g(0()) -> 0() g(s(x)) -> minus(s(x),f(g(x))) Subterm Criterion Processor: simple projection: pi(minus#) = 1 problem: DPs: TRS: minus(x,0()) -> x minus(s(x),s(y)) -> minus(x,y) f(0()) -> s(0()) f(s(x)) -> minus(s(x),g(f(x))) g(0()) -> 0() g(s(x)) -> minus(s(x),f(g(x))) Qed