11 #ifndef CglLandPSimplex_H 
   12 #define CglLandPSimplex_H 
   26 #ifdef COIN_HAS_OSICLP 
   35 #define OLD_COMPUTATION 
   82 #ifdef COIN_HAS_OSICLP 
   95 #ifdef COIN_HAS_OSICLP 
  105                    std::vector<int> &M1, std::vector<int> &M2,
 
  141     void append_row(
int row_num, 
bool modularize) ;
 
  143     void update_row(
TabRow &row);
 
  145     void check_mod_row(
TabRow &row);
 
  149     bool changeBasis(
int incoming, 
int leaving, 
int direction, 
 
  151                      bool recompute_source_row,
 
  162                                 double pivotTol, 
double rhsTol,
 
  164                                 bool allowNonImproving,
 
  165                                 double &bestSigma, 
bool modularize);
 
  268                       std::vector<int> &M1,
 
  269                       std::vector<int> &M2,
 
  270                       std::vector<int> &M3);
 
  280 #ifdef COIN_HAS_OSICLP 
  288     void removeRows(
int nDelete, 
const int * rowsIdx);
 
  291     void compute_p_q_r_s(
double gamma, 
int gammaSign, 
double &p, 
double & q, 
double & r , 
double &s);
 
  414                             double pivotTol, 
bool reducedSpace, 
bool allowDegeneratePivot,
 
  417     int plotCGLPobj(
int direction, 
double gammaTolerance,
 
  418                     double pivotTol, 
bool reducedSpace, 
bool allowDegenerate, 
bool modularize);
 
  433         double f_i = alpha_i - floor(alpha_i);
 
  435             return f_i*(1- beta);
 
  437             return (1 - f_i)*beta;
 
