All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Classes |
Public Member Functions |
Private Member Functions |
Static Private Member Functions |
List of all members
SPxBoundFlippingRT Class Reference Bound flipping ratio test ("long step dual") for SoPlex.Class SPxBoundFlippingRT provides an implementation of the bound flipping ratio test as a derived class of SPxRatioTester. Dual step length is increased beyond some breakpoints and corresponding primal nonbasic variables are set to their other bound to handle the resulting dual infeasibility. More...
Inheritance diagram for SPxBoundFlippingRT:
![]()
Detailed DescriptionBound flipping ratio test ("long step dual") for SoPlex. Class SPxBoundFlippingRT provides an implementation of the bound flipping ratio test as a derived class of SPxRatioTester. Dual step length is increased beyond some breakpoints and corresponding primal nonbasic variables are set to their other bound to handle the resulting dual infeasibility. The implementation mostly follows the papers
See SPxRatioTester for a class documentation. Definition at line 50 of file spxboundflippingrt.h. Member Enumeration Documentation
enumerator to remember which vector we have been searching to find a breakpoint
Definition at line 57 of file spxboundflippingrt.h. Constructor & Destructor Documentationdefault constructor Definition at line 176 of file spxboundflippingrt.h. Referenced by SPxBoundFlippingRT::clone().
copy constructor Definition at line 186 of file spxboundflippingrt.h.
destructor Definition at line 206 of file spxboundflippingrt.h. Member Function Documentation
clone function for polymorphism Reimplemented from SPxFastRT. Definition at line 209 of file spxboundflippingrt.h. References SPxBoundFlippingRT::SPxBoundFlippingRT().
store all available pivots/breakpoints in an array (positive pivot search direction)
Definition at line 165 of file spxboundflippingrt.cpp. References SPxBoundFlippingRT::breakpoints, SPxFastRT::epsilon, SPxFastRT::fastDelta, and soplex::infinity. Referenced by SPxBoundFlippingRT::selectEnter().
store all available pivots/breakpoints in an array (negative pivot search direction)
Definition at line 239 of file spxboundflippingrt.cpp. References SPxBoundFlippingRT::breakpoints, SPxFastRT::epsilon, SPxFastRT::fastDelta, and soplex::infinity. Referenced by SPxBoundFlippingRT::selectEnter().
perform necessary bound flips to restore dual feasibility
Definition at line 37 of file spxboundflippingrt.cpp. References SPxSolver::basis(), SPxBoundFlippingRT::breakpoints, Vector::clear(), SSVector::clear(), SPxSolver::COLUMN, SPxBoundFlippingRT::COPVEC, SPxSolver::coPvec(), SPxBasis::Desc::coStatus(), UpdateVector::delta(), SPxBasis::desc(), SPxSolver::dim(), soplex::infinity, SPxLP::lhs(), SPxLP::lower(), MSG_DEBUG, MSG_WARNING, SSVector::multAdd(), SPxBasis::Desc::P_ON_LOWER, SPxBasis::Desc::P_ON_UPPER, SPxSolver::primRhs, SPxBoundFlippingRT::PVEC, SPxSolver::pVec(), DVector::reDim(), SSVector::reDim(), SPxSolver::rep(), SPxLP::rhs(), SSVector::setup(), SPxSolver::setup4solve2(), SSVector::setValue(), soplex::spxout, SPxBasis::Desc::status(), SPxSolver::theCoLbound, SPxSolver::theCoUbound, SPxSolver::theLbound, SPxRatioTester::thesolver, SPxSolver::theUbound, SPxBoundFlippingRT::updPrimRhs, SPxBoundFlippingRT::updPrimVec, SPxLP::upper(), and SPxSolver::vector(). Referenced by SPxBoundFlippingRT::selectEnter().
get values for entering index and perform shifts if necessary Definition at line 313 of file spxboundflippingrt.cpp. References SPxSolver::coId(), SPxSolver::coPvec(), SPxSolver::id(), SPxSolver::lcBound(), SPxSolver::lpBound(), SPxBoundFlippingRT::PVEC, SPxSolver::pVec(), SPxSolver::shiftLCbound(), SPxSolver::shiftLPbound(), SPxSolver::shiftUCbound(), SPxSolver::shiftUPbound(), SPxSolver::theShift, SPxRatioTester::thesolver, SPxSolver::ucBound(), SPxSolver::upBound(), and SPxSolver::vector(). Referenced by SPxBoundFlippingRT::selectEnter().
comparison method for breakpoints Definition at line 155 of file spxboundflippingrt.h. References SPxBoundFlippingRT::Breakpoint::val.
assignment operator Definition at line 196 of file spxboundflippingrt.h. References SPxFastRT::operator=(). determine entering variable Reimplemented from SPxFastRT. Definition at line 389 of file spxboundflippingrt.cpp. References SPxSolver::basis(), SPxSolver::boundflips, SPxBoundFlippingRT::breakpoints, SSVector::clearIdx(), SPxBoundFlippingRT::collectBreakpointsMax(), SPxBoundFlippingRT::collectBreakpointsMin(), SPxBoundFlippingRT::COPVEC, SPxSolver::coPvec(), SPxRatioTester::delta, UpdateVector::delta(), SPxBoundFlippingRT::enableLongsteps, SPxBoundFlippingRT::BreakpointCompare::entry, SPxFastRT::epsilon, SPxFastRT::fastDelta, SPxBoundFlippingRT::flipAndUpdate(), SPxBoundFlippingRT::flipPotential, SPxSolver::fTest(), Vector::get_const_ptr(), SPxBoundFlippingRT::getData(), SSVector::indexMem(), SPxSolver::instableLeave, SPxSolver::instableLeaveNum, SPxSolver::instableLeaveVal, SPxSolver::isBasic(), SPxSolver::isCoBasic(), SPxId::isValid(), SPxBasis::iteration(), SPxSolver::lcBound(), SPxSolver::LEAVE, SPxSolver::leaveCount, SPxLP::lhs(), LONGSTEP_FREQ, SPxLP::lower(), LOWSTAB, SPxSolver::lpBound(), SPxRatioTester::m_type, MAX_RELAX_COUNT, MIN_LONGSTEP, SPxFastRT::minStability(), MSG_DEBUG, SPxBoundFlippingRT::PVEC, SPxSolver::pVec(), SPxFastRT::relax(), SPxBoundFlippingRT::relax_count, SPxSolver::rep(), SPxFastRT::resetTols(), SPxLP::rhs(), SPxSolver::ROW, SPxFastRT::selectEnter(), SSVector::size(), soplex::sorter_qsortPart(), soplex::spxout, SPxRatioTester::thesolver, SPxFastRT::tighten(), SPxSolver::ucBound(), SPxSolver::upBound(), SPxLP::upper(), SSVector::values(), and SPxSolver::vector(). Reimplemented from SPxFastRT. Definition at line 746 of file spxboundflippingrt.cpp. References SPxFastRT::selectLeave().
Definition at line 165 of file spxboundflippingrt.h. References SPxBoundFlippingRT::enableLongsteps. Member Data Documentation
array of breakpoints Definition at line 103 of file spxboundflippingrt.h. Referenced by SPxBoundFlippingRT::collectBreakpointsMax(), SPxBoundFlippingRT::collectBreakpointsMin(), SPxBoundFlippingRT::flipAndUpdate(), and SPxBoundFlippingRT::selectEnter().
enable or disable long steps (bound flips) Definition at line 100 of file spxboundflippingrt.h. Referenced by SPxBoundFlippingRT::selectEnter(), and SPxBoundFlippingRT::setLongsteps().
tracks bound flip history and decides which ratio test to use Definition at line 101 of file spxboundflippingrt.h. Referenced by SPxBoundFlippingRT::selectEnter().
count rounds of ratio test Definition at line 102 of file spxboundflippingrt.h. Referenced by SPxBoundFlippingRT::selectEnter().
right hand side vector of additional system to be solved after the ratio test Definition at line 104 of file spxboundflippingrt.h. Referenced by SPxBoundFlippingRT::flipAndUpdate().
allocation of memory for additional solution vector Definition at line 105 of file spxboundflippingrt.h. Referenced by SPxBoundFlippingRT::flipAndUpdate().
|