Twostep MIR Cut Generator Class. More...
#include <CglTwomir.hpp>
Public Member Functions | |
Generate Cuts | |
virtual void | generateCuts (const OsiSolverInterface &si, OsiCuts &cs, const CglTreeInfo info=CglTreeInfo()) const |
Generate Two step MIR cuts either from the tableau rows or from the formulation rows. | |
virtual bool | needsOptimalBasis () const |
Return true if needs optimal basis to do cuts (will return true). | |
Change criterion on which scalings to use (default = 1,1,1,1) | |
void | setMirScale (int tmin, int tmax) |
Set. | |
void | setTwomirScale (int qmin, int qmax) |
Set. | |
void | setAMax (int a) |
Set. | |
void | setMaxElements (int n) |
Set. | |
void | setCutTypes (bool mir, bool twomir, bool tab, bool form) |
Set. | |
void | setFormulationRows (int n) |
Set. | |
int | getTmin () const |
Get. | |
int | getTmax () const |
Set. | |
int | getQmin () const |
Set. | |
int | getQmax () const |
Set. | |
int | getAmax () const |
Set. | |
int | getMaxElements () const |
Set. | |
int | getIfMir () const |
Set. | |
int | getIfTwomir () const |
Set. | |
int | getIfTableau () const |
Set. | |
int | getIfFormulation () const |
Set. | |
Constructors and destructors | |
CglTwomir () | |
Default constructor. | |
CglTwomir (const CglTwomir &) | |
Copy constructor. | |
virtual CglCutGenerator * | clone () const |
Clone. | |
CglTwomir & | operator= (const CglTwomir &rhs) |
Assignment operator. | |
virtual | ~CglTwomir () |
Destructor. | |
virtual std::string | generateCpp (FILE *fp) |
Create C++ lines to get to current state. | |
Public Attributes | |
std::string | probname_ |
Problem name. | |
Private Attributes | |
Private member data | |
bool | do_mir_ |
t_min - first value of t to use for tMIR inequalities | |
bool | do_2mir_ |
t_min - first value of t to use for tMIR inequalities | |
bool | do_tab_ |
t_min - first value of t to use for tMIR inequalities | |
bool | do_form_ |
t_min - first value of t to use for tMIR inequalities | |
int | t_min_ |
t_min - first value of t to use for tMIR inequalities | |
int | t_max_ |
t_min - first value of t to use for tMIR inequalities | |
int | q_min_ |
t_max - last value of t to use for tMIR inequalities | |
int | q_max_ |
q_min - first value of t to use for 2-Step tMIR inequalities | |
int | a_max_ |
q_max - last value of t to use for 2-Step tMIR inequalities | |
int | max_elements_ |
a_max - maximum value of bhat/alpha | |
int | form_nrows_ |
Maximum number of elements in cut. | |
Friends | |
void | CglTwomirUnitTest (const OsiSolverInterface *siP, const std::string mpdDir) |
A function that tests the methods in the CglTwomir class. |
Twostep MIR Cut Generator Class.
Definition at line 88 of file CglTwomir.hpp.
CglTwomir::CglTwomir | ( | ) |
Default constructor.
CglTwomir::CglTwomir | ( | const CglTwomir & | ) |
Copy constructor.
virtual CglTwomir::~CglTwomir | ( | ) | [virtual] |
Destructor.
virtual void CglTwomir::generateCuts | ( | const OsiSolverInterface & | si, | |
OsiCuts & | cs, | |||
const CglTreeInfo | info = CglTreeInfo() | |||
) | const [virtual] |
Generate Two step MIR cuts either from the tableau rows or from the formulation rows.
Implements CglCutGenerator.
virtual bool CglTwomir::needsOptimalBasis | ( | ) | const [virtual] |
Return true if needs optimal basis to do cuts (will return true).
Reimplemented from CglCutGenerator.
void CglTwomir::setMirScale | ( | int | tmin, | |
int | tmax | |||
) | [inline] |
Set.
Definition at line 112 of file CglTwomir.hpp.
void CglTwomir::setTwomirScale | ( | int | qmin, | |
int | qmax | |||
) | [inline] |
Set.
Definition at line 113 of file CglTwomir.hpp.
void CglTwomir::setAMax | ( | int | a | ) | [inline] |
Set.
Definition at line 114 of file CglTwomir.hpp.
void CglTwomir::setMaxElements | ( | int | n | ) | [inline] |
Set.
Definition at line 115 of file CglTwomir.hpp.
void CglTwomir::setCutTypes | ( | bool | mir, | |
bool | twomir, | |||
bool | tab, | |||
bool | form | |||
) | [inline] |
Set.
Definition at line 116 of file CglTwomir.hpp.
void CglTwomir::setFormulationRows | ( | int | n | ) | [inline] |
Set.
Definition at line 118 of file CglTwomir.hpp.
int CglTwomir::getTmin | ( | ) | const [inline] |
Get.
Definition at line 121 of file CglTwomir.hpp.
int CglTwomir::getTmax | ( | ) | const [inline] |
Set.
Definition at line 122 of file CglTwomir.hpp.
int CglTwomir::getQmin | ( | ) | const [inline] |
Set.
Definition at line 123 of file CglTwomir.hpp.
int CglTwomir::getQmax | ( | ) | const [inline] |
Set.
Definition at line 124 of file CglTwomir.hpp.
int CglTwomir::getAmax | ( | ) | const [inline] |
Set.
Definition at line 125 of file CglTwomir.hpp.
int CglTwomir::getMaxElements | ( | ) | const [inline] |
Set.
Definition at line 126 of file CglTwomir.hpp.
int CglTwomir::getIfMir | ( | ) | const [inline] |
Set.
Definition at line 127 of file CglTwomir.hpp.
int CglTwomir::getIfTwomir | ( | ) | const [inline] |
Set.
Definition at line 128 of file CglTwomir.hpp.
int CglTwomir::getIfTableau | ( | ) | const [inline] |
Set.
Definition at line 129 of file CglTwomir.hpp.
int CglTwomir::getIfFormulation | ( | ) | const [inline] |
Set.
Definition at line 130 of file CglTwomir.hpp.
virtual CglCutGenerator* CglTwomir::clone | ( | ) | const [virtual] |
Clone.
Implements CglCutGenerator.
Assignment operator.
Reimplemented from CglCutGenerator.
virtual std::string CglTwomir::generateCpp | ( | FILE * | fp | ) | [virtual] |
Create C++ lines to get to current state.
Reimplemented from CglCutGenerator.
void CglTwomirUnitTest | ( | const OsiSolverInterface * | siP, | |
const std::string | mpdDir | |||
) | [friend] |
A function that tests the methods in the CglTwomir class.
The only reason for it not to be a member method is that this way it doesn't have to be compiled into the library. And that's a gain, because the library should be compiled with optimization on, but this method should be compiled with debugging.
std::string CglTwomir::probname_ [mutable] |
Problem name.
Definition at line 97 of file CglTwomir.hpp.
bool CglTwomir::do_mir_ [private] |
t_min - first value of t to use for tMIR inequalities
Definition at line 157 of file CglTwomir.hpp.
bool CglTwomir::do_2mir_ [private] |
t_min - first value of t to use for tMIR inequalities
Definition at line 158 of file CglTwomir.hpp.
bool CglTwomir::do_tab_ [private] |
t_min - first value of t to use for tMIR inequalities
Definition at line 159 of file CglTwomir.hpp.
bool CglTwomir::do_form_ [private] |
t_min - first value of t to use for tMIR inequalities
Definition at line 160 of file CglTwomir.hpp.
int CglTwomir::t_min_ [private] |
t_min - first value of t to use for tMIR inequalities
Definition at line 162 of file CglTwomir.hpp.
int CglTwomir::t_max_ [private] |
t_min - first value of t to use for tMIR inequalities
Definition at line 163 of file CglTwomir.hpp.
int CglTwomir::q_min_ [private] |
t_max - last value of t to use for tMIR inequalities
Definition at line 164 of file CglTwomir.hpp.
int CglTwomir::q_max_ [private] |
q_min - first value of t to use for 2-Step tMIR inequalities
Definition at line 165 of file CglTwomir.hpp.
int CglTwomir::a_max_ [private] |
q_max - last value of t to use for 2-Step tMIR inequalities
Definition at line 166 of file CglTwomir.hpp.
int CglTwomir::max_elements_ [private] |
a_max - maximum value of bhat/alpha
Definition at line 167 of file CglTwomir.hpp.
int CglTwomir::form_nrows_ [private] |
Maximum number of elements in cut.
Definition at line 169 of file CglTwomir.hpp.