diff options
Diffstat (limited to 'thirdparty/linux/include/coin/CbcHeuristicDiveLineSearch.hpp')
-rw-r--r-- | thirdparty/linux/include/coin/CbcHeuristicDiveLineSearch.hpp | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/thirdparty/linux/include/coin/CbcHeuristicDiveLineSearch.hpp b/thirdparty/linux/include/coin/CbcHeuristicDiveLineSearch.hpp new file mode 100644 index 0000000..30c5f63 --- /dev/null +++ b/thirdparty/linux/include/coin/CbcHeuristicDiveLineSearch.hpp @@ -0,0 +1,52 @@ +/* $Id: CbcHeuristicDiveLineSearch.hpp 1899 2013-04-09 18:12:08Z stefan $ */ +// Copyright (C) 2008, International Business Machines +// Corporation and others. All Rights Reserved. +// This code is licensed under the terms of the Eclipse Public License (EPL). + +#ifndef CbcHeuristicDiveLineSearch_H +#define CbcHeuristicDiveLineSearch_H + +#include "CbcHeuristicDive.hpp" + +/** DiveLineSearch class + */ + +class CbcHeuristicDiveLineSearch : public CbcHeuristicDive { +public: + + // Default Constructor + CbcHeuristicDiveLineSearch (); + + // Constructor with model - assumed before cuts + CbcHeuristicDiveLineSearch (CbcModel & model); + + // Copy constructor + CbcHeuristicDiveLineSearch ( const CbcHeuristicDiveLineSearch &); + + // Destructor + ~CbcHeuristicDiveLineSearch (); + + /// Clone + virtual CbcHeuristicDiveLineSearch * clone() const; + + /// Assignment operator + CbcHeuristicDiveLineSearch & operator=(const CbcHeuristicDiveLineSearch& rhs); + + /// Create C++ lines to get to current state + virtual void generateCpp( FILE * fp) ; + + /// Selects the next variable to branch on + /** Returns true if all the fractional variables can be trivially + rounded. Returns false, if there is at least one fractional variable + that is not trivially roundable. In this case, the bestColumn + returned will not be trivially roundable. + */ + virtual bool selectVariableToBranch(OsiSolverInterface* solver, + const double* newSolution, + int& bestColumn, + int& bestRound); + +}; + +#endif + |