Runtime Complexity TRS:
The TRS R consists of the following rules:
a__U11(tt, N) → mark(N)
a__U21(tt, M, N) → s(a__plus(mark(N), mark(M)))
a__U31(tt) → 0
a__U41(tt, M, N) → a__plus(a__x(mark(N), mark(M)), mark(N))
a__and(tt, X) → mark(X)
a__isNat(0) → tt
a__isNat(plus(V1, V2)) → a__and(a__isNat(V1), isNat(V2))
a__isNat(s(V1)) → a__isNat(V1)
a__isNat(x(V1, V2)) → a__and(a__isNat(V1), isNat(V2))
a__plus(N, 0) → a__U11(a__isNat(N), N)
a__plus(N, s(M)) → a__U21(a__and(a__isNat(M), isNat(N)), M, N)
a__x(N, 0) → a__U31(a__isNat(N))
a__x(N, s(M)) → a__U41(a__and(a__isNat(M), isNat(N)), M, N)
mark(U11(X1, X2)) → a__U11(mark(X1), X2)
mark(U21(X1, X2, X3)) → a__U21(mark(X1), X2, X3)
mark(plus(X1, X2)) → a__plus(mark(X1), mark(X2))
mark(U31(X)) → a__U31(mark(X))
mark(U41(X1, X2, X3)) → a__U41(mark(X1), X2, X3)
mark(x(X1, X2)) → a__x(mark(X1), mark(X2))
mark(and(X1, X2)) → a__and(mark(X1), X2)
mark(isNat(X)) → a__isNat(X)
mark(tt) → tt
mark(s(X)) → s(mark(X))
mark(0) → 0
a__U11(X1, X2) → U11(X1, X2)
a__U21(X1, X2, X3) → U21(X1, X2, X3)
a__plus(X1, X2) → plus(X1, X2)
a__U31(X) → U31(X)
a__U41(X1, X2, X3) → U41(X1, X2, X3)
a__x(X1, X2) → x(X1, X2)
a__and(X1, X2) → and(X1, X2)
a__isNat(X) → isNat(X)
Renamed function symbols to avoid clashes with predefined symbol.
Runtime Complexity TRS:
The TRS R consists of the following rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Infered types.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Heuristically decided to analyse the following defined symbols:
a__U11', mark', a__U21', a__plus', a__U41', a__x', a__and', a__isNat'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
mark', a__U11', a__U21', a__plus', a__U41', a__x', a__and', a__isNat'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Proved the following rewrite lemma:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4), rt ∈ Ω(1 + n4)
Induction Base:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0)) →RΩ(1)
tt'
Induction Step:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(_$n5, 1))) →RΩ(1)
s'(mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_$n5))) →IH
s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_$n5))
We have rt ∈ Ω(n) and sz ∈ O(n). Thus, we have ircR ∈ Ω(n).
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4), rt ∈ Ω(1 + n4)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__U11', a__U21', a__plus', a__U41', a__x', a__and', a__isNat'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Could not prove a rewrite lemma for the defined symbol a__U11'.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4), rt ∈ Ω(1 + n4)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__U21', a__plus', a__U41', a__x', a__and', a__isNat'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Could not prove a rewrite lemma for the defined symbol a__U21'.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4), rt ∈ Ω(1 + n4)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__plus', a__U41', a__x', a__and', a__isNat'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Could not prove a rewrite lemma for the defined symbol a__plus'.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4), rt ∈ Ω(1 + n4)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__isNat', a__U41', a__x', a__and'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Proved the following rewrite lemma:
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _n25291))) → _*3, rt ∈ Ω(n25291)
Induction Base:
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, 0)))
Induction Step:
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, +(_$n25292, 1)))) →RΩ(1)
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _$n25292))) →IH
_*3
We have rt ∈ Ω(n) and sz ∈ O(n). Thus, we have ircR ∈ Ω(n).
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4), rt ∈ Ω(1 + n4)
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _n25291))) → _*3, rt ∈ Ω(n25291)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__and', a__U11', mark', a__U21', a__plus', a__U41', a__x'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Could not prove a rewrite lemma for the defined symbol a__and'.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4), rt ∈ Ω(1 + n4)
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _n25291))) → _*3, rt ∈ Ω(n25291)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__U41', a__U11', mark', a__U21', a__plus', a__x'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Could not prove a rewrite lemma for the defined symbol a__U41'.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4), rt ∈ Ω(1 + n4)
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _n25291))) → _*3, rt ∈ Ω(n25291)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__x', a__U11', mark', a__U21', a__plus'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Could not prove a rewrite lemma for the defined symbol a__x'.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n4), rt ∈ Ω(1 + n4)
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _n25291))) → _*3, rt ∈ Ω(n25291)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
mark', a__U11', a__U21', a__plus'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Proved the following rewrite lemma:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931), rt ∈ Ω(1 + n40931)
Induction Base:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0)) →RΩ(1)
tt'
Induction Step:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(_$n40932, 1))) →RΩ(1)
s'(mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_$n40932))) →IH
s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_$n40932))
We have rt ∈ Ω(n) and sz ∈ O(n). Thus, we have ircR ∈ Ω(n).
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931), rt ∈ Ω(1 + n40931)
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _n25291))) → _*3, rt ∈ Ω(n25291)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__U11', a__U21', a__plus'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Could not prove a rewrite lemma for the defined symbol a__U11'.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931), rt ∈ Ω(1 + n40931)
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _n25291))) → _*3, rt ∈ Ω(n25291)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__U21', a__plus'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Could not prove a rewrite lemma for the defined symbol a__U21'.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931), rt ∈ Ω(1 + n40931)
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _n25291))) → _*3, rt ∈ Ω(n25291)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
The following defined symbols remain to be analysed:
a__plus'
They will be analysed ascendingly in the following order:
a__U11' = mark'
a__U11' = a__U21'
a__U11' = a__plus'
a__U11' = a__U41'
a__U11' = a__x'
a__U11' = a__and'
a__U11' = a__isNat'
mark' = a__U21'
mark' = a__plus'
mark' = a__U41'
mark' = a__x'
mark' = a__and'
mark' = a__isNat'
a__U21' = a__plus'
a__U21' = a__U41'
a__U21' = a__x'
a__U21' = a__and'
a__U21' = a__isNat'
a__plus' = a__U41'
a__plus' = a__x'
a__plus' = a__and'
a__plus' = a__isNat'
a__U41' = a__x'
a__U41' = a__and'
a__U41' = a__isNat'
a__x' = a__and'
a__x' = a__isNat'
a__and' = a__isNat'
Could not prove a rewrite lemma for the defined symbol a__plus'.
Rules:
a__U11'(tt', N) → mark'(N)
a__U21'(tt', M, N) → s'(a__plus'(mark'(N), mark'(M)))
a__U31'(tt') → 0'
a__U41'(tt', M, N) → a__plus'(a__x'(mark'(N), mark'(M)), mark'(N))
a__and'(tt', X) → mark'(X)
a__isNat'(0') → tt'
a__isNat'(plus'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__isNat'(s'(V1)) → a__isNat'(V1)
a__isNat'(x'(V1, V2)) → a__and'(a__isNat'(V1), isNat'(V2))
a__plus'(N, 0') → a__U11'(a__isNat'(N), N)
a__plus'(N, s'(M)) → a__U21'(a__and'(a__isNat'(M), isNat'(N)), M, N)
a__x'(N, 0') → a__U31'(a__isNat'(N))
a__x'(N, s'(M)) → a__U41'(a__and'(a__isNat'(M), isNat'(N)), M, N)
mark'(U11'(X1, X2)) → a__U11'(mark'(X1), X2)
mark'(U21'(X1, X2, X3)) → a__U21'(mark'(X1), X2, X3)
mark'(plus'(X1, X2)) → a__plus'(mark'(X1), mark'(X2))
mark'(U31'(X)) → a__U31'(mark'(X))
mark'(U41'(X1, X2, X3)) → a__U41'(mark'(X1), X2, X3)
mark'(x'(X1, X2)) → a__x'(mark'(X1), mark'(X2))
mark'(and'(X1, X2)) → a__and'(mark'(X1), X2)
mark'(isNat'(X)) → a__isNat'(X)
mark'(tt') → tt'
mark'(s'(X)) → s'(mark'(X))
mark'(0') → 0'
a__U11'(X1, X2) → U11'(X1, X2)
a__U21'(X1, X2, X3) → U21'(X1, X2, X3)
a__plus'(X1, X2) → plus'(X1, X2)
a__U31'(X) → U31'(X)
a__U41'(X1, X2, X3) → U41'(X1, X2, X3)
a__x'(X1, X2) → x'(X1, X2)
a__and'(X1, X2) → and'(X1, X2)
a__isNat'(X) → isNat'(X)
Types:
a__U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
tt' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
mark' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
s' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
0' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
a__isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
plus' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
isNat' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
x' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U11' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U21' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U31' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
U41' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
and' :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and' → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_hole_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'1 :: tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2 :: Nat → tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'
Lemmas:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931), rt ∈ Ω(1 + n40931)
a__isNat'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(1, _n25291))) → _*3, rt ∈ Ω(n25291)
Generator Equations:
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(0) ⇔ tt'
_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(+(x, 1)) ⇔ s'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(x))
No more defined symbols left to analyse.
The lowerbound Ω(n) was proven with the following lemma:
mark'(_gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931)) → _gen_tt':s':0':plus':isNat':x':U11':U21':U31':U41':and'2(_n40931), rt ∈ Ω(1 + n40931)