R
↳Dependency Pair Analysis
2ND(cons(X, XS)) -> HEAD(activate(XS))
2ND(cons(X, XS)) -> ACTIVATE(XS)
TAKE(s(N), cons(X, XS)) -> ACTIVATE(XS)
SEL(s(N), cons(X, XS)) -> SEL(N, activate(XS))
SEL(s(N), cons(X, XS)) -> ACTIVATE(XS)
ACTIVATE(nfrom(X)) -> FROM(X)
ACTIVATE(ntake(X1, X2)) -> TAKE(X1, X2)
R
↳DPs
→DP Problem 1
↳Forward Instantiation Transformation
→DP Problem 2
↳Nar
TAKE(s(N), cons(X, XS)) -> ACTIVATE(XS)
ACTIVATE(ntake(X1, X2)) -> TAKE(X1, X2)
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
one new Dependency Pair is created:
TAKE(s(N), cons(X, XS)) -> ACTIVATE(XS)
TAKE(s(N), cons(X, ntake(X1'', X2''))) -> ACTIVATE(ntake(X1'', X2''))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 3
↳Forward Instantiation Transformation
→DP Problem 2
↳Nar
TAKE(s(N), cons(X, ntake(X1'', X2''))) -> ACTIVATE(ntake(X1'', X2''))
ACTIVATE(ntake(X1, X2)) -> TAKE(X1, X2)
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
one new Dependency Pair is created:
ACTIVATE(ntake(X1, X2)) -> TAKE(X1, X2)
ACTIVATE(ntake(s(N''), cons(X'', ntake(X1'''', X2'''')))) -> TAKE(s(N''), cons(X'', ntake(X1'''', X2'''')))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 3
↳FwdInst
...
→DP Problem 4
↳Forward Instantiation Transformation
→DP Problem 2
↳Nar
ACTIVATE(ntake(s(N''), cons(X'', ntake(X1'''', X2'''')))) -> TAKE(s(N''), cons(X'', ntake(X1'''', X2'''')))
TAKE(s(N), cons(X, ntake(X1'', X2''))) -> ACTIVATE(ntake(X1'', X2''))
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
one new Dependency Pair is created:
TAKE(s(N), cons(X, ntake(X1'', X2''))) -> ACTIVATE(ntake(X1'', X2''))
TAKE(s(N), cons(X, ntake(s(N''''), cons(X'''', ntake(X1'''''', X2''''''))))) -> ACTIVATE(ntake(s(N''''), cons(X'''', ntake(X1'''''', X2''''''))))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 3
↳FwdInst
...
→DP Problem 5
↳Forward Instantiation Transformation
→DP Problem 2
↳Nar
TAKE(s(N), cons(X, ntake(s(N''''), cons(X'''', ntake(X1'''''', X2''''''))))) -> ACTIVATE(ntake(s(N''''), cons(X'''', ntake(X1'''''', X2''''''))))
ACTIVATE(ntake(s(N''), cons(X'', ntake(X1'''', X2'''')))) -> TAKE(s(N''), cons(X'', ntake(X1'''', X2'''')))
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
one new Dependency Pair is created:
ACTIVATE(ntake(s(N''), cons(X'', ntake(X1'''', X2'''')))) -> TAKE(s(N''), cons(X'', ntake(X1'''', X2'''')))
ACTIVATE(ntake(s(N'''), cons(X''', ntake(s(N''''''), cons(X'''''', ntake(X1'''''''', X2'''''''')))))) -> TAKE(s(N'''), cons(X''', ntake(s(N''''''), cons(X'''''', ntake(X1'''''''', X2'''''''')))))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 3
↳FwdInst
...
→DP Problem 6
↳Argument Filtering and Ordering
→DP Problem 2
↳Nar
ACTIVATE(ntake(s(N'''), cons(X''', ntake(s(N''''''), cons(X'''''', ntake(X1'''''''', X2'''''''')))))) -> TAKE(s(N'''), cons(X''', ntake(s(N''''''), cons(X'''''', ntake(X1'''''''', X2'''''''')))))
TAKE(s(N), cons(X, ntake(s(N''''), cons(X'''', ntake(X1'''''', X2''''''))))) -> ACTIVATE(ntake(s(N''''), cons(X'''', ntake(X1'''''', X2''''''))))
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
ACTIVATE(ntake(s(N'''), cons(X''', ntake(s(N''''''), cons(X'''''', ntake(X1'''''''', X2'''''''')))))) -> TAKE(s(N'''), cons(X''', ntake(s(N''''''), cons(X'''''', ntake(X1'''''''', X2'''''''')))))
TAKE(s(N), cons(X, ntake(s(N''''), cons(X'''', ntake(X1'''''', X2''''''))))) -> ACTIVATE(ntake(s(N''''), cons(X'''', ntake(X1'''''', X2''''''))))
cons > ACTIVATE
ntake > TAKE
TAKE(x1, x2) -> TAKE(x1, x2)
ACTIVATE(x1) -> ACTIVATE(x1)
s(x1) -> s(x1)
cons(x1, x2) -> cons(x1, x2)
ntake(x1, x2) -> ntake(x1, x2)
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 3
↳FwdInst
...
→DP Problem 7
↳Dependency Graph
→DP Problem 2
↳Nar
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Narrowing Transformation
SEL(s(N), cons(X, XS)) -> SEL(N, activate(XS))
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
three new Dependency Pairs are created:
SEL(s(N), cons(X, XS)) -> SEL(N, activate(XS))
SEL(s(N), cons(X, nfrom(X''))) -> SEL(N, from(X''))
SEL(s(N), cons(X, ntake(X1', X2'))) -> SEL(N, take(X1', X2'))
SEL(s(N), cons(X, XS')) -> SEL(N, XS')
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 8
↳Narrowing Transformation
SEL(s(N), cons(X, XS')) -> SEL(N, XS')
SEL(s(N), cons(X, ntake(X1', X2'))) -> SEL(N, take(X1', X2'))
SEL(s(N), cons(X, nfrom(X''))) -> SEL(N, from(X''))
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
two new Dependency Pairs are created:
SEL(s(N), cons(X, nfrom(X''))) -> SEL(N, from(X''))
SEL(s(N), cons(X, nfrom(X'''))) -> SEL(N, cons(X''', nfrom(s(X'''))))
SEL(s(N), cons(X, nfrom(X'''))) -> SEL(N, nfrom(X'''))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 8
↳Nar
...
→DP Problem 9
↳Narrowing Transformation
SEL(s(N), cons(X, nfrom(X'''))) -> SEL(N, cons(X''', nfrom(s(X'''))))
SEL(s(N), cons(X, ntake(X1', X2'))) -> SEL(N, take(X1', X2'))
SEL(s(N), cons(X, XS')) -> SEL(N, XS')
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
three new Dependency Pairs are created:
SEL(s(N), cons(X, ntake(X1', X2'))) -> SEL(N, take(X1', X2'))
SEL(s(N), cons(X, ntake(0, X2''))) -> SEL(N, nil)
SEL(s(N), cons(X, ntake(s(N''), cons(X'', XS')))) -> SEL(N, cons(X'', ntake(N'', activate(XS'))))
SEL(s(N), cons(X, ntake(X1'', X2''))) -> SEL(N, ntake(X1'', X2''))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 8
↳Nar
...
→DP Problem 10
↳Forward Instantiation Transformation
SEL(s(N), cons(X, ntake(s(N''), cons(X'', XS')))) -> SEL(N, cons(X'', ntake(N'', activate(XS'))))
SEL(s(N), cons(X, XS')) -> SEL(N, XS')
SEL(s(N), cons(X, nfrom(X'''))) -> SEL(N, cons(X''', nfrom(s(X'''))))
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
three new Dependency Pairs are created:
SEL(s(N), cons(X, XS')) -> SEL(N, XS')
SEL(s(s(N'')), cons(X, cons(X'', XS'''))) -> SEL(s(N''), cons(X'', XS'''))
SEL(s(s(N'')), cons(X, cons(X'', nfrom(X''''')))) -> SEL(s(N''), cons(X'', nfrom(X''''')))
SEL(s(s(N'')), cons(X, cons(X'', ntake(s(N''''), cons(X'''', XS'''))))) -> SEL(s(N''), cons(X'', ntake(s(N''''), cons(X'''', XS'''))))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 8
↳Nar
...
→DP Problem 11
↳Argument Filtering and Ordering
SEL(s(N), cons(X, ntake(s(N''), cons(X'', XS')))) -> SEL(N, cons(X'', ntake(N'', activate(XS'))))
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
SEL(s(N), cons(X, ntake(s(N''), cons(X'', XS')))) -> SEL(N, cons(X'', ntake(N'', activate(XS'))))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
{ntake, take} > {activate, from} > nfrom
{ntake, take} > {activate, from} > cons
{ntake, take} > {activate, from} > s
0 > nil
SEL(x1, x2) -> SEL(x1, x2)
s(x1) -> s(x1)
cons(x1, x2) -> cons(x1, x2)
ntake(x1, x2) -> ntake(x1, x2)
activate(x1) -> activate(x1)
nfrom(x1) -> nfrom(x1)
from(x1) -> from(x1)
take(x1, x2) -> take(x1, x2)
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 8
↳Nar
...
→DP Problem 14
↳Dependency Graph
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 8
↳Nar
...
→DP Problem 12
↳Argument Filtering and Ordering
SEL(s(N), cons(X, nfrom(X'''))) -> SEL(N, cons(X''', nfrom(s(X'''))))
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
SEL(s(N), cons(X, nfrom(X'''))) -> SEL(N, cons(X''', nfrom(s(X'''))))
SEL > nfrom
SEL > cons
SEL > s
SEL(x1, x2) -> SEL(x1, x2)
s(x1) -> s(x1)
cons(x1, x2) -> cons(x1, x2)
nfrom(x1) -> nfrom(x1)
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 8
↳Nar
...
→DP Problem 13
↳Argument Filtering and Ordering
SEL(s(s(N'')), cons(X, cons(X'', XS'''))) -> SEL(s(N''), cons(X'', XS'''))
from(X) -> cons(X, nfrom(s(X)))
from(X) -> nfrom(X)
head(cons(X, XS)) -> X
2nd(cons(X, XS)) -> head(activate(XS))
take(0, XS) -> nil
take(s(N), cons(X, XS)) -> cons(X, ntake(N, activate(XS)))
take(X1, X2) -> ntake(X1, X2)
sel(0, cons(X, XS)) -> X
sel(s(N), cons(X, XS)) -> sel(N, activate(XS))
activate(nfrom(X)) -> from(X)
activate(ntake(X1, X2)) -> take(X1, X2)
activate(X) -> X
innermost
SEL(s(s(N'')), cons(X, cons(X'', XS'''))) -> SEL(s(N''), cons(X'', XS'''))
trivial
SEL(x1, x2) -> SEL(x1, x2)
s(x1) -> s(x1)
cons(x1, x2) -> cons(x1, x2)