//===- PresbugerParserTest.cpp - Presburger parsing unit tests --*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file contains tests for parsing IntegerSets to IntegerPolyhedron. // The tests with invalid input check that the parser only accepts well-formed // IntegerSets. The tests with well-formed input compare the returned FACs to // manually constructed FACs with a PresburgerSet equality check. // //===----------------------------------------------------------------------===// #include "Parser.h" #include using namespace mlir; using namespace presburger; /// Construct a IntegerPolyhedron from a set of inequality, equality, and /// division constraints. static IntegerPolyhedron makeFACFromConstraints( unsigned dims, unsigned syms, ArrayRef> ineqs, ArrayRef> eqs = {}, ArrayRef, int64_t>> divs = {}) { IntegerPolyhedron fac(ineqs.size(), eqs.size(), dims + syms + 1, PresburgerSpace::getSetSpace(dims, syms, 0)); for (const auto &div : divs) fac.addLocalFloorDiv(div.first, div.second); for (const auto &eq : eqs) fac.addEquality(eq); for (const auto &ineq : ineqs) fac.addInequality(ineq); return fac; } /// Parses and compares the `str` to the `ex`. The equality check is performed /// by using PresburgerSet::isEqual static bool parseAndCompare(StringRef str, const IntegerPolyhedron &ex) { IntegerPolyhedron poly = parseIntegerPolyhedron(str); return PresburgerSet(poly).isEqual(PresburgerSet(ex)); } TEST(ParseFACTest, ParseAndCompareTest) { // simple ineq EXPECT_TRUE(parseAndCompare("(x)[] : (x >= 0)", makeFACFromConstraints(1, 0, {{1, 0}}))); // simple eq EXPECT_TRUE(parseAndCompare("(x)[] : (x == 0)", makeFACFromConstraints(1, 0, {}, {{1, 0}}))); // multiple constraints EXPECT_TRUE(parseAndCompare("(x)[] : (7 * x >= 0, -7 * x + 5 >= 0)", makeFACFromConstraints(1, 0, {{7, 0}, {-7, 5}}))); // multiple dimensions EXPECT_TRUE(parseAndCompare("(x,y,z)[] : (x + y - z >= 0)", makeFACFromConstraints(3, 0, {{1, 1, -1, 0}}))); // dimensions and symbols EXPECT_TRUE( parseAndCompare("(x,y,z)[a,b] : (x + y - z + 2 * a - 15 * b >= 0)", makeFACFromConstraints(3, 2, {{1, 1, -1, 2, -15, 0}}))); // only symbols EXPECT_TRUE(parseAndCompare("()[a] : (2 * a - 4 == 0)", makeFACFromConstraints(0, 1, {}, {{2, -4}}))); // simple floordiv EXPECT_TRUE(parseAndCompare( "(x, y) : (y - 3 * ((x + y - 13) floordiv 3) - 42 == 0)", makeFACFromConstraints(2, 0, {}, {{0, 1, -3, -42}}, {{{1, 1, -13}, 3}}))); // multiple floordiv EXPECT_TRUE(parseAndCompare( "(x, y) : (y - x floordiv 3 - y floordiv 2 == 0)", makeFACFromConstraints(2, 0, {}, {{0, 1, -1, -1, 0}}, {{{1, 0, 0}, 3}, {{0, 1, 0, 0}, 2}}))); // nested floordiv EXPECT_TRUE(parseAndCompare( "(x, y) : (y - (x + y floordiv 2) floordiv 3 == 0)", makeFACFromConstraints(2, 0, {}, {{0, 1, 0, -1, 0}}, {{{0, 1, 0}, 2}, {{1, 0, 1, 0}, 3}}))); }