Minotaur 0.4.1
Docs for developers
Public Member Functions | List of all members
Minotaur::CplexMILPEngine Class Reference

The CplexMILPEngine class can be called to solve MILP problems. More...

#include <CplexMILPEngine.h>

Inheritance diagram for Minotaur::CplexMILPEngine:
Inheritance graph
[legend]
Collaboration diagram for Minotaur::CplexMILPEngine:
Collaboration graph
[legend]

Public Member Functions

void doNothing ()
 
 CplexMILPEngine (EnvPtr env)
 Constructor with an environment.
 
 ~CplexMILPEngine ()
 Destroy.
 
void addConstraint (ConstraintPtr)
 Add a new constraint to the engine. More...
 
void changeBound (ConstraintPtr cons, BoundType lu, double new_val)
 Change a bound of a constraint. More...
 
void changeBound (VariablePtr var, BoundType lu, double new_val)
 Change a bound of a variable. More...
 
void changeBound (VariablePtr var, double new_lb, double new_ub)
 Change both bounds of a variable. More...
 
void changeConstraint (ConstraintPtr con, LinearFunctionPtr lf, double lb, double ub)
 Change the linear function, and the bounds of a constraint. More...
 
void changeConstraint (ConstraintPtr c, NonlinearFunctionPtr nlf)
 Change the nonlinear function, and the bounds of a constraint. More...
 
void changeObj (FunctionPtr f, double cb)
 Change objective function. More...
 
void clear ()
 Clear the problem. More...
 
void disableStrBrSetup ()
 Restore settings after strong branching. More...
 
EnginePtr emptyCopy ()
 Return an empty CplexMILPEngine pointer. More...
 
void enableStrBrSetup ()
 Make settings for strong branching. More...
 
UInt getNumSols ()
 Get the number of solutions in solution pool after recent solve. More...
 
double getSolutionValue ()
 Return the solution value of the objective after solving the LP. More...
 
ConstSolutionPtr getSolution ()
 Get the solution obtained after solving the problem. More...
 
ConstSolutionPtr getSolutionFromPool (int index)
 Get a particular solution from solution pool. More...
 
EngineStatus getStatus ()
 Get the status of the last solve command. More...
 
std::string getName () const
 Get the name. More...
 
ConstWarmStartPtr getWarmStart ()
 
WarmStartPtr getWarmStartCopy ()
 
void load (ProblemPtr problem)
 
void loadFromWarmStart (const WarmStartPtr)
 
void negateObj ()
 Negate the objective function. Min f is changed to Min -f. More...
 
void printx (double *x, UInt size)
 
void removeCons (std::vector< ConstraintPtr > &delcons)
 Delete constraints from the engine. More...
 
void resetIterationLimit ()
 Reset the iteration limit to maximum possible. More...
 
void setIterationLimit (int)
 
int setDualObjLimit (double)
 Set the dual objective limit. More...
 
void setTimeLimit (double)
 Set time limit for an iteration. More...
 
void setUpperCutoff (double)
 Set upper cutoff for an iteration. More...
 
EngineStatus solve ()
 Solve the problem that was loaded previously. More...
 
EngineStatus solveST (double *objLb, SolutionPtr *sol, STOAHandlerPtr stoa_hand, SolveStatus *solveStatus)
 
EngineStatus solveSTLazy (double *objLb, SolutionPtr *sol, STOAHandlerPtr stoa_hand, SolveStatus *solveStatus)
 
void writeLP (const char *filename) const
 Writes an LP file of the loaded problem.
 
void writeLP ()
 Writes an LP file in the directory of problem file.
 
void writeStats (std::ostream &out) const
 Write statistics. More...
 
- Public Member Functions inherited from Minotaur::MILPEngine
 MILPEngine ()
 Constructor. May set default parameters/options here.
 
virtual ~MILPEngine ()
 Destructor must be implemented if memory needs to be freed.
 
virtual void setTimeLimit (double)=0
 Set time limit for an iteration. More...
 
virtual void setUpperCutoff (double)=0
 Set upper cutoff for an iteration. More...
 
virtual UInt getNumSols ()=0
 Get number of solutions in the solution pool of MILP engine. More...
 
virtual ConstSolutionPtr getSolutionFromPool (int)=0
 Get a particular solution from solution pool. More...
 
- Public Member Functions inherited from Minotaur::Engine
 Engine ()
 Default constructor.
 
virtual ~Engine ()
 Destroy.
 
virtual void addConstraint (ConstraintPtr)=0
 Add a new constraint to the engine. More...
 
virtual void changeBound (ConstraintPtr cons, BoundType lu, double new_val)=0
 Change a bound of a constraint. More...
 
virtual void changeBound (VariablePtr var, BoundType lu, double new_val)=0
 Change a bound of a variable. More...
 
