diff --git a/mlir/include/mlir/Analysis/AffineStructures.h b/mlir/include/mlir/Analysis/AffineStructures.h --- a/mlir/include/mlir/Analysis/AffineStructures.h +++ b/mlir/include/mlir/Analysis/AffineStructures.h @@ -81,6 +81,9 @@ 1, numDims, numSymbols, numLocals) {} + explicit FlatAffineConstraints(const IntegerPolyhedron &poly) + : IntegerPolyhedron(poly) {} + /// Return a system with no constraints, i.e., one which is satisfied by all /// points. static FlatAffineConstraints getUniverse(unsigned numDims = 0, @@ -212,10 +215,6 @@ void projectOut(unsigned pos, unsigned num); inline void projectOut(unsigned pos) { return projectOut(pos, 1); } - /// Sets the `values.size()` identifiers starting at `po`s to the specified - /// values and removes them. - void setAndEliminate(unsigned pos, ArrayRef values); - /// Changes the partition between dimensions and symbols. Depending on the new /// symbol count, either a chunk of trailing dimensional identifiers becomes /// symbols, or some of the leading symbols become dimensions. diff --git a/mlir/include/mlir/Analysis/Presburger/IntegerPolyhedron.h b/mlir/include/mlir/Analysis/Presburger/IntegerPolyhedron.h --- a/mlir/include/mlir/Analysis/Presburger/IntegerPolyhedron.h +++ b/mlir/include/mlir/Analysis/Presburger/IntegerPolyhedron.h @@ -185,6 +185,10 @@ /// Removes all equalities and inequalities. void clearConstraints(); + /// Sets the `values.size()` identifiers starting at `po`s to the specified + /// values and removes them. + void setAndEliminate(unsigned pos, ArrayRef values); + /// Gather positions of all lower and upper bounds of the identifier at `pos`, /// and optionally any equalities on it. In addition, the bounds are to be /// independent of identifiers in position range [`offset`, `offset` + `num`). diff --git a/mlir/include/mlir/Analysis/LinearTransform.h b/mlir/include/mlir/Analysis/Presburger/LinearTransform.h rename from mlir/include/mlir/Analysis/LinearTransform.h rename to mlir/include/mlir/Analysis/Presburger/LinearTransform.h --- a/mlir/include/mlir/Analysis/LinearTransform.h +++ b/mlir/include/mlir/Analysis/Presburger/LinearTransform.h @@ -6,14 +6,14 @@ // //===----------------------------------------------------------------------===// // -// Support for linear transforms and applying them to FlatAffineConstraints. +// Support for linear transforms and applying them to an IntegerPolyhedron. // //===----------------------------------------------------------------------===// #ifndef MLIR_ANALYSIS_LINEARTRANSFORM_H #define MLIR_ANALYSIS_LINEARTRANSFORM_H -#include "mlir/Analysis/AffineStructures.h" +#include "mlir/Analysis/Presburger/IntegerPolyhedron.h" #include "mlir/Analysis/Presburger/Matrix.h" #include "llvm/ADT/SmallVector.h" @@ -33,9 +33,9 @@ static std::pair makeTransformToColumnEchelon(Matrix m); - // Returns a FlatAffineConstraints having a constraint vector vT for every - // constraint vector v in fac, where T is this transform. - FlatAffineConstraints applyTo(const FlatAffineConstraints &fac) const; + // Returns an IntegerPolyhedron having a constraint vector vT for every + // constraint vector v in poly, where T is this transform. + IntegerPolyhedron applyTo(const IntegerPolyhedron &poly) const; // The given vector is interpreted as a row vector v. Post-multiply v with // this transform, say T, and return vT. diff --git a/mlir/lib/Analysis/AffineStructures.cpp b/mlir/lib/Analysis/AffineStructures.cpp --- a/mlir/lib/Analysis/AffineStructures.cpp +++ b/mlir/lib/Analysis/AffineStructures.cpp @@ -11,7 +11,7 @@ //===----------------------------------------------------------------------===// #include "mlir/Analysis/AffineStructures.h" -#include "mlir/Analysis/LinearTransform.h" +#include "mlir/Analysis/Presburger/LinearTransform.h" #include "mlir/Analysis/Presburger/Simplex.h" #include "mlir/Analysis/Presburger/Utils.h" #include "mlir/Dialect/Affine/IR/AffineOps.h" @@ -1090,11 +1090,11 @@ LinearTransform::makeTransformToColumnEchelon(std::move(m)); const LinearTransform &transform = result.second; // 1) Apply T to S to obtain S*T. - FlatAffineConstraints transformedSet = transform.applyTo(*this); + IntegerPolyhedron transformedSet = transform.applyTo(*this); // 2) Remove the unbounded dimensions and constraints involving them to // obtain a bounded set. - FlatAffineConstraints boundedSet = transformedSet; + FlatAffineConstraints boundedSet(transformedSet); unsigned numBoundedDims = result.first; unsigned numUnboundedDims = getNumIds() - numBoundedDims; removeConstraintsInvolvingSuffixDims(boundedSet, numUnboundedDims); @@ -1111,7 +1111,7 @@ // 4) Substitute the values of the bounded dimensions into S*T to obtain a // full-dimensional cone, which necessarily contains an integer sample. transformedSet.setAndEliminate(0, *boundedSample); - FlatAffineConstraints &cone = transformedSet; + IntegerPolyhedron &cone = transformedSet; // 5) Obtain an integer sample from the cone. // @@ -1139,10 +1139,10 @@ // negative a_i, so we accomodate this by shifting the inequality by this // amount for the shrunken cone. for (unsigned i = 0, e = cone.getNumInequalities(); i < e; ++i) { - for (unsigned j = 0; j < cone.numIds; ++j) { + for (unsigned j = 0; j < cone.getNumIds(); ++j) { int64_t coeff = cone.atIneq(i, j); if (coeff < 0) - cone.atIneq(i, cone.numIds) += coeff; + cone.atIneq(i, cone.getNumIds()) += coeff; } } @@ -2303,24 +2303,6 @@ return -1; } -void FlatAffineConstraints::setAndEliminate(unsigned pos, - ArrayRef values) { - if (values.empty()) - return; - assert(pos + values.size() <= getNumIds() && - "invalid position or too many values"); - // Setting x_j = p in sum_i a_i x_i + c is equivalent to adding p*a_j to the - // constant term and removing the id x_j. We do this for all the ids - // pos, pos + 1, ... pos + values.size() - 1. - for (unsigned r = 0, e = getNumInequalities(); r < e; r++) - for (unsigned i = 0, numVals = values.size(); i < numVals; ++i) - atIneq(r, getNumCols() - 1) += atIneq(r, pos + i) * values[i]; - for (unsigned r = 0, e = getNumEqualities(); r < e; r++) - for (unsigned i = 0, numVals = values.size(); i < numVals; ++i) - atEq(r, getNumCols() - 1) += atEq(r, pos + i) * values[i]; - removeIdRange(pos, pos + values.size()); -} - LogicalResult FlatAffineConstraints::constantFoldId(unsigned pos) { assert(pos < getNumIds() && "invalid position"); int rowIdx; diff --git a/mlir/lib/Analysis/CMakeLists.txt b/mlir/lib/Analysis/CMakeLists.txt --- a/mlir/lib/Analysis/CMakeLists.txt +++ b/mlir/lib/Analysis/CMakeLists.txt @@ -6,7 +6,6 @@ CallGraph.cpp DataFlowAnalysis.cpp DataLayoutAnalysis.cpp - LinearTransform.cpp Liveness.cpp LoopAnalysis.cpp NestedMatcher.cpp @@ -48,7 +47,6 @@ add_mlir_library(MLIRLoopAnalysis AffineAnalysis.cpp AffineStructures.cpp - LinearTransform.cpp LoopAnalysis.cpp NestedMatcher.cpp PresburgerSet.cpp diff --git a/mlir/lib/Analysis/Presburger/CMakeLists.txt b/mlir/lib/Analysis/Presburger/CMakeLists.txt --- a/mlir/lib/Analysis/Presburger/CMakeLists.txt +++ b/mlir/lib/Analysis/Presburger/CMakeLists.txt @@ -1,5 +1,6 @@ add_mlir_library(MLIRPresburger IntegerPolyhedron.cpp + LinearTransform.cpp Matrix.cpp Simplex.cpp Utils.cpp diff --git a/mlir/lib/Analysis/Presburger/IntegerPolyhedron.cpp b/mlir/lib/Analysis/Presburger/IntegerPolyhedron.cpp --- a/mlir/lib/Analysis/Presburger/IntegerPolyhedron.cpp +++ b/mlir/lib/Analysis/Presburger/IntegerPolyhedron.cpp @@ -285,6 +285,24 @@ return true; } +void IntegerPolyhedron::setAndEliminate(unsigned pos, + ArrayRef values) { + if (values.empty()) + return; + assert(pos + values.size() <= getNumIds() && + "invalid position or too many values"); + // Setting x_j = p in sum_i a_i x_i + c is equivalent to adding p*a_j to the + // constant term and removing the id x_j. We do this for all the ids + // pos, pos + 1, ... pos + values.size() - 1. + for (unsigned r = 0, e = getNumInequalities(); r < e; r++) + for (unsigned i = 0, numVals = values.size(); i < numVals; ++i) + atIneq(r, getNumCols() - 1) += atIneq(r, pos + i) * values[i]; + for (unsigned r = 0, e = getNumEqualities(); r < e; r++) + for (unsigned i = 0, numVals = values.size(); i < numVals; ++i) + atEq(r, getNumCols() - 1) += atEq(r, pos + i) * values[i]; + removeIdRange(pos, pos + values.size()); +} + void IntegerPolyhedron::printSpace(raw_ostream &os) const { os << "\nConstraints (" << getNumDimIds() << " dims, " << getNumSymbolIds() << " symbols, " << getNumLocalIds() << " locals), (" << getNumConstraints() diff --git a/mlir/lib/Analysis/LinearTransform.cpp b/mlir/lib/Analysis/Presburger/LinearTransform.cpp rename from mlir/lib/Analysis/LinearTransform.cpp rename to mlir/lib/Analysis/Presburger/LinearTransform.cpp --- a/mlir/lib/Analysis/LinearTransform.cpp +++ b/mlir/lib/Analysis/Presburger/LinearTransform.cpp @@ -6,8 +6,8 @@ // //===----------------------------------------------------------------------===// -#include "mlir/Analysis/LinearTransform.h" -#include "mlir/Analysis/AffineStructures.h" +#include "mlir/Analysis/Presburger/LinearTransform.h" +#include "mlir/Analysis/Presburger/IntegerPolyhedron.h" namespace mlir { @@ -135,12 +135,12 @@ return result; } -FlatAffineConstraints -LinearTransform::applyTo(const FlatAffineConstraints &fac) const { - FlatAffineConstraints result(fac.getNumIds()); +IntegerPolyhedron +LinearTransform::applyTo(const IntegerPolyhedron &poly) const { + IntegerPolyhedron result(poly.getNumIds()); - for (unsigned i = 0, e = fac.getNumEqualities(); i < e; ++i) { - ArrayRef eq = fac.getEquality(i); + for (unsigned i = 0, e = poly.getNumEqualities(); i < e; ++i) { + ArrayRef eq = poly.getEquality(i); int64_t c = eq.back(); @@ -149,8 +149,8 @@ result.addEquality(newEq); } - for (unsigned i = 0, e = fac.getNumInequalities(); i < e; ++i) { - ArrayRef ineq = fac.getInequality(i); + for (unsigned i = 0, e = poly.getNumInequalities(); i < e; ++i) { + ArrayRef ineq = poly.getInequality(i); int64_t c = ineq.back(); diff --git a/mlir/unittests/Analysis/CMakeLists.txt b/mlir/unittests/Analysis/CMakeLists.txt --- a/mlir/unittests/Analysis/CMakeLists.txt +++ b/mlir/unittests/Analysis/CMakeLists.txt @@ -2,7 +2,6 @@ AffineStructuresParser.cpp AffineStructuresParserTest.cpp AffineStructuresTest.cpp - LinearTransformTest.cpp PresburgerSetTest.cpp ) diff --git a/mlir/unittests/Analysis/Presburger/CMakeLists.txt b/mlir/unittests/Analysis/Presburger/CMakeLists.txt --- a/mlir/unittests/Analysis/Presburger/CMakeLists.txt +++ b/mlir/unittests/Analysis/Presburger/CMakeLists.txt @@ -1,5 +1,6 @@ add_mlir_unittest(MLIRPresburgerTests IntegerPolyhedronTest.cpp + LinearTransformTest.cpp MatrixTest.cpp SimplexTest.cpp ../AffineStructuresParser.cpp diff --git a/mlir/unittests/Analysis/LinearTransformTest.cpp b/mlir/unittests/Analysis/Presburger/LinearTransformTest.cpp rename from mlir/unittests/Analysis/LinearTransformTest.cpp rename to mlir/unittests/Analysis/Presburger/LinearTransformTest.cpp --- a/mlir/unittests/Analysis/LinearTransformTest.cpp +++ b/mlir/unittests/Analysis/Presburger/LinearTransformTest.cpp @@ -6,7 +6,7 @@ // //===----------------------------------------------------------------------===// -#include "mlir/Analysis/LinearTransform.h" +#include "mlir/Analysis/Presburger/LinearTransform.h" #include #include