14#ifndef OR_TOOLS_BOP_BOP_PORTFOLIO_H_
15#define OR_TOOLS_BOP_BOP_PORTFOLIO_H_
22#include "ortools/bop/bop_parameters.pb.h"
26#include "ortools/sat/boolean_problem.pb.h"
69 const BopSolverOptimizerSet& optimizer_set,
70 const std::string&
name);
83 void AddOptimizer(
const sat::LinearBooleanProblem& problem,
85 const BopOptimizerMethod& optimizer_method);
86 void CreateOptimizers(
const sat::LinearBooleanProblem& problem,
88 const BopSolverOptimizerSet& optimizer_set);
91 int64_t state_update_stamp_;
93 std::unique_ptr<OptimizerSelector> selector_;
96 BopParameters parameters_;
99 int number_of_consecutive_failing_optimizers_;
156 std::string
PrintStats(OptimizerIndex optimizer_index)
const;
165 void NewSolutionFound(int64_t gain);
168 void UpdateDeterministicTime(
double time_spent);
174 RunInfo(OptimizerIndex i,
const std::string& n)
175 : optimizer_index(i),
181 time_spent_since_last_solution(0),
186 bool RunnableAndSelectable()
const {
return runnable && selectable; }
188 OptimizerIndex optimizer_index;
194 double time_spent_since_last_solution;
200 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
void UpdateScore(int64_t gain, double time_spent)
std::string PrintStats(OptimizerIndex optimizer_index) const
int NumCallsForOptimizer(OptimizerIndex optimizer_index) const
OptimizerSelector(const absl::StrongVector< OptimizerIndex, BopOptimizerBase * > &optimizers)
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)
ModelSharedTimeLimit * time_limit
const OptimizerIndex kInvalidOptimizerIndex(-1)
DEFINE_STRONG_INDEX_TYPE(OptimizerIndex)
Collection of objects used to extend the Constraint Solver library.
std::mt19937 random_engine_t