virtual void changeBound (VariablePtr var, double new_lb, double new_ub)=0
 Change both bounds of a variable. More...
 
virtual void changeConstraint (ConstraintPtr c, LinearFunctionPtr lf, double lb, double ub)=0
 Change the linear function, and the bounds of a constraint. More...
 
virtual void changeConstraint (ConstraintPtr c, NonlinearFunctionPtr nlf)=0
 Change the nonlinear function, and the bounds of a constraint. More...
 
virtual void changeObj (FunctionPtr f, double cb)=0
 Change objective function. More...
 
virtual void clear ()=0
 Clear the loaded problem, if any, from the engine. More...
 
virtual void disableStrBrSetup ()=0
 Restore settings after strong branching. More...
 
virtual EnginePtr emptyCopy ()
 Get a fresh copy of the engine, without the problem loaded into it. More...
 
virtual void enableStrBrSetup ()=0
 Make settings for strong branching. More...
 
virtual ConstSolutionPtr getSolution ()=0
 Get the solution obtained after solving the problem. More...
 
virtual double getSolutionValue ()=0
 Get the solution value. More...
 
virtual EngineStatus solve ()=0
 Solve the problem that was loaded previously. More...
 
virtual std::string getName () const =0
 Get the name. More...
 
virtual EngineStatus getStatus ()=0
 Get the status of the last solve command. More...
 
virtual std::string getStatusString ()
 Return a string that describes the status in simple words.
 
virtual ConstWarmStartPtr getWarmStart ()=0
 
virtual WarmStartPtr getWarmStartCopy ()=0
 
virtual void load (ProblemPtr problem)=0
 
virtual void loadFromWarmStart (const WarmStartPtr ws)=0
 
virtual void negateObj ()=0
 Negate the objective function. Min f is changed to Min -f. More...
 
virtual LoggerPtr getLogger ()
 Return pointer to the log manager.
 
virtual void removeCons (std::vector< ConstraintPtr > &delcons)=0
 Delete constraints from the engine. More...
 
virtual void resetIterationLimit ()=0
 Reset the iteration limit to maximum possible. More...
 
virtual int setDualObjLimit (double)=0
 Set the dual objective limit. More...
 
virtual void setIterationLimit (int limit)=0
 
virtual void setLogger (LoggerPtr logger)
 Set a new log manager.
 
virtual void setOptionsForSingleSolve ()
 
virtual void setOptionsForRepeatedSolve ()
 Set options to solve the NLP repeatedly, with few changes. More...
 
virtual void writeStats (std::ostream &) const
 
virtual void fillStats (std::vector< double > &)
 Accumulate statistics from different threads in a common data. More...
 

Additional Inherited Members

- Protected Attributes inherited from Minotaur::Engine
EngineStatus status_
 Status of the last solve.
 
LoggerPtr logger_
 Keep log.
 

Detailed Description

The CplexMILPEngine class can be called to solve MILP problems.

Member Function Documentation

◆ addConstraint()

void CplexMILPEngine::addConstraint ( ConstraintPtr  )
virtual

Add a new constraint to the engine.

Implements Minotaur::Engine.

◆ changeBound() [1/3]

void CplexMILPEngine::changeBound ( ConstraintPtr  cons,
BoundType  lu,
double  new_val 
)
virtual

Change a bound of a constraint.

Implements Minotaur::Engine.

◆ changeBound() [2/3]

void CplexMILPEngine::changeBound ( VariablePtr  var,
BoundType  lu,
double  new_val 
)
virtual

Change a bound of a variable.

Implements Minotaur::Engine.

◆ changeBound() [3/3]

void CplexMILPEngine::changeBound ( VariablePtr  var,
double  new_lb,
double  new_ub 
)
virtual

Change both bounds of a variable.

Implements Minotaur::Engine.

◆ changeConstraint() [1/2]

void CplexMILPEngine::changeConstraint ( ConstraintPtr  c,
NonlinearFunctionPtr  nlf 
)
virtual

Change the nonlinear function, and the bounds of a constraint.

Parameters
[in]cOriginal constraint that is to be changed.
[nlf]The new nonlinear function.

Implements Minotaur::Engine.

◆ changeConstraint() [2/2]

void CplexMILPEngine::changeConstraint ( ConstraintPtr  c,
LinearFunctionPtr  lf,
double  lb,
double  ub 
)
virtual

Change the linear function, and the bounds of a constraint.

Parameters
[in]cOriginal constraint that is to be changed.
[lf]The new linear function.
[lb]The new lower bound.
[ub]The new upper bound.

Implements Minotaur::Engine.

◆ changeObj()

void CplexMILPEngine::changeObj ( FunctionPtr  f,
double  cb 
)
virtual

