tvm
Public Member Functions | Public Attributes | Static Public Attributes | List of all members
tvm::te::TensorComputeOpNode Class Reference

A TenorCompute op that compute a tensor with an tensor intrinsic. More...

#include <operation.h>

Inheritance diagram for tvm::te::TensorComputeOpNode:
Collaboration diagram for tvm::te::TensorComputeOpNode:

Public Member Functions

 TensorComputeOpNode ()
 constructor More...
 
int num_outputs () const final
 
DataType output_dtype (size_t i) const final
 Get data type. i-th output tensor. More...
 
Array< TensorInputTensors () const final
 List all the input Tensors. More...
 
Operation ReplaceInputs (const Operation &self, const std::unordered_map< Tensor, Tensor > &rmap) const final
 Replace the input of the operation by pattern specified by rmap. More...
 
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 final
 Propagate the bounds to inputs. More...
 
Stmt BuildProvide (const Stage &stage, const std::unordered_map< IterVar, Range > &dom_map, bool debug_keep_trivial_loop) const final
 Build the statement that provide the output tensors. More...
 
size_t num_schedulable_dims () const final
 
void VisitAttrs (AttrVisitor *v)
 
 TVM_DECLARE_FINAL_OBJECT_INFO (TensorComputeOpNode, BaseComputeOpNode)
 
- Public Member Functions inherited from tvm::te::BaseComputeOpNode
Array< IterVarroot_iter_vars () const final
 
Array< PrimExproutput_shape (size_t idx) const final
 Get shape of i-th output tensor. More...
 
void GatherBound (const Operation &self, const std::unordered_map< Tensor, TensorDom > &tensor_dom, std::unordered_map< IterVar, Range > *out_dom_map) const final
 Gather the bound from output tensor. Set the range of each root_iter_vars in the op to out_dom_map. More...
 
Stmt BuildRealize (const Stage &stage, const std::unordered_map< IterVar, Range > &realize_map, const Stmt &body, String storage_scope="") const final
 Build the Realize statement that realizes the op's output tensors. More...
 
 TVM_DECLARE_BASE_OBJECT_INFO (BaseComputeOpNode, OperationNode)
 
- Public Member Functions inherited from tvm::te::OperationNode
virtual ~OperationNode ()
 
 TVM_DECLARE_BASE_OBJECT_INFO (OperationNode, Object)
 
- Public Member Functions inherited from tvm::runtime::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)
 
Objectoperator= (const Object &other)
 
Objectoperator= (Object &&other)
 

Public Attributes

int schedulable_ndim
 number of axes that can be scheduled More...
 
TensorIntrin intrin
 TensorIntrin used to compute. More...
 
Array< Tensorinputs
 input tensors of intrin More...
 
Array< Regioninput_regions
 region of input tensors More...
 
Array< PrimExprscalar_inputs
 scalar expression inputs More...
 
- Public Attributes inherited from tvm::te::BaseComputeOpNode
Array< IterVaraxis
 IterVar on each axis. More...
 
Array< IterVarreduce_axis
 IterVar on each reduction axis, if the body is a Reduce. More...
 
- Public Attributes inherited from tvm::te::OperationNode
std::string name
 optional name of the operation More...
 
std::string tag
 optional tag of the operation More...
 
Map< String, ObjectRefattrs
 additional attributes of the operation More...
 

Static Public Attributes

static constexpr const char * _type_key = "TensorComputeOp"
 
- Static Public Attributes inherited from tvm::te::BaseComputeOpNode
static constexpr const char * _type_key = "BaseComputeOp"
 
- Static Public Attributes inherited from tvm::te::OperationNode
static constexpr const char * _type_key = "Operation"
 
- Static Public Attributes inherited from tvm::runtime::Object
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

- Public Types inherited from tvm::runtime::Object
typedef void(* FDeleter) (Object *self)
 Object deleter. More...
 
using RefCounterType = std::atomic< int32_t >
 
- Static Public Member Functions inherited from tvm::runtime::Object
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 ()
 
