Halide
SearchSpace.h
Go to the documentation of this file.
1 #ifndef SEARCH_SPACE_H
2 #define SEARCH_SPACE_H
3 
4 #include "ASLog.h"
5 #include "CostModel.h"
6 #include "DefaultCostModel.h"
7 #include "Featurization.h"
8 #include "FunctionDAG.h"
9 #include "LoopNest.h"
10 #include "LoopNestParser.h"
11 #include "PerfectHashMap.h"
12 #include "SearchSpaceOptions.h"
13 #include "State.h"
14 #include <set>
15 #include <unordered_map>
16 #include <unordered_set>
17 #include <vector>
18 
19 namespace Halide {
20 namespace Internal {
21 namespace Autoscheduler {
22 
23 struct SearchSpace {
24  using StateVector = std::vector<IntrusivePtr<State>>;
25  const FunctionDAG &dag;
27  const Target &target;
29  std::mt19937 &rng;
33 
37 
40  const Target &target,
41  std::mt19937 &rng,
45 
46  // Sort / filter parallel tile options
48  vector<int64_t> outer_tiling;
49  vector<int64_t> inner_tiling;
53  bool operator<(const ParallelTileOption &other) const {
54  return idle_core_wastage < other.idle_core_wastage;
55  }
56 
57  // Ensure we don't accidentally copy this type
58  ParallelTileOption() = default;
61  ParallelTileOption(const ParallelTileOption &) = delete;
63  };
64 
65  vector<ParallelTileOption> filter_parallel_tile_options(const IntrusivePtr<State> &state,
66  const FunctionDAG::Node *node,
67  vector<vector<int64_t>> &inner_tilings,
68  const vector<int64_t> &pure_size) const;
69 
70  vector<ThreadTileOption> filter_thread_tile_options(vector<IntrusivePtr<const LoopNest>> &loop_nests) const;
71 
72  void memoize_blocks(const FunctionDAG::Node *node, LoopNest *new_root);
73 
75  std::function<void(IntrusivePtr<State> &&)> &accept_child,
76  const FunctionDAG::Node *node,
77  int &num_children) const;
78 
79  // Generate successor states for given 'state'
80  void generate_children(const IntrusivePtr<State> &state,
81  std::function<void(IntrusivePtr<State> &&)> &accept_child,
82  int pass_idx,
83  bool is_pre_pass);
84 
86 
87  vector<vector<int64_t>> generate_compute_root_serial_tilings(const IntrusivePtr<const LoopNest> &pure_stage, const FunctionDAG::Node *node) const;
88 
89  bool add_child(const IntrusivePtr<State> &state,
90  const IntrusivePtr<const LoopNest> &new_root,
91  std::function<void(IntrusivePtr<State> &&)> &accept_child) const;
92 
93  void process_pending_states(std::unordered_map<uint64_t, StateVector> &primary_options,
94  std::unordered_map<uint64_t, StateVector> &secondary_options,
95  int &num_children,
96  std::function<void(IntrusivePtr<State> &&)> &accept_child,
97  const FunctionDAG::Node *node);
98 
99  bool is_in_partial_schedule(const FunctionDAG::Node *node) const;
100 };
101 
102 } // namespace Autoscheduler
103 } // namespace Internal
104 } // namespace Halide
105 
106 #endif // SEARCH_SPACE_H
Halide::Internal::Autoscheduler::SearchSpace::add_child
bool add_child(const IntrusivePtr< State > &state, const IntrusivePtr< const LoopNest > &new_root, std::function< void(IntrusivePtr< State > &&)> &accept_child) const
Halide::Internal::Autoscheduler::SearchSpace::filter_thread_tile_options
vector< ThreadTileOption > filter_thread_tile_options(vector< IntrusivePtr< const LoopNest >> &loop_nests) const
Halide::Internal::Autoscheduler::SearchSpace::partial_schedule
const LoopNestParser * partial_schedule
Definition: SearchSpace.h:32
Halide::Internal::Autoscheduler::SearchSpace::generate_compute_root_serial_tilings
vector< vector< int64_t > > generate_compute_root_serial_tilings(const IntrusivePtr< const LoopNest > &pure_stage, const FunctionDAG::Node *node) const
Halide::Internal::Autoscheduler::SearchSpace::ParallelTileOption::inner_tiling
vector< int64_t > inner_tiling
Definition: SearchSpace.h:49
Halide::Internal::Autoscheduler::SearchSpace::generate_children
void generate_children(const IntrusivePtr< State > &state, std::function< void(IntrusivePtr< State > &&)> &accept_child, int pass_idx, bool is_pre_pass)
Halide::Internal::Autoscheduler::SearchSpace::ParallelTileOption::operator<
bool operator<(const ParallelTileOption &other) const
Definition: SearchSpace.h:53
Halide::Internal::Autoscheduler::SearchSpace::add_states_from_memoized_blocks
bool add_states_from_memoized_blocks(const IntrusivePtr< State > &state, std::function< void(IntrusivePtr< State > &&)> &accept_child, const FunctionDAG::Node *node, int &num_children) const
Halide::Internal::Autoscheduler::FunctionDAG
Definition: FunctionDAG.h:368
Halide::Internal::Autoscheduler::SearchSpace::ParallelTileOption::idle_core_wastage
double idle_core_wastage
Definition: SearchSpace.h:50
Halide::Internal::Autoscheduler::SearchSpace
Definition: SearchSpace.h:23
Halide::Internal::Autoscheduler::Statistics
Definition: Statistics.h:63
Halide::Internal::Autoscheduler::SearchSpace::memoize_blocks
void memoize_blocks(const FunctionDAG::Node *node, LoopNest *new_root)
Halide::Internal::Autoscheduler::SearchSpace::ParallelTileOption::operator=
ParallelTileOption & operator=(ParallelTileOption &&)=default
Halide::Internal::Autoscheduler::SearchSpace::ParallelTileOption
Definition: SearchSpace.h:47
Halide::Internal::Autoscheduler::SearchSpace::SearchSpace
SearchSpace(const FunctionDAG &dag, const Anderson2021Params &params, const Target &target, std::mt19937 &rng, CostModel *cost_model, Statistics &stats, const LoopNestParser *partial_schedule)
Halide::Internal::IntrusivePtr
Intrusive shared pointers have a reference count (a RefCount object) stored in the class itself.
Definition: IntrusivePtr.h:68
Halide::Internal::Autoscheduler::LoopNestParser
Definition: LoopNestParser.h:17
Halide::Internal::Autoscheduler::SearchSpace::is_in_partial_schedule
bool is_in_partial_schedule(const FunctionDAG::Node *node) const
Halide
This file defines the class FunctionDAG, which is our representation of a Halide pipeline,...
Definition: AbstractGenerator.h:19
PerfectHashMap.h
Halide::LinkageType::Internal
@ Internal
Not visible externally, similar to 'static' linkage in C.
Halide::Internal::Autoscheduler::LoopNest
Definition: LoopNest.h:34
Halide::CostModel
Definition: CostModel.h:61
FunctionDAG.h
Halide::Internal::Autoscheduler::SearchSpace::ParallelTileOption::max_parallelism
int64_t max_parallelism
Definition: SearchSpace.h:52
Halide::Internal::Autoscheduler::SearchSpace::ParallelTileOption::outer_tiling
vector< int64_t > outer_tiling
Definition: SearchSpace.h:48
Halide::Internal::Autoscheduler::SearchSpace::target
const Target & target
Definition: SearchSpace.h:27
Halide::Internal::Autoscheduler::SearchSpace::rng
std::mt19937 & rng
Definition: SearchSpace.h:29
Halide::Internal::Autoscheduler::SearchSpace::memoized_compute_root_blocks
NodeMap< std::map< int, std::vector< IntrusivePtr< const LoopNest > > > > memoized_compute_root_blocks
Definition: SearchSpace.h:36
Featurization.h
Halide::Internal::Autoscheduler::SearchSpaceOptions
Definition: SearchSpaceOptions.h:12
Halide::Internal::Autoscheduler::SearchSpace::ParallelTileOption::ParallelTileOption
ParallelTileOption()=default
int64_t
signed __INT64_TYPE__ int64_t
Definition: runtime_internal.h:22
Halide::Internal::Autoscheduler::SearchSpace::inlined_nodes
NodeMap< bool > inlined_nodes
Definition: SearchSpace.h:34
State.h
Halide::Internal::Autoscheduler::SearchSpace::cost_model
CostModel * cost_model
Definition: SearchSpace.h:30
SearchSpaceOptions.h
ASLog.h
Halide::Internal::Autoscheduler::SearchSpace::freeze_lowest_cost_stages
void freeze_lowest_cost_stages(const IntrusivePtr< State > &best)
Halide::Internal::Autoscheduler::SearchSpace::ParallelTileOption::min_parallelism
int64_t min_parallelism
Definition: SearchSpace.h:51
CostModel.h
Halide::Internal::Autoscheduler::SearchSpace::params
const Anderson2021Params & params
Definition: SearchSpace.h:26
LoopNestParser.h
PerfectHashMap
Definition: PerfectHashMap.h:38
Halide::Internal::Autoscheduler::Anderson2021Params
Definition: CostModel.h:18
Halide::Internal::Autoscheduler::SearchSpace::filter_parallel_tile_options
vector< ParallelTileOption > filter_parallel_tile_options(const IntrusivePtr< State > &state, const FunctionDAG::Node *node, vector< vector< int64_t >> &inner_tilings, const vector< int64_t > &pure_size) const
Halide::Internal::Autoscheduler::FunctionDAG::Node
Definition: FunctionDAG.h:379
Halide::Internal::Autoscheduler::SearchSpace::StateVector
std::vector< IntrusivePtr< State > > StateVector
Definition: SearchSpace.h:24
Halide::Internal::Autoscheduler::SearchSpace::search_space_options
SearchSpaceOptions search_space_options
Definition: SearchSpace.h:28
Halide::Internal::Autoscheduler::SearchSpace::process_pending_states
void process_pending_states(std::unordered_map< uint64_t, StateVector > &primary_options, std::unordered_map< uint64_t, StateVector > &secondary_options, int &num_children, std::function< void(IntrusivePtr< State > &&)> &accept_child, const FunctionDAG::Node *node)
Halide::Internal::Autoscheduler::SearchSpace::dag
const FunctionDAG & dag
Definition: SearchSpace.h:25
DefaultCostModel.h
Halide::Internal::Autoscheduler::SearchSpace::stats
Statistics & stats
Definition: SearchSpace.h:31
Halide::Target
A struct representing a target machine and os to generate code for.
Definition: Target.h:19
Halide::Internal::Autoscheduler::SearchSpace::compute_root_nodes
NodeMap< std::vector< IntrusivePtr< const LoopNest > > > compute_root_nodes
Definition: SearchSpace.h:35
LoopNest.h