tvm
Public Member Functions | Static Public Attributes | List of all members
tvm::meta_schedule::SearchStrategyNode Class Referenceabstract

The search strategy for measure candidates generation. More...

#include <search_strategy.h>

Inheritance diagram for tvm::meta_schedule::SearchStrategyNode:
Collaboration diagram for tvm::meta_schedule::SearchStrategyNode:

Public Member Functions

virtual ~SearchStrategyNode ()=default
 Virtual destructor. More...
 
virtual void InitializeWithTuneContext (const TuneContext &context)=0
 Initialize the search strategy with tuning context. More...
 
virtual void PreTuning (int max_trials, int num_trials_per_iter, const Array< tir::Schedule > &design_spaces, const Optional< Database > &database, const Optional< CostModel > &cost_model)=0
 Pre-tuning for the search strategy. More...
 
virtual void PostTuning ()=0
 Post-tuning for the search strategy. More...
 
virtual Optional< Array< MeasureCandidate > > GenerateMeasureCandidates ()=0
 Generate measure candidates from design spaces for measurement. More...
 
virtual void NotifyRunnerResults (const Array< MeasureCandidate > &measure_candidates, const Array< RunnerResult > &results)=0
 Update the search strategy with measurement results. More...
 
virtual SearchStrategy Clone () const =0
 Clone the search strategy. More...
 
 TVM_DECLARE_BASE_OBJECT_INFO (SearchStrategyNode, 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)
 

Static Public Attributes

static constexpr const char * _type_key = "meta_schedule.SearchStrategy"
 
- 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

The search strategy for measure candidates generation.

Note
The relationship between SearchStrategy and other classes are as follows: ┌──────────────────────────────────────────────────────────────┐ ┌──┴───────────────────────────────────────────────────────────┐ │ ┌──┴────────────────── Tune Context ───────────────────────────┐ │ │ │ ┌─────────────────────┐ │ │ │ │ │ │ Generate │ │ │ │ │ Space Generator ├──────────────┐ │ │ │ │ │ │ │ │ │ │ │ └─────────────────────┘ ▼ │ │ │ │ Design Space │ │ │ │ ┌─────────────────────┐ │ │ │ │ │ Generate │ │ Pretuning │ │ │ │ │ ┌───────────┤ Search Strategy │◄─────────────┘ │ │ │ │ │ │ │ │ ├──┘ │ │ └─────────────────────┘ ├──┘ └────┼─────────────────────────────────────────────────────────┘ │ │ ┌────┼──────────────── Managed By Task Scheduler ─────────────────────┐ │ │ ┌───────────┐ │ │ │ Send to │ │ Send to │ │ ▼ ┌─────────────►│ Builder ├──────────┐ │ │ Measure Candidate │ Builder │ │ Runner │ │ │ │ │ └───────────┘ │ │ │ │ ┌────────────┴────────┐ │ │ │ │ │ │ ┌───────────┐ │ │ │ └────►│ Task Scheduler │ │ │ │ │ │ │ │ │ Runner │◄─────────┘ │ │ └─────────────────────┘ │ │ │ │ ▲ └─────┬─────┘ │ │ │ │ │ │ └─── Runner Future ◄────┘ │ └─────────────────────────────────────────────────────────────────────┘

Constructor & Destructor Documentation

◆ ~SearchStrategyNode()

virtual tvm::meta_schedule::SearchStrategyNode::~SearchStrategyNode ( )
virtualdefault

Virtual destructor.

Member Function Documentation

◆ Clone()

virtual SearchStrategy tvm::meta_schedule::SearchStrategyNode::Clone ( ) const
pure virtual

Clone the search strategy.

Returns
The cloned search strategy.

Implemented in tvm::meta_schedule::PySearchStrategyNode.

◆ GenerateMeasureCandidates()

virtual Optional<Array<MeasureCandidate> > tvm::meta_schedule::SearchStrategyNode::GenerateMeasureCandidates ( )
pure virtual

Generate measure candidates from design spaces for measurement.

Returns
The measure candidates generated, nullptr if finished.

Implemented in tvm::meta_schedule::PySearchStrategyNode.

◆ InitializeWithTuneContext()

virtual void tvm::meta_schedule::SearchStrategyNode::InitializeWithTuneContext ( const TuneContext context)
pure virtual

Initialize the search strategy with tuning context.

Parameters
contextThe tuning context for initialization.
Note
This method is supposed to be called only once before every other method.

Implemented in tvm::meta_schedule::PySearchStrategyNode.

◆ NotifyRunnerResults()

virtual void tvm::meta_schedule::SearchStrategyNode::NotifyRunnerResults ( const Array< MeasureCandidate > &  measure_candidates,
const Array< RunnerResult > &  results 
)
pure virtual

Update the search strategy with measurement results.

Parameters
measure_candidatesThe candidates to be measured.
resultsThe measurement results from the runner.

Implemented in tvm::meta_schedule::PySearchStrategyNode.

◆ PostTuning()

virtual void tvm::meta_schedule::SearchStrategyNode::PostTuning ( )
pure virtual

Post-tuning for the search strategy.

Note
Post-tuning is supposed to be called after the tuning process and before we reset the search strategy with another pre-tuning. Post-tuning can be empty.

Implemented in tvm::meta_schedule::PySearchStrategyNode.

◆ PreTuning()

virtual void tvm::meta_schedule::SearchStrategyNode::PreTuning ( int  max_trials,
int  num_trials_per_iter,
const Array< tir::Schedule > &  design_spaces,
const Optional< Database > &  database,
const Optional< CostModel > &  cost_model 
)
pure virtual

Pre-tuning for the search strategy.

Parameters
max_trialsThe maximum number of trials.
num_trials_per_iterThe number of trials per iteration.
design_spacesThe design spaces used during tuning process.
databaseThe database used during tuning process.
cost_modelThe cost model used during tuning process.
Note
Pre-tuning is supposed to be called before the tuning process and after the initialization. Because the search strategy is stateful, we can always call pretuning and reset the search strategy.

Implemented in tvm::meta_schedule::PySearchStrategyNode.

◆ TVM_DECLARE_BASE_OBJECT_INFO()

tvm::meta_schedule::SearchStrategyNode::TVM_DECLARE_BASE_OBJECT_INFO ( SearchStrategyNode  ,
Object   
)

Member Data Documentation

◆ _type_key

constexpr const char* tvm::meta_schedule::SearchStrategyNode::_type_key = "meta_schedule.SearchStrategy"
staticconstexpr

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