All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
SPxDefaultRT Class Reference Textbook ratio test for SoPlex.Class SPxDefaultRT provides an implementation of the textbook ratio test as a derived class of SPxRatioTester. This class is not intended for reliably solving LPs (even though it does the job for ``numerically simple'' LPs). Instead, it should serve as a demonstration of how to write ratio tester classes. More...
Inheritance diagram for SPxDefaultRT:
![]()
Detailed DescriptionTextbook ratio test for SoPlex. Class SPxDefaultRT provides an implementation of the textbook ratio test as a derived class of SPxRatioTester. This class is not intended for reliably solving LPs (even though it does the job for ``numerically simple'' LPs). Instead, it should serve as a demonstration of how to write ratio tester classes. See SPxRatioTester for a class documentation. Definition at line 42 of file spxdefaultrt.h. Constructor & Destructor Documentation
default constructor Definition at line 50 of file spxdefaultrt.h. Referenced by SPxDefaultRT::clone().
copy constructor Definition at line 54 of file spxdefaultrt.h.
destructor Definition at line 68 of file spxdefaultrt.h. Member Function Documentation
clone function for polymorphism Implements SPxRatioTester. Definition at line 71 of file spxdefaultrt.h. References SPxDefaultRT::SPxDefaultRT().
assignment operator Definition at line 58 of file spxdefaultrt.h. References SPxRatioTester::operator=(). Here comes the ratio test. It is assumed that theCoPvec.delta() and theCoPvec.idx() have been setup correctly! Implements SPxRatioTester. Definition at line 177 of file spxdefaultrt.cpp. References SSVector::clearNum(), SPxSolver::coId(), SPxSolver::coPvec(), SPxRatioTester::delta, UpdateVector::delta(), SPxSolver::epsilon(), Vector::get_const_ptr(), SPxSolver::id(), UpdateVector::idx(), IdxSet::index(), soplex::infinity, SPxSolver::isBasic(), SPxId::isValid(), SPxSolver::lcBound(), SPxSolver::lpBound(), MSG_DEBUG, SPxSolver::pVec(), SSVector::setup(), IdxSet::size(), SPxRatioTester::solver(), soplex::spxout, SPxSolver::ucBound(), SPxSolver::upBound(), and SSVector::values(). Here comes the ratio test for selecting a variable to leave the basis. It is assumed that Vec.delta() and fVec.idx() have been setup correctly! The leaving variable is selected such that the update of fVec() (using fVec.value() * fVec.delta()) keeps the basis feasible within solver()->entertol(). Hence, fVec.value() must be chosen such that one updated value of theFvec just reaches its bound and no other one exceeds them by more than solver()->entertol(). Further, fVec.value() must have the same sign as argument The return value of selectLeave() is the number of a variable in the basis selected to leave the basis. -1 indicates that no variable could be selected. Otherwise, parameter Implements SPxRatioTester. Definition at line 42 of file spxdefaultrt.cpp. References ASSERT_WARN, SPxRatioTester::delta, UpdateVector::delta(), SPxSolver::epsilon(), SPxSolver::fVec(), Vector::get_const_ptr(), UpdateVector::idx(), IdxSet::index(), soplex::infinity, SPxSolver::lbBound(), SSVector::setup(), IdxSet::size(), SPxRatioTester::solver(), SPxSolver::ubBound(), and SSVector::values().
|