MAYBE We are left with following problem, upon which TcT provides the certificate MAYBE. Strict Trs: { cond1(true(), x, y) -> cond2(gr(x, y), x, y) , cond2(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond2(false(), x, y) -> cond3(eq(x, y), x, y) , gr(0(), x) -> false() , gr(s(x), 0()) -> true() , gr(s(x), s(y)) -> gr(x, y) , add(0(), x) -> x , add(s(x), y) -> s(add(x, y)) , p(0()) -> 0() , p(s(x)) -> x , cond3(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond3(false(), x, y) -> cond1(gr(add(x, y), 0()), x, p(y)) , eq(0(), 0()) -> true() , eq(0(), s(x)) -> false() , eq(s(x), 0()) -> false() , eq(s(x), s(y)) -> eq(x, y) } Obligation: innermost runtime complexity Answer: MAYBE We add following dependency tuples: Strict DPs: { cond1^#(true(), x, y) -> c_1(cond2^#(gr(x, y), x, y), gr^#(x, y)) , cond2^#(true(), x, y) -> c_2(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond2^#(false(), x, y) -> c_3(cond3^#(eq(x, y), x, y), eq^#(x, y)) , gr^#(0(), x) -> c_4() , gr^#(s(x), 0()) -> c_5() , gr^#(s(x), s(y)) -> c_6(gr^#(x, y)) , add^#(0(), x) -> c_7() , add^#(s(x), y) -> c_8(add^#(x, y)) , p^#(0()) -> c_9() , p^#(s(x)) -> c_10() , cond3^#(true(), x, y) -> c_11(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond3^#(false(), x, y) -> c_12(cond1^#(gr(add(x, y), 0()), x, p(y)), gr^#(add(x, y), 0()), add^#(x, y), p^#(y)) , eq^#(0(), 0()) -> c_13() , eq^#(0(), s(x)) -> c_14() , eq^#(s(x), 0()) -> c_15() , eq^#(s(x), s(y)) -> c_16(eq^#(x, y)) } and mark the set of starting terms. We are left with following problem, upon which TcT provides the certificate MAYBE. Strict DPs: { cond1^#(true(), x, y) -> c_1(cond2^#(gr(x, y), x, y), gr^#(x, y)) , cond2^#(true(), x, y) -> c_2(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond2^#(false(), x, y) -> c_3(cond3^#(eq(x, y), x, y), eq^#(x, y)) , gr^#(0(), x) -> c_4() , gr^#(s(x), 0()) -> c_5() , gr^#(s(x), s(y)) -> c_6(gr^#(x, y)) , add^#(0(), x) -> c_7() , add^#(s(x), y) -> c_8(add^#(x, y)) , p^#(0()) -> c_9() , p^#(s(x)) -> c_10() , cond3^#(true(), x, y) -> c_11(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond3^#(false(), x, y) -> c_12(cond1^#(gr(add(x, y), 0()), x, p(y)), gr^#(add(x, y), 0()), add^#(x, y), p^#(y)) , eq^#(0(), 0()) -> c_13() , eq^#(0(), s(x)) -> c_14() , eq^#(s(x), 0()) -> c_15() , eq^#(s(x), s(y)) -> c_16(eq^#(x, y)) } Weak Trs: { cond1(true(), x, y) -> cond2(gr(x, y), x, y) , cond2(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond2(false(), x, y) -> cond3(eq(x, y), x, y) , gr(0(), x) -> false() , gr(s(x), 0()) -> true() , gr(s(x), s(y)) -> gr(x, y) , add(0(), x) -> x , add(s(x), y) -> s(add(x, y)) , p(0()) -> 0() , p(s(x)) -> x , cond3(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond3(false(), x, y) -> cond1(gr(add(x, y), 0()), x, p(y)) , eq(0(), 0()) -> true() , eq(0(), s(x)) -> false() , eq(s(x), 0()) -> false() , eq(s(x), s(y)) -> eq(x, y) } Obligation: innermost runtime complexity Answer: MAYBE We estimate the number of application of {4,5,7,9,10,13,14,15} by applications of Pre({4,5,7,9,10,13,14,15}) = {1,2,3,6,8,11,12,16}. Here rules are labeled as follows: DPs: { 1: cond1^#(true(), x, y) -> c_1(cond2^#(gr(x, y), x, y), gr^#(x, y)) , 2: cond2^#(true(), x, y) -> c_2(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , 3: cond2^#(false(), x, y) -> c_3(cond3^#(eq(x, y), x, y), eq^#(x, y)) , 4: gr^#(0(), x) -> c_4() , 5: gr^#(s(x), 0()) -> c_5() , 6: gr^#(s(x), s(y)) -> c_6(gr^#(x, y)) , 7: add^#(0(), x) -> c_7() , 8: add^#(s(x), y) -> c_8(add^#(x, y)) , 9: p^#(0()) -> c_9() , 10: p^#(s(x)) -> c_10() , 11: cond3^#(true(), x, y) -> c_11(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , 12: cond3^#(false(), x, y) -> c_12(cond1^#(gr(add(x, y), 0()), x, p(y)), gr^#(add(x, y), 0()), add^#(x, y), p^#(y)) , 13: eq^#(0(), 0()) -> c_13() , 14: eq^#(0(), s(x)) -> c_14() , 15: eq^#(s(x), 0()) -> c_15() , 16: eq^#(s(x), s(y)) -> c_16(eq^#(x, y)) } We are left with following problem, upon which TcT provides the certificate MAYBE. Strict DPs: { cond1^#(true(), x, y) -> c_1(cond2^#(gr(x, y), x, y), gr^#(x, y)) , cond2^#(true(), x, y) -> c_2(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond2^#(false(), x, y) -> c_3(cond3^#(eq(x, y), x, y), eq^#(x, y)) , gr^#(s(x), s(y)) -> c_6(gr^#(x, y)) , add^#(s(x), y) -> c_8(add^#(x, y)) , cond3^#(true(), x, y) -> c_11(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond3^#(false(), x, y) -> c_12(cond1^#(gr(add(x, y), 0()), x, p(y)), gr^#(add(x, y), 0()), add^#(x, y), p^#(y)) , eq^#(s(x), s(y)) -> c_16(eq^#(x, y)) } Weak DPs: { gr^#(0(), x) -> c_4() , gr^#(s(x), 0()) -> c_5() , add^#(0(), x) -> c_7() , p^#(0()) -> c_9() , p^#(s(x)) -> c_10() , eq^#(0(), 0()) -> c_13() , eq^#(0(), s(x)) -> c_14() , eq^#(s(x), 0()) -> c_15() } Weak Trs: { cond1(true(), x, y) -> cond2(gr(x, y), x, y) , cond2(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond2(false(), x, y) -> cond3(eq(x, y), x, y) , gr(0(), x) -> false() , gr(s(x), 0()) -> true() , gr(s(x), s(y)) -> gr(x, y) , add(0(), x) -> x , add(s(x), y) -> s(add(x, y)) , p(0()) -> 0() , p(s(x)) -> x , cond3(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond3(false(), x, y) -> cond1(gr(add(x, y), 0()), x, p(y)) , eq(0(), 0()) -> true() , eq(0(), s(x)) -> false() , eq(s(x), 0()) -> false() , eq(s(x), s(y)) -> eq(x, y) } Obligation: innermost runtime complexity Answer: MAYBE The following weak DPs constitute a sub-graph of the DG that is closed under successors. The DPs are removed. { gr^#(0(), x) -> c_4() , gr^#(s(x), 0()) -> c_5() , add^#(0(), x) -> c_7() , p^#(0()) -> c_9() , p^#(s(x)) -> c_10() , eq^#(0(), 0()) -> c_13() , eq^#(0(), s(x)) -> c_14() , eq^#(s(x), 0()) -> c_15() } We are left with following problem, upon which TcT provides the certificate MAYBE. Strict DPs: { cond1^#(true(), x, y) -> c_1(cond2^#(gr(x, y), x, y), gr^#(x, y)) , cond2^#(true(), x, y) -> c_2(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond2^#(false(), x, y) -> c_3(cond3^#(eq(x, y), x, y), eq^#(x, y)) , gr^#(s(x), s(y)) -> c_6(gr^#(x, y)) , add^#(s(x), y) -> c_8(add^#(x, y)) , cond3^#(true(), x, y) -> c_11(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond3^#(false(), x, y) -> c_12(cond1^#(gr(add(x, y), 0()), x, p(y)), gr^#(add(x, y), 0()), add^#(x, y), p^#(y)) , eq^#(s(x), s(y)) -> c_16(eq^#(x, y)) } Weak Trs: { cond1(true(), x, y) -> cond2(gr(x, y), x, y) , cond2(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond2(false(), x, y) -> cond3(eq(x, y), x, y) , gr(0(), x) -> false() , gr(s(x), 0()) -> true() , gr(s(x), s(y)) -> gr(x, y) , add(0(), x) -> x , add(s(x), y) -> s(add(x, y)) , p(0()) -> 0() , p(s(x)) -> x , cond3(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond3(false(), x, y) -> cond1(gr(add(x, y), 0()), x, p(y)) , eq(0(), 0()) -> true() , eq(0(), s(x)) -> false() , eq(s(x), 0()) -> false() , eq(s(x), s(y)) -> eq(x, y) } Obligation: innermost runtime complexity Answer: MAYBE Due to missing edges in the dependency-graph, the right-hand sides of following rules could be simplified: { cond2^#(true(), x, y) -> c_2(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond3^#(true(), x, y) -> c_11(cond1^#(gr(add(x, y), 0()), p(x), y), gr^#(add(x, y), 0()), add^#(x, y), p^#(x)) , cond3^#(false(), x, y) -> c_12(cond1^#(gr(add(x, y), 0()), x, p(y)), gr^#(add(x, y), 0()), add^#(x, y), p^#(y)) } We are left with following problem, upon which TcT provides the certificate MAYBE. Strict DPs: { cond1^#(true(), x, y) -> c_1(cond2^#(gr(x, y), x, y), gr^#(x, y)) , cond2^#(true(), x, y) -> c_2(cond1^#(gr(add(x, y), 0()), p(x), y), add^#(x, y)) , cond2^#(false(), x, y) -> c_3(cond3^#(eq(x, y), x, y), eq^#(x, y)) , gr^#(s(x), s(y)) -> c_4(gr^#(x, y)) , add^#(s(x), y) -> c_5(add^#(x, y)) , cond3^#(true(), x, y) -> c_6(cond1^#(gr(add(x, y), 0()), p(x), y), add^#(x, y)) , cond3^#(false(), x, y) -> c_7(cond1^#(gr(add(x, y), 0()), x, p(y)), add^#(x, y)) , eq^#(s(x), s(y)) -> c_8(eq^#(x, y)) } Weak Trs: { cond1(true(), x, y) -> cond2(gr(x, y), x, y) , cond2(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond2(false(), x, y) -> cond3(eq(x, y), x, y) , gr(0(), x) -> false() , gr(s(x), 0()) -> true() , gr(s(x), s(y)) -> gr(x, y) , add(0(), x) -> x , add(s(x), y) -> s(add(x, y)) , p(0()) -> 0() , p(s(x)) -> x , cond3(true(), x, y) -> cond1(gr(add(x, y), 0()), p(x), y) , cond3(false(), x, y) -> cond1(gr(add(x, y), 0()), x, p(y)) , eq(0(), 0()) -> true() , eq(0(), s(x)) -> false() , eq(s(x), 0()) -> false() , eq(s(x), s(y)) -> eq(x, y) } Obligation: innermost runtime complexity Answer: MAYBE We replace rewrite rules by usable rules: Weak Usable Rules: { gr(0(), x) -> false() , gr(s(x), 0()) -> true() , gr(s(x), s(y)) -> gr(x, y) , add(0(), x) -> x , add(s(x), y) -> s(add(x, y)) , p(0()) -> 0() , p(s(x)) -> x , eq(0(), 0()) -> true() , eq(0(), s(x)) -> false() , eq(s(x), 0()) -> false() , eq(s(x), s(y)) -> eq(x, y) } We are left with following problem, upon which TcT provides the certificate MAYBE. Strict DPs: { cond1^#(true(), x, y) -> c_1(cond2^#(gr(x, y), x, y), gr^#(x, y)) , cond2^#(true(), x, y) -> c_2(cond1^#(gr(add(x, y), 0()), p(x), y), add^#(x, y)) , cond2^#(false(), x, y) -> c_3(cond3^#(eq(x, y), x, y), eq^#(x, y)) , gr^#(s(x), s(y)) -> c_4(gr^#(x, y)) , add^#(s(x), y) -> c_5(add^#(x, y)) , cond3^#(true(), x, y) -> c_6(cond1^#(gr(add(x, y), 0()), p(x), y), add^#(x, y)) , cond3^#(false(), x, y) -> c_7(cond1^#(gr(add(x, y), 0()), x, p(y)), add^#(x, y)) , eq^#(s(x), s(y)) -> c_8(eq^#(x, y)) } Weak Trs: { gr(0(), x) -> false() , gr(s(x), 0()) -> true() , gr(s(x), s(y)) -> gr(x, y) , add(0(), x) -> x , add(s(x), y) -> s(add(x, y)) , p(0()) -> 0() , p(s(x)) -> x , eq(0(), 0()) -> true() , eq(0(), s(x)) -> false() , eq(s(x), 0()) -> false() , eq(s(x), s(y)) -> eq(x, y) } Obligation: innermost runtime complexity Answer: MAYBE The input cannot be shown compatible Arrrr..