1#ifndef DEFAULT_COST_MODEL_H
2#define DEFAULT_COST_MODEL_H
16 std::vector<std::vector<double> *> cost_per_stage_ptrs;
17 int cursor, num_stages, num_cores;
20 const std::string weights_in_path, weights_out_path;
21 const bool randomize_weights;
24 head1_filter_update, head1_bias_update,
25 head2_filter_update, head2_bias_update,
26 conv1_filter_update, conv1_bias_update;
33 const std::string &weights_out_path,
34 bool randomize_weights,
36 : weights_in_path(weights_in_path),
37 weights_out_path(weights_out_path),
38 randomize_weights(randomize_weights),
53 std::vector<double> *cost_per_stage_ptr)
override;
71 const std::string &weights_in_dir =
"",
72 const std::string &weights_out_dir =
"",
73 bool randomize_weights =
false);
void enqueue(int ns, Runtime::Buffer< float > *schedule_feats, double *cost_ptr, std::vector< double > *cost_per_stage_ptr)
float backprop(const Runtime::Buffer< const float > &true_runtimes, float learning_rate)
void set_pipeline_features(const Runtime::Buffer< float > &, int n)
void evaluate_costs() override
void enqueue(const Internal::Autoscheduler::FunctionDAG &dag, const Halide::Internal::Autoscheduler::StageMapOfScheduleFeatures &schedule_feats, double *cost_ptr, std::vector< double > *cost_per_stage_ptr) override
void set_pipeline_features(const Internal::Autoscheduler::FunctionDAG &dag, const Internal::Autoscheduler::Anderson2021Params ¶ms) override
DefaultCostModel(const std::string &weights_in_path, const std::string &weights_out_path, bool randomize_weights, Internal::Autoscheduler::Statistics &stats)
A templated Buffer class that wraps halide_buffer_t and adds functionality.
This file defines the class FunctionDAG, which is our representation of a Halide pipeline,...
std::unique_ptr< DefaultCostModel > make_default_cost_model(const std::string &weights_in_dir="", const std::string &weights_out_dir="", bool randomize_weights=false)