Halide
Statistics.h
Go to the documentation of this file.
1 #ifndef STATISTICS_H
2 #define STATISTICS_H
3 
4 #include <chrono>
5 #include <set>
6 #include <string>
7 #include <vector>
8 
9 #include "ASLog.h"
10 
11 namespace Halide {
12 namespace Internal {
13 namespace Autoscheduler {
14 
15 using Clock = std::chrono::high_resolution_clock;
16 
17 template<typename T>
19  const T &value;
20  std::string msg;
21 
22  ScopedStatistic(const T &value, const std::string &msg)
23  : value{value}, msg{msg} {
24  }
25 
27  aslog(1) << msg << " = " << value << "\n";
28  }
29 };
30 
31 struct ScopedTimer {
32  std::chrono::time_point<Clock> start;
33  std::string msg;
34 
35  ScopedTimer(const std::string &msg)
36  : start{Clock::now()}, msg{msg} {
37  aslog(1) << "Start: " << msg << "\n";
38  }
39 
41  auto duration = Clock::now() - start;
42  auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(duration).count();
43  aslog(1) << "Duration (ms): " << msg << " = " << ms << "\n";
44  }
45 };
46 
47 struct Timer {
48  std::chrono::time_point<Clock> start;
49 
51  : start{Clock::now()} {
52  }
53 
54  void restart() {
55  start = Clock::now();
56  }
57 
58  std::chrono::duration<double> elapsed() const {
59  return Clock::now() - start;
60  }
61 };
62 
63 struct Statistics {
73  std::chrono::duration<double> generate_children_time{0};
74  std::chrono::duration<double> calculate_cost_time{0};
75  std::chrono::duration<double> enqueue_time{0};
76  std::chrono::duration<double> compute_in_tiles_time{0};
77  std::chrono::duration<double> filter_thread_tiles_time{0};
78  std::chrono::duration<double> filter_parallel_tiles_time{0};
79  std::chrono::duration<double> feature_write_time{0};
80  std::chrono::duration<double> featurization_time{0};
82  std::chrono::duration<double> cost_model_evaluation_time{0};
83 
85  return std::chrono::duration_cast<std::chrono::milliseconds>(generate_children_time).count();
86  }
87 
88  double total_compute_in_tiles_time() const {
89  return std::chrono::duration_cast<std::chrono::milliseconds>(compute_in_tiles_time).count();
90  }
91 
93  return std::chrono::duration_cast<std::chrono::milliseconds>(filter_thread_tiles_time).count();
94  }
95 
97  return std::chrono::duration_cast<std::chrono::milliseconds>(filter_parallel_tiles_time).count();
98  }
99 
100  double total_feature_write_time() const {
101  return std::chrono::duration_cast<std::chrono::milliseconds>(feature_write_time).count();
102  }
103 
104  double total_calculate_cost_time() const {
105  return std::chrono::duration_cast<std::chrono::milliseconds>(calculate_cost_time).count();
106  }
107 
108  double total_featurization_time() const {
109  return std::chrono::duration_cast<std::chrono::milliseconds>(featurization_time).count();
110  }
111 
112  double average_featurization_time() const {
113  return total_featurization_time() / (double)num_featurizations;
114  }
115 
116  double total_enqueue_time() const {
117  return std::chrono::duration_cast<std::chrono::milliseconds>(enqueue_time).count();
118  }
119 
121  return std::chrono::duration_cast<std::chrono::milliseconds>(enqueue_time + cost_model_evaluation_time).count();
122  }
123 
126  }
127 };
128 
129 } // namespace Autoscheduler
130 } // namespace Internal
131 } // namespace Halide
132 
133 #endif // STATISTICS_H
Halide::Internal::Autoscheduler::Statistics::filter_thread_tiles_time
std::chrono::duration< double > filter_thread_tiles_time
Definition: Statistics.h:77
Halide::Internal::Autoscheduler::Statistics::generate_children_time
std::chrono::duration< double > generate_children_time
Definition: Statistics.h:73
Halide::Internal::Autoscheduler::Statistics::num_tilings_generated
int num_tilings_generated
Definition: Statistics.h:72
Halide::Internal::Autoscheduler::Timer::start
std::chrono::time_point< Clock > start
Definition: Timer.h:34
Halide::Internal::Autoscheduler::ScopedTimer::msg
std::string msg
Definition: Timer.h:19
Halide::Internal::Autoscheduler::Statistics::average_featurization_time
double average_featurization_time() const
Definition: Statistics.h:112
Halide::Internal::Autoscheduler::Statistics::total_filter_thread_tiles_time
double total_filter_thread_tiles_time() const
Definition: Statistics.h:92
Halide::Internal::Autoscheduler::Statistics::total_compute_in_tiles_time
double total_compute_in_tiles_time() const
Definition: Statistics.h:88
Halide::Internal::Autoscheduler::Statistics::num_memoized_featurizations
int num_memoized_featurizations
Definition: Statistics.h:68
Halide::Internal::Autoscheduler::Statistics::total_filter_parallel_tiles_time
double total_filter_parallel_tiles_time() const
Definition: Statistics.h:96
Halide::Internal::Autoscheduler::Statistics::filter_parallel_tiles_time
std::chrono::duration< double > filter_parallel_tiles_time
Definition: Statistics.h:78
Halide::Internal::Autoscheduler::ScopedStatistic
Definition: Statistics.h:18
Halide::Internal::Autoscheduler::Statistics::total_feature_write_time
double total_feature_write_time() const
Definition: Statistics.h:100
Halide::Internal::Autoscheduler::Statistics::total_generate_children_time
double total_generate_children_time() const
Definition: Statistics.h:84
Halide::Internal::Autoscheduler::Statistics
Definition: Statistics.h:63
Halide::Internal::aslog
Definition: ASLog.h:16
Halide::Internal::Autoscheduler::Clock
std::chrono::high_resolution_clock Clock
Definition: Timer.h:15
Halide::Internal::Autoscheduler::Statistics::average_cost_model_evaluation_time
double average_cost_model_evaluation_time() const
Definition: Statistics.h:124
Halide::Internal::Autoscheduler::Statistics::featurization_time
std::chrono::duration< double > featurization_time
Definition: Statistics.h:80
Halide::Internal::Autoscheduler::ScopedStatistic::~ScopedStatistic
~ScopedStatistic()
Definition: Statistics.h:26
Halide::Internal::Autoscheduler::Statistics::total_featurization_time
double total_featurization_time() const
Definition: Statistics.h:108
Halide::Internal::Autoscheduler::Statistics::cost_model_evaluation_time
std::chrono::duration< double > cost_model_evaluation_time
Definition: Statistics.h:82
Halide::Internal::Autoscheduler::Statistics::num_block_memoization_misses
int num_block_memoization_misses
Definition: Statistics.h:67
Halide
This file defines the class FunctionDAG, which is our representation of a Halide pipeline,...
Definition: AbstractGenerator.h:19
Halide::LinkageType::Internal
@ Internal
Not visible externally, similar to 'static' linkage in C.
Halide::Internal::Autoscheduler::Statistics::num_tilings_accepted
int num_tilings_accepted
Definition: Statistics.h:71
Halide::Internal::Autoscheduler::Statistics::num_featurizations
int num_featurizations
Definition: Statistics.h:64
Halide::Internal::Autoscheduler::Statistics::total_cost_model_evaluation_time
double total_cost_model_evaluation_time() const
Definition: Statistics.h:120
Halide::Internal::Autoscheduler::Statistics::enqueue_time
std::chrono::duration< double > enqueue_time
Definition: Statistics.h:75
Halide::Internal::Autoscheduler::Statistics::total_enqueue_time
double total_enqueue_time() const
Definition: Statistics.h:116
Halide::Internal::Autoscheduler::Statistics::num_memoization_hits
int num_memoization_hits
Definition: Statistics.h:69
ASLog.h
Halide::Internal::Autoscheduler::Statistics::num_schedules_enqueued
int num_schedules_enqueued
Definition: Statistics.h:81
Halide::Internal::Autoscheduler::ScopedStatistic::ScopedStatistic
ScopedStatistic(const T &value, const std::string &msg)
Definition: Statistics.h:22
Halide::Internal::Autoscheduler::Timer::elapsed
std::chrono::duration< double > elapsed() const
Definition: Statistics.h:58
Halide::Internal::Autoscheduler::ScopedTimer::ScopedTimer
ScopedTimer(const std::string &msg)
Definition: Statistics.h:35
Halide::Internal::Autoscheduler::Statistics::num_states_added
int num_states_added
Definition: Statistics.h:65
Halide::Internal::Autoscheduler::Statistics::calculate_cost_time
std::chrono::duration< double > calculate_cost_time
Definition: Statistics.h:74
Halide::Internal::Autoscheduler::Statistics::num_memoization_misses
int num_memoization_misses
Definition: Statistics.h:70
Halide::Internal::Autoscheduler::ScopedTimer::start
std::chrono::time_point< Clock > start
Definition: Timer.h:18
Halide::Internal::Autoscheduler::ScopedStatistic::value
const T & value
Definition: Statistics.h:19
Halide::Internal::Autoscheduler::Statistics::num_block_memoization_hits
int num_block_memoization_hits
Definition: Statistics.h:66
Halide::Internal::Autoscheduler::Statistics::compute_in_tiles_time
std::chrono::duration< double > compute_in_tiles_time
Definition: Statistics.h:76
Halide::Internal::Autoscheduler::Statistics::feature_write_time
std::chrono::duration< double > feature_write_time
Definition: Statistics.h:79
Halide::Internal::Autoscheduler::ScopedTimer::~ScopedTimer
~ScopedTimer()
Definition: Statistics.h:40
Halide::Internal::Autoscheduler::Timer::Timer
Timer()
Definition: Statistics.h:50
Halide::Internal::Autoscheduler::Statistics::total_calculate_cost_time
double total_calculate_cost_time() const
Definition: Statistics.h:104
Halide::Internal::Autoscheduler::Timer::restart
void restart()
Definition: Statistics.h:54
Halide::Internal::Autoscheduler::ScopedStatistic::msg
std::string msg
Definition: Statistics.h:20