All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
SPxFastRT Class Reference Fast shifting ratio test.Class SPxFastRT is an implementation class of SPxRatioTester providing fast and stable ratio test. Stability is achieved by allowing some infeasibility to ensure numerical stability such as the Harris procedure. Performance is achieved by skipping the second phase if the first phase already shows a stable enough pivot. More...
Inheritance diagram for SPxFastRT:
![]()
Detailed DescriptionFast shifting ratio test. Class SPxFastRT is an implementation class of SPxRatioTester providing fast and stable ratio test. Stability is achieved by allowing some infeasibility to ensure numerical stability such as the Harris procedure. Performance is achieved by skipping the second phase if the first phase already shows a stable enough pivot. See SPxRatioTester for a class documentation. Definition at line 41 of file spxfastrt.h. Constructor & Destructor Documentation
copy constructor Definition at line 176 of file spxfastrt.h.
bound flipping constructor Definition at line 198 of file spxfastrt.h.
destructor Definition at line 203 of file spxfastrt.h. Member Function Documentation
clone function for polymorphism Implements SPxRatioTester. Reimplemented in SPxBoundFlippingRT. Definition at line 206 of file spxfastrt.h. References SPxFastRT::SPxFastRT().
Reimplemented from SPxRatioTester. Definition at line 232 of file spxfastrt.h. References SPxFastRT::fastDelta.
Reimplemented from SPxRatioTester. Definition at line 1290 of file spxfastrt.cpp. References SPxFastRT::setType(), SPxRatioTester::thesolver, and SPxSolver::type().
Max phase 1 value. Computes the maximum value Definition at line 103 of file spxfastrt.cpp. References SSVector::altIndexMem(), SSVector::altValues(), UpdateVector::delta(), Vector::dim(), SPxFastRT::epsilon, SPxFastRT::fastDelta, SSVector::forceSetup(), Vector::get_const_ptr(), SSVector::indexMem(), soplex::infinity, SPxSolver::isBasic(), SPxSolver::isCoBasic(), SPxFastRT::iscoid, SSVector::isSetup(), SPxSolver::LEAVE, SPxRatioTester::m_type, SSVector::setSize(), SSVector::size(), SPxRatioTester::thesolver, and SSVector::values(). Referenced by SPxFastRT::maxDelta(), SPxFastRT::selectEnter(), and SPxFastRT::selectLeave(). Definition at line 413 of file spxfastrt.cpp. References SPxSolver::fVec(), SPxSolver::lbBound(), SPxFastRT::maxDelta(), SPxRatioTester::thesolver, and SPxSolver::ubBound(). Definition at line 429 of file spxfastrt.cpp. References SPxSolver::coId(), SPxSolver::coPvec(), SPxSolver::id(), SPxFastRT::iscoid, SPxSolver::lcBound(), SPxSolver::lpBound(), SPxFastRT::maxDelta(), SPxSolver::pVec(), SPxRatioTester::thesolver, SPxSolver::ucBound(), and SPxSolver::upBound(). Definition at line 957 of file spxfastrt.cpp. References SSVector::clearIdx(), SPxSolver::coPvec(), UpdateVector::delta(), SPxFastRT::fastDelta, SPxSolver::isBasic(), SPxSolver::isCoBasic(), SPxSolver::isCoId(), SPxSolver::isId(), SPxSolver::lcBound(), SPxSolver::lpBound(), SPxSolver::pVec(), SPxSolver::theShift, SPxRatioTester::thesolver, SPxSolver::ucBound(), SPxSolver::upBound(), and SPxSolver::vector(). Referenced by SPxFastRT::selectEnter(). Definition at line 777 of file spxfastrt.cpp. References UpdateVector::delta(), SPxFastRT::fastDelta, SPxSolver::fVec(), SPxSolver::lbBound(), SPxSolver::shiftLBbound(), SPxSolver::shiftUBbound(), SPxRatioTester::thesolver, and SPxSolver::ubBound(). Referenced by SPxFastRT::selectLeave().
selects stable index for maximizing ratio test. Selects from all update values Definition at line 567 of file spxfastrt.cpp. References UpdateVector::delta(), Vector::get_const_ptr(), SSVector::indexMem(), SPxSolver::isBasic(), SPxSolver::isCoBasic(), SPxFastRT::iscoid, SPxSolver::LEAVE, SPxRatioTester::m_type, SSVector::size(), SPxRatioTester::thesolver, and SSVector::values(). Referenced by SPxFastRT::maxSelect(), SPxFastRT::selectEnter(), and SPxFastRT::selectLeave(). Definition at line 646 of file spxfastrt.cpp. References SPxSolver::fVec(), soplex::infinity, SPxSolver::lbBound(), SPxFastRT::maxSelect(), SPxRatioTester::thesolver, and SPxSolver::ubBound(). Definition at line 658 of file spxfastrt.cpp. References SPxSolver::coId(), SPxSolver::coPvec(), SPxSolver::id(), soplex::infinity, SPxFastRT::iscoid, SPxSolver::lcBound(), SPxSolver::lpBound(), SPxFastRT::maxSelect(), SPxSolver::pVec(), SPxRatioTester::thesolver, SPxSolver::ucBound(), and SPxSolver::upBound(). Definition at line 733 of file spxfastrt.cpp. References UpdateVector::delta(), SPxSolver::fVec(), SPxSolver::lbBound(), SHORT, SPxRatioTester::thesolver, and SPxSolver::ubBound(). Referenced by SPxFastRT::selectLeave().
Min phase 1 value. Computes the minimum value Definition at line 258 of file spxfastrt.cpp. References SSVector::altIndexMem(), SSVector::altValues(), UpdateVector::delta(), Vector::dim(), SPxFastRT::epsilon, SPxFastRT::fastDelta, SSVector::forceSetup(), Vector::get_const_ptr(), SSVector::indexMem(), soplex::infinity, SPxSolver::isBasic(), SPxSolver::isCoBasic(), SPxFastRT::iscoid, SSVector::isSetup(), SPxSolver::LEAVE, SPxRatioTester::m_type, SSVector::setSize(), SSVector::size(), SPxRatioTester::thesolver, and SSVector::values(). Referenced by SPxFastRT::minDelta(), SPxFastRT::selectEnter(), and SPxFastRT::selectLeave(). Definition at line 421 of file spxfastrt.cpp. References SPxSolver::fVec(), SPxSolver::lbBound(), SPxFastRT::minDelta(), SPxRatioTester::thesolver, and SPxSolver::ubBound(). Definition at line 457 of file spxfastrt.cpp. References SPxSolver::coId(), SPxSolver::coPvec(), SPxSolver::id(), SPxFastRT::iscoid, SPxSolver::lcBound(), SPxSolver::lpBound(), SPxFastRT::minDelta(), SPxSolver::pVec(), SPxRatioTester::thesolver, SPxSolver::ucBound(), and SPxSolver::upBound(). numerical stability check. Tests whether the selected enter Definition at line 1049 of file spxfastrt.cpp. References SSVector::clearIdx(), SPxSolver::coPvec(), UpdateVector::delta(), SPxFastRT::fastDelta, SPxSolver::isBasic(), SPxSolver::isCoBasic(), SPxSolver::isCoId(), SPxSolver::isId(), SPxSolver::lcBound(), SPxSolver::lpBound(), SPxSolver::pVec(), SPxSolver::theShift, SPxRatioTester::thesolver, SPxSolver::ucBound(), SPxSolver::upBound(), and SPxSolver::vector(). Referenced by SPxFastRT::selectEnter(). numerical stability tests. Tests whether the selected leave index needs to be discarded (and do so) and the ratio test is to be recomputed. Definition at line 809 of file spxfastrt.cpp. References UpdateVector::delta(), SPxFastRT::fastDelta, SPxSolver::fVec(), SPxSolver::lbBound(), SPxSolver::theShift, SPxRatioTester::thesolver, and SPxSolver::ubBound(). Referenced by SPxFastRT::selectLeave().
selects stable index for minimizing ratio test. Select from all update values Definition at line 488 of file spxfastrt.cpp. References UpdateVector::delta(), Vector::get_const_ptr(), SSVector::indexMem(), SPxSolver::isBasic(), SPxSolver::isCoBasic(), SPxFastRT::iscoid, SPxSolver::LEAVE, SPxRatioTester::m_type, SSVector::size(), SPxRatioTester::thesolver, and SSVector::values(). Referenced by SPxFastRT::minSelect(), SPxFastRT::selectEnter(), and SPxFastRT::selectLeave(). Definition at line 690 of file spxfastrt.cpp. References SPxSolver::fVec(), soplex::infinity, SPxSolver::lbBound(), SPxFastRT::minSelect(), SPxRatioTester::thesolver, and SPxSolver::ubBound(). Definition at line 702 of file spxfastrt.cpp. References SPxSolver::coId(), SPxSolver::coPvec(), SPxSolver::id(), soplex::infinity, SPxFastRT::iscoid, SPxSolver::lcBound(), SPxSolver::lpBound(), SPxFastRT::minSelect(), SPxSolver::pVec(), SPxRatioTester::thesolver, SPxSolver::ucBound(), and SPxSolver::upBound(). tests for stop after phase 1. Tests whether a shortcut after phase 1 is feasible for the selected leave pivot. In this case return the update value in Definition at line 755 of file spxfastrt.cpp. References UpdateVector::delta(), SPxSolver::fVec(), SPxSolver::lbBound(), SHORT, SPxRatioTester::thesolver, and SPxSolver::ubBound(). Referenced by SPxFastRT::selectLeave(). Compute stability requirement. Definition at line 89 of file spxfastrt.cpp. References SPxFastRT::minStab. Referenced by SPxFastRT::selectEnter(), SPxBoundFlippingRT::selectEnter(), and SPxFastRT::selectLeave(). assignment operator Definition at line 184 of file spxfastrt.h. References SPxFastRT::epsilon, SPxFastRT::fastDelta, SPxFastRT::iscoid, SPxFastRT::minStab, and SPxRatioTester::operator=(). Referenced by SPxBoundFlippingRT::operator=().
relaxes stability requirements. Definition at line 82 of file spxfastrt.cpp. References DELTA_SHIFT, SPxFastRT::fastDelta, and SPxFastRT::minStab. Referenced by SPxFastRT::selectEnter(), SPxBoundFlippingRT::selectEnter(), and SPxFastRT::selectLeave().
resets tolerances (epsilon). Definition at line 50 of file spxfastrt.cpp. References EPSILON, and SPxFastRT::epsilon. Referenced by SPxFastRT::selectEnter(), SPxBoundFlippingRT::selectEnter(), and SPxFastRT::selectLeave(). Implements SPxRatioTester. Reimplemented in SPxBoundFlippingRT. Definition at line 1169 of file spxfastrt.cpp. References SPxSolver::basis(), SPxSolver::coPvec(), UpdateVector::delta(), DELTA_SHIFT, SPxFastRT::epsilon, SPxSolver::instableLeave, SPxSolver::isCoId(), SPxId::isValid(), SPxBasis::iteration(), SPxSolver::LEAVE, LOWSTAB, SPxRatioTester::m_type, SPxFastRT::maxDelta(), SPxFastRT::maxReEnter(), SPxFastRT::maxSelect(), SPxFastRT::minDelta(), SPxFastRT::minReEnter(), SPxFastRT::minSelect(), SPxFastRT::minStab, SPxFastRT::minStability(), MSG_DEBUG, SPxLP::number(), SPxSolver::pVec(), SPxFastRT::relax(), SPxFastRT::resetTols(), SPxFastRT::shortEnter(), SPxRatioTester::solver(), soplex::spxout, SPxRatioTester::thesolver, SPxFastRT::tighten(), and TRIES. Referenced by SPxBoundFlippingRT::selectEnter(). Implements SPxRatioTester. Reimplemented in SPxBoundFlippingRT. Definition at line 853 of file spxfastrt.cpp. References SPxBasis::baseId(), SPxSolver::basis(), SPxBasis::Desc::colStatus(), UpdateVector::delta(), DELTA_SHIFT, SPxBasis::desc(), SPxSolver::ENTER, SPxFastRT::epsilon, SPxSolver::epsilon(), SPxSolver::fVec(), SPxId::isSPxColId(), SPxBasis::iteration(), SPxRatioTester::m_type, SPxFastRT::maxDelta(), SPxFastRT::maxReLeave(), SPxFastRT::maxSelect(), SPxFastRT::maxShortLeave(), SPxFastRT::minDelta(), SPxFastRT::minReLeave(), SPxFastRT::minSelect(), SPxFastRT::minShortLeave(), SPxFastRT::minStab, SPxFastRT::minStability(), MSG_DEBUG, SPxLP::number(), SPxBasis::Desc::P_FIXED, SPxFastRT::relax(), SPxFastRT::resetTols(), SPxRatioTester::solver(), soplex::spxout, SPxBasis::stability(), SPxRatioTester::thesolver, SPxFastRT::tighten(), TRIES, and SPxSolver::value(). Referenced by SPxBoundFlippingRT::selectLeave().
Reimplemented from SPxRatioTester. Definition at line 224 of file spxfastrt.h. References DEFAULT_EPS_ZERO, SPxRatioTester::delta, and SPxFastRT::fastDelta.
Reimplemented from SPxRatioTester. Definition at line 1296 of file spxfastrt.cpp. References SPxRatioTester::delta, SPxFastRT::fastDelta, SPxRatioTester::m_type, MINSTAB, and SPxFastRT::minStab. Referenced by SPxFastRT::load(). Tests and returns whether a shortcut after phase 1 is feasible for the selected enter pivot. Definition at line 1139 of file spxfastrt.cpp. References SPxSolver::coPvec(), UpdateVector::delta(), SPxSolver::isCoId(), SPxSolver::isId(), SPxSolver::pVec(), SHORT, and SPxRatioTester::thesolver. Referenced by SPxFastRT::selectEnter().
tightens stability requirements. Definition at line 60 of file spxfastrt.cpp. References SPxRatioTester::delta, DELTA_SHIFT, SPxFastRT::fastDelta, MINSTAB, and SPxFastRT::minStab. Referenced by SPxFastRT::selectEnter(), SPxBoundFlippingRT::selectEnter(), and SPxFastRT::selectLeave(). Member Data Documentation
|value| < epsilon is considered 0. Definition at line 50 of file spxfastrt.h. Referenced by SPxBoundFlippingRT::collectBreakpointsMax(), SPxBoundFlippingRT::collectBreakpointsMin(), SPxFastRT::maxDelta(), SPxFastRT::minDelta(), SPxFastRT::operator=(), SPxFastRT::resetTols(), SPxFastRT::selectEnter(), SPxBoundFlippingRT::selectEnter(), and SPxFastRT::selectLeave().
currently allowed infeasibility. Definition at line 52 of file spxfastrt.h. Referenced by SPxBoundFlippingRT::collectBreakpointsMax(), SPxBoundFlippingRT::collectBreakpointsMin(), SPxFastRT::getDelta(), SPxFastRT::maxDelta(), SPxFastRT::maxReEnter(), SPxFastRT::maxReLeave(), SPxFastRT::minDelta(), SPxFastRT::minReEnter(), SPxFastRT::minReLeave(), SPxFastRT::operator=(), SPxFastRT::relax(), SPxBoundFlippingRT::selectEnter(), SPxFastRT::setDelta(), SPxFastRT::setType(), and SPxFastRT::tighten().
flag used in methods minSelect/maxSelect to retrieve correct basis status Definition at line 54 of file spxfastrt.h. Referenced by SPxFastRT::maxDelta(), SPxFastRT::maxSelect(), SPxFastRT::minDelta(), SPxFastRT::minSelect(), and SPxFastRT::operator=().
parameter for computing minimum stability requirement Definition at line 48 of file spxfastrt.h. Referenced by SPxFastRT::minStability(), SPxFastRT::operator=(), SPxFastRT::relax(), SPxFastRT::selectEnter(), SPxFastRT::selectLeave(), SPxFastRT::setType(), and SPxFastRT::tighten().
|