0 QTRS
↳1 DependencyPairsProof (⇔)
↳2 QDP
↳3 QDPOrderProof (⇔)
↳4 QDP
↳5 QDPOrderProof (⇔)
↳6 QDP
↳7 PisEmptyProof (⇔)
↳8 TRUE
dx(X) → one
dx(a) → zero
dx(plus(ALPHA, BETA)) → plus(dx(ALPHA), dx(BETA))
dx(times(ALPHA, BETA)) → plus(times(BETA, dx(ALPHA)), times(ALPHA, dx(BETA)))
dx(minus(ALPHA, BETA)) → minus(dx(ALPHA), dx(BETA))
dx(neg(ALPHA)) → neg(dx(ALPHA))
dx(div(ALPHA, BETA)) → minus(div(dx(ALPHA), BETA), times(ALPHA, div(dx(BETA), exp(BETA, two))))
dx(ln(ALPHA)) → div(dx(ALPHA), ALPHA)
dx(exp(ALPHA, BETA)) → plus(times(BETA, times(exp(ALPHA, minus(BETA, one)), dx(ALPHA))), times(exp(ALPHA, BETA), times(ln(ALPHA), dx(BETA))))
DX(plus(ALPHA, BETA)) → DX(ALPHA)
DX(plus(ALPHA, BETA)) → DX(BETA)
DX(times(ALPHA, BETA)) → DX(ALPHA)
DX(times(ALPHA, BETA)) → DX(BETA)
DX(minus(ALPHA, BETA)) → DX(ALPHA)
DX(minus(ALPHA, BETA)) → DX(BETA)
DX(neg(ALPHA)) → DX(ALPHA)
DX(div(ALPHA, BETA)) → DX(ALPHA)
DX(div(ALPHA, BETA)) → DX(BETA)
DX(ln(ALPHA)) → DX(ALPHA)
DX(exp(ALPHA, BETA)) → DX(ALPHA)
DX(exp(ALPHA, BETA)) → DX(BETA)
dx(X) → one
dx(a) → zero
dx(plus(ALPHA, BETA)) → plus(dx(ALPHA), dx(BETA))
dx(times(ALPHA, BETA)) → plus(times(BETA, dx(ALPHA)), times(ALPHA, dx(BETA)))
dx(minus(ALPHA, BETA)) → minus(dx(ALPHA), dx(BETA))
dx(neg(ALPHA)) → neg(dx(ALPHA))
dx(div(ALPHA, BETA)) → minus(div(dx(ALPHA), BETA), times(ALPHA, div(dx(BETA), exp(BETA, two))))
dx(ln(ALPHA)) → div(dx(ALPHA), ALPHA)
dx(exp(ALPHA, BETA)) → plus(times(BETA, times(exp(ALPHA, minus(BETA, one)), dx(ALPHA))), times(exp(ALPHA, BETA), times(ln(ALPHA), dx(BETA))))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
DX(plus(ALPHA, BETA)) → DX(ALPHA)
DX(plus(ALPHA, BETA)) → DX(BETA)
DX(times(ALPHA, BETA)) → DX(ALPHA)
DX(times(ALPHA, BETA)) → DX(BETA)
DX(minus(ALPHA, BETA)) → DX(ALPHA)
DX(minus(ALPHA, BETA)) → DX(BETA)
DX(div(ALPHA, BETA)) → DX(ALPHA)
DX(div(ALPHA, BETA)) → DX(BETA)
DX(ln(ALPHA)) → DX(ALPHA)
DX(exp(ALPHA, BETA)) → DX(ALPHA)
DX(exp(ALPHA, BETA)) → DX(BETA)
dx1 > div2 > times2 > one
dx1 > div2 > minus2 > one
dx1 > div2 > two > one
dx1 > exp2 > plus2 > one
dx1 > exp2 > times2 > one
dx1 > exp2 > minus2 > one
dx1 > exp2 > ln1 > one
dx1 > zero > one
a > one
plus2: [1,2]
times2: multiset
minus2: multiset
div2: multiset
ln1: multiset
exp2: multiset
dx1: [1]
one: multiset
a: multiset
zero: multiset
two: multiset
dx(X) → one
dx(a) → zero
dx(plus(ALPHA, BETA)) → plus(dx(ALPHA), dx(BETA))
dx(times(ALPHA, BETA)) → plus(times(BETA, dx(ALPHA)), times(ALPHA, dx(BETA)))
dx(minus(ALPHA, BETA)) → minus(dx(ALPHA), dx(BETA))
dx(neg(ALPHA)) → neg(dx(ALPHA))
dx(div(ALPHA, BETA)) → minus(div(dx(ALPHA), BETA), times(ALPHA, div(dx(BETA), exp(BETA, two))))
dx(ln(ALPHA)) → div(dx(ALPHA), ALPHA)
dx(exp(ALPHA, BETA)) → plus(times(BETA, times(exp(ALPHA, minus(BETA, one)), dx(ALPHA))), times(exp(ALPHA, BETA), times(ln(ALPHA), dx(BETA))))
DX(neg(ALPHA)) → DX(ALPHA)
dx(X) → one
dx(a) → zero
dx(plus(ALPHA, BETA)) → plus(dx(ALPHA), dx(BETA))
dx(times(ALPHA, BETA)) → plus(times(BETA, dx(ALPHA)), times(ALPHA, dx(BETA)))
dx(minus(ALPHA, BETA)) → minus(dx(ALPHA), dx(BETA))
dx(neg(ALPHA)) → neg(dx(ALPHA))
dx(div(ALPHA, BETA)) → minus(div(dx(ALPHA), BETA), times(ALPHA, div(dx(BETA), exp(BETA, two))))
dx(ln(ALPHA)) → div(dx(ALPHA), ALPHA)
dx(exp(ALPHA, BETA)) → plus(times(BETA, times(exp(ALPHA, minus(BETA, one)), dx(ALPHA))), times(exp(ALPHA, BETA), times(ln(ALPHA), dx(BETA))))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
DX(neg(ALPHA)) → DX(ALPHA)
dx1 > one > neg1
dx1 > zero > neg1
dx1 > minus > neg1
dx1 > div > times2 > neg1
dx1 > div > exp2 > neg1
dx1 > div > two > neg1
a > neg1
neg1: multiset
dx1: [1]
one: multiset
a: multiset
zero: multiset
times2: multiset
minus: multiset
div: []
exp2: [1,2]
two: multiset
dx(X) → one
dx(a) → zero
dx(plus(ALPHA, BETA)) → plus(dx(ALPHA), dx(BETA))
dx(times(ALPHA, BETA)) → plus(times(BETA, dx(ALPHA)), times(ALPHA, dx(BETA)))
dx(minus(ALPHA, BETA)) → minus(dx(ALPHA), dx(BETA))
dx(neg(ALPHA)) → neg(dx(ALPHA))
dx(div(ALPHA, BETA)) → minus(div(dx(ALPHA), BETA), times(ALPHA, div(dx(BETA), exp(BETA, two))))
dx(ln(ALPHA)) → div(dx(ALPHA), ALPHA)
dx(exp(ALPHA, BETA)) → plus(times(BETA, times(exp(ALPHA, minus(BETA, one)), dx(ALPHA))), times(exp(ALPHA, BETA), times(ln(ALPHA), dx(BETA))))
dx(X) → one
dx(a) → zero
dx(plus(ALPHA, BETA)) → plus(dx(ALPHA), dx(BETA))
dx(times(ALPHA, BETA)) → plus(times(BETA, dx(ALPHA)), times(ALPHA, dx(BETA)))
dx(minus(ALPHA, BETA)) → minus(dx(ALPHA), dx(BETA))
dx(neg(ALPHA)) → neg(dx(ALPHA))
dx(div(ALPHA, BETA)) → minus(div(dx(ALPHA), BETA), times(ALPHA, div(dx(BETA), exp(BETA, two))))
dx(ln(ALPHA)) → div(dx(ALPHA), ALPHA)
dx(exp(ALPHA, BETA)) → plus(times(BETA, times(exp(ALPHA, minus(BETA, one)), dx(ALPHA))), times(exp(ALPHA, BETA), times(ln(ALPHA), dx(BETA))))