Change objective function.

Implements Minotaur::Engine.

◆ clear()

void CplexMILPEngine::clear ( )
virtual

Clear the problem.

Implements Minotaur::Engine.

◆ disableStrBrSetup()

void Minotaur::CplexMILPEngine::disableStrBrSetup ( )
inlinevirtual

Restore settings after strong branching.

Implements Minotaur::Engine.

◆ emptyCopy()

EnginePtr CplexMILPEngine::emptyCopy ( )
virtual

Return an empty CplexMILPEngine pointer.

Reimplemented from Minotaur::Engine.

◆ enableStrBrSetup()

void Minotaur::CplexMILPEngine::enableStrBrSetup ( )
inlinevirtual

Make settings for strong branching.

Implements Minotaur::Engine.

◆ getName()

std::string CplexMILPEngine::getName ( ) const
virtual

Get the name.

Implements Minotaur::Engine.

◆ getNumSols()

UInt CplexMILPEngine::getNumSols ( )
virtual

Get the number of solutions in solution pool after recent solve.

Implements Minotaur::MILPEngine.

◆ getSolution()

ConstSolutionPtr CplexMILPEngine::getSolution ( )
virtual

Get the solution obtained after solving the problem.

Implements Minotaur::Engine.

◆ getSolutionFromPool()

ConstSolutionPtr CplexMILPEngine::getSolutionFromPool ( int  )
virtual

Get a particular solution from solution pool.

Implements Minotaur::MILPEngine.

◆ getSolutionValue()

double CplexMILPEngine::getSolutionValue ( )
virtual

Return the solution value of the objective after solving the LP.

Implements Minotaur::Engine.

◆ getStatus()

EngineStatus CplexMILPEngine::getStatus ( )
virtual

Get the status of the last solve command.

Implements Minotaur::Engine.

◆ getWarmStart()

ConstWarmStartPtr Minotaur::CplexMILPEngine::getWarmStart ( )
inlinevirtual

Get warm start information from the engine. This warm start information can change if the engine is used to solve something else again.

Implements Minotaur::Engine.

◆ getWarmStartCopy()

WarmStartPtr Minotaur::CplexMILPEngine::getWarmStartCopy ( )
inlinevirtual

Get a full copy of warm start information from the engine. Does not change even if the engine starts solving something else later on.

Implements Minotaur::Engine.

◆ load()

void CplexMILPEngine::load ( ProblemPtr  problem)
virtual

Load the problem into the engine. We create arrays of variables and constraints, the A matrix, rhs, objective etc from the problem and initialize the LP solver.

Implements Minotaur::Engine.

◆ loadFromWarmStart()

void Minotaur::CplexMILPEngine::loadFromWarmStart ( const  ws)
inlinevirtual

Use warm start information for solving the next problem. May Create a copy of WarmStart and use the copy inside the engine; the copy (but not the original) gets updated after solving a relaxation.

Implements Minotaur::Engine.

◆ negateObj()

void CplexMILPEngine::negateObj ( )
virtual

Negate the objective function. Min f is changed to Min -f.

Implements Minotaur::Engine.

◆ removeCons()

void CplexMILPEngine::removeCons ( std::vector< ConstraintPtr > &  delcons)
virtual

Delete constraints from the engine.

Parameters
[in]delconsA vector of constraint pointers that should be deleted from the engine.

Implements Minotaur::Engine.

◆ resetIterationLimit()

void CplexMILPEngine::resetIterationLimit ( )
virtual

Reset the iteration limit to maximum possible.

Implements Minotaur::Engine.

◆ setDualObjLimit()

int Minotaur::CplexMILPEngine::setDualObjLimit ( double  )
inlinevirtual

Set the dual objective limit.

Implements Minotaur::Engine.

◆ setIterationLimit()

void CplexMILPEngine::setIterationLimit ( int  limit)
virtual

Set a limit on number of iterations. For strong-branching, for instance.

Implements Minotaur::Engine.

◆ setTimeLimit()

void CplexMILPEngine::setTimeLimit ( double  )
virtual

Set time limit for an iteration.

Implements Minotaur::MILPEngine.

◆ setUpperCutoff()

void CplexMILPEngine::setUpperCutoff ( double  )
virtual

Set upper cutoff for an iteration.

Implements Minotaur::MILPEngine.

◆ solve()

EngineStatus CplexMILPEngine::solve ( )
virtual

Solve the problem that was loaded previously.

Implements Minotaur::Engine.

◆ writeStats()

void CplexMILPEngine::writeStats ( std::ostream &  out) const
virtual

Write statistics.

Reimplemented from Minotaur::Engine.


The documentation for this class was generated from the following files:

Minotaur source code documented by Doxygen 1.9.4 on Thu Apr 24 2025