74 const std::string &netlibDir);
93 bool dropNames =
true,
bool dropIntegers =
true);
111 const double *collb,
const double *colub,
113 const double *rowlb,
const double *rowub,
116 const double *collb,
const double *colub,
118 const double *rowlb,
const double *rowub,
123 void loadProblem(
const int numcols,
const int numrows,
126 const double *collb,
const double *colub,
128 const double *rowlb,
const double *rowub,
131 void loadProblem(
const int numcols,
const int numrows,
133 const double *value,
const int *length,
134 const double *collb,
const double *colub,
136 const double *rowlb,
const double *rowub,
139 int readMps(
const char *filename,
140 bool keepNames =
false,
141 bool ignoreErrors =
false);
287 void fixFixed(
bool reallyFix =
true);
343 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] | 1);
347 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] & ~1);
349 inline bool fixed(
int sequence)
const
351 return ((
status_[sequence] & 1) != 0);
357 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] | 2);
361 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] & ~2);
365 return ((
status_[sequence] & 2) != 0);
371 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] | 4);
375 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] & ~4);
379 return ((
status_[sequence] & 4) != 0);
385 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] | 8);
389 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] & ~8);
393 return ((
status_[sequence] & 8) != 0);
399 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] | 16);
403 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] & ~16);
407 return ((
status_[sequence] & 16) != 0);
413 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] | 32);
417 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] & ~32);
421 return ((
status_[sequence] & 32) != 0);
427 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] | 64);
431 status_[sequence] =
static_cast< unsigned char >(
status_[sequence] & ~64);
435 return ((
status_[sequence] & 64) != 0);
536 #define LENGTH_HISTORY 5
617 const std::string &netlibDir);
int algorithm() const
Current (or last) algorithm.
bool goneDualFeasible_
goneDualFeasible.
void clearUpperBound(int sequence)
bool flagged(int sequence) const
CoinWorkDouble diagonalNorm_
diagonalNorm.
CoinWorkDouble maximumBoundInfeasibility_
maximumBoundInfeasibility.
friend void ClpInteriorUnitTest(const std::string &mpsDir, const std::string &netlibDir)
A function that tests the methods in the ClpInterior class.
CoinWorkDouble complementarityGap() const
ComplementarityGap.
CoinWorkDouble gamma() const
gamma
CoinWorkDouble smallestInfeasibility_
smallestInfeasibility
void ClpInteriorUnitTest(const std::string &mpsDir, const std::string &netlibDir)
A function that tests the methods in the ClpInterior class.
void setDelta(CoinWorkDouble value)
CoinWorkDouble * columnLowerWork_
Column lower bounds - working copy.
CoinWorkDouble worstComplementarity_
Worst complementarity.
void setFixedOrFree(int sequence)
To say a variable is fixed OR free.
int numberComplementarityItems_
numberComplementarityItems_ i.e. number of active bounds
Abstract base class for Clp Matrices.
CoinWorkDouble * rhsL_
rhsL.
CoinWorkDouble * solution_
solution
This solves LPs using interior point methods.
CoinWorkDouble rawObjectiveValue() const
Raw objective value (so always minimize)
void setUpperBound(int sequence)
To say a variable has upper bound.
CoinWorkDouble primalObjective() const
primalObjective.
CoinWorkDouble historyInfeasibility_[LENGTH_HISTORY]
CoinWorkDouble * lower_
Working copy of lower bounds (Owner of arrays below)
CoinWorkDouble solutionNorm_
solutionNorm.
bool fakeLower(int sequence) const
This class implements LSQR.
CoinWorkDouble linearPerturbation() const
linearPerturbation
CoinWorkDouble * primalR() const
Primal erturbation vector.
CoinWorkDouble diagonalPerturbation_
diagonalPerturbation
void clearFixedOrFree(int sequence)
CoinWorkDouble * deltaSU_
deltaS.
CoinWorkDouble sumPrimalInfeasibilities() const
Sum of primal infeasibilities.
bool lowerBound(int sequence) const
******** DATA to be moved into protected section of ClpInterior
CoinWorkDouble * rhsC_
rhs C
CoinWorkDouble largestPrimalError() const
Largest error on Ax-b.
bool gonePrimalFeasible_
gonePrimalFeasible.
~ClpInterior()
Destructor.
CoinWorkDouble targetGap_
targetGap
void setFixed(int sequence)
To say a variable is fixed.
CoinWorkDouble * errorRegion_
errorRegion. i.e. Ax
CoinWorkDouble objectiveNorm_
objectiveNorm.
int algorithm_
Which algorithm being used.
bool fakeUpper(int sequence) const
CoinWorkDouble * deltaY_
delta Y
int maximumBarrierIterations_
Maximum iterations.
void setGamma(CoinWorkDouble value)
CoinWorkDouble * upperSlack_
upperSlack
int isColumn(int sequence) const
Returns 1 if sequence indicates column.
int numberColumns() const
void clearFakeUpper(int sequence)
Base class for Clp Cholesky factorization Will do better factorization.
CoinWorkDouble baseObjectiveNorm_
baseObjectiveNorm
CoinWorkDouble * rhsFixRegion_
rhsFixRegion.
void clearLowerBound(int sequence)
CoinWorkDouble * rhsZ_
rhsZ.
#define LENGTH_HISTORY
historyInfeasibility.
CoinWorkDouble delta() const
delta
void setFakeLower(int sequence)
To say a variable has fake lower bound.
void clearFixed(int sequence)
void setLinearPerturbation(CoinWorkDouble value)
******** DATA to be moved into protected section of ClpInterior
CoinWorkDouble * rhsW_
rhsW.
CoinWorkDouble projectionTolerance_
projectionTolerance
CoinWorkDouble * zVec_
zVec
int numberComplementarityPairs_
numberComplementarityPairs i.e. ones with lower and/or upper bounds (not fixed)
int sequenceWithin(int sequence) const
Returns sequence number within section.
int primalDual()
Primal-Dual Predictor-Corrector barrier.
CoinWorkDouble * deltaSL_
CoinWorkDouble * workArray_
work array
CoinWorkDouble sumPrimalInfeasibilities_
Sum of primal infeasibilities.
CoinWorkDouble diagonalNorm() const
diagonalNorm
void gutsOfCopy(const ClpInterior &rhs)
Does most of copying.
ClpInterior()
Default constructor.
CoinWorkDouble complementarityGap_
complementarityGap.
void setFakeUpper(int sequence)
To say a variable has fake upper bound.
CoinWorkDouble maximumRHSError_
maximumRHSError. maximum Ax
CoinWorkDouble maximumDualError_
maximumDualError.
CoinWorkDouble * diagonal_
diagonal
CoinWorkDouble primalObjective_
primalObjective.
Abstract base class for tailoring everything for Pcdo.
CoinWorkDouble * dualR() const
Dual erturbation vector.
int numberColumns_
Number of columns.
ClpInterior & operator=(const ClpInterior &rhs)
Assignment operator. This copies the data.
void setAlgorithm(int value)
Set algorithm.
void checkSolution()
Checks solution.
CoinWorkDouble * columnUpperWork_
Column upper bounds - working copy.
CoinWorkDouble quadraticDjs(CoinWorkDouble *djRegion, const CoinWorkDouble *solution, CoinWorkDouble scaleFactor)
Modifies djs to allow for quadratic.
int readMps(const char *filename, bool keepNames=false, bool ignoreErrors=false)
Read an mps file from the given filename.
double * rowObjective() const
Row Objective.
CoinWorkDouble largestDualError() const
Largest error on basic duals.
CoinWorkDouble * upper_
Working copy of upper bounds (Owner of arrays below)
void setMaximumBarrierIterations(int value)
void setProjectionTolerance(CoinWorkDouble value)
CoinWorkDouble * rowUpperWork_
Row upper bounds - working copy.
CoinWorkDouble * deltaW_
deltaW.
void clearFlagged(int sequence)
CoinWorkDouble actualPrimalStep_
actualPrimalStep
CoinWorkDouble sumDualInfeasibilities() const
Sum of dual infeasibilities.
ClpLsqr * lsqrObject_
Pointer to Lsqr object.
int pdco()
Pdco algorithm - see ClpPdco.hpp for method.
Sparse Matrix Base Class.
CoinWorkDouble * dualR_
Dual regularization array.
CoinWorkDouble dualObjective() const
dualObjective.
ClpPdcoBase * pdcoStuff_
Pointer to stuff.
bool dualFeasible() const
If problem is dual feasible.
CoinWorkDouble maximumRHSChange_
maximumRHSChange
CoinWorkDouble rhsNorm_
rhsNorm.
CoinWorkDouble sumDualInfeasibilities_
Sum of dual infeasibilities.
bool fixed(int sequence) const
bool fixedOrFree(int sequence) const
int numberRows() const
Number of rows.
void setLowerBound(int sequence)
To say a variable has lower bound.
int housekeeping()
This does housekeeping.
bool upperBound(int sequence) const
CoinWorkDouble scaleFactor_
scaleFactor. For scaling objective
CoinWorkDouble * deltaX_
delta X
CoinWorkDouble stepLength_
stepLength
bool sanityCheck()
Sanity check on input rim data.
CoinWorkDouble * lowerSlack_
lowerSlack
unsigned char * status_
Status (i.e.
bool primalFeasible() const
If problem is primal feasible.
void fixFixed(bool reallyFix=true)
fix variables interior says should be.
CoinWorkDouble diagonalPerturbation() const
diagonalPerturbation
void setCholesky(ClpCholeskyBase *cholesky)
Set cholesky (and delete present one)
CoinWorkDouble * cost_
Working copy of objective.
CoinWorkDouble * wVec_
wVec
void returnModel(ClpModel &otherModel)
Return model - updates any scalars.
int maximumBarrierIterations() const
Maximum iterations.
CoinWorkDouble largestPrimalError_
Largest error on Ax-b.
int numberFixed() const
Return number fixed to see if worth presolving.
CoinWorkDouble * rhs_
Rhs.
bool createWorkingData()
Returns true if data looks okay, false if not.
CoinWorkDouble * rowLowerWork_
Row lower bounds - working copy.
CoinWorkDouble actualDualStep_
actualDualStep
CoinWorkDouble * rhsU_
rhsU.
void borrowModel(ClpModel &otherModel)
Borrow model.
CoinWorkDouble linearPerturbation_
linearPerturbation
CoinWorkDouble worstDirectionAccuracy_
worstDirectionAccuracy
ClpCholeskyBase * cholesky_
cholesky.
CoinWorkDouble dualObjective_
dualObjective.
void dropNames()
Drops names - makes lengthnames 0 and names empty.
CoinWorkDouble * primalR_
Primal regularization array.
double objectiveValue_
Objective value.
CoinWorkDouble projectionTolerance() const
projectionTolerance
CoinWorkDouble * rhsB_
rhs B
void setFlagged(int sequence)
To flag a variable.
CoinWorkDouble * deltaZ_
deltaZ.
CoinPackedMatrix * matrix() const
Matrix (if not ClpPackedmatrix be careful about memory leak.
CoinWorkDouble diagonalScaleFactor_
diagonalScaleFactor.
void loadProblem(const ClpMatrixBase &matrix, const double *collb, const double *colub, const double *obj, const double *rowlb, const double *rowub, const double *rowObjective=NULL)
Loads a problem (the constraints on the rows are given by lower and upper bounds).
******** DATA to be moved into protected section of ClpInterior
CoinWorkDouble mu_
Below here is standard barrier stuff mu.
void gutsOfDelete()
Does most of deletion.
CoinWorkDouble largestDualError_
Largest error on basic duals.
void clearFakeLower(int sequence)
void setDiagonalPerturbation(CoinWorkDouble value)