0 QTRS
↳1 Overlay + Local Confluence (⇔)
↳2 QTRS
↳3 DependencyPairsProof (⇔)
↳4 QDP
↳5 DependencyGraphProof (⇔)
↳6 AND
↳7 QDP
↳8 QDPOrderProof (⇔)
↳9 QDP
↳10 QDPOrderProof (⇔)
↳11 QDP
↳12 PisEmptyProof (⇔)
↳13 TRUE
↳14 QDP
↳15 QDPOrderProof (⇔)
↳16 QDP
↳17 PisEmptyProof (⇔)
↳18 TRUE
↳19 QDP
times(x, y) → help(x, y, 0)
help(x, y, c) → if(lt(c, y), x, y, c)
if(true, x, y, c) → plus(x, help(x, y, s(c)))
if(false, x, y, c) → 0
lt(0, s(x)) → true
lt(s(x), 0) → false
lt(s(x), s(y)) → lt(x, y)
plus(x, 0) → x
plus(0, x) → x
plus(x, s(y)) → s(plus(x, y))
plus(s(x), y) → s(plus(x, y))
times(x, y) → help(x, y, 0)
help(x, y, c) → if(lt(c, y), x, y, c)
if(true, x, y, c) → plus(x, help(x, y, s(c)))
if(false, x, y, c) → 0
lt(0, s(x)) → true
lt(s(x), 0) → false
lt(s(x), s(y)) → lt(x, y)
plus(x, 0) → x
plus(0, x) → x
plus(x, s(y)) → s(plus(x, y))
plus(s(x), y) → s(plus(x, y))
times(x0, x1)
help(x0, x1, x2)
if(true, x0, x1, x2)
if(false, x0, x1, x2)
lt(0, s(x0))
lt(s(x0), 0)
lt(s(x0), s(x1))
plus(x0, 0)
plus(0, x0)
plus(x0, s(x1))
plus(s(x0), x1)
TIMES(x, y) → HELP(x, y, 0)
HELP(x, y, c) → IF(lt(c, y), x, y, c)
HELP(x, y, c) → LT(c, y)
IF(true, x, y, c) → PLUS(x, help(x, y, s(c)))
IF(true, x, y, c) → HELP(x, y, s(c))
LT(s(x), s(y)) → LT(x, y)
PLUS(x, s(y)) → PLUS(x, y)
PLUS(s(x), y) → PLUS(x, y)
times(x, y) → help(x, y, 0)
help(x, y, c) → if(lt(c, y), x, y, c)
if(true, x, y, c) → plus(x, help(x, y, s(c)))
if(false, x, y, c) → 0
lt(0, s(x)) → true
lt(s(x), 0) → false
lt(s(x), s(y)) → lt(x, y)
plus(x, 0) → x
plus(0, x) → x
plus(x, s(y)) → s(plus(x, y))
plus(s(x), y) → s(plus(x, y))
times(x0, x1)
help(x0, x1, x2)
if(true, x0, x1, x2)
if(false, x0, x1, x2)
lt(0, s(x0))
lt(s(x0), 0)
lt(s(x0), s(x1))
plus(x0, 0)
plus(0, x0)
plus(x0, s(x1))
plus(s(x0), x1)
PLUS(s(x), y) → PLUS(x, y)
PLUS(x, s(y)) → PLUS(x, y)
times(x, y) → help(x, y, 0)
help(x, y, c) → if(lt(c, y), x, y, c)
if(true, x, y, c) → plus(x, help(x, y, s(c)))
if(false, x, y, c) → 0
lt(0, s(x)) → true
lt(s(x), 0) → false
lt(s(x), s(y)) → lt(x, y)
plus(x, 0) → x
plus(0, x) → x
plus(x, s(y)) → s(plus(x, y))
plus(s(x), y) → s(plus(x, y))
times(x0, x1)
help(x0, x1, x2)
if(true, x0, x1, x2)
if(false, x0, x1, x2)
lt(0, s(x0))
lt(s(x0), 0)
lt(s(x0), s(x1))
plus(x0, 0)
plus(0, x0)
plus(x0, s(x1))
plus(s(x0), x1)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
PLUS(x, s(y)) → PLUS(x, y)
s1 > PLUS1
PLUS1: multiset
s1: [1]
PLUS(s(x), y) → PLUS(x, y)
times(x, y) → help(x, y, 0)
help(x, y, c) → if(lt(c, y), x, y, c)
if(true, x, y, c) → plus(x, help(x, y, s(c)))
if(false, x, y, c) → 0
lt(0, s(x)) → true
lt(s(x), 0) → false
lt(s(x), s(y)) → lt(x, y)
plus(x, 0) → x
plus(0, x) → x
plus(x, s(y)) → s(plus(x, y))
plus(s(x), y) → s(plus(x, y))
times(x0, x1)
help(x0, x1, x2)
if(true, x0, x1, x2)
if(false, x0, x1, x2)
lt(0, s(x0))
lt(s(x0), 0)
lt(s(x0), s(x1))
plus(x0, 0)
plus(0, x0)
plus(x0, s(x1))
plus(s(x0), x1)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
PLUS(s(x), y) → PLUS(x, y)
[PLUS2, s1]
PLUS2: [2,1]
s1: multiset
times(x, y) → help(x, y, 0)
help(x, y, c) → if(lt(c, y), x, y, c)
if(true, x, y, c) → plus(x, help(x, y, s(c)))
if(false, x, y, c) → 0
lt(0, s(x)) → true
lt(s(x), 0) → false
lt(s(x), s(y)) → lt(x, y)
plus(x, 0) → x
plus(0, x) → x
plus(x, s(y)) → s(plus(x, y))
plus(s(x), y) → s(plus(x, y))
times(x0, x1)
help(x0, x1, x2)
if(true, x0, x1, x2)
if(false, x0, x1, x2)
lt(0, s(x0))
lt(s(x0), 0)
lt(s(x0), s(x1))
plus(x0, 0)
plus(0, x0)
plus(x0, s(x1))
plus(s(x0), x1)
LT(s(x), s(y)) → LT(x, y)
times(x, y) → help(x, y, 0)
help(x, y, c) → if(lt(c, y), x, y, c)
if(true, x, y, c) → plus(x, help(x, y, s(c)))
if(false, x, y, c) → 0
lt(0, s(x)) → true
lt(s(x), 0) → false
lt(s(x), s(y)) → lt(x, y)
plus(x, 0) → x
plus(0, x) → x
plus(x, s(y)) → s(plus(x, y))
plus(s(x), y) → s(plus(x, y))
times(x0, x1)
help(x0, x1, x2)
if(true, x0, x1, x2)
if(false, x0, x1, x2)
lt(0, s(x0))
lt(s(x0), 0)
lt(s(x0), s(x1))
plus(x0, 0)
plus(0, x0)
plus(x0, s(x1))
plus(s(x0), x1)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
LT(s(x), s(y)) → LT(x, y)
trivial
LT1: [1]
s1: multiset
times(x, y) → help(x, y, 0)
help(x, y, c) → if(lt(c, y), x, y, c)
if(true, x, y, c) → plus(x, help(x, y, s(c)))
if(false, x, y, c) → 0
lt(0, s(x)) → true
lt(s(x), 0) → false
lt(s(x), s(y)) → lt(x, y)
plus(x, 0) → x
plus(0, x) → x
plus(x, s(y)) → s(plus(x, y))
plus(s(x), y) → s(plus(x, y))
times(x0, x1)
help(x0, x1, x2)
if(true, x0, x1, x2)
if(false, x0, x1, x2)
lt(0, s(x0))
lt(s(x0), 0)
lt(s(x0), s(x1))
plus(x0, 0)
plus(0, x0)
plus(x0, s(x1))
plus(s(x0), x1)
IF(true, x, y, c) → HELP(x, y, s(c))
HELP(x, y, c) → IF(lt(c, y), x, y, c)
times(x, y) → help(x, y, 0)
help(x, y, c) → if(lt(c, y), x, y, c)
if(true, x, y, c) → plus(x, help(x, y, s(c)))
if(false, x, y, c) → 0
lt(0, s(x)) → true
lt(s(x), 0) → false
lt(s(x), s(y)) → lt(x, y)
plus(x, 0) → x
plus(0, x) → x
plus(x, s(y)) → s(plus(x, y))
plus(s(x), y) → s(plus(x, y))
times(x0, x1)
help(x0, x1, x2)
if(true, x0, x1, x2)
if(false, x0, x1, x2)
lt(0, s(x0))
lt(s(x0), 0)
lt(s(x0), s(x1))
plus(x0, 0)
plus(0, x0)
plus(x0, s(x1))
plus(s(x0), x1)