0 QTRS
↳1 DependencyPairsProof (⇔)
↳2 QDP
↳3 DependencyGraphProof (⇔)
↳4 AND
↳5 QDP
↳6 QDPOrderProof (⇔)
↳7 QDP
↳8 PisEmptyProof (⇔)
↳9 TRUE
↳10 QDP
↳11 QDPOrderProof (⇔)
↳12 QDP
↳13 PisEmptyProof (⇔)
↳14 TRUE
↳15 QDP
↳16 QDPOrderProof (⇔)
↳17 QDP
↳18 PisEmptyProof (⇔)
↳19 TRUE
↳20 QDP
↳21 QDPOrderProof (⇔)
↳22 QDP
↳23 PisEmptyProof (⇔)
↳24 TRUE
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
APP(app(map, f), app(app(cons, x), xs)) → APP(app(cons, app(f, x)), app(app(map, f), xs))
APP(app(map, f), app(app(cons, x), xs)) → APP(cons, app(f, x))
APP(app(map, f), app(app(cons, x), xs)) → APP(f, x)
APP(app(map, f), app(app(cons, x), xs)) → APP(app(map, f), xs)
APP(app(append, app(app(cons, x), xs)), ys) → APP(app(cons, x), app(app(append, xs), ys))
APP(app(append, app(app(cons, x), xs)), ys) → APP(app(append, xs), ys)
APP(app(append, app(app(cons, x), xs)), ys) → APP(append, xs)
APP(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → APP(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
APP(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → APP(cons, app(app(append, xs), ys))
APP(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → APP(app(append, xs), ys)
APP(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → APP(append, xs)
APP(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → APP(app(zip, xss), yss)
APP(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → APP(zip, xss)
APP(app(combine, xs), app(app(cons, ys), yss)) → APP(app(combine, app(app(zip, xs), ys)), yss)
APP(app(combine, xs), app(app(cons, ys), yss)) → APP(combine, app(app(zip, xs), ys))
APP(app(combine, xs), app(app(cons, ys), yss)) → APP(app(zip, xs), ys)
APP(app(combine, xs), app(app(cons, ys), yss)) → APP(zip, xs)
APP(levels, app(app(node, x), xs)) → APP(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
APP(levels, app(app(node, x), xs)) → APP(cons, app(app(cons, x), nil))
APP(levels, app(app(node, x), xs)) → APP(app(cons, x), nil)
APP(levels, app(app(node, x), xs)) → APP(cons, x)
APP(levels, app(app(node, x), xs)) → APP(app(combine, nil), app(app(map, levels), xs))
APP(levels, app(app(node, x), xs)) → APP(combine, nil)
APP(levels, app(app(node, x), xs)) → APP(app(map, levels), xs)
APP(levels, app(app(node, x), xs)) → APP(map, levels)
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
APP(app(append, app(app(cons, x), xs)), ys) → APP(app(append, xs), ys)
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(app(append, app(app(cons, x), xs)), ys) → APP(app(append, xs), ys)
append > app2
cons > app2
app2: [2,1]
append: []
cons: []
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
APP(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → APP(app(zip, xss), yss)
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → APP(app(zip, xss), yss)
zip > [APP2, app2]
cons > [APP2, app2]
APP2: [1,2]
app2: [1,2]
zip: []
cons: []
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
APP(app(combine, xs), app(app(cons, ys), yss)) → APP(app(combine, app(app(zip, xs), ys)), yss)
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(app(combine, xs), app(app(cons, ys), yss)) → APP(app(combine, app(app(zip, xs), ys)), yss)
[combine, zip] > [cons, append] > app2
app2: [1,2]
combine: []
cons: []
zip: []
nil: []
append: []
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
APP(app(map, f), app(app(cons, x), xs)) → APP(app(map, f), xs)
APP(app(map, f), app(app(cons, x), xs)) → APP(f, x)
APP(levels, app(app(node, x), xs)) → APP(app(map, levels), xs)
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(app(map, f), app(app(cons, x), xs)) → APP(app(map, f), xs)
APP(app(map, f), app(app(cons, x), xs)) → APP(f, x)
APP(levels, app(app(node, x), xs)) → APP(app(map, levels), xs)
app2 > [APP2, cons] > [map, levels, node]
APP2: [1,2]
app2: [1,2]
map: []
cons: []
levels: []
node: []
app(app(map, f), nil) → nil
app(app(map, f), app(app(cons, x), xs)) → app(app(cons, app(f, x)), app(app(map, f), xs))
app(app(append, xs), nil) → xs
app(app(append, nil), ys) → ys
app(app(append, app(app(cons, x), xs)), ys) → app(app(cons, x), app(app(append, xs), ys))
app(app(zip, nil), yss) → yss
app(app(zip, xss), nil) → xss
app(app(zip, app(app(cons, xs), xss)), app(app(cons, ys), yss)) → app(app(cons, app(app(append, xs), ys)), app(app(zip, xss), yss))
app(app(combine, xs), nil) → xs
app(app(combine, xs), app(app(cons, ys), yss)) → app(app(combine, app(app(zip, xs), ys)), yss)
app(levels, app(app(node, x), xs)) → app(app(cons, app(app(cons, x), nil)), app(app(combine, nil), app(app(map, levels), xs)))