tvm
|
Base class of all operation nodes. More...
#include <operation.h>
Public Member Functions | |
virtual | ~OperationNode () |
virtual int | num_outputs () const =0 |
virtual Array< IterVar > | root_iter_vars () const =0 |
virtual DataType | output_dtype (size_t i) const =0 |
Get data type. i-th output tensor. More... | |
virtual Array< PrimExpr > | output_shape (size_t i) const =0 |
Get shape of i-th output tensor. More... | |
virtual Array< Tensor > | InputTensors () const =0 |
List all the input Tensors. More... | |
virtual Operation | ReplaceInputs (const Operation &self, const std::unordered_map< Tensor, Tensor > &rmap) const =0 |
Replace the input of the operation by pattern specified by rmap. More... | |
virtual void | PropBoundToInputs (const Operation &self, arith::Analyzer *analyzer, const std::unordered_map< const VarNode *, IntSet > &dom_map, std::unordered_map< Tensor, TensorDom > *out_dom_map) const =0 |
Propagate the bounds to inputs. More... | |
virtual void | GatherBound (const Operation &self, const std::unordered_map< Tensor, TensorDom > &tensor_dom, std::unordered_map< IterVar, Range > *out_dom_map) const =0 |
Gather the bound from output tensor. Set the range of each root_iter_vars in the op to out_dom_map. More... | |
virtual Stmt | BuildRealize (const Stage &stage, const std::unordered_map< IterVar, Range > &realize_map, const Stmt &body, String storage_scope="") const =0 |
Build the Realize statement that realizes the op's output tensors. More... | |
virtual Stmt | BuildProvide (const Stage &stage, const std::unordered_map< IterVar, Range > &dom_map, bool debug_keep_trivial_loop) const =0 |
Build the statement that provide the output tensors. More... | |
TVM_DECLARE_BASE_OBJECT_INFO (OperationNode, Object) | |
![]() | |
uint32_t | type_index () const |
std::string | GetTypeKey () const |
size_t | GetTypeKeyHash () const |
template<typename TargetType > | |
bool | IsInstance () const |
bool | unique () const |
Object () | |
Object (const Object &other) | |
Object (Object &&other) | |
Object & | operator= (const Object &other) |
Object & | operator= (Object &&other) |
Public Attributes | |
std::string | name |
optional name of the operation More... | |
std::string | tag |
optional tag of the operation More... | |
Map< String, ObjectRef > | attrs |
additional attributes of the operation More... | |
Static Public Attributes | |
static constexpr const char * | _type_key = "Operation" |
![]() | |
static constexpr const char * | _type_key = "runtime.Object" |
static constexpr bool | _type_final = false |
static constexpr uint32_t | _type_child_slots = 0 |
static constexpr bool | _type_child_slots_can_overflow = true |
static constexpr bool | _type_has_method_visit_attrs = true |
static constexpr bool | _type_has_method_sequal_reduce = false |
static constexpr bool | _type_has_method_shash_reduce = false |
static constexpr uint32_t | _type_index = TypeIndex::kDynamic |
Additional Inherited Members | |
![]() | |
typedef void(* | FDeleter) (Object *self) |
Object deleter. More... | |
using | RefCounterType = std::atomic< int32_t > |
![]() | |
static std::string | TypeIndex2Key (uint32_t tindex) |
Get the type key of the corresponding index from runtime. More... | |
static size_t | TypeIndex2KeyHash (uint32_t tindex) |
Get the type key hash of the corresponding index from runtime. More... | |
static uint32_t | TypeKey2Index (const std::string &key) |
Get the type index of the corresponding key from runtime. More... | |
static uint32_t | _GetOrAllocRuntimeTypeIndex () |
static uint32_t | RuntimeTypeIndex () |
![]() | |
void | IncRef () |
developer function, increases reference counter. More... | |
void | DecRef () |
developer function, decrease reference counter. More... | |
![]() | |
static uint32_t | GetOrAllocRuntimeTypeIndex (const std::string &key, uint32_t static_tindex, uint32_t parent_tindex, uint32_t type_child_slots, bool type_child_slots_can_overflow) |
Get the type index using type key. More... | |
![]() | |
uint32_t | type_index_ {0} |
Type index(tag) that indicates the type of the object. More... | |
RefCounterType | ref_counter_ {0} |
The internal reference counter. More... | |
FDeleter | deleter_ = nullptr |
deleter of this object to enable customized allocation. If the deleter is nullptr, no deletion will be performed. The creator of the object must always set the deleter field properly. More... | |
Base class of all operation nodes.
|
inlinevirtual |
|
pure virtual |
Build the statement that provide the output tensors.
stage | The schedule stage of the op. |
dom_map | The domain map of all iteration domains. |
debug_keep_trivial_loop | Whether keep trivial loops with extent of 1 |
Implemented in tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, tvm::te::TensorComputeOpNode, tvm::te::ComputeOpNode, and tvm::te::PlaceholderOpNode.
|
pure virtual |
Build the Realize statement that realizes the op's output tensors.
stage | the op's stage. |
realize_map | The realization domain map of the operators. |
body | The body that is going to get |
storage_scope | The storage scope associated with this realization |
Implemented in tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, tvm::te::BaseComputeOpNode, and tvm::te::PlaceholderOpNode.
|
pure virtual |
Gather the bound from output tensor. Set the range of each root_iter_vars in the op to out_dom_map.
self | The reference to self. |
tensor_dom | Domain map of Tensor->access set of each dimension. |
out_dom_map | The output domain map of each IterVar to be setted. |
Implemented in tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, tvm::te::BaseComputeOpNode, and tvm::te::PlaceholderOpNode.
List all the input Tensors.
Implemented in tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, tvm::te::TensorComputeOpNode, tvm::te::ComputeOpNode, and tvm::te::PlaceholderOpNode.
|
pure virtual |
Implemented in tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, tvm::te::TensorComputeOpNode, tvm::te::ComputeOpNode, and tvm::te::PlaceholderOpNode.
|
pure virtual |
Get data type. i-th output tensor.
i | The output index. |
Implemented in tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, tvm::te::TensorComputeOpNode, tvm::te::ComputeOpNode, and tvm::te::PlaceholderOpNode.
Get shape of i-th output tensor.
i | The output index. |
Implemented in tvm::te::BaseComputeOpNode, tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, and tvm::te::PlaceholderOpNode.
|
pure virtual |
Propagate the bounds to inputs.
self | The reference to self. |
analyzer | The analyzer to be used in the function. |
dom_map | the domain map of Variables(corresponds to root_iter_vars) |
out_dom_map | The output domain. The function is only asked to fill the bounds for Tensors that is already in the out_dom_map |
Implemented in tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, tvm::te::TensorComputeOpNode, tvm::te::ComputeOpNode, and tvm::te::PlaceholderOpNode.
|
pure virtual |
Replace the input of the operation by pattern specified by rmap.
self | The reference to self. |
rmap | The replacement map. |
Implemented in tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, tvm::te::TensorComputeOpNode, tvm::te::ComputeOpNode, and tvm::te::PlaceholderOpNode.
Implemented in tvm::te::HybridOpNode, tvm::te::ExternOpNode, tvm::te::ScanOpNode, tvm::te::BaseComputeOpNode, and tvm::te::PlaceholderOpNode.
tvm::te::OperationNode::TVM_DECLARE_BASE_OBJECT_INFO | ( | OperationNode | , |
Object | |||
) |
|
staticconstexpr |
std::string tvm::te::OperationNode::name |
optional name of the operation
std::string tvm::te::OperationNode::tag |
optional tag of the operation