YES
0 QTRS
↳1 QTRSRRRProof (⇔, 0 ms)
↳2 QTRS
↳3 QTRSRRRProof (⇔, 0 ms)
↳4 QTRS
↳5 RisEmptyProof (⇔, 0 ms)
↳6 YES
fst(0, Z) → nil
fst(s, cons(Y)) → cons(Y)
from(X) → cons(X)
add(0, X) → X
add(s, Y) → s
len(nil) → 0
len(cons(X)) → s
With this ordering the following rules can be removed by the rule removal processor [LPAR04] because they are oriented strictly:
POL(0) = 1
POL(add(x1, x2)) = 2 + 2·x1 + x2
POL(cons(x1)) = 2 + x1
POL(from(x1)) = 2 + 2·x1
POL(fst(x1, x2)) = 2 + x1 + 2·x2
POL(len(x1)) = 2 + 2·x1
POL(nil) = 2
POL(s) = 1
fst(0, Z) → nil
fst(s, cons(Y)) → cons(Y)
add(0, X) → X
add(s, Y) → s
len(nil) → 0
len(cons(X)) → s
from(X) → cons(X)
from1 > cons1
from_1=1
cons_1=1
from(X) → cons(X)