0 QTRS
↳1 Overlay + Local Confluence (⇔)
↳2 QTRS
↳3 DependencyPairsProof (⇔)
↳4 QDP
↳5 DependencyGraphProof (⇔)
↳6 AND
↳7 QDP
↳8 QDPOrderProof (⇔)
↳9 QDP
↳10 QDPOrderProof (⇔)
↳11 QDP
↳12 QDPOrderProof (⇔)
↳13 QDP
↳14 PisEmptyProof (⇔)
↳15 TRUE
↳16 QDP
↳17 QDPOrderProof (⇔)
↳18 QDP
↳19 PisEmptyProof (⇔)
↳20 TRUE
↳21 QDP
↳22 QDPOrderProof (⇔)
↳23 QDP
↳24 PisEmptyProof (⇔)
↳25 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(s(x), h, z) → A(x, z, z)
a3 > s1 > h > A1
app2 > A1
nil > A1
sum1 > h > A1
A1: [1]
s1: [1]
a3: [1,2,3]
h: []
app2: [1,2]
nil: []
sum1: [1]
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)
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))
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), h) → A(x, y, s(h))
a3 > s1 > h > A2
app2 > A2
nil > A2
sum1 > h > A2
A2: [2,1]
s1: [1]
a3: [1,2,3]
h: []
app2: [1,2]
nil: []
sum1: [1]
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)
A(x, s(y), s(z)) → A(x, s(y), 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, s(y), z)
app2 > A3
nil > A3
sum1 > h > A3
a3 > s1 > h > A3
A3: [2,3,1]
s1: [1]
app2: [1,2]
nil: []
sum1: [1]
a3: [1,2,3]
h: []
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))
SUM1 > cons1
SUM1 > h
app2 > cons1
sum1 > cons1
sum1 > h
sum1 > nil
SUM1: [1]
cons1: [1]
h: []
app2: [1,2]
nil: []
sum1: [1]
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 > APP2
nil > APP2
sum1 > cons1 > APP2
sum1 > h > APP2
APP2: [1,2]
cons1: [1]
app2: [1,2]
nil: []
sum1: [1]
h: []
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)