|
SoPlex Doxygen Documentation
|
Steepest edge pricer.Class SPxSteepPR implements a steepest edge pricer to be used with SoPlex.
More...
#include <spxsteeppr.h>
Steepest edge pricer.
Class SPxSteepPR implements a steepest edge pricer to be used with SoPlex.
See SPxPricer for a class documentation.
Definition at line 41 of file spxsteeppr.h.
How to setup the direction multipliers.
Possible settings are EXACT for starting with exactly computed values, or DEFAULT for starting with multipliers set to 1. The latter is the default.
Enumerator |
---|
EXACT |
starting with exactly computed values
|
DEFAULT |
starting with multipliers set to 1
|
Definition at line 53 of file spxsteeppr.h.
void addedCoVecs |
( |
int |
n | ) |
|
|
virtual |
n covectors have been added to loaded LP.
Reimplemented from SPxPricer.
Definition at line 736 of file spxsteeppr.cpp.
References SPxSteepPR::coPenalty, SPxSteepPR::coPref, Vector::dim(), SPxSolver::dim(), SPxSteepPR::leavePref, SPxSteepPR::prefSetup, DVector::reDim(), DataArray< T >::reSize(), SPxSteepPR::setupPrefs(), SPxPricer::thesolver, SPxSolver::type(), and SPxSteepPR::workVec.
Referenced by SPxHybridPR::addedCoVecs().
n vectors have been added to loaded LP.
Reimplemented from SPxPricer.
Definition at line 721 of file spxsteeppr.cpp.
References SPxSolver::coDim(), Vector::dim(), SPxSolver::ENTER, SPxSteepPR::penalty, SPxSteepPR::pref, SPxSteepPR::prefSetup, DVector::reDim(), DataArray< T >::reSize(), SPxSteepPR::setupPrefs(), SPxPricer::thesolver, and SPxSolver::type().
Referenced by SPxHybridPR::addedVecs().
void entered4 |
( |
SPxId |
id, |
|
|
int |
n |
|
) |
| |
|
virtual |
Reimplemented from SPxPricer.
Definition at line 481 of file spxsteeppr.cpp.
References SPxSolver::basis(), SPxSteepPR::coPenalty, SPxSolver::coPvec(), UpdateVector::delta(), SPxSolver::ENTER, SPxSolver::epsilon(), SPxSolver::fVec(), Vector::get_const_ptr(), Vector::get_ptr(), UpdateVector::idx(), IdxSet::index(), soplex::infinity, SPxBasis::iteration(), SPxSteepPR::penalty, SPxSteepPR::pi_p, SPxSolver::pVec(), IdxSet::size(), SPxPricer::thesolver, SPxSolver::type(), SSVector::values(), SPxSolver::vector(), and SPxSteepPR::workVec.
bool isConsistent |
( |
| ) |
const |
|
virtual |
Reimplemented from SPxPricer.
Definition at line 794 of file spxsteeppr.cpp.
References SPxSolver::basis(), SPxSolver::coDim(), SPxSteepPR::coPenalty, SPxBasis::coSolve(), SPxSolver::dim(), SPxSolver::ENTER, SPxSolver::epsilon(), SPxSteepPR::EXACT, SPxSolver::LEAVE, SPxSolver::leavetol(), Vector::length2(), MSG_ERROR, MSGinconsistent, SPxSteepPR::penalty, SPxSteepPR::setup, soplex::spxout, SPxPricer::thesolver, SPxSolver::type(), and SPxSolver::unitVector().
Referenced by SPxHybridPR::isConsistent(), SPxSteepExPR::operator=(), SPxSteepPR::operator=(), SPxSteepPR::selectEnter(), SPxSteepPR::selectLeave(), SPxSteepExPR::SPxSteepExPR(), and SPxSteepPR::SPxSteepPR().
void left4 |
( |
int |
n, |
|
|
SPxId |
id |
|
) |
| |
|
virtual |
Reimplemented from SPxPricer.
Definition at line 208 of file spxsteeppr.cpp.
References SPxSolver::basis(), SPxSteepPR::coPenalty, SPxSteepPR::coPref, SPxSolver::coPvec(), UpdateVector::delta(), SPxSolver::fVec(), Vector::get_const_ptr(), Vector::get_ptr(), UpdateVector::idx(), soplex::infinity, SPxSolver::isCoId(), SPxSolver::isId(), SPxBasis::iteration(), SPxSolver::LEAVE, SPxSteepPR::leavePref, SSVector::length2(), MSG_ERROR, SPxLP::number(), SPxSteepPR::pref, IdxSet::size(), soplex::spxout, SPxPricer::theeps, SPxPricer::thesolver, SPxSolver::type(), SSVector::values(), and SPxSteepPR::workVec.
sets the solver
Reimplemented from SPxPricer.
Definition at line 36 of file spxsteeppr.cpp.
References Vector::clear(), SSVector::clear(), SPxSolver::coDim(), SPxSteepPR::coPref, SPxSolver::dim(), SPxSteepPR::leavePref, SPxSteepPR::pref, SPxSteepPR::prefSetup, DVector::reDim(), SSVector::reDim(), DataArray< T >::reSize(), SPxPricer::thesolver, SPxSteepPR::workRhs, and SPxSteepPR::workVec.
Referenced by SPxHybridPR::load().
assignment operator
Definition at line 136 of file spxsteeppr.h.
References SPxSteepPR::accuracy, SPxSteepPR::coPenalty, SPxSteepPR::coPref, SPxSteepPR::isConsistent(), SPxSteepPR::leavePref, SPxPricer::operator=(), SPxSteepPR::penalty, SPxSteepPR::pi_p, SPxSteepPR::pref, SPxSteepPR::prefSetup, SPxSteepPR::setup, SPxSteepPR::startpricing, SPxSteepPR::workRhs, and SPxSteepPR::workVec.
Referenced by SPxSteepExPR::operator=().
void removedCoVec |
( |
int |
i | ) |
|
|
virtual |
void removedCoVecs |
( |
const int |
perm[] | ) |
|
|
virtual |
void removedVecs |
( |
const int |
perm[] | ) |
|
|
virtual |
Implements SPxPricer.
Definition at line 544 of file spxsteeppr.cpp.
References SPxSteepPR::accuracy, SPxSolver::basis(), UpdateVector::delta(), SPxSolver::fVec(), SPxSteepPR::isConsistent(), SPxId::isValid(), SSVector::length2(), SPxSteepPR::pi_p, SPxSteepPR::selectEnterX(), SSVector::setEpsilon(), SPxSolver::setup4coSolve(), SSVector::setup_and_assign(), SPxBasis::solve4update(), SPxPricer::thesolver, SPxSolver::vector(), SPxSteepPR::workRhs, and SPxSteepPR::workVec.
implementation of sparse pricing for the entering Simplex
Definition at line 628 of file spxsteeppr.cpp.
References DataArray< T >::get_const_ptr(), Vector::get_const_ptr(), SPxSolver::id(), IdxSet::index(), SPxSolver::infeasibilitiesCo, SPxSolver::isInfeasibleCo, SPxSteepPR::penalty, SPxSteepPR::pref, IdxSet::remove(), IdxSet::size(), SPxSolver::test(), SPxPricer::theeps, and SPxPricer::thesolver.
Referenced by SPxSteepPR::selectEnterX().
implementation of sparse pricing for the entering Simplex (slack variables)
Definition at line 588 of file spxsteeppr.cpp.
References SPxSolver::coId(), SPxSteepPR::coPenalty, SPxSteepPR::coPref, SPxSolver::coTest(), DataArray< T >::get_const_ptr(), Vector::get_const_ptr(), IdxSet::index(), SPxSolver::infeasibilities, SPxSolver::isInfeasible, IdxSet::remove(), IdxSet::size(), SPxPricer::theeps, and SPxPricer::thesolver.
Referenced by SPxSteepPR::selectEnterX().
- Todo:
- this was an assert! is an assertion correct?
Implements SPxPricer.
Definition at line 258 of file spxsteeppr.cpp.
References SPxSteepPR::accuracy, SPxSolver::basis(), SPxSteepPR::coPenalty, SPxSolver::coPvec(), SPxBasis::coSolve(), UpdateVector::delta(), SPxSolver::dim(), SPxSolver::fTest(), DataArray< T >::get_const_ptr(), Vector::get_const_ptr(), soplex::infinity, SPxSteepPR::isConsistent(), SSVector::isConsistent(), SPxSteepPR::leavePref, MSG_WARNING, SPxSteepPR::selectLeavePart(), SPxSteepPR::selectLeaveSparse(), SSVector::setEpsilon(), SPxSolver::setup4solve(), SSVector::setup_and_assign(), SPxSolver::sparsePricingLeave, soplex::spxout, SPxPricer::theeps, SPxPricer::thesolver, SPxSolver::unitVector(), SPxSteepPR::workRhs, and SPxSteepPR::workVec.
implementation of partial pricing
Definition at line 321 of file spxsteeppr.cpp.
References SPxSteepPR::accuracy, SPxSolver::basis(), SPxSteepPR::coPenalty, SPxSolver::coPvec(), SPxBasis::coSolve(), UpdateVector::delta(), SPxSolver::dim(), SPxSolver::fTest(), DataArray< T >::get_const_ptr(), Vector::get_const_ptr(), IMPROVEMENT_STEPLENGTH, IMPROVEMENT_THRESHOLD, soplex::infinity, SSVector::isConsistent(), SPxSteepPR::leavePref, MAX_PRICING_CANDIDATES, MSG_WARNING, SSVector::setEpsilon(), SPxSolver::setup4solve(), SSVector::setup_and_assign(), soplex::spxout, SPxSteepPR::startpricing, SPxPricer::theeps, SPxPricer::thesolver, SPxSolver::unitVector(), SPxSteepPR::workRhs, and SPxSteepPR::workVec.
Referenced by SPxSteepPR::selectLeave().
int selectLeaveSparse |
( |
| ) |
|
implementation of sparse pricing in the leaving Simplex
Definition at line 418 of file spxsteeppr.cpp.
References SPxSteepPR::accuracy, SPxSolver::basis(), SPxSteepPR::coPenalty, SPxSolver::coPvec(), SPxBasis::coSolve(), UpdateVector::delta(), SPxSolver::fTest(), DataArray< T >::get_const_ptr(), Vector::get_const_ptr(), IdxSet::index(), SPxSolver::infeasibilities, soplex::infinity, SSVector::isConsistent(), SPxSolver::isInfeasible, SPxSteepPR::leavePref, MSG_WARNING, IdxSet::remove(), SSVector::setEpsilon(), SPxSolver::setup4solve(), SSVector::setup_and_assign(), IdxSet::size(), soplex::spxout, SPxPricer::theeps, SPxPricer::thesolver, SPxSolver::unitVector(), SPxSteepPR::workRhs, and SPxSteepPR::workVec.
Referenced by SPxSteepPR::selectLeave().
set entering/leaving algorithm
Reimplemented from SPxPricer.
Definition at line 54 of file spxsteeppr.cpp.
References Vector::clear(), SSVector::clear(), SPxSolver::coDim(), SPxSteepPR::coPref, SPxSolver::dim(), SPxSolver::epsilon(), SPxSteepPR::pref, DataArray< T >::reSize(), SSVector::setEpsilon(), SPxSteepPR::setupPrefs(), SPxSteepPR::setupWeights(), SPxPricer::thesolver, SPxSteepPR::workRhs, and SPxSteepPR::workVec.
setup steepest edge weights
Definition at line 66 of file spxsteeppr.cpp.
References SPxBasis::baseId(), SPxSolver::basis(), SPxSolver::coDim(), SPxSteepPR::coPenalty, SPxSteepPR::coPref, SPxBasis::coSolve(), SPxSteepPR::DEFAULT, SPxSolver::dim(), SPxSolver::ENTER, SPxSolver::epsilon(), SPxSolver::isId(), SPxSolver::LEAVE, SPxSteepPR::leavePref, Vector::length2(), SVector::length2(), MSG_INFO1, SPxLP::number(), SPxSteepPR::penalty, SPxSteepPR::pref, DVector::reDim(), SPxSteepPR::setup, soplex::spxout, SPxPricer::thesolver, SPxSolver::unitVector(), and SPxSolver::vector().
Referenced by SPxSteepPR::setType().
vector of pricing penalties
Definition at line 69 of file spxsteeppr.h.
Referenced by SPxSteepPR::addedCoVecs(), SPxSteepPR::entered4(), SPxSteepPR::isConsistent(), SPxSteepPR::left4(), SPxSteepPR::operator=(), SPxSteepPR::removedCoVec(), SPxSteepPR::removedCoVecs(), SPxSteepPR::selectEnterDenseDim(), SPxSteepPR::selectEnterSparseDim(), SPxSteepPR::selectLeave(), SPxSteepPR::selectLeavePart(), SPxSteepPR::selectLeaveSparse(), SPxSteepPR::setRep(), and SPxSteepPR::setupWeights().
working vector
Definition at line 71 of file spxsteeppr.h.
Referenced by SPxSteepPR::addedCoVecs(), SPxSteepPR::entered4(), SPxSteepPR::left4(), SPxSteepPR::load(), SPxSteepPR::operator=(), SPxSteepPR::selectEnter(), SPxSteepPR::selectLeave(), SPxSteepPR::selectLeavePart(), SPxSteepPR::selectLeaveSparse(), SPxSteepPR::setRep(), and SPxSteepPR::setType().
|