tvm
Public Member Functions | Public Attributes | Static Public Attributes | List of all members
tvm::auto_scheduler::CacheReadStepNode Class Reference

Cache read step that corresponds to te::Schedule::cache_read. More...

#include <transform_step.h>

Inheritance diagram for tvm::auto_scheduler::CacheReadStepNode:
Collaboration diagram for tvm::auto_scheduler::CacheReadStepNode:

Public Member Functions

void WriteToRecord (dmlc::JSONWriter *writer) const final
 Serialize the current step record to JSONWriter. More...
 
int ApplyToState (State *state, const ComputeDAG &dag) const
 Apply the current step to State. More...
 
te::Tensor ApplyToSchedule (Array< te::Stage > *stages, StageToAxesMap *stage_to_axes, te::Schedule *schedule) const
 Apply the current step to tvm.schedule. More...
 
String PrintAsPythonAPI (Array< te::Stage > *stages, StageToAxesMap *stage_to_axes, te::Schedule *schedule) const
 Print the current step as equivalent python schedule API. More...
 
 TVM_DECLARE_FINAL_OBJECT_INFO (CacheReadStepNode, StepNode)
 
- Public Member Functions inherited from tvm::auto_scheduler::StepNode
 TVM_DECLARE_BASE_OBJECT_INFO (StepNode, 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

String scope_name
 The scope name of the newly added read stage. (e.g., local, shared, global) More...
 
Array< Integerreader_stage_ids
 The indices of read stages. More...
 
- Public Attributes inherited from tvm::auto_scheduler::StepNode
int stage_id
 The index of the stage. More...
 

Static Public Attributes

static constexpr const char * record_prefix_str = "CHR"
 
static constexpr const char * _type_key = "auto_scheduler.CacheReadStep"
 
- Static Public Attributes inherited from tvm::auto_scheduler::StepNode
static constexpr const char * _type_key = "auto_scheduler.Step"
 
- 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

Cache read step that corresponds to te::Schedule::cache_read.

Note
Cache read step adds an extra stage to the original ComputeDAG, an up-to-date ComputeDAG will be stored in State's current_compute_dag.

Member Function Documentation

◆ ApplyToSchedule()

te::Tensor tvm::auto_scheduler::CacheReadStepNode::ApplyToSchedule ( Array< te::Stage > *  stages,
StageToAxesMap stage_to_axes,
te::Schedule schedule 
) const

Apply the current step to tvm.schedule.

Parameters
stagesThe list of current stages
stage_to_axesA map that maps stage ot all its iterators.
scheduleA mutable pointer to a te::Schedule.
Returns
The output Tensor of the new added stage.

◆ ApplyToState()

int tvm::auto_scheduler::CacheReadStepNode::ApplyToState ( State state,
const ComputeDAG dag 
) const

Apply the current step to State.

Parameters
stateA mutable pointer to state, which will be updated.
dagThe original ComputeDAG of this state.
Returns
The index of the new added stage.

◆ PrintAsPythonAPI()

String tvm::auto_scheduler::CacheReadStepNode::PrintAsPythonAPI ( Array< te::Stage > *  stages,
StageToAxesMap stage_to_axes,
te::Schedule schedule 
) const

Print the current step as equivalent python schedule API.

Parameters
stagesThe list of current stages
stage_to_axesA map that maps stage ot all its iterators.
scheduleA mutable pointer to a te::Schedule.
Returns
Python schedule code.

◆ TVM_DECLARE_FINAL_OBJECT_INFO()

tvm::auto_scheduler::CacheReadStepNode::TVM_DECLARE_FINAL_OBJECT_INFO ( CacheReadStepNode  ,
StepNode   
)

◆ WriteToRecord()

void tvm::auto_scheduler::CacheReadStepNode::WriteToRecord ( dmlc::JSONWriter *  writer) const
finalvirtual

Serialize the current step record to JSONWriter.

Parameters
writerThe output JSONWriter.

Implements tvm::auto_scheduler::StepNode.

Member Data Documentation

◆ _type_key

constexpr const char* tvm::auto_scheduler::CacheReadStepNode::_type_key = "auto_scheduler.CacheReadStep"
staticconstexpr

◆ reader_stage_ids

Array<Integer> tvm::auto_scheduler::CacheReadStepNode::reader_stage_ids

The indices of read stages.

◆ record_prefix_str

constexpr const char* tvm::auto_scheduler::CacheReadStepNode::record_prefix_str = "CHR"
staticconstexpr

◆ scope_name

String tvm::auto_scheduler::CacheReadStepNode::scope_name

The scope name of the newly added read stage. (e.g., local, shared, global)


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