YES
0 QTRS
↳1 Overlay + Local Confluence (⇔, 19 ms)
↳2 QTRS
↳3 DependencyPairsProof (⇔, 0 ms)
↳4 QDP
↳5 DependencyGraphProof (⇔, 0 ms)
↳6 AND
↳7 QDP
↳8 UsableRulesProof (⇔, 0 ms)
↳9 QDP
↳10 ATransformationProof (⇔, 0 ms)
↳11 QDP
↳12 QReductionProof (⇔, 0 ms)
↳13 QDP
↳14 QDPSizeChangeProof (⇔, 0 ms)
↳15 YES
↳16 QDP
↳17 UsableRulesProof (⇔, 0 ms)
↳18 QDP
↳19 ATransformationProof (⇔, 0 ms)
↳20 QDP
↳21 QReductionProof (⇔, 0 ms)
↳22 QDP
↳23 QDPSizeChangeProof (⇔, 0 ms)
↳24 YES
↳25 QDP
↳26 UsableRulesProof (⇔, 0 ms)
↳27 QDP
↳28 ATransformationProof (⇔, 0 ms)
↳29 QDP
↳30 QReductionProof (⇔, 0 ms)
↳31 QDP
↳32 QDPSizeChangeProof (⇔, 0 ms)
↳33 YES
↳34 QDP
↳35 UsableRulesProof (⇔, 0 ms)
↳36 QDP
↳37 ATransformationProof (⇔, 0 ms)
↳38 QDP
↳39 QReductionProof (⇔, 0 ms)
↳40 QDP
↳41 QDPOrderProof (⇔, 10 ms)
↳42 QDP
↳43 PisEmptyProof (⇔, 0 ms)
↳44 YES
↳45 QDP
↳46 UsableRulesProof (⇔, 0 ms)
↳47 QDP
↳48 QDPSizeChangeProof (⇔, 0 ms)
↳49 YES
app(app(app(if, true), xs), ys) → xs
app(app(app(if, false), xs), ys) → ys
app(app(sub, x), 0) → x
app(app(sub, app(s, x)), app(s, y)) → app(app(sub, x), y)
app(app(gtr, 0), y) → false
app(app(gtr, app(s, x)), 0) → true
app(app(gtr, app(s, x)), app(s, y)) → app(app(gtr, x), y)
app(app(d, x), 0) → true
app(app(d, app(s, x)), app(s, y)) → app(app(app(if, app(app(gtr, x), y)), false), app(app(d, app(s, x)), app(app(sub, y), x)))
app(len, nil) → 0
app(len, app(app(cons, x), xs)) → app(s, app(len, xs))
app(app(filter, p), nil) → nil
app(app(filter, p), app(app(cons, x), xs)) → app(app(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs))), app(app(filter, p), xs))
app(app(app(if, true), xs), ys) → xs
app(app(app(if, false), xs), ys) → ys
app(app(sub, x), 0) → x
app(app(sub, app(s, x)), app(s, y)) → app(app(sub, x), y)
app(app(gtr, 0), y) → false
app(app(gtr, app(s, x)), 0) → true
app(app(gtr, app(s, x)), app(s, y)) → app(app(gtr, x), y)
app(app(d, x), 0) → true
app(app(d, app(s, x)), app(s, y)) → app(app(app(if, app(app(gtr, x), y)), false), app(app(d, app(s, x)), app(app(sub, y), x)))
app(len, nil) → 0
app(len, app(app(cons, x), xs)) → app(s, app(len, xs))
app(app(filter, p), nil) → nil
app(app(filter, p), app(app(cons, x), xs)) → app(app(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs))), app(app(filter, p), xs))
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
APP(app(sub, app(s, x)), app(s, y)) → APP(app(sub, x), y)
APP(app(sub, app(s, x)), app(s, y)) → APP(sub, x)
APP(app(gtr, app(s, x)), app(s, y)) → APP(app(gtr, x), y)
APP(app(gtr, app(s, x)), app(s, y)) → APP(gtr, x)
APP(app(d, app(s, x)), app(s, y)) → APP(app(app(if, app(app(gtr, x), y)), false), app(app(d, app(s, x)), app(app(sub, y), x)))
APP(app(d, app(s, x)), app(s, y)) → APP(app(if, app(app(gtr, x), y)), false)
APP(app(d, app(s, x)), app(s, y)) → APP(if, app(app(gtr, x), y))
APP(app(d, app(s, x)), app(s, y)) → APP(app(gtr, x), y)
APP(app(d, app(s, x)), app(s, y)) → APP(gtr, x)
APP(app(d, app(s, x)), app(s, y)) → APP(app(d, app(s, x)), app(app(sub, y), x))
APP(app(d, app(s, x)), app(s, y)) → APP(app(sub, y), x)
APP(app(d, app(s, x)), app(s, y)) → APP(sub, y)
APP(len, app(app(cons, x), xs)) → APP(s, app(len, xs))
APP(len, app(app(cons, x), xs)) → APP(len, xs)
APP(app(filter, p), app(app(cons, x), xs)) → APP(app(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs))), app(app(filter, p), xs))
APP(app(filter, p), app(app(cons, x), xs)) → APP(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs)))
APP(app(filter, p), app(app(cons, x), xs)) → APP(if, app(p, x))
APP(app(filter, p), app(app(cons, x), xs)) → APP(p, x)
APP(app(filter, p), app(app(cons, x), xs)) → APP(app(cons, x), app(app(filter, p), xs))
APP(app(filter, p), app(app(cons, x), xs)) → APP(app(filter, p), xs)
app(app(app(if, true), xs), ys) → xs
app(app(app(if, false), xs), ys) → ys
app(app(sub, x), 0) → x
app(app(sub, app(s, x)), app(s, y)) → app(app(sub, x), y)
app(app(gtr, 0), y) → false
app(app(gtr, app(s, x)), 0) → true
app(app(gtr, app(s, x)), app(s, y)) → app(app(gtr, x), y)
app(app(d, x), 0) → true
app(app(d, app(s, x)), app(s, y)) → app(app(app(if, app(app(gtr, x), y)), false), app(app(d, app(s, x)), app(app(sub, y), x)))
app(len, nil) → 0
app(len, app(app(cons, x), xs)) → app(s, app(len, xs))
app(app(filter, p), nil) → nil
app(app(filter, p), app(app(cons, x), xs)) → app(app(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs))), app(app(filter, p), xs))
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
APP(len, app(app(cons, x), xs)) → APP(len, xs)
app(app(app(if, true), xs), ys) → xs
app(app(app(if, false), xs), ys) → ys
app(app(sub, x), 0) → x
app(app(sub, app(s, x)), app(s, y)) → app(app(sub, x), y)
app(app(gtr, 0), y) → false
app(app(gtr, app(s, x)), 0) → true
app(app(gtr, app(s, x)), app(s, y)) → app(app(gtr, x), y)
app(app(d, x), 0) → true
app(app(d, app(s, x)), app(s, y)) → app(app(app(if, app(app(gtr, x), y)), false), app(app(d, app(s, x)), app(app(sub, y), x)))
app(len, nil) → 0
app(len, app(app(cons, x), xs)) → app(s, app(len, xs))
app(app(filter, p), nil) → nil
app(app(filter, p), app(app(cons, x), xs)) → app(app(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs))), app(app(filter, p), xs))
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
APP(len, app(app(cons, x), xs)) → APP(len, xs)
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
len1(cons(x, xs)) → len1(xs)
if(true, x0, x1)
if(false, x0, x1)
sub(x0, 0)
sub(s(x0), s(x1))
gtr(0, x0)
gtr(s(x0), 0)
gtr(s(x0), s(x1))
d(x0, 0)
d(s(x0), s(x1))
len(nil)
len(cons(x0, x1))
filter(x0, nil)
filter(x0, cons(x1, x2))
if(true, x0, x1)
if(false, x0, x1)
sub(x0, 0)
sub(s(x0), s(x1))
gtr(0, x0)
gtr(s(x0), 0)
gtr(s(x0), s(x1))
d(x0, 0)
d(s(x0), s(x1))
len(nil)
len(cons(x0, x1))
filter(x0, nil)
filter(x0, cons(x1, x2))
len1(cons(x, xs)) → len1(xs)
From the DPs we obtained the following set of size-change graphs:
APP(app(gtr, app(s, x)), app(s, y)) → APP(app(gtr, x), y)
app(app(app(if, true), xs), ys) → xs
app(app(app(if, false), xs), ys) → ys
app(app(sub, x), 0) → x
app(app(sub, app(s, x)), app(s, y)) → app(app(sub, x), y)
app(app(gtr, 0), y) → false
app(app(gtr, app(s, x)), 0) → true
app(app(gtr, app(s, x)), app(s, y)) → app(app(gtr, x), y)
app(app(d, x), 0) → true
app(app(d, app(s, x)), app(s, y)) → app(app(app(if, app(app(gtr, x), y)), false), app(app(d, app(s, x)), app(app(sub, y), x)))
app(len, nil) → 0
app(len, app(app(cons, x), xs)) → app(s, app(len, xs))
app(app(filter, p), nil) → nil
app(app(filter, p), app(app(cons, x), xs)) → app(app(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs))), app(app(filter, p), xs))
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
APP(app(gtr, app(s, x)), app(s, y)) → APP(app(gtr, x), y)
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
gtr1(s(x), s(y)) → gtr1(x, y)
if(true, x0, x1)
if(false, x0, x1)
sub(x0, 0)
sub(s(x0), s(x1))
gtr(0, x0)
gtr(s(x0), 0)
gtr(s(x0), s(x1))
d(x0, 0)
d(s(x0), s(x1))
len(nil)
len(cons(x0, x1))
filter(x0, nil)
filter(x0, cons(x1, x2))
if(true, x0, x1)
if(false, x0, x1)
sub(x0, 0)
sub(s(x0), s(x1))
gtr(0, x0)
gtr(s(x0), 0)
gtr(s(x0), s(x1))
d(x0, 0)
d(s(x0), s(x1))
len(nil)
len(cons(x0, x1))
filter(x0, nil)
filter(x0, cons(x1, x2))
gtr1(s(x), s(y)) → gtr1(x, y)
From the DPs we obtained the following set of size-change graphs:
APP(app(sub, app(s, x)), app(s, y)) → APP(app(sub, x), y)
app(app(app(if, true), xs), ys) → xs
app(app(app(if, false), xs), ys) → ys
app(app(sub, x), 0) → x
app(app(sub, app(s, x)), app(s, y)) → app(app(sub, x), y)
app(app(gtr, 0), y) → false
app(app(gtr, app(s, x)), 0) → true
app(app(gtr, app(s, x)), app(s, y)) → app(app(gtr, x), y)
app(app(d, x), 0) → true
app(app(d, app(s, x)), app(s, y)) → app(app(app(if, app(app(gtr, x), y)), false), app(app(d, app(s, x)), app(app(sub, y), x)))
app(len, nil) → 0
app(len, app(app(cons, x), xs)) → app(s, app(len, xs))
app(app(filter, p), nil) → nil
app(app(filter, p), app(app(cons, x), xs)) → app(app(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs))), app(app(filter, p), xs))
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
APP(app(sub, app(s, x)), app(s, y)) → APP(app(sub, x), y)
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
sub1(s(x), s(y)) → sub1(x, y)
if(true, x0, x1)
if(false, x0, x1)
sub(x0, 0)
sub(s(x0), s(x1))
gtr(0, x0)
gtr(s(x0), 0)
gtr(s(x0), s(x1))
d(x0, 0)
d(s(x0), s(x1))
len(nil)
len(cons(x0, x1))
filter(x0, nil)
filter(x0, cons(x1, x2))
if(true, x0, x1)
if(false, x0, x1)
sub(x0, 0)
sub(s(x0), s(x1))
gtr(0, x0)
gtr(s(x0), 0)
gtr(s(x0), s(x1))
d(x0, 0)
d(s(x0), s(x1))
len(nil)
len(cons(x0, x1))
filter(x0, nil)
filter(x0, cons(x1, x2))
sub1(s(x), s(y)) → sub1(x, y)
From the DPs we obtained the following set of size-change graphs:
APP(app(d, app(s, x)), app(s, y)) → APP(app(d, app(s, x)), app(app(sub, y), x))
app(app(app(if, true), xs), ys) → xs
app(app(app(if, false), xs), ys) → ys
app(app(sub, x), 0) → x
app(app(sub, app(s, x)), app(s, y)) → app(app(sub, x), y)
app(app(gtr, 0), y) → false
app(app(gtr, app(s, x)), 0) → true
app(app(gtr, app(s, x)), app(s, y)) → app(app(gtr, x), y)
app(app(d, x), 0) → true
app(app(d, app(s, x)), app(s, y)) → app(app(app(if, app(app(gtr, x), y)), false), app(app(d, app(s, x)), app(app(sub, y), x)))
app(len, nil) → 0
app(len, app(app(cons, x), xs)) → app(s, app(len, xs))
app(app(filter, p), nil) → nil
app(app(filter, p), app(app(cons, x), xs)) → app(app(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs))), app(app(filter, p), xs))
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
APP(app(d, app(s, x)), app(s, y)) → APP(app(d, app(s, x)), app(app(sub, y), x))
app(app(sub, x), 0) → x
app(app(sub, app(s, x)), app(s, y)) → app(app(sub, x), y)
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
d1(s(x), s(y)) → d1(s(x), sub(y, x))
sub(x, 0) → x
sub(s(x), s(y)) → sub(x, y)
if(true, x0, x1)
if(false, x0, x1)
sub(x0, 0)
sub(s(x0), s(x1))
gtr(0, x0)
gtr(s(x0), 0)
gtr(s(x0), s(x1))
d(x0, 0)
d(s(x0), s(x1))
len(nil)
len(cons(x0, x1))
filter(x0, nil)
filter(x0, cons(x1, x2))
if(true, x0, x1)
if(false, x0, x1)
gtr(0, x0)
gtr(s(x0), 0)
gtr(s(x0), s(x1))
d(x0, 0)
d(s(x0), s(x1))
len(nil)
len(cons(x0, x1))
filter(x0, nil)
filter(x0, cons(x1, x2))
d1(s(x), s(y)) → d1(s(x), sub(y, x))
sub(x, 0) → x
sub(s(x), s(y)) → sub(x, y)
sub(x0, 0)
sub(s(x0), s(x1))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
d1(s(x), s(y)) → d1(s(x), sub(y, x))
trivial
s_1=1
dummyConstant=1
sub(x, 0) → x
sub(s(x), s(y)) → sub(x, y)
sub(x, 0) → x
sub(s(x), s(y)) → sub(x, y)
sub(x0, 0)
sub(s(x0), s(x1))
APP(app(filter, p), app(app(cons, x), xs)) → APP(app(filter, p), xs)
APP(app(filter, p), app(app(cons, x), xs)) → APP(p, x)
app(app(app(if, true), xs), ys) → xs
app(app(app(if, false), xs), ys) → ys
app(app(sub, x), 0) → x
app(app(sub, app(s, x)), app(s, y)) → app(app(sub, x), y)
app(app(gtr, 0), y) → false
app(app(gtr, app(s, x)), 0) → true
app(app(gtr, app(s, x)), app(s, y)) → app(app(gtr, x), y)
app(app(d, x), 0) → true
app(app(d, app(s, x)), app(s, y)) → app(app(app(if, app(app(gtr, x), y)), false), app(app(d, app(s, x)), app(app(sub, y), x)))
app(len, nil) → 0
app(len, app(app(cons, x), xs)) → app(s, app(len, xs))
app(app(filter, p), nil) → nil
app(app(filter, p), app(app(cons, x), xs)) → app(app(app(if, app(p, x)), app(app(cons, x), app(app(filter, p), xs))), app(app(filter, p), xs))
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
APP(app(filter, p), app(app(cons, x), xs)) → APP(app(filter, p), xs)
APP(app(filter, p), app(app(cons, x), xs)) → APP(p, x)
app(app(app(if, true), x0), x1)
app(app(app(if, false), x0), x1)
app(app(sub, x0), 0)
app(app(sub, app(s, x0)), app(s, x1))
app(app(gtr, 0), x0)
app(app(gtr, app(s, x0)), 0)
app(app(gtr, app(s, x0)), app(s, x1))
app(app(d, x0), 0)
app(app(d, app(s, x0)), app(s, x1))
app(len, nil)
app(len, app(app(cons, x0), x1))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
From the DPs we obtained the following set of size-change graphs: