14#ifndef OR_TOOLS_BOP_BOP_PORTFOLIO_H_
15#define OR_TOOLS_BOP_BOP_PORTFOLIO_H_
69 const std::string&
name);
90 int64_t state_update_stamp_;
92 std::unique_ptr<OptimizerSelector> selector_;
98 int number_of_consecutive_failing_optimizers_;
155 std::string
PrintStats(OptimizerIndex optimizer_index)
const;
164 void NewSolutionFound(int64_t gain);
167 void UpdateDeterministicTime(
double time_spent);
173 RunInfo(OptimizerIndex i,
const std::string& n)
174 : optimizer_index(i),
180 time_spent_since_last_solution(0),
185 bool RunnableAndSelectable()
const {
return runnable && selectable; }
187 OptimizerIndex optimizer_index;
193 double time_spent_since_last_solution;
199 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_INT_TYPE(OptimizerIndex, int)
Collection of objects used to extend the Constraint Solver library.
std::mt19937 random_engine_t