- Protected Member Functions inherited from tvm::runtime::Object
void IncRef ()
 developer function, increases reference counter. More...
 
void DecRef ()
 developer function, decrease reference counter. More...
 
- Static Protected Member Functions inherited from tvm::runtime::Object
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...
 
- Protected Attributes inherited from tvm::runtime::Object
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...
 

Detailed Description

A TenorCompute op that compute a tensor with an tensor intrinsic.

Constructor & Destructor Documentation

◆ TensorComputeOpNode()

tvm::te::TensorComputeOpNode::TensorComputeOpNode ( )
inline

constructor

Member Function Documentation

◆ BuildProvide()

Stmt tvm::te::TensorComputeOpNode::BuildProvide ( const Stage stage,
const std::unordered_map< IterVar, Range > &  dom_map,
bool  debug_keep_trivial_loop 
) const
finalvirtual

Build the statement that provide the output tensors.

Parameters
stageThe schedule stage of the op.
dom_mapThe domain map of all iteration domains.
debug_keep_trivial_loopWhether keep trivial loops with extent of 1
Returns
A statement that add production and wraps consumer.

Implements tvm::te::OperationNode.

◆ InputTensors()

Array<Tensor> tvm::te::TensorComputeOpNode::InputTensors ( ) const
finalvirtual

List all the input Tensors.

Returns
List of input tensors.

Implements tvm::te::OperationNode.

◆ num_outputs()

int tvm::te::TensorComputeOpNode::num_outputs ( ) const
finalvirtual
Returns
number of outputs

Implements tvm::te::OperationNode.

◆ num_schedulable_dims()

size_t tvm::te::TensorComputeOpNode::num_schedulable_dims ( ) const
finalvirtual

◆ output_dtype()

DataType tvm::te::TensorComputeOpNode::output_dtype ( size_t  i) const
finalvirtual

Get data type. i-th output tensor.

Parameters
iThe output index.
Returns
type of i-th output.

Implements tvm::te::OperationNode.

◆ PropBoundToInputs()

void tvm::te::TensorComputeOpNode::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
finalvirtual

Propagate the bounds to inputs.

Parameters
selfThe reference to self.
analyzerThe analyzer to be used in the function.
dom_mapthe domain map of Variables(corresponds to root_iter_vars)
out_dom_mapThe output domain. The function is only asked to fill the bounds for Tensors that is already in the out_dom_map

Implements tvm::te::OperationNode.

◆ ReplaceInputs()

Operation tvm::te::TensorComputeOpNode::ReplaceInputs ( const Operation self,
const std::unordered_map< Tensor, Tensor > &  rmap 
) const
finalvirtual

Replace the input of the operation by pattern specified by rmap.

Parameters
selfThe reference to self.
rmapThe replacement map.
Returns
self if nothing is replaced, otherwise return replaced op.

Implements tvm::te::OperationNode.

◆ TVM_DECLARE_FINAL_OBJECT_INFO()

tvm::te::TensorComputeOpNode::TVM_DECLARE_FINAL_OBJECT_INFO ( TensorComputeOpNode  ,
BaseComputeOpNode   
)

◆ VisitAttrs()

void tvm::te::TensorComputeOpNode::VisitAttrs ( AttrVisitor v)
inline

Member Data Documentation

◆ _type_key

constexpr const char* tvm::te::TensorComputeOpNode::_type_key = "TensorComputeOp"
staticconstexpr

◆ input_regions

Array<Region> tvm::te::TensorComputeOpNode::input_regions

region of input tensors

◆ inputs

Array<Tensor> tvm::te::TensorComputeOpNode::inputs

input tensors of intrin

◆ intrin

TensorIntrin tvm::te::TensorComputeOpNode::intrin

TensorIntrin used to compute.

◆ scalar_inputs

Array<PrimExpr> tvm::te::TensorComputeOpNode::scalar_inputs

scalar expression inputs

◆ schedulable_ndim

int tvm::te::TensorComputeOpNode::schedulable_ndim

number of axes that can be scheduled


The documentation for this class was generated from the following file: