app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
↳ QTRS
↳ Overlay + Local Confluence
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
PREFIX(L) → ZWADR(L, prefix(L))
ZWADR(cons(X, XS), cons(Y, YS)) → ZWADR(XS, YS)
ZWADR(cons(X, XS), cons(Y, YS)) → APP(Y, cons(X, nil))
PREFIX(L) → PREFIX(L)
APP(cons(X, XS), YS) → APP(XS, YS)
FROM(X) → FROM(s(X))
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
PREFIX(L) → ZWADR(L, prefix(L))
ZWADR(cons(X, XS), cons(Y, YS)) → ZWADR(XS, YS)
ZWADR(cons(X, XS), cons(Y, YS)) → APP(Y, cons(X, nil))
PREFIX(L) → PREFIX(L)
APP(cons(X, XS), YS) → APP(XS, YS)
FROM(X) → FROM(s(X))
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
↳ QDP
FROM(X) → FROM(s(X))
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
↳ QDP
FROM(X) → FROM(s(X))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ QDP
↳ QDP
FROM(X) → FROM(s(X))
FROM(s(z0)) → FROM(s(s(z0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ QDP
↳ QDP
FROM(s(z0)) → FROM(s(s(z0)))
FROM(s(s(z0))) → FROM(s(s(s(z0))))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ NonTerminationProof
↳ QDP
↳ QDP
↳ QDP
FROM(s(s(z0))) → FROM(s(s(s(z0))))
FROM(s(s(z0))) → FROM(s(s(s(z0))))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
APP(cons(X, XS), YS) → APP(XS, YS)
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
APP(cons(X, XS), YS) → APP(XS, YS)
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
↳ QDP
APP(cons(X, XS), YS) → APP(XS, YS)
From the DPs we obtained the following set of size-change graphs:
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
ZWADR(cons(X, XS), cons(Y, YS)) → ZWADR(XS, YS)
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
ZWADR(cons(X, XS), cons(Y, YS)) → ZWADR(XS, YS)
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
ZWADR(cons(X, XS), cons(Y, YS)) → ZWADR(XS, YS)
From the DPs we obtained the following set of size-change graphs:
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
PREFIX(L) → PREFIX(L)
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
PREFIX(L) → PREFIX(L)
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ NonTerminationProof
PREFIX(L) → PREFIX(L)
PREFIX(L) → PREFIX(L)