0 QTRS
↳1 Overlay + Local Confluence (⇔)
↳2 QTRS
↳3 DependencyPairsProof (⇔)
↳4 QDP
↳5 DependencyGraphProof (⇔)
↳6 AND
↳7 QDP
↳8 QDP
↳9 QDPOrderProof (⇔)
↳10 QDP
↳11 PisEmptyProof (⇔)
↳12 TRUE
↳13 QDP
↳14 QDPOrderProof (⇔)
↳15 QDP
↳16 PisEmptyProof (⇔)
↳17 TRUE
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, x0)
app(x0, nil)
app(cons(x0, x1), x2)
sum(cons(x0, nil))
sum(cons(x0, cons(x1, x2)))
a(h, h, x0)
a(x0, s(x1), h)
a(x0, s(x1), s(x2))
a(s(x0), h, x1)
APP(cons(x, l), k) → APP(l, k)
SUM(cons(x, cons(y, l))) → SUM(cons(a(x, y, h), l))
SUM(cons(x, cons(y, l))) → A(x, y, h)
A(x, s(y), h) → A(x, y, s(h))
A(x, s(y), s(z)) → A(x, y, a(x, s(y), z))
A(x, s(y), s(z)) → A(x, s(y), z)
A(s(x), h, z) → A(x, z, z)
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, x0)
app(x0, nil)
app(cons(x0, x1), x2)
sum(cons(x0, nil))
sum(cons(x0, cons(x1, x2)))
a(h, h, x0)
a(x0, s(x1), h)
a(x0, s(x1), s(x2))
a(s(x0), h, x1)
A(x, s(y), s(z)) → A(x, y, a(x, s(y), z))
A(x, s(y), s(z)) → A(x, s(y), z)
A(x, s(y), h) → A(x, y, s(h))
A(s(x), h, z) → A(x, z, z)
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, x0)
app(x0, nil)
app(cons(x0, x1), x2)
sum(cons(x0, nil))
sum(cons(x0, cons(x1, x2)))
a(h, h, x0)
a(x0, s(x1), h)
a(x0, s(x1), s(x2))
a(s(x0), h, x1)
SUM(cons(x, cons(y, l))) → SUM(cons(a(x, y, h), l))
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, x0)
app(x0, nil)
app(cons(x0, x1), x2)
sum(cons(x0, nil))
sum(cons(x0, cons(x1, x2)))
a(h, h, x0)
a(x0, s(x1), h)
a(x0, s(x1), s(x2))
a(s(x0), h, x1)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
SUM(cons(x, cons(y, l))) → SUM(cons(a(x, y, h), l))
h > [cons2, a, s]
app2 > [cons2, a, s]
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, x0)
app(x0, nil)
app(cons(x0, x1), x2)
sum(cons(x0, nil))
sum(cons(x0, cons(x1, x2)))
a(h, h, x0)
a(x0, s(x1), h)
a(x0, s(x1), s(x2))
a(s(x0), h, x1)
APP(cons(x, l), k) → APP(l, k)
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, x0)
app(x0, nil)
app(cons(x0, x1), x2)
sum(cons(x0, nil))
sum(cons(x0, cons(x1, x2)))
a(h, h, x0)
a(x0, s(x1), h)
a(x0, s(x1), s(x2))
a(s(x0), h, x1)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(cons(x, l), k) → APP(l, k)
app2 > [cons2, sum1] > h > nil
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, k) → k
app(l, nil) → l
app(cons(x, l), k) → cons(x, app(l, k))
sum(cons(x, nil)) → cons(x, nil)
sum(cons(x, cons(y, l))) → sum(cons(a(x, y, h), l))
a(h, h, x) → s(x)
a(x, s(y), h) → a(x, y, s(h))
a(x, s(y), s(z)) → a(x, y, a(x, s(y), z))
a(s(x), h, z) → a(x, z, z)
app(nil, x0)
app(x0, nil)
app(cons(x0, x1), x2)
sum(cons(x0, nil))
sum(cons(x0, cons(x1, x2)))
a(h, h, x0)
a(x0, s(x1), h)
a(x0, s(x1), s(x2))
a(s(x0), h, x1)