summaryrefslogtreecommitdiff
path: root/thirdparty/linux/include/coin/BonHeuristicDiveMIPVectorLength.hpp
diff options
context:
space:
mode:
authorHarpreet2016-09-03 00:36:51 +0530
committerHarpreet2016-09-03 00:36:51 +0530
commita0d9443af147e949c1e6a01ac24749d12593ec5b (patch)
tree1a1955c5482ae608fd7f618b06f4ecc6a0d39a23 /thirdparty/linux/include/coin/BonHeuristicDiveMIPVectorLength.hpp
parent4b64cf486f5c999fd8167758cae27839f3b50848 (diff)
downloadFOSSEE-Optim-toolbox-development-a0d9443af147e949c1e6a01ac24749d12593ec5b.tar.gz
FOSSEE-Optim-toolbox-development-a0d9443af147e949c1e6a01ac24749d12593ec5b.tar.bz2
FOSSEE-Optim-toolbox-development-a0d9443af147e949c1e6a01ac24749d12593ec5b.zip
cbcintlinprog added
Diffstat (limited to 'thirdparty/linux/include/coin/BonHeuristicDiveMIPVectorLength.hpp')
-rw-r--r--thirdparty/linux/include/coin/BonHeuristicDiveMIPVectorLength.hpp74
1 files changed, 74 insertions, 0 deletions
diff --git a/thirdparty/linux/include/coin/BonHeuristicDiveMIPVectorLength.hpp b/thirdparty/linux/include/coin/BonHeuristicDiveMIPVectorLength.hpp
new file mode 100644
index 0000000..c14ba30
--- /dev/null
+++ b/thirdparty/linux/include/coin/BonHeuristicDiveMIPVectorLength.hpp
@@ -0,0 +1,74 @@
+// Copyright (C) 2007, International Business Machines Corporation and others.
+// All Rights Reserved.
+// This code is published under the Eclipse Public License.
+//
+// Authors :
+// Joao P. Goncalves, International Business Machines Corporation
+//
+// Date : November 12, 2007
+
+#ifndef BonHeuristicDiveMIPVectorLength_H
+#define BonHeuristicDiveMIPVectorLength_H
+
+#include "BonBonminSetup.hpp"
+#include "BonHeuristicDiveMIP.hpp"
+
+/** DiveMIPVectorLength class
+ */
+
+namespace Bonmin
+{
+ class HeuristicDiveMIPVectorLength : public HeuristicDiveMIP {
+ public:
+ /// Default Constructor
+ HeuristicDiveMIPVectorLength ();
+
+ /// Constructor with setup
+ HeuristicDiveMIPVectorLength(BonminSetup * setup);
+
+ /// Copy constructor
+ HeuristicDiveMIPVectorLength(const HeuristicDiveMIPVectorLength &copy);
+
+ /// Destructor
+ ~HeuristicDiveMIPVectorLength()
+ {
+ delete [] columnLength_;
+ }
+
+ /// Assignment operator
+ HeuristicDiveMIPVectorLength & operator=(const HeuristicDiveMIPVectorLength & rhs);
+
+ /// Clone
+ virtual CbcHeuristic * clone() const;
+
+ /** Change setup used for heuristic.*/
+ virtual void setSetup(BonminSetup * setup){
+ HeuristicDiveMIP::setSetup(setup);
+ Initialize(setup->options());
+ }
+
+ /// sets internal variables
+ virtual void setInternalVariables(TMINLP2TNLP* minlp);
+
+ /// Selects the next variable to branch on
+ /** If bestColumn = -1, it means that no variable was found
+ */
+ virtual void selectVariableToBranch(TMINLP2TNLP* minlp,
+ const vector<int> & integerColumns,
+ const double* newSolution,
+ int& bestColumn,
+ int& bestRound);
+
+ /** Register the options common to all local search based heuristics.*/
+ static void registerOptions(Ipopt::SmartPtr<Bonmin::RegisteredOptions> roptions);
+
+ /** Initiaize using passed options.*/
+ void Initialize(Ipopt::SmartPtr<Ipopt::OptionsList> options);
+
+ private:
+ /// the number of nonzero elements in each column
+ int* columnLength_;
+
+ };
+}
+#endif