Runtime Complexity TRS:
The TRS R consists of the following rules:
from(X) → cons(X, n__from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, activate(XS))
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), n__zWquot(activate(XS), activate(YS)))
from(X) → n__from(X)
zWquot(X1, X2) → n__zWquot(X1, X2)
activate(n__from(X)) → from(X)
activate(n__zWquot(X1, X2)) → zWquot(X1, X2)
activate(X) → X
Renamed function symbols to avoid clashes with predefined symbol.
Runtime Complexity TRS:
The TRS R consists of the following rules:
from'(X) → cons'(X, n__from'(s'(X)))
sel'(0', cons'(X, XS)) → X
sel'(s'(N), cons'(X, XS)) → sel'(N, activate'(XS))
minus'(X, 0') → 0'
minus'(s'(X), s'(Y)) → minus'(X, Y)
quot'(0', s'(Y)) → 0'
quot'(s'(X), s'(Y)) → s'(quot'(minus'(X, Y), s'(Y)))
zWquot'(XS, nil') → nil'
zWquot'(nil', XS) → nil'
zWquot'(cons'(X, XS), cons'(Y, YS)) → cons'(quot'(X, Y), n__zWquot'(activate'(XS), activate'(YS)))
from'(X) → n__from'(X)
zWquot'(X1, X2) → n__zWquot'(X1, X2)
activate'(n__from'(X)) → from'(X)
activate'(n__zWquot'(X1, X2)) → zWquot'(X1, X2)
activate'(X) → X
Infered types.
Rules:
from'(X) → cons'(X, n__from'(s'(X)))
sel'(0', cons'(X, XS)) → X
sel'(s'(N), cons'(X, XS)) → sel'(N, activate'(XS))
minus'(X, 0') → 0'
minus'(s'(X), s'(Y)) → minus'(X, Y)
quot'(0', s'(Y)) → 0'
quot'(s'(X), s'(Y)) → s'(quot'(minus'(X, Y), s'(Y)))
zWquot'(XS, nil') → nil'
zWquot'(nil', XS) → nil'
zWquot'(cons'(X, XS), cons'(Y, YS)) → cons'(quot'(X, Y), n__zWquot'(activate'(XS), activate'(YS)))
from'(X) → n__from'(X)
zWquot'(X1, X2) → n__zWquot'(X1, X2)
activate'(n__from'(X)) → from'(X)
activate'(n__zWquot'(X1, X2)) → zWquot'(X1, X2)
activate'(X) → X
Types:
from' :: s':0' → n__from':cons':nil':n__zWquot'
cons' :: s':0' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
n__from' :: s':0' → n__from':cons':nil':n__zWquot'
s' :: s':0' → s':0'
sel' :: s':0' → n__from':cons':nil':n__zWquot' → s':0'
0' :: s':0'
activate' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
minus' :: s':0' → s':0' → s':0'
quot' :: s':0' → s':0' → s':0'
zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
nil' :: n__from':cons':nil':n__zWquot'
n__zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
_hole_n__from':cons':nil':n__zWquot'1 :: n__from':cons':nil':n__zWquot'
_hole_s':0'2 :: s':0'
_gen_n__from':cons':nil':n__zWquot'3 :: Nat → n__from':cons':nil':n__zWquot'
_gen_s':0'4 :: Nat → s':0'
Heuristically decided to analyse the following defined symbols:
sel', activate', minus', quot'
They will be analysed ascendingly in the following order:
activate' < sel'
quot' < activate'
minus' < quot'
Rules:
from'(X) → cons'(X, n__from'(s'(X)))
sel'(0', cons'(X, XS)) → X
sel'(s'(N), cons'(X, XS)) → sel'(N, activate'(XS))
minus'(X, 0') → 0'
minus'(s'(X), s'(Y)) → minus'(X, Y)
quot'(0', s'(Y)) → 0'
quot'(s'(X), s'(Y)) → s'(quot'(minus'(X, Y), s'(Y)))
zWquot'(XS, nil') → nil'
zWquot'(nil', XS) → nil'
zWquot'(cons'(X, XS), cons'(Y, YS)) → cons'(quot'(X, Y), n__zWquot'(activate'(XS), activate'(YS)))
from'(X) → n__from'(X)
zWquot'(X1, X2) → n__zWquot'(X1, X2)
activate'(n__from'(X)) → from'(X)
activate'(n__zWquot'(X1, X2)) → zWquot'(X1, X2)
activate'(X) → X
Types:
from' :: s':0' → n__from':cons':nil':n__zWquot'
cons' :: s':0' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
n__from' :: s':0' → n__from':cons':nil':n__zWquot'
s' :: s':0' → s':0'
sel' :: s':0' → n__from':cons':nil':n__zWquot' → s':0'
0' :: s':0'
activate' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
minus' :: s':0' → s':0' → s':0'
quot' :: s':0' → s':0' → s':0'
zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
nil' :: n__from':cons':nil':n__zWquot'
n__zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
_hole_n__from':cons':nil':n__zWquot'1 :: n__from':cons':nil':n__zWquot'
_hole_s':0'2 :: s':0'
_gen_n__from':cons':nil':n__zWquot'3 :: Nat → n__from':cons':nil':n__zWquot'
_gen_s':0'4 :: Nat → s':0'
Generator Equations:
_gen_n__from':cons':nil':n__zWquot'3(0) ⇔ n__from'(0')
_gen_n__from':cons':nil':n__zWquot'3(+(x, 1)) ⇔ cons'(0', _gen_n__from':cons':nil':n__zWquot'3(x))
_gen_s':0'4(0) ⇔ 0'
_gen_s':0'4(+(x, 1)) ⇔ s'(_gen_s':0'4(x))
The following defined symbols remain to be analysed:
minus', sel', activate', quot'
They will be analysed ascendingly in the following order:
activate' < sel'
quot' < activate'
minus' < quot'
Proved the following rewrite lemma:
minus'(_gen_s':0'4(_n6), _gen_s':0'4(_n6)) → _gen_s':0'4(0), rt ∈ Ω(1 + n6)
Induction Base:
minus'(_gen_s':0'4(0), _gen_s':0'4(0)) →RΩ(1)
0'
Induction Step:
minus'(_gen_s':0'4(+(_$n7, 1)), _gen_s':0'4(+(_$n7, 1))) →RΩ(1)
minus'(_gen_s':0'4(_$n7), _gen_s':0'4(_$n7)) →IH
_gen_s':0'4(0)
We have rt ∈ Ω(n) and sz ∈ O(n). Thus, we have ircR ∈ Ω(n).
Rules:
from'(X) → cons'(X, n__from'(s'(X)))
sel'(0', cons'(X, XS)) → X
sel'(s'(N), cons'(X, XS)) → sel'(N, activate'(XS))
minus'(X, 0') → 0'
minus'(s'(X), s'(Y)) → minus'(X, Y)
quot'(0', s'(Y)) → 0'
quot'(s'(X), s'(Y)) → s'(quot'(minus'(X, Y), s'(Y)))
zWquot'(XS, nil') → nil'
zWquot'(nil', XS) → nil'
zWquot'(cons'(X, XS), cons'(Y, YS)) → cons'(quot'(X, Y), n__zWquot'(activate'(XS), activate'(YS)))
from'(X) → n__from'(X)
zWquot'(X1, X2) → n__zWquot'(X1, X2)
activate'(n__from'(X)) → from'(X)
activate'(n__zWquot'(X1, X2)) → zWquot'(X1, X2)
activate'(X) → X
Types:
from' :: s':0' → n__from':cons':nil':n__zWquot'
cons' :: s':0' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
n__from' :: s':0' → n__from':cons':nil':n__zWquot'
s' :: s':0' → s':0'
sel' :: s':0' → n__from':cons':nil':n__zWquot' → s':0'
0' :: s':0'
activate' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
minus' :: s':0' → s':0' → s':0'
quot' :: s':0' → s':0' → s':0'
zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
nil' :: n__from':cons':nil':n__zWquot'
n__zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
_hole_n__from':cons':nil':n__zWquot'1 :: n__from':cons':nil':n__zWquot'
_hole_s':0'2 :: s':0'
_gen_n__from':cons':nil':n__zWquot'3 :: Nat → n__from':cons':nil':n__zWquot'
_gen_s':0'4 :: Nat → s':0'
Lemmas:
minus'(_gen_s':0'4(_n6), _gen_s':0'4(_n6)) → _gen_s':0'4(0), rt ∈ Ω(1 + n6)
Generator Equations:
_gen_n__from':cons':nil':n__zWquot'3(0) ⇔ n__from'(0')
_gen_n__from':cons':nil':n__zWquot'3(+(x, 1)) ⇔ cons'(0', _gen_n__from':cons':nil':n__zWquot'3(x))
_gen_s':0'4(0) ⇔ 0'
_gen_s':0'4(+(x, 1)) ⇔ s'(_gen_s':0'4(x))
The following defined symbols remain to be analysed:
quot', sel', activate'
They will be analysed ascendingly in the following order:
activate' < sel'
quot' < activate'
Could not prove a rewrite lemma for the defined symbol quot'.
Rules:
from'(X) → cons'(X, n__from'(s'(X)))
sel'(0', cons'(X, XS)) → X
sel'(s'(N), cons'(X, XS)) → sel'(N, activate'(XS))
minus'(X, 0') → 0'
minus'(s'(X), s'(Y)) → minus'(X, Y)
quot'(0', s'(Y)) → 0'
quot'(s'(X), s'(Y)) → s'(quot'(minus'(X, Y), s'(Y)))
zWquot'(XS, nil') → nil'
zWquot'(nil', XS) → nil'
zWquot'(cons'(X, XS), cons'(Y, YS)) → cons'(quot'(X, Y), n__zWquot'(activate'(XS), activate'(YS)))
from'(X) → n__from'(X)
zWquot'(X1, X2) → n__zWquot'(X1, X2)
activate'(n__from'(X)) → from'(X)
activate'(n__zWquot'(X1, X2)) → zWquot'(X1, X2)
activate'(X) → X
Types:
from' :: s':0' → n__from':cons':nil':n__zWquot'
cons' :: s':0' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
n__from' :: s':0' → n__from':cons':nil':n__zWquot'
s' :: s':0' → s':0'
sel' :: s':0' → n__from':cons':nil':n__zWquot' → s':0'
0' :: s':0'
activate' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
minus' :: s':0' → s':0' → s':0'
quot' :: s':0' → s':0' → s':0'
zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
nil' :: n__from':cons':nil':n__zWquot'
n__zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
_hole_n__from':cons':nil':n__zWquot'1 :: n__from':cons':nil':n__zWquot'
_hole_s':0'2 :: s':0'
_gen_n__from':cons':nil':n__zWquot'3 :: Nat → n__from':cons':nil':n__zWquot'
_gen_s':0'4 :: Nat → s':0'
Lemmas:
minus'(_gen_s':0'4(_n6), _gen_s':0'4(_n6)) → _gen_s':0'4(0), rt ∈ Ω(1 + n6)
Generator Equations:
_gen_n__from':cons':nil':n__zWquot'3(0) ⇔ n__from'(0')
_gen_n__from':cons':nil':n__zWquot'3(+(x, 1)) ⇔ cons'(0', _gen_n__from':cons':nil':n__zWquot'3(x))
_gen_s':0'4(0) ⇔ 0'
_gen_s':0'4(+(x, 1)) ⇔ s'(_gen_s':0'4(x))
The following defined symbols remain to be analysed:
activate', sel'
They will be analysed ascendingly in the following order:
activate' < sel'
Could not prove a rewrite lemma for the defined symbol activate'.
Rules:
from'(X) → cons'(X, n__from'(s'(X)))
sel'(0', cons'(X, XS)) → X
sel'(s'(N), cons'(X, XS)) → sel'(N, activate'(XS))
minus'(X, 0') → 0'
minus'(s'(X), s'(Y)) → minus'(X, Y)
quot'(0', s'(Y)) → 0'
quot'(s'(X), s'(Y)) → s'(quot'(minus'(X, Y), s'(Y)))
zWquot'(XS, nil') → nil'
zWquot'(nil', XS) → nil'
zWquot'(cons'(X, XS), cons'(Y, YS)) → cons'(quot'(X, Y), n__zWquot'(activate'(XS), activate'(YS)))
from'(X) → n__from'(X)
zWquot'(X1, X2) → n__zWquot'(X1, X2)
activate'(n__from'(X)) → from'(X)
activate'(n__zWquot'(X1, X2)) → zWquot'(X1, X2)
activate'(X) → X
Types:
from' :: s':0' → n__from':cons':nil':n__zWquot'
cons' :: s':0' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
n__from' :: s':0' → n__from':cons':nil':n__zWquot'
s' :: s':0' → s':0'
sel' :: s':0' → n__from':cons':nil':n__zWquot' → s':0'
0' :: s':0'
activate' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
minus' :: s':0' → s':0' → s':0'
quot' :: s':0' → s':0' → s':0'
zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
nil' :: n__from':cons':nil':n__zWquot'
n__zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
_hole_n__from':cons':nil':n__zWquot'1 :: n__from':cons':nil':n__zWquot'
_hole_s':0'2 :: s':0'
_gen_n__from':cons':nil':n__zWquot'3 :: Nat → n__from':cons':nil':n__zWquot'
_gen_s':0'4 :: Nat → s':0'
Lemmas:
minus'(_gen_s':0'4(_n6), _gen_s':0'4(_n6)) → _gen_s':0'4(0), rt ∈ Ω(1 + n6)
Generator Equations:
_gen_n__from':cons':nil':n__zWquot'3(0) ⇔ n__from'(0')
_gen_n__from':cons':nil':n__zWquot'3(+(x, 1)) ⇔ cons'(0', _gen_n__from':cons':nil':n__zWquot'3(x))
_gen_s':0'4(0) ⇔ 0'
_gen_s':0'4(+(x, 1)) ⇔ s'(_gen_s':0'4(x))
The following defined symbols remain to be analysed:
sel'
Could not prove a rewrite lemma for the defined symbol sel'.
The following conjecture could not be proven:
sel'(_gen_s':0'4(_n1080), _gen_n__from':cons':nil':n__zWquot'3(1)) →? _*5
Rules:
from'(X) → cons'(X, n__from'(s'(X)))
sel'(0', cons'(X, XS)) → X
sel'(s'(N), cons'(X, XS)) → sel'(N, activate'(XS))
minus'(X, 0') → 0'
minus'(s'(X), s'(Y)) → minus'(X, Y)
quot'(0', s'(Y)) → 0'
quot'(s'(X), s'(Y)) → s'(quot'(minus'(X, Y), s'(Y)))
zWquot'(XS, nil') → nil'
zWquot'(nil', XS) → nil'
zWquot'(cons'(X, XS), cons'(Y, YS)) → cons'(quot'(X, Y), n__zWquot'(activate'(XS), activate'(YS)))
from'(X) → n__from'(X)
zWquot'(X1, X2) → n__zWquot'(X1, X2)
activate'(n__from'(X)) → from'(X)
activate'(n__zWquot'(X1, X2)) → zWquot'(X1, X2)
activate'(X) → X
Types:
from' :: s':0' → n__from':cons':nil':n__zWquot'
cons' :: s':0' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
n__from' :: s':0' → n__from':cons':nil':n__zWquot'
s' :: s':0' → s':0'
sel' :: s':0' → n__from':cons':nil':n__zWquot' → s':0'
0' :: s':0'
activate' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
minus' :: s':0' → s':0' → s':0'
quot' :: s':0' → s':0' → s':0'
zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
nil' :: n__from':cons':nil':n__zWquot'
n__zWquot' :: n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot' → n__from':cons':nil':n__zWquot'
_hole_n__from':cons':nil':n__zWquot'1 :: n__from':cons':nil':n__zWquot'
_hole_s':0'2 :: s':0'
_gen_n__from':cons':nil':n__zWquot'3 :: Nat → n__from':cons':nil':n__zWquot'
_gen_s':0'4 :: Nat → s':0'
Lemmas:
minus'(_gen_s':0'4(_n6), _gen_s':0'4(_n6)) → _gen_s':0'4(0), rt ∈ Ω(1 + n6)
Generator Equations:
_gen_n__from':cons':nil':n__zWquot'3(0) ⇔ n__from'(0')
_gen_n__from':cons':nil':n__zWquot'3(+(x, 1)) ⇔ cons'(0', _gen_n__from':cons':nil':n__zWquot'3(x))
_gen_s':0'4(0) ⇔ 0'
_gen_s':0'4(+(x, 1)) ⇔ s'(_gen_s':0'4(x))
No more defined symbols left to analyse.
The lowerbound Ω(n) was proven with the following lemma:
minus'(_gen_s':0'4(_n6), _gen_s':0'4(_n6)) → _gen_s':0'4(0), rt ∈ Ω(1 + n6)