0 QTRS
↳1 AAECC Innermost (⇔)
↳2 QTRS
↳3 DependencyPairsProof (⇔)
↳4 QDP
↳5 DependencyGraphProof (⇔)
↳6 AND
↳7 QDP
↳8 QDPOrderProof (⇔)
↳9 QDP
↳10 PisEmptyProof (⇔)
↳11 TRUE
↳12 QDP
cond1(true, x, y, z) → cond2(gr(x, 0), x, y, z)
cond2(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), p(x), y, z)
cond2(false, x, y, z) → cond3(gr(y, 0), x, y, z)
cond3(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, p(y), z)
cond3(false, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, y, z)
gr(0, x) → false
gr(s(x), 0) → true
gr(s(x), s(y)) → gr(x, y)
or(false, false) → false
or(true, x) → true
or(x, true) → true
p(0) → 0
p(s(x)) → x
gr(0, x) → false
gr(s(x), 0) → true
gr(s(x), s(y)) → gr(x, y)
or(false, false) → false
or(true, x) → true
or(x, true) → true
p(0) → 0
p(s(x)) → x
cond1(true, x, y, z) → cond2(gr(x, 0), x, y, z)
cond2(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), p(x), y, z)
cond2(false, x, y, z) → cond3(gr(y, 0), x, y, z)
cond3(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, p(y), z)
cond3(false, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, y, z)
cond1(true, x, y, z) → cond2(gr(x, 0), x, y, z)
cond2(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), p(x), y, z)
cond2(false, x, y, z) → cond3(gr(y, 0), x, y, z)
cond3(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, p(y), z)
cond3(false, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, y, z)
gr(0, x) → false
gr(s(x), 0) → true
gr(s(x), s(y)) → gr(x, y)
or(false, false) → false
or(true, x) → true
or(x, true) → true
p(0) → 0
p(s(x)) → x
cond1(true, x0, x1, x2)
cond2(true, x0, x1, x2)
cond2(false, x0, x1, x2)
cond3(true, x0, x1, x2)
cond3(false, x0, x1, x2)
gr(0, x0)
gr(s(x0), 0)
gr(s(x0), s(x1))
or(false, false)
or(true, x0)
or(x0, true)
p(0)
p(s(x0))
COND1(true, x, y, z) → COND2(gr(x, 0), x, y, z)
COND1(true, x, y, z) → GR(x, 0)
COND2(true, x, y, z) → COND1(or(gr(x, z), gr(y, z)), p(x), y, z)
COND2(true, x, y, z) → OR(gr(x, z), gr(y, z))
COND2(true, x, y, z) → GR(x, z)
COND2(true, x, y, z) → GR(y, z)
COND2(true, x, y, z) → P(x)
COND2(false, x, y, z) → COND3(gr(y, 0), x, y, z)
COND2(false, x, y, z) → GR(y, 0)
COND3(true, x, y, z) → COND1(or(gr(x, z), gr(y, z)), x, p(y), z)
COND3(true, x, y, z) → OR(gr(x, z), gr(y, z))
COND3(true, x, y, z) → GR(x, z)
COND3(true, x, y, z) → GR(y, z)
COND3(true, x, y, z) → P(y)
COND3(false, x, y, z) → COND1(or(gr(x, z), gr(y, z)), x, y, z)
COND3(false, x, y, z) → OR(gr(x, z), gr(y, z))
COND3(false, x, y, z) → GR(x, z)
COND3(false, x, y, z) → GR(y, z)
GR(s(x), s(y)) → GR(x, y)
cond1(true, x, y, z) → cond2(gr(x, 0), x, y, z)
cond2(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), p(x), y, z)
cond2(false, x, y, z) → cond3(gr(y, 0), x, y, z)
cond3(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, p(y), z)
cond3(false, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, y, z)
gr(0, x) → false
gr(s(x), 0) → true
gr(s(x), s(y)) → gr(x, y)
or(false, false) → false
or(true, x) → true
or(x, true) → true
p(0) → 0
p(s(x)) → x
cond1(true, x0, x1, x2)
cond2(true, x0, x1, x2)
cond2(false, x0, x1, x2)
cond3(true, x0, x1, x2)
cond3(false, x0, x1, x2)
gr(0, x0)
gr(s(x0), 0)
gr(s(x0), s(x1))
or(false, false)
or(true, x0)
or(x0, true)
p(0)
p(s(x0))
GR(s(x), s(y)) → GR(x, y)
cond1(true, x, y, z) → cond2(gr(x, 0), x, y, z)
cond2(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), p(x), y, z)
cond2(false, x, y, z) → cond3(gr(y, 0), x, y, z)
cond3(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, p(y), z)
cond3(false, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, y, z)
gr(0, x) → false
gr(s(x), 0) → true
gr(s(x), s(y)) → gr(x, y)
or(false, false) → false
or(true, x) → true
or(x, true) → true
p(0) → 0
p(s(x)) → x
cond1(true, x0, x1, x2)
cond2(true, x0, x1, x2)
cond2(false, x0, x1, x2)
cond3(true, x0, x1, x2)
cond3(false, x0, x1, x2)
gr(0, x0)
gr(s(x0), 0)
gr(s(x0), s(x1))
or(false, false)
or(true, x0)
or(x0, true)
p(0)
p(s(x0))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
GR(s(x), s(y)) → GR(x, y)
GR1 > [s1, true, gr, false]
p1 > 0 > [s1, true, gr, false]
cond1(true, x, y, z) → cond2(gr(x, 0), x, y, z)
cond2(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), p(x), y, z)
cond2(false, x, y, z) → cond3(gr(y, 0), x, y, z)
cond3(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, p(y), z)
cond3(false, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, y, z)
gr(0, x) → false
gr(s(x), 0) → true
gr(s(x), s(y)) → gr(x, y)
or(false, false) → false
or(true, x) → true
or(x, true) → true
p(0) → 0
p(s(x)) → x
cond1(true, x, y, z) → cond2(gr(x, 0), x, y, z)
cond2(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), p(x), y, z)
cond2(false, x, y, z) → cond3(gr(y, 0), x, y, z)
cond3(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, p(y), z)
cond3(false, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, y, z)
gr(0, x) → false
gr(s(x), 0) → true
gr(s(x), s(y)) → gr(x, y)
or(false, false) → false
or(true, x) → true
or(x, true) → true
p(0) → 0
p(s(x)) → x
cond1(true, x0, x1, x2)
cond2(true, x0, x1, x2)
cond2(false, x0, x1, x2)
cond3(true, x0, x1, x2)
cond3(false, x0, x1, x2)
gr(0, x0)
gr(s(x0), 0)
gr(s(x0), s(x1))
or(false, false)
or(true, x0)
or(x0, true)
p(0)
p(s(x0))
COND2(true, x, y, z) → COND1(or(gr(x, z), gr(y, z)), p(x), y, z)
COND1(true, x, y, z) → COND2(gr(x, 0), x, y, z)
COND2(false, x, y, z) → COND3(gr(y, 0), x, y, z)
COND3(true, x, y, z) → COND1(or(gr(x, z), gr(y, z)), x, p(y), z)
COND3(false, x, y, z) → COND1(or(gr(x, z), gr(y, z)), x, y, z)
cond1(true, x, y, z) → cond2(gr(x, 0), x, y, z)
cond2(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), p(x), y, z)
cond2(false, x, y, z) → cond3(gr(y, 0), x, y, z)
cond3(true, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, p(y), z)
cond3(false, x, y, z) → cond1(or(gr(x, z), gr(y, z)), x, y, z)
gr(0, x) → false
gr(s(x), 0) → true
gr(s(x), s(y)) → gr(x, y)
or(false, false) → false
or(true, x) → true
or(x, true) → true
p(0) → 0
p(s(x)) → x
cond1(true, x0, x1, x2)
cond2(true, x0, x1, x2)
cond2(false, x0, x1, x2)
cond3(true, x0, x1, x2)
cond3(false, x0, x1, x2)
gr(0, x0)
gr(s(x0), 0)
gr(s(x0), s(x1))
or(false, false)
or(true, x0)
or(x0, true)
p(0)
p(s(x0))