le(0, y) → true
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
log(s(0)) → 0
log(s(s(x))) → s(log(s(quot(x, s(s(0))))))
↳ QTRS
↳ Overlay + Local Confluence
le(0, y) → true
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
log(s(0)) → 0
log(s(s(x))) → s(log(s(quot(x, s(s(0))))))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
le(0, y) → true
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
log(s(0)) → 0
log(s(s(x))) → s(log(s(quot(x, s(s(0))))))
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
QUOT(s(x), s(y)) → QUOT(minus(x, y), s(y))
LOG(s(s(x))) → QUOT(x, s(s(0)))
MINUS(s(x), y) → LE(s(x), y)
LOG(s(s(x))) → LOG(s(quot(x, s(s(0)))))
IF_MINUS(false, s(x), y) → MINUS(x, y)
MINUS(s(x), y) → IF_MINUS(le(s(x), y), s(x), y)
LE(s(x), s(y)) → LE(x, y)
QUOT(s(x), s(y)) → MINUS(x, y)
le(0, y) → true
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
log(s(0)) → 0
log(s(s(x))) → s(log(s(quot(x, s(s(0))))))
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
QUOT(s(x), s(y)) → QUOT(minus(x, y), s(y))
LOG(s(s(x))) → QUOT(x, s(s(0)))
MINUS(s(x), y) → LE(s(x), y)
LOG(s(s(x))) → LOG(s(quot(x, s(s(0)))))
IF_MINUS(false, s(x), y) → MINUS(x, y)
MINUS(s(x), y) → IF_MINUS(le(s(x), y), s(x), y)
LE(s(x), s(y)) → LE(x, y)
QUOT(s(x), s(y)) → MINUS(x, y)
le(0, y) → true
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
log(s(0)) → 0
log(s(s(x))) → s(log(s(quot(x, s(s(0))))))
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
↳ QDP
LE(s(x), s(y)) → LE(x, y)
le(0, y) → true
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
log(s(0)) → 0
log(s(s(x))) → s(log(s(quot(x, s(s(0))))))
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
↳ QDP
LE(s(x), s(y)) → LE(x, y)
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
↳ QDP
↳ QDP
LE(s(x), s(y)) → LE(x, y)
From the DPs we obtained the following set of size-change graphs:
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
IF_MINUS(false, s(x), y) → MINUS(x, y)
MINUS(s(x), y) → IF_MINUS(le(s(x), y), s(x), y)
le(0, y) → true
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
log(s(0)) → 0
log(s(s(x))) → s(log(s(quot(x, s(s(0))))))
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
IF_MINUS(false, s(x), y) → MINUS(x, y)
MINUS(s(x), y) → IF_MINUS(le(s(x), y), s(x), y)
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
le(0, y) → true
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
↳ QDP
MINUS(s(x), y) → IF_MINUS(le(s(x), y), s(x), y)
IF_MINUS(false, s(x), y) → MINUS(x, y)
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
le(0, y) → true
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
From the DPs we obtained the following set of size-change graphs:
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
QUOT(s(x), s(y)) → QUOT(minus(x, y), s(y))
le(0, y) → true
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
log(s(0)) → 0
log(s(s(x))) → s(log(s(quot(x, s(s(0))))))
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
QUOT(s(x), s(y)) → QUOT(minus(x, y), s(y))
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
le(0, y) → true
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPOrderProof
↳ QDP
QUOT(s(x), s(y)) → QUOT(minus(x, y), s(y))
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
le(0, y) → true
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
QUOT(s(x), s(y)) → QUOT(minus(x, y), s(y))
POL(0) = 0
POL(QUOT(x1, x2)) = x1
POL(false) = 0
POL(if_minus(x1, x2, x3)) = x2
POL(le(x1, x2)) = 0
POL(minus(x1, x2)) = x1
POL(s(x1)) = 1 + x1
POL(true) = 0
if_minus(false, s(x), y) → s(minus(x, y))
if_minus(true, s(x), y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
minus(0, y) → 0
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
le(0, y) → true
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
LOG(s(s(x))) → LOG(s(quot(x, s(s(0)))))
le(0, y) → true
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
log(s(0)) → 0
log(s(s(x))) → s(log(s(quot(x, s(s(0))))))
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
LOG(s(s(x))) → LOG(s(quot(x, s(s(0)))))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
le(0, y) → true
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
log(s(0))
log(s(s(x0)))
log(s(0))
log(s(s(x0)))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPOrderProof
LOG(s(s(x))) → LOG(s(quot(x, s(s(0)))))
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
le(0, y) → true
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
LOG(s(s(x))) → LOG(s(quot(x, s(s(0)))))
POL(0) = 0
POL(LOG(x1)) = x1
POL(false) = 0
POL(if_minus(x1, x2, x3)) = x2
POL(le(x1, x2)) = 1
POL(minus(x1, x2)) = x1
POL(quot(x1, x2)) = x1
POL(s(x1)) = 1 + x1
POL(true) = 1
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
minus(0, y) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
quot(0, s(y)) → 0
if_minus(false, s(x), y) → s(minus(x, y))
if_minus(true, s(x), y) → 0
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
quot(0, s(y)) → 0
quot(s(x), s(y)) → s(quot(minus(x, y), s(y)))
minus(0, y) → 0
minus(s(x), y) → if_minus(le(s(x), y), s(x), y)
le(s(x), 0) → false
le(s(x), s(y)) → le(x, y)
if_minus(true, s(x), y) → 0
if_minus(false, s(x), y) → s(minus(x, y))
le(0, y) → true
le(0, x0)
le(s(x0), 0)
le(s(x0), s(x1))
minus(0, x0)
minus(s(x0), x1)
if_minus(true, s(x0), x1)
if_minus(false, s(x0), x1)
quot(0, s(x0))
quot(s(x0), s(x1))