CoinWarmStartBasis * basis_
Keep track of basis status. 
TabRow original_row_k_
Original version of source row (without modularization). 
int insertAllExtr(OsiCuts &cs, CoinRelFltEq eq)
insert all extra cuts in cs. 
Normalization
Normalization. 
CglLandPSimplex()
No default constructor. 
int * nonBasics_
Stores the nonBasicVariables. 
std::vector< double > lo_bounds_
bool optimize(int var, OsiRowCut &cut, const CglLandP::CachedData &cached, const CglLandP::Parameters ¶ms)
Perfom pivots to find the best cuts. 
int ncols_orig_
cached numcols in original problem 
bool * colCandidateToLeave_
Flag columns which have to be considered for leaving the basis. 
bool resetSolver(const CoinWarmStartBasis *basis)
reset the solver to optimal basis 
bool * rowFlags_
Flag rows which we don't want to try anymore. 
std::vector< double > rWk1_
first work vector in row space. 
void printTableau(std::ostream &os)
print the tableau of current basis. 
Class storing parameters. 
Status getStructStatus(int i) const 
Return the status of the specified structural variable. 
std::vector< int > M2_
Stores the variables which are always in M2 for a given k. 
std::vector< int > original_index_
Original index of variable before deletions. 
CoinMessageHandler * handler_
Message handler. 
void setColsolToCut(int index, double value)
Access to value in solution to cut (indexed in reduced problem) 
std::vector< double > rWk3_
third work vector in row space. 
CglLandPSimplex & operator=(const CglLandPSimplex &)
No assignment operator. 
bool inDegenerateSequence_
Say if we are in a sequence of degenerate pivots. 
double normalizationFactor(const TabRow &row) const 
Compute the normalization factor of the cut. 
double rhs_weight_
Weight for rhs of normalization constraint.*/. 
void computeWeights(CglLandP::LHSnorm norm, CglLandP::Normalization type, CglLandP::RhsWeightType rhs)
Compute normalization weights. 
int nrows_orig_
cached numrows in original problem 
CoinWarmStartBasis::Status getStatus(int index) const 
Get the basic status of a variable (structural or slack). 
Collections of row cuts and column cuts. 
double sigma_
stores the cglp value of the normalized cut obtained from row k_ 
TabRow row_i_
Row of leaving candidate. 
void cacheUpdate(const CglLandP::CachedData &cached, bool reducedSpace=0)
Update cached information in case of basis change in a round. 
double * colsol_
Pointer to the current basic solution. 
std::vector< int > M1_
Stores the variables which are always in M1 for a given k. 
void pullTableauRow(TabRow &row) const 
Get the row i of the tableau. 
The default COIN simplex (basis-oriented) warm start class. 
int rescanReducedCosts(int &direction, int &gammaSign, double tolerance)
Rescan reduced costs tables. 
std::vector< double > rWk4_
fourth work vector in row space. 
int generateExtraCut(int i, const CglLandP::CachedData &cached, const CglLandP::Parameters ¶ms)
Generate a constrainte for a row of the tableau different from the source row. 
void genThisBasisMigs(const CglLandP::CachedData &cached, const CglLandP::Parameters ¶ms)
void outPivInfo(int ncuts)
RhsWeightType
RHS weight in normalization. 
int nNegativeRcRows_
number of rows with a <0 rc in current iteration 
Base class for message handling. 
const bool * integers_
pointer to array of integer info for both structural and slacks 
bool own_
Own the data or not? 
double computeRedCostConstantsInRow()
Compute the value of sigma and thau (which are constants for a row i as defined in Mike Perregaard th...
bool changeBasis(int incoming, int leaving, int direction, bool modularize)
Perform a change in the basis (direction is 1 if leaving variable is going to ub, 0 otherwise) ...
int numPivots_
Record the number of pivots. 
Abstract Base Class for describing an interface to a solver. 
std::vector< int > M3_
Stores the variables which could be either in M1 or M2. 
double normedCoef(double a, int ii) const 
Evenutaly multiply a by w if normed_weights_ is not empty. 
void createIntersectionCut(TabRow &row, OsiRowCut &cut) const 
Create the intersection cut of row k. 
Validator & validator_
A pointer to a cut validator. 
double getUpBound(int index) const 
Get upper bound for variable or constraint. 
double strengthenedIntersectionCutCoef(int i, double alpha_i, double beta) const 
return the coefficients of the strengthened intersection cut takes one extra argument seens needs to ...
void printEverything()
Print everything . 
int fastFindCutImprovingPivotRow(int &direction, int &gammaSign, double tolerance, bool flagPositiveRows)
Find a row which can be used to perform an improving pivot the fast way (i.e., find the leaving varia...
Some informations that will be changed by the pivots and that we want to keep. 
double chosenReducedCostVal_
Value for the reduced cost chosen for pivoting. 
void get_M1_M2_M3(const TabRow &row, std::vector< int > &M1, std::vector< int > &M2, std::vector< int > &M3)
Put variables in M1 M2 and M3 according to their sign. 
This is a first attempt at a message handler. 
Equality to a scaled tolerance. 
std::vector< int > rIntWork_
integer valued work vector on the rows 
CoinPackedVector gammas_
vector to sort the gammas 
Status getArtifStatus(int i) const 
Return the status of the specified artificial variable. 
void eliminate_slacks(double *vec) const 
Put a vector in structural sapce. 
int findBestPivot(int &leaving, int &direction, const CglLandP::Parameters ¶ms)
Find incoming and leaving variables which lead to the most violated adjacent normalized lift-and-proj...
int findBestPivotColumn(int direction, double pivotTol, bool reducedSpace, bool allowDegeneratePivot, bool modularize)
Find the column which leads to the best cut (i.e., find incoming variable). 
double * colsolToCut_
Pointer to the solution to cut (need to be modified after each pivot because we are only considering ...
int fastFindBestPivotColumn(int direction, int gammaSign, double pivotTol, double rhsTol, bool reducedSpace, bool allowNonImproving, double &bestSigma, bool modularize)
Find the column which leads to the best cut (i.e., find incoming variable). 
~CglLandPSimplex()
Destructor. 
std::vector< double > rWk2_
scond work vector in row space. 
double intersectionCutCoef(double alpha_i, double beta)
return the coefficients of the intersection cut 
bool checkBasis()
Check that the basis is correct. 
Cuts cuts_
Stores extra cuts which are generated along the procedure. 
int * basics_
Store the basics variable. 
std::vector< double > norm_weights_
Weights for the normalization constraint. 
double getLoBound(int index) const 
Get lower bound for variable or constraint. 
void printTableauLateX(std::ostream &os)
print the tableau of current basis. 
const int * getBasics() const 
TabRow row_k_
Source row for cut. 
int generateExtraCuts(const CglLandP::CachedData &cached, const CglLandP::Parameters ¶ms)
Find extra constraints in current tableau. 
bool isGtConst(int index) const 
void setSi(OsiSolverInterface *si)
const CoinWarmStartBasis * getBasis() const 
CoinMessageHandler & message(int messageNumber, const CoinMessages &messages)
Start a message. 
int ncols_
cached number of columns in reduced size problem 
void compute_p_q_r_s(double gamma, int gammaSign, double &p, double &q, double &r, double &s)
void removeRows(int nDelete, const int *rowsIdx)
Remove rows from current tableau. 
CoinMessages messages_
Messages. 
void loadBasis(const OsiSolverInterface &si, std::vector< int > &M1, std::vector< int > &M2, int k)
Status
Enum for status of variables. 
void setLogLevel(int level)
OsiSolverInterface * si_
Pointer to the solver interface. 
int findCutImprovingPivotRow(int &direction, int &gammaSign, double tolerance)
Find a row which can be used to perform an improving pivot return index of the cut or -1 if none exis...
std::vector< double > up_bounds_
std::vector< bool > col_in_subspace
Flag columns which are in the subspace (usualy remove nonbasic structurals in subspace) ...
To store extra cuts generated by columns from which they origin. 
void scaleCut(OsiRowCut &cut, double factor) const 
Scale the cut by factor. 
void printCglpBasis(std::ostream &os=std::cout)
Print CGLP basis corresponding to current tableau and source row. 
This file contains the enum for the standard set of Coin messages and a class definition whose sole p...
double computeCglpRedCost(int direction, int gammaSign, double tau)
Compute the reduced cost of Cglp. 
int numSourceRowEntered_
Record the number of times the source row entered the basis. 
int numIncreased_
Record the number of times that sigma increased. 
const int * getNonBasics() const 
double getColsolToCut(int index) const 
Access to value in solution to cut (indexed in reduced problem) 
int plotCGLPobj(int direction, double gammaTolerance, double pivotTol, bool reducedSpace, bool allowDegenerate, bool modularize)
void adjustTableauRow(int var, TabRow &row, int direction)
Adjust the row of the tableau to reflect leaving variable direction. 
void resetOriginalTableauRow(int var, TabRow &row, int direction)
reset the tableau row after a call to adjustTableauRow 
void printRowLateX(std::ostream &os, int i)
bool generateMig(int row, OsiRowCut &cut, const CglLandP::Parameters ¶ms)
Find Gomory cut (i.e. 
bool isInteger(int index) const 
Say if variable index by i in current tableau is integer. 
double computeCglpObjective(const TabRow &row, bool modularize=false) const 
Compute the objective value of the Cglp for given row and rhs (if strengthening shall be applied row ...
Class to validate or reject a cut. 
void createMIG(TabRow &row, OsiRowCut &cut) const 
Create strenghtened row. 
Class to hold and manipulate an array of massaged messages. 
int nrows_
Cached number of rows in reduced size problem. 
void setLogLevel(int value)
Set current log (detail) level. 
void printCutLateX(std::ostream &os, int i)
double newRowCoefficient(int j, double gamma) const 
return the coefficient of the new row (combining row_k + gamma row_i). 
void updateM1_M2_M3(TabRow &row, double tolerance, bool alwaysComputeCheap)
Update values in M1 M2 and M3 before an iteration.