Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Bound #521

Open
wants to merge 25 commits into
base: master
Choose a base branch
from
Open

Bound #521

Show file tree
Hide file tree
Changes from 22 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
d4d492b
add API for split with flag
manya-bansal Oct 29, 2021
b765721
add test for splitUpDown and bound attributes for IndexVars
manya-bansal Nov 30, 2021
cbc872c
start substituting bound rel function calls
manya-bansal Jan 9, 2022
897bb04
add index notation falg
manya-bansal Jan 22, 2022
d6c5bb7
don't add such that node for bound relation
manya-bansal Jan 22, 2022
f2e5cfb
change derive iter
manya-bansal Jan 26, 2022
aa1a114
bound rel node deleted, change workspace tests to reflect changes
manya-bansal Jan 26, 2022
fc86897
api change + new tests
manya-bansal Feb 5, 2022
e74bf06
bounds test file
manya-bansal Feb 13, 2022
9ae9908
bound and rebound test
manya-bansal Feb 13, 2022
ba95326
adding tests for bound
manya-bansal Feb 13, 2022
2cf16af
add more tests
manya-bansal Feb 14, 2022
6dc9ad4
print prov graph
manya-bansal Feb 26, 2022
9ec3e6e
print prov graph
manya-bansal Feb 27, 2022
79f2d47
added an additional test
manya-bansal Feb 27, 2022
ba621eb
merge conflicts
manya-bansal Apr 10, 2022
12af135
change taco-cli-tests.bats to refkect new bound api
manya-bansal Apr 10, 2022
27288ff
ataco-cli-test passing
manya-bansal Apr 12, 2022
a52bb4e
remove assert
manya-bansal Apr 17, 2022
57dd389
check literal split
manya-bansal Apr 17, 2022
c27ef8a
check biunds against literal values
manya-bansal Apr 17, 2022
e21812b
change ir simplify logic + add additional ir tests
manya-bansal Apr 24, 2022
e258dca
remove split up and down
manya-bansal May 30, 2022
af4ff8f
change bound abstraction from indexVar to indexStmt
manya-bansal Jun 6, 2022
b437560
merge upstream
manya-bansal Jun 6, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
22 changes: 22 additions & 0 deletions include/taco/index_notation/index_notation.h
Original file line number Diff line number Diff line change
Expand Up @@ -601,6 +601,8 @@ class IndexStmt : public util::IntrusivePtr<const IndexStmtNode> {
/// variable, a \textit{tail strategy} is employed such as emitting a variable
/// sized loop that handles remaining iterations.
/// Preconditions: splitFactor is a positive nonzero integer
IndexStmt splitUpDown(IndexVar i, IndexVar i1, IndexVar i2, bool split_up, size_t splitFactor) const;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It feels like this shouldn't be a separate API call, but instead an additional argument to the existing split call that takes in an enum, with an enum that has a default value.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Removed: it is not relevant to this pull request


IndexStmt split(IndexVar i, IndexVar i1, IndexVar i2, size_t splitFactor) const; // TODO: TailStrategy

/// The divide transformation splits one index variable into
Expand Down Expand Up @@ -736,8 +738,13 @@ class IndexStmt : public util::IntrusivePtr<const IndexStmtNode> {
/// Preconditions:
/// The precondition for bound is that the computation bounds supplied are
/// correct given the inputs that this code will be run on.
// IndexStmt bound(IndexVar i, IndexVar i1, size_t bound, BoundType bound_type) const;

IndexStmt bound(IndexVar i, IndexVar i1, size_t bound, BoundType bound_type) const;


IndexStmt bound(IndexVar i, size_t bound, BoundType bound_type) const;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You can probably remove the old bound call and replace all users with the new method (I don't think we care that much about backwards compat, and bound doesn't have that many users).


/// The unroll primitive unrolls the corresponding loop by a statically-known
/// integer number of iterations
/// Preconditions: unrollFactor is a positive nonzero integer
Expand Down Expand Up @@ -1031,6 +1038,18 @@ class IndexVar : public IndexExpr, public IndexVarInterface {
/// Returns the name of the index variable.
std::string getName() const;

size_t& getBound() const;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why are these things attached to this index variable instead of tagged to a particular for loop?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Mapping a for all to an index var's bound is not possible since adding schedules replaces the occurrence of the index var from the stmt in certain cases.

Instead, in the updated pull request, we tag this information to a suchThatNode, adding a map that relates the bounded variable, bound size and bound type.


const BoundType& getBoundType() const;

void setBoundType(BoundType boundType);

void setBound(size_t bound);

void bound(size_t bound, BoundType boundType);

bool isBound();

// Need these to overshadow the comparisons in for the IndexExpr instrusive pointer
friend bool operator==(const IndexVar&, const IndexVar&);
friend bool operator<(const IndexVar&, const IndexVar&);
Expand All @@ -1055,6 +1074,9 @@ class IndexVar : public IndexExpr, public IndexVarInterface {

struct IndexVar::Content {
std::string name;
size_t bound;
taco::BoundType boundType;
bool isbound;
};

struct WindowedIndexVar::Content {
Expand Down
42 changes: 8 additions & 34 deletions include/taco/index_notation/provenance_graph.h
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

namespace taco {
struct IndexVarRelNode;
enum IndexVarRelType {UNDEFINED, SPLIT, DIVIDE, POS, FUSE, BOUND, PRECOMPUTE};
enum IndexVarRelType {UNDEFINED, SPLIT, DIVIDE, POS, FUSE, PRECOMPUTE};

/// A pointer class for IndexVarRelNodes provides some operations for all IndexVarRelTypes
class IndexVarRel : public util::IntrusivePtr<const IndexVarRelNode> {
Expand Down Expand Up @@ -244,39 +244,6 @@ struct FuseRelNode : public IndexVarRelNode {

bool operator==(const FuseRelNode&, const FuseRelNode&);

/// The bound relation allows expressing a constraint or value known at compile-time that allows for compile-time optimizations
struct BoundRelNode : public IndexVarRelNode {
BoundRelNode(IndexVar parentVar, IndexVar boundVar, size_t bound, BoundType boundType);

const IndexVar& getParentVar() const;
const IndexVar& getBoundVar() const;
const size_t& getBound() const;
const BoundType& getBoundType() const;

void print(std::ostream& stream) const;
bool equals(const BoundRelNode &rel) const;
std::vector<IndexVar> getParents() const; // parentVar
std::vector<IndexVar> getChildren() const; // boundVar
std::vector<IndexVar> getIrregulars() const; // boundVar

/// Coordinate bounds remain unchanged, only iteration bounds change
std::vector<ir::Expr> computeRelativeBound(std::set<IndexVar> definedVars, std::map<IndexVar, std::vector<ir::Expr>> computedBounds, std::map<IndexVar, ir::Expr> variableExprs, Iterators iterators, ProvenanceGraph provGraph) const;

/// Constrained depending on bound_type
std::vector<ir::Expr> deriveIterBounds(IndexVar indexVar, std::map<IndexVar, std::vector<ir::Expr>> parentIterBounds, std::map<IndexVar, std::vector<ir::Expr>> parentCoordBounds, std::map<taco::IndexVar, taco::ir::Expr> variableNames, Iterators iterators, ProvenanceGraph provGraph) const;

/// parentVar = boundVar
ir::Expr recoverVariable(IndexVar indexVar, std::map<IndexVar, ir::Expr> variableNames, Iterators iterators, std::map<IndexVar, std::vector<ir::Expr>> parentIterBounds, std::map<IndexVar, std::vector<ir::Expr>> parentCoordBounds, ProvenanceGraph provGraph) const;

/// boundVar = parentVar
ir::Stmt recoverChild(IndexVar indexVar, std::map<IndexVar, ir::Expr> relVariables, bool emitVarDecl, Iterators iterators, ProvenanceGraph provGraph) const;
private:
struct Content;
std::shared_ptr<Content> content;
};

bool operator==(const BoundRelNode&, const BoundRelNode&);

/// The precompute relation allows creating a new precomputeVar that is iterated over for the precompute loop and shares same sizes as parentVar
/// This allows precomputeVar to be scheduled separately from the parentVar
struct PrecomputeRelNode : public IndexVarRelNode {
Expand Down Expand Up @@ -310,6 +277,7 @@ class ProvenanceGraph {
public:
ProvenanceGraph() {}
ProvenanceGraph(IndexStmt concreteStmt);


/// Returns the children of a given index variable, {} if no children or if indexVar is not in graph
std::vector<IndexVar> getChildren(IndexVar indexVar) const;
Expand Down Expand Up @@ -390,6 +358,10 @@ class ProvenanceGraph {
/// does the index variable have an exact bound known at compile-time
bool hasExactBound(IndexVar indexVar) const;

void printGraphParent(void) const;

void printGraphChild(void) const;

/// Once indexVar is defined what new variables become recoverable
/// returned in order of recovery (ie if parent being recovered allows its parent to also be recovered then parent comes first)
std::vector<IndexVar> newlyRecoverableParents(IndexVar indexVar, std::set<IndexVar> previouslyDefined) const;
Expand All @@ -411,6 +383,8 @@ class ProvenanceGraph {
/// a `.divide` scheduling operation.
bool isDivided(IndexVar indexVar) const;



private:
std::map<IndexVar, IndexVarRel> childRelMap;
std::map<IndexVar, IndexVarRel> parentRelMap;
Expand Down
Loading