17 const ::idol::Bilevel::Description& m_description;
18 std::unique_ptr<OptimizerFactory> m_optimistic_bilevel_optimizer;
20 std::optional<Model> m_optimistic_bilevel_model;
21 std::optional<::idol::Bilevel::Description> m_optimistic_bilevel_annotation;
24 const ::idol::Bilevel::Description& t_description,
27 std::string name()
const override;
29 SolutionStatus get_status()
const override;
31 SolutionReason get_reason()
const override;
33 double get_best_obj()
const override;
35 double get_best_bound()
const override;
37 double get_relative_gap()
const override;
39 double get_absolute_gap()
const override;
41 double get_var_primal(
const Var &t_var)
const override;
43 double get_var_reduced_cost(
const Var &t_var)
const override;
45 double get_var_ray(
const Var &t_var)
const override;
47 double get_ctr_dual(
const Ctr &t_ctr)
const override;
49 double get_ctr_farkas(
const Ctr &t_ctr)
const override;
51 unsigned int get_n_solutions()
const override;
53 unsigned int get_solution_index()
const override;
56 void add(
const Var &t_var)
override;
58 void add(
const Ctr &t_ctr)
override;
60 void add(
const QCtr &t_ctr)
override;
62 void remove(
const Var &t_var)
override;
64 void remove(
const Ctr &t_ctr)
override;
66 void remove(
const QCtr &t_ctr)
override;
68 void update()
override;
70 void write(
const std::string &t_name)
override;
72 void hook_optimize()
override;
74 void set_solution_index(
unsigned int t_index)
override;
76 void update_obj_sense()
override;
78 void update_obj()
override;
80 void update_rhs()
override;
82 void update_obj_constant()
override;
84 void update_mat_coeff(
const Ctr &t_ctr,
const Var &t_var)
override;
86 void update_ctr_type(
const Ctr &t_ctr)
override;
88 void update_ctr_rhs(
const Ctr &t_ctr)
override;
90 void update_var_type(
const Var &t_var)
override;
92 void update_var_lb(
const Var &t_var)
override;
94 void update_var_ub(
const Var &t_var)
override;
96 void update_var_obj(
const Var &t_var)
override;