Commit fc020b87 by Sergei Grechanik Committed by Tianqi Chen

[ARITH] Fix the rule y < x && x <= y (#4220)

parent 2be444f9
...@@ -1610,7 +1610,7 @@ Mutate_(const And* op, const Expr& self) { ...@@ -1610,7 +1610,7 @@ Mutate_(const And* op, const Expr& self) {
TVM_TRY_REWRITE(x != y && x == y, cfalse); TVM_TRY_REWRITE(x != y && x == y, cfalse);
TVM_TRY_REWRITE(x && !x, cfalse); TVM_TRY_REWRITE(x && !x, cfalse);
TVM_TRY_REWRITE(x <= y && y < x, cfalse); TVM_TRY_REWRITE(x <= y && y < x, cfalse);
TVM_TRY_REWRITE(y < x && y <= x, cfalse); TVM_TRY_REWRITE(y < x && x <= y, cfalse);
TVM_TRY_REWRITE_IF(x < c1 && c2 < x, cfalse, TVM_TRY_REWRITE_IF(x < c1 && c2 < x, cfalse,
c2.Eval()->value + 1 >= c1.Eval()->value); c2.Eval()->value + 1 >= c1.Eval()->value);
......
...@@ -783,7 +783,7 @@ def test_logical_simplify(): ...@@ -783,7 +783,7 @@ def test_logical_simplify():
tvm.const(False, "bool")) tvm.const(False, "bool"))
ck.verify(tvm.expr.And(x > 1, tvm.expr.Not(x > 1)), tvm.const(False, "bool")) ck.verify(tvm.expr.And(x > 1, tvm.expr.Not(x > 1)), tvm.const(False, "bool"))
ck.verify(tvm.expr.And(x <= y, y < x), tvm.const(False, "bool")) ck.verify(tvm.expr.And(x <= y, y < x), tvm.const(False, "bool"))
ck.verify(tvm.expr.And(y < x, y <= x), tvm.const(False, "bool")) ck.verify(tvm.expr.And(y < x, x <= y), tvm.const(False, "bool"))
ck.verify(tvm.expr.And(x < 1, 0 < x), tvm.const(False, "bool")) ck.verify(tvm.expr.And(x < 1, 0 < x), tvm.const(False, "bool"))
ck.verify(tvm.expr.And(x < 0, 1 < x), tvm.const(False, "bool")) ck.verify(tvm.expr.And(x < 0, 1 < x), tvm.const(False, "bool"))
ck.verify(tvm.expr.And(x < 1, 1 <= x), tvm.const(False, "bool")) ck.verify(tvm.expr.And(x < 1, 1 <= x), tvm.const(False, "bool"))
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment