15#ifndef MINOTAURLOGHANDLER_H
16#define MINOTAURLOGHANDLER_H
27 typedef LinearFunction *LinearFunctionPtr;
28 typedef Objective *ObjectivePtr;
61 bool &should_prune,
double &inf_meas);
66 ModVector &p_mods, ModVector &r_mods,
bool *sol_found,
77 ModVector &mods, BrVarCandSet &cands,
78 BrCandVector &gencands,
bool &is_inf);
93 ModVector &p_mods, ModVector &r_mods);
96 std::string
getName()
const override;
99 void writeStats(std::ostream &out)
const override;
117 ConstraintVector linCons;
133 typedef LogCons *LogConsPtr;
134 typedef std::vector<LogConsPtr> LogConsVec;
135 typedef LogConsVec::iterator LogConsIter;
141 static const std::string me_;
156 struct LogPresolveStats
174 struct BoundTighteningStats
183 BoundTighteningStats bStats_;
184 LogPresolveStats pStats_;
199 ConstraintVector optCuts_;
225 void addCut_(VariablePtr x, VariablePtr y,
double xval,
double yval,
226 RelaxationPtr rel,
bool& ifcuts);
230 double addDefaultLogBounds_(VariablePtr x,
BoundType lu);
236 void addLin_(LogCons &cd, RelaxationPtr rel, DoubleVector &tmpX,
237 DoubleVector &grad, ModVector &mods,
bool init);
244 void addSecant_(LogCons &cd, RelaxationPtr rel, DoubleVector &tmpX,
245 ModVector &mods,
bool init);
259 void dupRows_(
bool *changed);
269 LinearFunctionPtr getLogSec_(VariablePtr x, VariablePtr y,
double lb,
270 double ub,
double &rhs);
273 double getViol_(
const LogCons &cd,
const DoubleVector &x)
const;
277 bool isFeasible_(ConstSolutionPtr sol, RelaxationPtr relaxation,
278 bool &should_prune,
double &inf_meas);
287 void initRelax_(LogCons &cd, RelaxationPtr rel, DoubleVector &tmpX,
294 bool propLogBnds_(LogConsPtr lcd,
bool *changed);
297 bool treatDupRows_(ConstraintPtr c1, ConstraintPtr c2,
double mult,
310 void updateRelax_(LogCons &cd, RelaxationPtr rel, DoubleVector &tmpX,
311 DoubleVector &grad, ModVector &mods);
314 int updatePBnds_(VariablePtr p,
double newlb,
double newub,
317 int updatePBnds_(VariablePtr v,
double newlb,
double newub,
318 RelaxationPtr rel,
bool mod_rel,
bool *changed,
319 ModVector &p_mods, ModVector &r_mods);
322 bool varBndsFromCons_(
bool *changed);
Define abstract base class for handlers of various kinds.
Declare important 'types' used in Minotaur.
Base class for describing candidates for branching on a node in branch-and-bound.
Definition BrCand.h:32
The Constraint class is used to manage a constraint.
Definition Constraint.h:61
Abstract base class to manage cuts in the relaxation.
Definition CutManager.h:42
Definition Environment.h:28
Base class for handling specific types of constraints or objective.
Definition Handler.h:49
Definition LogHandler.h:31
void separate(ConstSolutionPtr sol, NodePtr node, RelaxationPtr rel, CutManager *cutman, SolutionPoolPtr s_pool, ModVector &p_mods, ModVector &r_mods, bool *sol_found, SeparationStatus *status)
add cuts to separate a given point.
Definition LogHandler.cpp:419
Branches getBranches(BrCandPtr cand, DoubleVector &x, RelaxationPtr rel, SolutionPoolPtr s_pool)
Return branches for branching.
Definition LogHandler.cpp:559
void relaxNodeFull(NodePtr, RelaxationPtr, bool *)
Create a relaxation for a node, building from scratch.
Definition LogHandler.h:70
std::string getName() const override
Return the name of the handler.
Definition LogHandler.cpp:1062
void relaxInitFull(RelaxationPtr, SolutionPool *, bool *)
Create root relaxation if doing full node relaxations.
Definition LogHandler.h:54
void relaxInitInc(RelaxationPtr rel, SolutionPool *, bool *is_inf)
Create root relaxation if doing incremental node relaxations.
Definition LogHandler.cpp:278
void addConstraint(ConstraintPtr)
Add constraint to be handled by this handler.
Definition LogHandler.h:50
bool isFeasible(ConstSolutionPtr sol, RelaxationPtr relaxation, bool &should_prune, double &inf_meas)
Check if a solution is feasible.
Definition LogHandler.cpp:360
ModificationPtr getBrMod(BrCandPtr cand, DoubleVector &x, RelaxationPtr rel, BranchDirection dir)
Get the modifcation that creates a given (up or down) branch.
Definition LogHandler.cpp:520
void writeStats(std::ostream &out) const override
Write statistics to ostream out.
Definition LogHandler.cpp:1067
SolveStatus presolve(PreModQ *pre_mods, bool *changed, Solution **sol)
Initial presolve.
Definition LogHandler.cpp:1024
void relaxNodeInc(NodePtr node, RelaxationPtr rel, bool *isInfeasible)
Create an incremental relaxation for a node.
Definition LogHandler.cpp:296
bool presolveNode(RelaxationPtr p, NodePtr node, SolutionPoolPtr s_pool, ModVector &p_mods, ModVector &r_mods)
Presolve the problem and its relaxation at a node.
Definition LogHandler.cpp:1051
void getBranchingCandidates(RelaxationPtr rel, const DoubleVector &x, ModVector &mods, BrVarCandSet &cands, BrCandVector &gencands, bool &is_inf)
find branching candidates.
Definition LogHandler.cpp:469
void addConstraint(ConstraintPtr newcon, ConstVariablePtr ivar, ConstVariablePtr ovar, char sense='E')
Definition LogHandler.cpp:315
Definition Modification.h:29
Definition Relaxation.h:53
Definition SolutionPool.h:28
Definition ActiveNodeStore.h:20
BranchDirection
Two directions for branching.
Definition Types.h:201
BoundType
Different types of variable-bounds.
Definition Types.h:131
unsigned int UInt
Unsigned integer.
Definition Types.h:30
SeparationStatus
Status from separation routine:
Definition Types.h:217
SolveStatus
Different states an algorithm like branch-and-bound can be in.
Definition Types.h:158