[MLIR][Presburger] Use SmallVector instead of std::vector in getLocalRepr

Use `SmallVector` instead of `std::vector` in `getLocalRepr` function.
 Also, fix the casing of a variable.

Reviewed By: arjunp

Differential Revision: https://reviews.llvm.org/D118722
This commit is contained in:
Prashant Kumar 2022-02-02 01:37:53 +05:30
parent d5bb0de75e
commit 3cc5447728
6 changed files with 27 additions and 24 deletions

View File

@ -285,12 +285,14 @@ public:
/// and the denominators in `denominators`. If no explicit representation /// and the denominators in `denominators`. If no explicit representation
/// could be found for the `i^th` local identifier, `denominators[i]` is set /// could be found for the `i^th` local identifier, `denominators[i]` is set
/// to 0. /// to 0.
void getLocalReprs(std::vector<SmallVector<int64_t, 8>> &dividends, void
SmallVector<unsigned, 4> &denominators, getLocalReprs(SmallVectorImpl<SmallVector<int64_t, 8>> &dividends,
std::vector<presburger_utils::MaybeLocalRepr> &repr) const; SmallVectorImpl<unsigned> &denominators,
void getLocalReprs(std::vector<presburger_utils::MaybeLocalRepr> &repr) const; SmallVectorImpl<presburger_utils::MaybeLocalRepr> &repr) const;
void getLocalReprs(std::vector<SmallVector<int64_t, 8>> &dividends, void
SmallVector<unsigned, 4> &denominators) const; getLocalReprs(SmallVectorImpl<presburger_utils::MaybeLocalRepr> &repr) const;
void getLocalReprs(SmallVectorImpl<SmallVector<int64_t, 8>> &dividends,
SmallVectorImpl<unsigned> &denominators) const;
/// The type of bound: equal, lower bound or upper bound. /// The type of bound: equal, lower bound or upper bound.
enum BoundType { EQ, LB, UB }; enum BoundType { EQ, LB, UB };

View File

