82 const Split &split,
bool is_update,
const std::string &prefix,
83 std::map<std::string, Expr> &dim_extent_alignment);
88 const Split &split,
const std::string &prefix);
Base classes for Halide expressions (Halide::Expr) and statements (Halide::Internal::Stmt)
Defines the internal representation of the schedule for a function.
std::vector< ApplySplitResult > apply_split(const Split &split, bool is_update, const std::string &prefix, std::map< std::string, Expr > &dim_extent_alignment)
Given a Split schedule on a definition (init or update), return a list of of predicates on the defini...
std::vector< std::pair< std::string, Expr > > compute_loop_bounds_after_split(const Split &split, const std::string &prefix)
Compute the loop bounds of the new dimensions resulting from applying the split schedules using the l...
This file defines the class FunctionDAG, which is our representation of a Halide pipeline,...
@ Internal
Not visible externally, similar to 'static' linkage in C.
A fragment of Halide syntax.
bool is_substitution_in_calls() const
ApplySplitResult(Expr val, Type t=Predicate)
bool is_substitution() const
bool is_blend_provides() const
bool is_predicate_calls() const
bool is_predicate_provides() const
ApplySplitResult(const std::string &n, Expr val, Type t)
bool is_substitution_in_provides() const
bool is_predicate() const
The statement form of a let node.