14 #ifndef OR_TOOLS_BOP_BOP_PORTFOLIO_H_
15 #define OR_TOOLS_BOP_BOP_PORTFOLIO_H_
65 const BopSolverOptimizerSet& optimizer_set,
66 const std::string&
name);
79 void AddOptimizer(
const sat::LinearBooleanProblem& problem,
81 const BopOptimizerMethod& optimizer_method);
82 void CreateOptimizers(
const sat::LinearBooleanProblem& problem,
84 const BopSolverOptimizerSet& optimizer_set);
86 std::unique_ptr<MTRandom> random_;
87 int64 state_update_stamp_;
89 std::unique_ptr<OptimizerSelector> selector_;
92 BopParameters parameters_;
95 int number_of_consecutive_failing_optimizers_;
152 std::string
PrintStats(OptimizerIndex optimizer_index)
const;
161 void NewSolutionFound(
int64 gain);
164 void UpdateDeterministicTime(
double time_spent);
170 RunInfo(OptimizerIndex i,
const std::string& n)
171 : optimizer_index(i),
177 time_spent_since_last_solution(0),
182 bool RunnableAndSelectable()
const {
return runnable && selectable; }
184 OptimizerIndex optimizer_index;
190 double time_spent_since_last_solution;
196 std::vector<RunInfo> run_infos_;
A simple class to enforce both an elapsed time limit and a deterministic time limit in the same threa...
const std::string & name() const
std::string PrintStats(OptimizerIndex optimizer_index) const
int NumCallsForOptimizer(OptimizerIndex optimizer_index) const
OptimizerSelector(const absl::StrongVector< OptimizerIndex, BopOptimizerBase * > &optimizers)
void UpdateScore(int64 gain, double time_spent)
OptimizerIndex SelectOptimizer()
void TemporarilyMarkOptimizerAsUnselectable(OptimizerIndex optimizer_index)
void SetOptimizerRunnability(OptimizerIndex optimizer_index, bool runnable)
~PortfolioOptimizer() override
bool ShouldBeRun(const ProblemState &problem_state) const override
Status Optimize(const BopParameters ¶meters, const ProblemState &problem_state, LearnedInfo *learned_info, TimeLimit *time_limit) override
PortfolioOptimizer(const ProblemState &problem_state, const BopParameters ¶meters, const BopSolverOptimizerSet &optimizer_set, const std::string &name)
SharedTimeLimit * time_limit
const OptimizerIndex kInvalidOptimizerIndex(-1)
DEFINE_INT_TYPE(OptimizerIndex, int)
The vehicle routing library lets one model and solve generic vehicle routing problems ranging from th...