/usr/include/OpenMS/DATASTRUCTURES/LPWrapper.h is in libopenms-dev 1.11.1-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 | // --------------------------------------------------------------------------
// OpenMS -- Open-Source Mass Spectrometry
// --------------------------------------------------------------------------
// Copyright The OpenMS Team -- Eberhard Karls University Tuebingen,
// ETH Zurich, and Freie Universitaet Berlin 2002-2013.
//
// This software is released under a three-clause BSD license:
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
// * Neither the name of any author or any participating institution
// may be used to endorse or promote products derived from this software
// without specific prior written permission.
// For a full list of authors, refer to the file AUTHORS.
// --------------------------------------------------------------------------
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL ANY OF THE AUTHORS OR THE CONTRIBUTING
// INSTITUTIONS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//
// --------------------------------------------------------------------------
// $Maintainer: Alexandra Zerck $
// $Authors: Alexandra Zerck $
// --------------------------------------------------------------------------
#ifndef OPENMS_DATASTRUCTURES_LPWRAPPER_H
#define OPENMS_DATASTRUCTURES_LPWRAPPER_H
#include <limits>
#include <OpenMS/DATASTRUCTURES/String.h>
// do NOT include glpk and CoinOr headers here, as they define bad stuff, which ripples through OpenMS then...
// include them in LPWrapper.C where they do not harm
// only declare them here
class CoinModel;
#define GLP_PROB_DEFINED
// depending on the glpk version
// define glp_prob as forward or struct
#if OPENMS_GLPK_VERSION_MINOR < 48
typedef struct
{
double _opaque_prob[100];
} glp_prob;
#else
class glp_prob;
#endif
namespace OpenMS
{
class OPENMS_DLLAPI LPWrapper
{
public:
/**
@brief Struct that holds the parameters of the LP solver
*/
struct SolverParam
{
SolverParam() :
message_level(3), branching_tech(4), backtrack_tech(3),
preprocessing_tech(2), enable_feas_pump_heuristic(true), enable_gmi_cuts(true),
enable_mir_cuts(true), enable_cov_cuts(true), enable_clq_cuts(true), mip_gap(0.0),
time_limit((std::numeric_limits<Int>::max)()), output_freq(5000), output_delay(10000), enable_presolve(true),
enable_binarization(true)
{
}
Int message_level;
Int branching_tech;
Int backtrack_tech;
Int preprocessing_tech;
bool enable_feas_pump_heuristic;
bool enable_gmi_cuts;
bool enable_mir_cuts;
bool enable_cov_cuts;
bool enable_clq_cuts;
DoubleReal mip_gap;
Int time_limit;
Int output_freq;
Int output_delay;
bool enable_presolve;
bool enable_binarization; // only with presolve
};
enum Type
{
UNBOUNDED = 1,
LOWER_BOUND_ONLY,
UPPER_BOUND_ONLY,
DOUBLE_BOUNDED,
FIXED
};
enum VariableType
{
CONTINUOUS = 1,
INTEGER,
BINARY
};
enum Sense
{
MIN = 1,
MAX
};
enum WriteFormat
{
FORMAT_LP = 0,
FORMAT_MPS,
FORMAT_GLPK
};
enum SOLVER
{
SOLVER_GLPK = 0
#if COINOR_SOLVER == 1
, SOLVER_COINOR
#endif
};
enum SolverStatus
{
UNDEFINED = 1,
OPTIMAL = 5,
FEASIBLE = 2,
NO_FEASIBLE_SOL = 4
};
LPWrapper();
virtual ~LPWrapper();
// problem creation/manipulation
/// adds a row to the LP matrix, returns index
Int addRow(std::vector<Int> row_indices, std::vector<DoubleReal> row_values, const String & name);
/// adds an empty column to the LP matrix, returns index
Int addColumn();
/// adds a column to the LP matrix, returns index
Int addColumn(std::vector<Int> column_indices, std::vector<DoubleReal> column_values, const String & name);
/**
@brief Adds a row with boundaries to the LP matrix, returns index
If you have a fixed variable, GLPK requires to use the "fixed" type, instead of "double-bounded" with equal bounds.
@param row_indices
@param row_values
@param name
@param lower_bound
@param upper_bound
@param type Type of the row 1 - unbounded, 2 - only lower bound, 3 - only upper bound, 4 - double-bounded variable, 5 - fixed variable
*/
Int addRow(std::vector<Int> & row_indices, std::vector<DoubleReal> & row_values, const String & name, DoubleReal lower_bound, DoubleReal upper_bound, Type type);
/**
@brief Adds a column with boundaries to the LP matrix, returns index
@param column_indices
@param column_values
@param name
@param lower_bound
@param upper_bound
@param type 1 - unbounded, 2 - only lower bound, 3 - only upper bound, 4 - double-bounded variable, 5 - fixed variable
*/
Int addColumn(std::vector<Int> & column_indices, std::vector<DoubleReal> & column_values, const String & name, DoubleReal lower_bound, DoubleReal upper_bound, Type type);
/// delete index-th row
void deleteRow(Int index);
/// sets name of the index-th column
void setColumnName(Int index, const String & name);
/// gets name of the index-th column
String getColumnName(Int index);
/// sets name of the index-th row
String getRowName(Int index);
/// gets index of the row with name
Int getRowIndex(const String & name);
/// gets index of the column with name
Int getColumnIndex(const String & name);
/// gets column's upper bound
DoubleReal getColumnUpperBound(Int index);
/// gets column's lower bound
DoubleReal getColumnLowerBound(Int index);
/// gets row's upper bound
DoubleReal getRowUpperBound(Int index);
/// gets row's lower bound
DoubleReal getRowLowerBound(Int index);
/// sets name of the index-th row
void setRowName(Int index, const String & name);
/**
@brief Set column bounds.
@param index
@param lower_bound
@param upper_bound
@param type 1 - unbounded, 2 - only lower bound, 3 - only upper bound, 4 - double-bounded variable, 5 - fixed variable
*/
void setColumnBounds(Int index, DoubleReal lower_bound, DoubleReal upper_bound, Type type);
/**
@brief Set row bounds.
@param index
@param lower_bound
@param upper_bound
@param type 1 - unbounded, 2 - only lower bound, 3 - only upper bound, 4 - double-bounded variable, 5 - fixed constraint
*/
void setRowBounds(Int index, DoubleReal lower_bound, DoubleReal upper_bound, Type type);
/**
@brief Set column/variable type.
@param index
@param type 1- continuous, 2- integer, 3- binary variable
*/
void setColumnType(Int index, VariableType type);
/**
@brief Get column/variable type.
@param index
@return 1- continuous, 2- integer, 3- binary variable
*/
VariableType getColumnType(Int index);
/// set objective value for column with index
void setObjective(Int index, DoubleReal obj_value);
/// get objective value for column with index
DoubleReal getObjective(Int index);
/**
@brief Set objective direction.
@param sense 1- minimize, 2- maximize
*/
void setObjectiveSense(Sense sense);
Sense getObjectiveSense();
/// get number of columns
Int getNumberOfColumns();
/// get number of rows
Int getNumberOfRows();
void setElement(Int row_index, Int column_index, DoubleReal value);
DoubleReal getElement(Int row_index, Int column_index);
// problem reading/writing
/**
@brief Read LP from file
@param filename Filename where to store the LP problem.
@param format LP, MPS or GLPK.
*/
void readProblem(String filename, String format);
/**
@brief Write LP formulation to a file.
@param filename output filename, if the filename ends with '.gz' it will be compressed
@param format MPS-format is supported by GLPK and COIN-OR; LP and GLPK-formats only by GLPK
*/
void writeProblem(const String & filename, const WriteFormat format) const;
/**
@brief solve problems, parameters like enabled heuristics can be given via solver_param
The verbose level (0,1,2) determines if the solver prints status messages and internals.
@param solver_param
@param verbose_level
@return solver dependent (todo: fix)
*/
Int solve(SolverParam & solver_param, const Size verbose_level = 0);
/**
@brief Get solution status.
@return status: 1 - undefined, 2 - integer optimal, 3- integer feasible (no optimality proven), 4- no integer feasible solution
*/
SolverStatus getStatus();
// solution access
DoubleReal getObjectiveValue();
DoubleReal getColumnValue(Int index);
Int getNumberOfNonZeroEntriesInRow(Int idx);
void getMatrixRow(Int idx, std::vector<Int> & indexes);
/// choose solver; by default, only GLPK is available
/// set this only at the very beginning of building your model, as otherwise your model is incomplete
void setSolver(const SOLVER s);
/// get currently active solver
SOLVER getSolver() const;
protected:
#if COINOR_SOLVER == 1
CoinModel * model_;
std::vector<DoubleReal> solution_;
#endif
glp_prob * lp_problem_;
SOLVER solver_;
}; // class
} // namespace
#endif // OPENMS_DATASTRUCTURES_LPWRAPPER_H
|