140 virtual void print();
virtual int compareOriginalObject(const CbcBranchingObject *brObj) const
Compare the original object of this with the original object of brObj.
virtual void feasibleRegion()=0
For the variable(s) referenced by the object, look at the current solution and set bounds to match th...
Define a cut branching class.
bool canFix_
True if one way can fix variables.
CbcCutBranchingObject & operator=(const CbcCutBranchingObject &rhs)
Assignment operator.
CbcBranchCut & operator=(const CbcBranchCut &rhs)
virtual CbcBranchingObject * createCbcBranch(OsiSolverInterface *solver, const OsiBranchingInformation *info, int way)
Creates a branching object.
virtual CbcRangeCompare compareBranchingObject(const CbcBranchingObject *brObj, const bool replaceIfOverlap=false)
Compare the this with brObj.
int preferredWay() const
If -1 down always chosen first, +1 up always, 0 normal.
Abstract Base Class for describing an interface to a solver.
virtual CbcObject * clone() const
Clone.
virtual CbcBranchingObject * preferredNewFeasible() const
Given a valid solution (with reduced costs, etc.), return a branching object which would give a new f...
virtual void feasibleRegion()
Set bounds to contain the current solution.
OsiRowCut down_
Cut for the down arm (way_ = -1)
double infeasibility() const
Return infeasibility.
CbcCutBranchingObject()
Default constructor.
OsiRowCut up_
Cut for the up arm (way_ = 1)
CbcModel * model() const
Return model.
virtual CbcBranchingObject * clone() const
Clone.
Abstract branching object base class Now just difference with OsiBranchingObject. ...
virtual void print()
Print something about branch - only if log level high.
virtual void resetBounds(const OsiSolverInterface *)
Reset variable bounds to their original values.
CbcModel * model() const
Return model.
virtual double branch()=0
Execute the actions required to branch, as specified by the current state of the branching object...
virtual void print() const
Print something about branch - only if log level high.
virtual double branch()
Sets the bounds for variables or adds a cut depending on the current arm of the branch and advances t...
virtual bool boundBranch() const
Return true if branch created by object should fix variables.
virtual void resetBounds()
Reset original upper and lower bound values from the solver.
virtual ~CbcCutBranchingObject()
Destructor.
virtual bool boundBranch() const
Return true if branch should fix variables.
virtual CbcBranchingObject * notPreferredNewFeasible() const
Given a valid solution (with reduced costs, etc.), return a branching object which would give a new f...
Simple Branch and bound class.
virtual CbcBranchObjType type() const
Return the type (an integer identifier) of this.