0 QTRS
↳1 DependencyPairsProof (⇔, 29 ms)
↳2 QDP
↳3 DependencyGraphProof (⇔, 0 ms)
↳4 AND
↳5 QDP
↳6 MNOCProof (⇔, 0 ms)
↳7 QDP
↳8 UsableRulesProof (⇔, 0 ms)
↳9 QDP
↳10 QReductionProof (⇔, 0 ms)
↳11 QDP
↳12 QDPOrderProof (⇔, 63 ms)
↳13 QDP
↳14 PisEmptyProof (⇔, 0 ms)
↳15 YES
↳16 QDP
↳17 NonLoopProof (⇔, 0 ms)
↳18 NO
primes → sieve(from(s(s(0))))
from(X) → cons(X, from(s(X)))
head(cons(X, Y)) → X
tail(cons(X, Y)) → Y
if(true, X, Y) → X
if(false, X, Y) → Y
filter(s(s(X)), cons(Y, Z)) → if(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
sieve(cons(X, Y)) → cons(X, filter(X, sieve(Y)))
PRIMES → SIEVE(from(s(s(0))))
PRIMES → FROM(s(s(0)))
FROM(X) → FROM(s(X))
FILTER(s(s(X)), cons(Y, Z)) → IF(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(s(s(X)), Z)
FILTER(s(s(X)), cons(Y, Z)) → FILTER(X, sieve(Y))
FILTER(s(s(X)), cons(Y, Z)) → SIEVE(Y)
SIEVE(cons(X, Y)) → FILTER(X, sieve(Y))
SIEVE(cons(X, Y)) → SIEVE(Y)
primes → sieve(from(s(s(0))))
from(X) → cons(X, from(s(X)))
head(cons(X, Y)) → X
tail(cons(X, Y)) → Y
if(true, X, Y) → X
if(false, X, Y) → Y
filter(s(s(X)), cons(Y, Z)) → if(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
sieve(cons(X, Y)) → cons(X, filter(X, sieve(Y)))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(X, sieve(Y))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(s(s(X)), Z)
FILTER(s(s(X)), cons(Y, Z)) → SIEVE(Y)
SIEVE(cons(X, Y)) → FILTER(X, sieve(Y))
SIEVE(cons(X, Y)) → SIEVE(Y)
primes → sieve(from(s(s(0))))
from(X) → cons(X, from(s(X)))
head(cons(X, Y)) → X
tail(cons(X, Y)) → Y
if(true, X, Y) → X
if(false, X, Y) → Y
filter(s(s(X)), cons(Y, Z)) → if(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
sieve(cons(X, Y)) → cons(X, filter(X, sieve(Y)))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(X, sieve(Y))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(s(s(X)), Z)
FILTER(s(s(X)), cons(Y, Z)) → SIEVE(Y)
SIEVE(cons(X, Y)) → FILTER(X, sieve(Y))
SIEVE(cons(X, Y)) → SIEVE(Y)
primes → sieve(from(s(s(0))))
from(X) → cons(X, from(s(X)))
head(cons(X, Y)) → X
tail(cons(X, Y)) → Y
if(true, X, Y) → X
if(false, X, Y) → Y
filter(s(s(X)), cons(Y, Z)) → if(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
sieve(cons(X, Y)) → cons(X, filter(X, sieve(Y)))
primes
from(x0)
head(cons(x0, x1))
tail(cons(x0, x1))
if(true, x0, x1)
if(false, x0, x1)
filter(s(s(x0)), cons(x1, x2))
sieve(cons(x0, x1))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(X, sieve(Y))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(s(s(X)), Z)
FILTER(s(s(X)), cons(Y, Z)) → SIEVE(Y)
SIEVE(cons(X, Y)) → FILTER(X, sieve(Y))
SIEVE(cons(X, Y)) → SIEVE(Y)
sieve(cons(X, Y)) → cons(X, filter(X, sieve(Y)))
filter(s(s(X)), cons(Y, Z)) → if(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
primes
from(x0)
head(cons(x0, x1))
tail(cons(x0, x1))
if(true, x0, x1)
if(false, x0, x1)
filter(s(s(x0)), cons(x1, x2))
sieve(cons(x0, x1))
primes
from(x0)
head(cons(x0, x1))
tail(cons(x0, x1))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(X, sieve(Y))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(s(s(X)), Z)
FILTER(s(s(X)), cons(Y, Z)) → SIEVE(Y)
SIEVE(cons(X, Y)) → FILTER(X, sieve(Y))
SIEVE(cons(X, Y)) → SIEVE(Y)
sieve(cons(X, Y)) → cons(X, filter(X, sieve(Y)))
filter(s(s(X)), cons(Y, Z)) → if(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
if(true, x0, x1)
if(false, x0, x1)
filter(s(s(x0)), cons(x1, x2))
sieve(cons(x0, x1))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
FILTER(s(s(X)), cons(Y, Z)) → FILTER(X, sieve(Y))
FILTER(s(s(X)), cons(Y, Z)) → FILTER(s(s(X)), Z)
FILTER(s(s(X)), cons(Y, Z)) → SIEVE(Y)
SIEVE(cons(X, Y)) → FILTER(X, sieve(Y))
SIEVE(cons(X, Y)) → SIEVE(Y)
POL( FILTER(x1, x2) ) = 2x1 + 2x2
POL( sieve(x1) ) = x1
POL( cons(x1, x2) ) = 2x1 + 2x2 + 1
POL( filter(x1, x2) ) = max{0, -1}
POL( s(x1) ) = 2x1
POL( if(x1, ..., x3) ) = max{0, 2x1 + x2 - 1}
POL( divides(x1, x2) ) = max{0, -2}
POL( SIEVE(x1) ) = x1 + 1
sieve(cons(X, Y)) → cons(X, filter(X, sieve(Y)))
filter(s(s(X)), cons(Y, Z)) → if(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
sieve(cons(X, Y)) → cons(X, filter(X, sieve(Y)))
filter(s(s(X)), cons(Y, Z)) → if(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
if(true, x0, x1)
if(false, x0, x1)
filter(s(s(x0)), cons(x1, x2))
sieve(cons(x0, x1))
FROM(X) → FROM(s(X))
primes → sieve(from(s(s(0))))
from(X) → cons(X, from(s(X)))
head(cons(X, Y)) → X
tail(cons(X, Y)) → Y
if(true, X, Y) → X
if(false, X, Y) → Y
filter(s(s(X)), cons(Y, Z)) → if(divides(s(s(X)), Y), filter(s(s(X)), Z), cons(Y, filter(X, sieve(Y))))
sieve(cons(X, Y)) → cons(X, filter(X, sieve(Y)))