tvm
|
A state in the search process. It consists of the current loop structure and a list of transformation steps used to construct it. Each State corresponds to a specific schedule for its ComputeDAG. More...
#include <loop_state.h>
Public Member Functions | |
void | VisitAttrs (tvm::AttrVisitor *v) |
TVM_DECLARE_FINAL_OBJECT_INFO (StateNode, 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) | |
Object & | operator= (const Object &other) |
Object & | operator= (Object &&other) |
Public Attributes | |
Array< Stage > | stages |
Current stages and loop structures. More... | |
Array< Step > | transform_steps |
History transformation steps. More... | |
AttachMap | attach_map |
The attach relations of stages and iterators. This is used to track the compute at operation. More... | |
Optional< ObjectRef > | current_compute_dag |
The up-to-date ComputeDAG of this state. The default value is an empty NullOpt, meaning the dag of this state is the same as the original ComputeDAG in the SearchTask. Otherwise, the stored value is the up-to-date ComputeDAG for this state, meaning some steps (e.g., CacheReadStep/CacheWriteStep) have modified the ComputeDAG. More... | |
bool | concrete |
Indicate whether this state has unfilled tile sizes. A concrete state means that all tile sizes of the state is filled. Only concrete state can be apply to TVM schedule. More... | |
Static Public Attributes | |
static constexpr const char * | _type_key = "auto_scheduler.State" |
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... | |
A state in the search process. It consists of the current loop structure and a list of transformation steps used to construct it. Each State corresponds to a specific schedule for its ComputeDAG.
|
inline |
|
staticconstexpr |
AttachMap tvm::auto_scheduler::StateNode::attach_map |
The attach relations of stages and iterators. This is used to track the compute at operation.
bool tvm::auto_scheduler::StateNode::concrete |
Indicate whether this state has unfilled tile sizes. A concrete state means that all tile sizes of the state is filled. Only concrete state can be apply to TVM schedule.
The up-to-date ComputeDAG of this state. The default value is an empty NullOpt, meaning the dag of this state is the same as the original ComputeDAG in the SearchTask. Otherwise, the stored value is the up-to-date ComputeDAG for this state, meaning some steps (e.g., CacheReadStep/CacheWriteStep) have modified the ComputeDAG.