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

Similar to FollowSplitStep, but uses split factors from multiple steps. More...

#include <transform_step.h>

Inheritance diagram for tvm::auto_scheduler::FollowFusedSplitStepNode:
Collaboration diagram for tvm::auto_scheduler::FollowFusedSplitStepNode:

Public Member Functions

void WriteToRecord (dmlc::JSONWriter *writer) const final
 Serialize the current step record to JSONWriter. More...
 
Optional< IntegerExtractSplitLength (const Array< Step > &transform_steps) const
 Extract split length. More...
 
Array< IteratorApplyToState (State *state) const
 Apply the current step to State. More...
 
Array< tir::IterVarApplyToSchedule (Array< te::Stage > *stages, StageToAxesMap *stage_to_axes, const Array< Step > &transform_steps) const
 Apply the current step to tvm.schedule. More...
 
String PrintAsPythonAPI (Array< te::Stage > *stages, StageToAxesMap *stage_to_axes, const Array< Step > &transform_steps) const
 Print the current step as equivalent python schedule API. More...
 
 TVM_DECLARE_FINAL_OBJECT_INFO (FollowFusedSplitStepNode, 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

int iter_id
 The id of the iter to split. More...
 
Array< Integersrc_step_ids
 The indices of the split steps to be followed in the history. More...
 
int level
 Use the length in this split level. More...
 
bool factor_or_nparts
 If this is true, use factor. Otherwise, use nparts. 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 = "FFSP"
 
static constexpr const char * _type_key = "auto_scheduler.FollowFusedSplitStep"
 
- 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

Similar to FollowSplitStep, but uses split factors from multiple steps.

Note
This can be used for the split in cooperative fetching.

Member Function Documentation

◆ ApplyToSchedule()

Array<tir::IterVar> tvm::auto_scheduler::FollowFusedSplitStepNode::ApplyToSchedule ( Array< te::Stage > *  stages,
StageToAxesMap stage_to_axes,
const Array< Step > &  transform_steps 
) 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.
transform_stepsAn array of history transform steps.
Returns
The iterator results after split.

◆ ApplyToState()

Array<Iterator> tvm::auto_scheduler::FollowFusedSplitStepNode::ApplyToState ( State state) const

Apply the current step to State.

Parameters
stateA mutable pointer to state, which will be updated.
Returns
The iterator results after split.

◆ ExtractSplitLength()

Optional<Integer> tvm::auto_scheduler::FollowFusedSplitStepNode::ExtractSplitLength ( const Array< Step > &  transform_steps) const

Extract split length.

Parameters
transform_stepsAn array of history transform steps.
Returns
Split factor.

◆ PrintAsPythonAPI()

String tvm::auto_scheduler::FollowFusedSplitStepNode::PrintAsPythonAPI ( Array< te::Stage > *  stages,
StageToAxesMap stage_to_axes,
const Array< Step > &  transform_steps 
) 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.
transform_stepsAn array of history transform steps.
Returns
Python schedule code.

◆ TVM_DECLARE_FINAL_OBJECT_INFO()

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

◆ WriteToRecord()

void tvm::auto_scheduler::FollowFusedSplitStepNode::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::FollowFusedSplitStepNode::_type_key = "auto_scheduler.FollowFusedSplitStep"
staticconstexpr

◆ factor_or_nparts

bool tvm::auto_scheduler::FollowFusedSplitStepNode::factor_or_nparts

If this is true, use factor. Otherwise, use nparts.

◆ iter_id

int tvm::auto_scheduler::FollowFusedSplitStepNode::iter_id

The id of the iter to split.

◆ level

int tvm::auto_scheduler::FollowFusedSplitStepNode::level

Use the length in this split level.

◆ record_prefix_str

constexpr const char* tvm::auto_scheduler::FollowFusedSplitStepNode::record_prefix_str = "FFSP"
staticconstexpr

◆ src_step_ids

Array<Integer> tvm::auto_scheduler::FollowFusedSplitStepNode::src_step_ids

The indices of the split steps to be followed in the history.


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