#include <CbcBranchToFixLots.hpp>
Inheritance diagram for CbcBranchToFixLots:


Public Member Functions | |
| CbcBranchToFixLots () | |
| CbcBranchToFixLots (CbcModel *model, double djTolerance, double fractionFixed, int depth, int numberClean=0, const char *mark=NULL, bool alwaysCreate=false) | |
| Useful constructor - passed reduced cost tolerance and fraction we would like fixed. | |
| CbcBranchToFixLots (const CbcBranchToFixLots &) | |
| virtual CbcObject * | clone () const |
| Clone. | |
| CbcBranchToFixLots & | operator= (const CbcBranchToFixLots &rhs) |
| ~CbcBranchToFixLots () | |
| int | shallWe () const |
| Does a lot of the work, Returns 0 if no good, 1 if dj, 2 if clean, 3 if both FIXME: should use enum or equivalent to make these numbers clearer. | |
| virtual double | infeasibility (const OsiBranchingInformation *info, int &preferredWay) const |
| Infeasibility for an integer variable - large is 0.5, but also can be infinity when known infeasible. | |
| virtual bool | canDoHeuristics () const |
| Return true if object can take part in normal heuristics. | |
| virtual CbcBranchingObject * | createCbcBranch (OsiSolverInterface *solver, const OsiBranchingInformation *info, int way) |
| Creates a branching object. | |
| virtual void | redoSequenceEtc (CbcModel *model, int numberColumns, const int *originalColumns) |
| Redoes data when sequence numbers change. | |
Protected Attributes | |
| double | djTolerance_ |
| Reduced cost tolerance i.e. dj has to be >= this before fixed. | |
| double | fractionFixed_ |
| We only need to make sure this fraction fixed. | |
| char * | mark_ |
| Never fix ones marked here. | |
| CoinPackedMatrix | matrixByRow_ |
| Matrix by row. | |
| int | depth_ |
| Do if depth multiple of this. | |
| int | numberClean_ |
| number of ==1 rows which need to be clean | |
| bool | alwaysCreate_ |
| If true then always create branch. | |
a) On reduced cost b) When enough ==1 or <=1 rows have been satisfied (not fixed - satisfied)
Definition at line 17 of file CbcBranchToFixLots.hpp.
| CbcBranchToFixLots::CbcBranchToFixLots | ( | ) |
| CbcBranchToFixLots::CbcBranchToFixLots | ( | CbcModel * | model, | |
| double | djTolerance, | |||
| double | fractionFixed, | |||
| int | depth, | |||
| int | numberClean = 0, |
|||
| const char * | mark = NULL, |
|||
| bool | alwaysCreate = false | |||
| ) |
Useful constructor - passed reduced cost tolerance and fraction we would like fixed.
Also depth level to do at. Also passed number of 1 rows which when clean triggers fix Always does if all 1 rows cleaned up and number>0 or if fraction columns reached Also whether to create branch if can't reach fraction.
| CbcBranchToFixLots::CbcBranchToFixLots | ( | const CbcBranchToFixLots & | ) |
| CbcBranchToFixLots::~CbcBranchToFixLots | ( | ) |
| virtual CbcObject* CbcBranchToFixLots::clone | ( | ) | const [virtual] |
| CbcBranchToFixLots& CbcBranchToFixLots::operator= | ( | const CbcBranchToFixLots & | rhs | ) |
| int CbcBranchToFixLots::shallWe | ( | ) | const |
Does a lot of the work, Returns 0 if no good, 1 if dj, 2 if clean, 3 if both FIXME: should use enum or equivalent to make these numbers clearer.
| virtual double CbcBranchToFixLots::infeasibility | ( | const OsiBranchingInformation * | info, | |
| int & | preferredWay | |||
| ) | const [virtual] |
Infeasibility for an integer variable - large is 0.5, but also can be infinity when known infeasible.
Reimplemented from CbcBranchCut.
| virtual bool CbcBranchToFixLots::canDoHeuristics | ( | ) | const [inline, virtual] |
Return true if object can take part in normal heuristics.
Reimplemented from OsiObject.
Definition at line 59 of file CbcBranchToFixLots.hpp.
| virtual CbcBranchingObject* CbcBranchToFixLots::createCbcBranch | ( | OsiSolverInterface * | solver, | |
| const OsiBranchingInformation * | info, | |||
| int | way | |||
| ) | [virtual] |
| virtual void CbcBranchToFixLots::redoSequenceEtc | ( | CbcModel * | model, | |
| int | numberColumns, | |||
| const int * | originalColumns | |||
| ) | [virtual] |
double CbcBranchToFixLots::djTolerance_ [protected] |
Reduced cost tolerance i.e. dj has to be >= this before fixed.
Definition at line 73 of file CbcBranchToFixLots.hpp.
double CbcBranchToFixLots::fractionFixed_ [protected] |
We only need to make sure this fraction fixed.
Definition at line 75 of file CbcBranchToFixLots.hpp.
char* CbcBranchToFixLots::mark_ [protected] |
CoinPackedMatrix CbcBranchToFixLots::matrixByRow_ [protected] |
int CbcBranchToFixLots::depth_ [protected] |
int CbcBranchToFixLots::numberClean_ [protected] |
bool CbcBranchToFixLots::alwaysCreate_ [protected] |
1.4.7