0 QTRS
↳1 Overlay + Local Confluence (⇔)
↳2 QTRS
↳3 DependencyPairsProof (⇔)
↳4 QDP
↳5 DependencyGraphProof (⇔)
↳6 AND
↳7 QDP
↳8 QDPOrderProof (⇔)
↳9 QDP
↳10 PisEmptyProof (⇔)
↳11 TRUE
↳12 QDP
↳13 QDPOrderProof (⇔)
↳14 QDP
↳15 PisEmptyProof (⇔)
↳16 TRUE
↳17 QDP
↳18 QDPOrderProof (⇔)
↳19 QDP
↳20 PisEmptyProof (⇔)
↳21 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)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
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)
A3 > a3 > s1 > h
app2 > cons1 > h
sum1 > nil > h
sum1 > cons1 > h
cons1: [1]
a3: [1,2,3]
sum1: [1]
A3: [1,2,3]
app2: [1,2]
s1: [1]
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)
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))
app2 > cons2 > h
nil > h
cons2: [1,2]
app2: [1,2]
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)
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 > cons1 > h > nil
sum > cons1 > h > nil
sum > a3 > s1 > h > nil
cons1: [1]
a3: [1,2,3]
s1: [1]
app2: [2,1]
h: []
sum: []
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)