@ -65,7 +65,7 @@ MaybeLocalRepr computeSingleVarRepr(const IntegerPolyhedron &cst,
/// the divisions are not merged. `merge` can also do side effects, For example /// the divisions are not merged. `merge` can also do side effects, For example
/// it can merge the local identifiers in IntegerPolyhedron. /// it can merge the local identifiers in IntegerPolyhedron.
void removeDuplicateDivs( void removeDuplicateDivs(
std::vector<SmallVector<int64_t, 8>> &divs, SmallVectorImpl<SmallVector<int64_t, 8>> &divs,
SmallVectorImpl<unsigned> &denoms, unsigned localOffset, SmallVectorImpl<unsigned> &denoms, unsigned localOffset,
llvm::function_ref<bool(unsigned i, unsigned j)> merge); llvm::function_ref<bool(unsigned i, unsigned j)> merge);

View File

@ -829,23 +829,24 @@ bool IntegerPolyhedron::containsPoint(ArrayRef<int64_t> point) const {
return true; return true;
} }
void IntegerPolyhedron::getLocalReprs(std::vector<MaybeLocalRepr> &repr) const { void IntegerPolyhedron::getLocalReprs(
std::vector<SmallVector<int64_t, 8>> dividends(getNumLocalIds()); SmallVectorImpl<MaybeLocalRepr> &repr) const {
SmallVector<SmallVector<int64_t, 8>> dividends(getNumLocalIds());
SmallVector<unsigned, 4> denominators(getNumLocalIds()); SmallVector<unsigned, 4> denominators(getNumLocalIds());
getLocalReprs(dividends, denominators, repr); getLocalReprs(dividends, denominators, repr);
} }
void IntegerPolyhedron::getLocalReprs( void IntegerPolyhedron::getLocalReprs(
std::vector<SmallVector<int64_t, 8>> &dividends, SmallVectorImpl<SmallVector<int64_t, 8>> &dividends,
SmallVector<unsigned, 4> &denominators) const { SmallVectorImpl<unsigned> &denominators) const {
std::vector<MaybeLocalRepr> repr(getNumLocalIds()); SmallVector<MaybeLocalRepr> repr(getNumLocalIds());
getLocalReprs(dividends, denominators, repr); getLocalReprs(dividends, denominators, repr);
} }
void IntegerPolyhedron::getLocalReprs( void IntegerPolyhedron::getLocalReprs(
std::vector<SmallVector<int64_t, 8>> &dividends, SmallVectorImpl<SmallVector<int64_t, 8>> &dividends,
SmallVector<unsigned, 4> &denominators, SmallVectorImpl<unsigned> &denominators,
std::vector<MaybeLocalRepr> &repr) const { SmallVectorImpl<MaybeLocalRepr> &repr) const {
repr.resize(getNumLocalIds()); repr.resize(getNumLocalIds());
dividends.resize(getNumLocalIds()); dividends.resize(getNumLocalIds());
@ -1103,7 +1104,7 @@ void IntegerPolyhedron::mergeLocalIds(IntegerPolyhedron &other) {
polyB.insertLocalId(0, initLocals); polyB.insertLocalId(0, initLocals);
// Get division representations from each poly. // Get division representations from each poly.
std::vector<SmallVector<int64_t, 8>> divsA, divsB; SmallVector<SmallVector<int64_t, 8>> divsA, divsB;
SmallVector<unsigned, 4> denomsA, denomsB; SmallVector<unsigned, 4> denomsA, denomsB;
polyA.getLocalReprs(divsA, denomsA); polyA.getLocalReprs(divsA, denomsA);
polyB.getLocalReprs(divsB, denomsB); polyB.getLocalReprs(divsB, denomsB);

View File

@ -213,7 +213,7 @@ static void subtractRecursively(IntegerPolyhedron &b, Simplex &simplex,
// Find out which inequalities of sI correspond to division inequalities for // Find out which inequalities of sI correspond to division inequalities for
// the local variables of sI. // the local variables of sI.
std::vector<MaybeLocalRepr> repr(sI.getNumLocalIds()); SmallVector<MaybeLocalRepr> repr(sI.getNumLocalIds());
sI.getLocalReprs(repr); sI.getLocalReprs(repr);
// Add sI's locals to b, after b's locals. Also add b's locals to sI, before // Add sI's locals to b, after b's locals. Also add b's locals to sI, before

View File

@ -160,14 +160,14 @@ static LogicalResult getDivRepr(const IntegerPolyhedron &cst, unsigned pos,
// Extract divisor, the divisor can be negative and hence its sign information // Extract divisor, the divisor can be negative and hence its sign information
// is stored in `signDiv` to reverse the sign of dividend's coefficients. // is stored in `signDiv` to reverse the sign of dividend's coefficients.
// Equality must involve the pos-th variable and hence `temp_div` != 0. // Equality must involve the pos-th variable and hence `tempDiv` != 0.
int64_t temp_div = cst.atEq(eqInd, pos); int64_t tempDiv = cst.atEq(eqInd, pos);
if (temp_div == 0) if (tempDiv == 0)
return failure(); return failure();
int64_t signDiv = temp_div < 0 ? -1 : 1; int64_t signDiv = tempDiv < 0 ? -1 : 1;
// The divisor is always a positive integer. // The divisor is always a positive integer.
divisor = temp_div * signDiv; divisor = tempDiv * signDiv;
expr.resize(cst.getNumCols(), 0); expr.resize(cst.getNumCols(), 0);
for (unsigned i = 0, e = cst.getNumIds(); i < e; ++i) for (unsigned i = 0, e = cst.getNumIds(); i < e; ++i)
@ -254,7 +254,7 @@ MaybeLocalRepr presburger_utils::computeSingleVarRepr(
} }
void presburger_utils::removeDuplicateDivs( void presburger_utils::removeDuplicateDivs(
std::vector<SmallVector<int64_t, 8>> &divs, SmallVectorImpl<SmallVector<int64_t, 8>> &divs,
SmallVectorImpl<unsigned> &denoms, unsigned localOffset, SmallVectorImpl<unsigned> &denoms, unsigned localOffset,
llvm::function_ref<bool(unsigned i, unsigned j)> merge) { llvm::function_ref<bool(unsigned i, unsigned j)> merge) {

View File

@ -624,7 +624,7 @@ static void checkDivisionRepresentation(
const std::vector<SmallVector<int64_t, 8>> &expectedDividends, const std::vector<SmallVector<int64_t, 8>> &expectedDividends,
const SmallVectorImpl<unsigned> &expectedDenominators) { const SmallVectorImpl<unsigned> &expectedDenominators) {
std::vector<SmallVector<int64_t, 8>> dividends; SmallVector<SmallVector<int64_t, 8>> dividends;
SmallVector<unsigned, 4> denominators; SmallVector<unsigned, 4> denominators;
poly.getLocalReprs(dividends, denominators); poly.getLocalReprs(dividends, denominators);