Clp  1.17.8
ClpDualRowSteepest.hpp
Go to the documentation of this file.
1 /* $Id$ */
2 // Copyright (C) 2002, International Business Machines
3 // Corporation and others. All Rights Reserved.
4 // This code is licensed under the terms of the Eclipse Public License (EPL).
5 
6 #ifndef ClpDualRowSteepest_H
7 #define ClpDualRowSteepest_H
8 
9 #include "ClpDualRowPivot.hpp"
10 class CoinIndexedVector;
11 
12 //#############################################################################
13 
21 
22 public:
24 
25 
27  virtual int pivotRow();
28 
31  virtual double updateWeights(CoinIndexedVector *input,
32  CoinIndexedVector *spare,
33  CoinIndexedVector *spare2,
34  CoinIndexedVector *updatedColumn);
35 
40  virtual void updatePrimalSolution(CoinIndexedVector *input,
41  double theta,
42  double &changeInObjective);
43 
54  virtual void saveWeights(ClpSimplex *model, int mode);
56  void passInSavedWeights(const CoinIndexedVector *saved);
58  inline CoinIndexedVector *savedWeights()
59  {
60  return savedWeights_;
61  }
63  virtual void unrollWeights();
65  virtual void clearArrays();
67  virtual bool looksOptimal() const;
69  virtual void maximumPivotsChanged();
71 
74  enum Persistence {
75  normal = 0x00, // create (if necessary) and destroy
76  keep = 0x01 // create (if necessary) and leave
77  };
78 
80 
81 
88  ClpDualRowSteepest(int mode = 3);
89 
92 
95 
97  void fill(const ClpDualRowSteepest &rhs);
98 
100  virtual ~ClpDualRowSteepest();
101 
103  virtual ClpDualRowPivot *clone(bool copyData = true) const;
104 
106 
108  inline int mode() const
110  {
111  return mode_;
112  }
114  inline void setMode(int mode)
115  {
116  mode_ = mode;
117  }
119  inline void setPersistence(Persistence life)
120  {
121  persistence_ = life;
122  }
123  inline Persistence persistence() const
124  {
125  return persistence_;
126  }
128 
129  //---------------------------------------------------------------------------
130 
131 protected:
133 
138  int state_;
141  int mode_;
145  double *weights_;
147  CoinIndexedVector *infeasible_;
149  CoinIndexedVector *alternateWeights_;
151  CoinIndexedVector *savedWeights_;
155 };
156 
157 #endif
158 
159 /* vi: softtabstop=2 shiftwidth=2 expandtab tabstop=2
160 */
ClpSimplex
This solves LPs using the simplex method.
Definition: ClpSimplex.hpp:106
ClpDualRowPivot::model
ClpSimplex * model()
Returns model.
Definition: ClpDualRowPivot.hpp:100
ClpDualRowSteepest::setPersistence
void setPersistence(Persistence life)
Set/ get persistence.
Definition: ClpDualRowSteepest.hpp:119
ClpDualRowSteepest::mode
int mode() const
Mode.
Definition: ClpDualRowSteepest.hpp:109
ClpDualRowSteepest::Persistence
Persistence
enums for persistence
Definition: ClpDualRowSteepest.hpp:74
ClpDualRowSteepest::saveWeights
virtual void saveWeights(ClpSimplex *model, int mode)
Saves any weights round factorization as pivot rows may change Save model May also recompute infeasib...
ClpDualRowSteepest::weights_
double * weights_
weight array
Definition: ClpDualRowSteepest.hpp:145
ClpDualRowSteepest::updatePrimalSolution
virtual void updatePrimalSolution(CoinIndexedVector *input, double theta, double &changeInObjective)
Updates primal solution (and maybe list of candidates) Uses input vector which it deletes Computes ch...
ClpDualRowSteepest::clone
virtual ClpDualRowPivot * clone(bool copyData=true) const
Clone.
ClpDualRowSteepest::state_
int state_
Status 0) Normal -1) Needs initialization 1) Weights are stored by sequence number.
Definition: ClpDualRowSteepest.hpp:138
ClpDualRowSteepest::looksOptimal
virtual bool looksOptimal() const
Returns true if would not find any row.
ClpDualRowSteepest::setMode
void setMode(int mode)
Set mode.
Definition: ClpDualRowSteepest.hpp:114
ClpDualRowSteepest
Dual Row Pivot Steepest Edge Algorithm Class.
Definition: ClpDualRowSteepest.hpp:20
ClpDualRowSteepest::maximumPivotsChanged
virtual void maximumPivotsChanged()
Called when maximum pivots changes.
ClpDualRowSteepest::alternateWeights_
CoinIndexedVector * alternateWeights_
alternate weight array (so we can unroll)
Definition: ClpDualRowSteepest.hpp:149
ClpDualRowSteepest::updateWeights
virtual double updateWeights(CoinIndexedVector *input, CoinIndexedVector *spare, CoinIndexedVector *spare2, CoinIndexedVector *updatedColumn)
Updates weights and returns pivot alpha.
ClpDualRowPivot.hpp
ClpDualRowSteepest::clearArrays
virtual void clearArrays()
Gets rid of all arrays.
ClpDualRowSteepest::normal
@ normal
Definition: ClpDualRowSteepest.hpp:75
ClpDualRowSteepest::persistence
Persistence persistence() const
Definition: ClpDualRowSteepest.hpp:123
ClpDualRowSteepest::mode_
int mode_
If 0 then we are using uninitialized weights, 1 then full, if 2 then uninitialized partial,...
Definition: ClpDualRowSteepest.hpp:141
ClpDualRowSteepest::persistence_
Persistence persistence_
Life of weights.
Definition: ClpDualRowSteepest.hpp:143
ClpDualRowSteepest::operator=
ClpDualRowSteepest & operator=(const ClpDualRowSteepest &rhs)
Assignment operator.
ClpDualRowSteepest::infeasible_
CoinIndexedVector * infeasible_
square of infeasibility array (just for infeasible rows)
Definition: ClpDualRowSteepest.hpp:147
ClpDualRowSteepest::keep
@ keep
Definition: ClpDualRowSteepest.hpp:76
ClpDualRowSteepest::passInSavedWeights
void passInSavedWeights(const CoinIndexedVector *saved)
Pass in saved weights.
ClpDualRowSteepest::ClpDualRowSteepest
ClpDualRowSteepest(int mode=3)
Default Constructor 0 is uninitialized, 1 full, 2 is partial uninitialized, 3 starts as 2 but may swi...
ClpDualRowSteepest::savedWeights_
CoinIndexedVector * savedWeights_
save weight array (so we can use checkpoint)
Definition: ClpDualRowSteepest.hpp:151
ClpDualRowSteepest::savedWeights
CoinIndexedVector * savedWeights()
Get saved weights.
Definition: ClpDualRowSteepest.hpp:58
ClpDualRowPivot
Dual Row Pivot Abstract Base Class.
Definition: ClpDualRowPivot.hpp:22
ClpDualRowSteepest::dubiousWeights_
int * dubiousWeights_
Dubious weights.
Definition: ClpDualRowSteepest.hpp:153
ClpDualRowSteepest::fill
void fill(const ClpDualRowSteepest &rhs)
Fill most values.
ClpDualRowSteepest::pivotRow
virtual int pivotRow()
Returns pivot row, -1 if none.
ClpDualRowSteepest::~ClpDualRowSteepest
virtual ~ClpDualRowSteepest()
Destructor.
ClpDualRowSteepest::unrollWeights
virtual void unrollWeights()
Gets rid of last update.