Clp  trunk
Public Member Functions | Protected Member Functions | Protected Attributes | Friends
CoinAbcDenseFactorization Class Reference

This deals with Factorization and Updates This is a simple dense version so other people can write a better one. More...

#include <CoinAbcDenseFactorization.hpp>

+ Inheritance diagram for CoinAbcDenseFactorization:
+ Collaboration diagram for CoinAbcDenseFactorization:

List of all members.

Public Member Functions

void gutsOfDestructor ()
 The real work of desstructor.
void gutsOfInitialize ()
 The real work of constructor.
void gutsOfCopy (const CoinAbcDenseFactorization &other)
 The real work of copy.
Constructors and destructor and copy
 CoinAbcDenseFactorization ()
 Default constructor.
 CoinAbcDenseFactorization (const CoinAbcDenseFactorization &other)
 Copy constructor.
virtual ~CoinAbcDenseFactorization ()
 Destructor.
CoinAbcDenseFactorizationoperator= (const CoinAbcDenseFactorization &other)
 = copy
virtual CoinAbcAnyFactorizationclone () const
 Clone.
Do factorization - public
virtual void getAreas (int numberRows, int numberColumns, CoinBigIndex maximumL, CoinBigIndex maximumU)
 Gets space for a factorization.
virtual void preProcess ()
 PreProcesses column ordered copy of basis.
virtual int factor (AbcSimplex *model)
 Does most of factorization returning status 0 - OK.
virtual void postProcess (const int *sequence, int *pivotVariable)
 Does post processing on valid factorization - putting variables on correct rows.
virtual void makeNonSingular (int *sequence)
 Makes a non-singular basis by replacing variables.
general stuff such as number of elements
virtual int numberElements () const
 Total number of elements in factorization.
double maximumCoefficient () const
 Returns maximum absolute value in factorization.
rank one updates which do exist
virtual int replaceColumn (CoinIndexedVector *regionSparse, int pivotRow, double pivotCheck, bool skipBtranU=false, double acceptablePivot=1.0e-8)
 Replaces one Column to basis, returns 0=OK, 1=Probably OK, 2=singular, 3=no room If skipBtranU is false will do btran part partial update already in U.
virtual int checkReplacePart2 (int pivotRow, double btranAlpha, double ftranAlpha, double ftAlpha, double acceptablePivot=1.0e-8)
 Checks if can replace one Column to basis, returns 0=OK, 1=Probably OK, 2=singular, 3=no room, 5 max pivots.
virtual void replaceColumnPart3 (const AbcSimplex *model, CoinIndexedVector *regionSparse, CoinIndexedVector *tableauColumn, int pivotRow, double alpha)
 Replaces one Column to basis, partial update already in U.
virtual void replaceColumnPart3 (const AbcSimplex *model, CoinIndexedVector *regionSparse, CoinIndexedVector *tableauColumn, CoinIndexedVector *, int pivotRow, double alpha)
 Replaces one Column to basis, partial update in vector.
various uses of factorization (return code number elements)

which user may want to know about

virtual int updateColumnFT (CoinIndexedVector &regionSparse)
 Updates one column (FTRAN) from unpacked regionSparse Tries to do FT update number returned is negative if no room.
virtual int updateColumnFTPart1 (CoinIndexedVector &regionSparse)
virtual void updateColumnFTPart2 (CoinIndexedVector &)
virtual void updateColumnFT (CoinIndexedVector &regionSparseFT, CoinIndexedVector &, int)
virtual int updateColumn (CoinIndexedVector &regionSparse) const
 This version has same effect as above with FTUpdate==false so number returned is always >=0.
virtual int updateTwoColumnsFT (CoinIndexedVector &regionFT, CoinIndexedVector &regionOther)
 does FTRAN on two unpacked columns
virtual int updateColumnTranspose (CoinIndexedVector &regionSparse) const
 Updates one column (BTRAN) from unpacked regionSparse.
virtual void updateFullColumn (CoinIndexedVector &regionSparse) const
 This version does FTRAN on array when indices not set up.
virtual void updateFullColumnTranspose (CoinIndexedVector &regionSparse) const
 Updates one column (BTRAN) from unpacked regionSparse.
virtual void updateWeights (CoinIndexedVector &regionSparse) const
 Updates one column for dual steepest edge weights (FTRAN)
various uses of factorization

*** Below this user may not want to know about

which user may not want to know about (left over from my LP code)

void clearArrays ()
 Get rid of all memory.
virtual int * indices () const
 Returns array to put basis indices in.
virtual int * permute () const
 Returns permute in.

Protected Member Functions

int checkPivot (double saveFromU, double oldPivot) const
 Returns accuracy status of replaceColumn returns 0=OK, 1=Probably OK, 2=singular.

Protected Attributes

CoinBigIndex maximumSpace_
 Maximum length of iterating area.
CoinSimplexInt maximumRowsAdjusted_
 Use for array size to get multiple of 8.

Friends

void CoinAbcDenseFactorizationUnitTest (const std::string &mpsDir)

Detailed Description

This deals with Factorization and Updates This is a simple dense version so other people can write a better one.

I am assuming that 32 bits is enough for number of rows or columns, but CoinBigIndex may be redefined to get 64 bits.

Definition at line 394 of file CoinAbcDenseFactorization.hpp.


Constructor & Destructor Documentation

Default constructor.

Copy constructor.

Destructor.


Member Function Documentation

CoinAbcDenseFactorization& CoinAbcDenseFactorization::operator= ( const CoinAbcDenseFactorization other)

= copy

Clone.

Implements CoinAbcAnyFactorization.

virtual void CoinAbcDenseFactorization::getAreas ( int  numberRows,
int  numberColumns,
CoinBigIndex  maximumL,
CoinBigIndex  maximumU 
) [virtual]

Gets space for a factorization.

Implements CoinAbcAnyFactorization.

virtual void CoinAbcDenseFactorization::preProcess ( ) [virtual]

PreProcesses column ordered copy of basis.

Implements CoinAbcAnyFactorization.

virtual int CoinAbcDenseFactorization::factor ( AbcSimplex model) [virtual]

Does most of factorization returning status 0 - OK.

-99 - needs more memory -1 - singular - use numberGoodColumns and redo

Implements CoinAbcAnyFactorization.

virtual void CoinAbcDenseFactorization::postProcess ( const int *  sequence,
int *  pivotVariable 
) [virtual]

Does post processing on valid factorization - putting variables on correct rows.

Implements CoinAbcAnyFactorization.

virtual void CoinAbcDenseFactorization::makeNonSingular ( int *  sequence) [virtual]

Makes a non-singular basis by replacing variables.

Implements CoinAbcAnyFactorization.

virtual int CoinAbcDenseFactorization::numberElements ( ) const [inline, virtual]

Total number of elements in factorization.

Implements CoinAbcAnyFactorization.

Definition at line 439 of file CoinAbcDenseFactorization.hpp.

Returns maximum absolute value in factorization.

virtual int CoinAbcDenseFactorization::replaceColumn ( CoinIndexedVector *  regionSparse,
int  pivotRow,
double  pivotCheck,
bool  skipBtranU = false,
double  acceptablePivot = 1.0e-8 
) [virtual]

Replaces one Column to basis, returns 0=OK, 1=Probably OK, 2=singular, 3=no room If skipBtranU is false will do btran part partial update already in U.

virtual int CoinAbcDenseFactorization::checkReplacePart2 ( int  pivotRow,
double  btranAlpha,
double  ftranAlpha,
double  ftAlpha,
double  acceptablePivot = 1.0e-8 
) [virtual]

Checks if can replace one Column to basis, returns 0=OK, 1=Probably OK, 2=singular, 3=no room, 5 max pivots.

Implements CoinAbcAnyFactorization.

virtual void CoinAbcDenseFactorization::replaceColumnPart3 ( const AbcSimplex model,
CoinIndexedVector *  regionSparse,
CoinIndexedVector *  tableauColumn,
int  pivotRow,
double  alpha 
) [virtual]

Replaces one Column to basis, partial update already in U.

Implements CoinAbcAnyFactorization.

virtual void CoinAbcDenseFactorization::replaceColumnPart3 ( const AbcSimplex model,
CoinIndexedVector *  regionSparse,
CoinIndexedVector *  tableauColumn,
CoinIndexedVector *  ,
int  pivotRow,
double  alpha 
) [inline, virtual]

Replaces one Column to basis, partial update in vector.

Implements CoinAbcAnyFactorization.

Definition at line 480 of file CoinAbcDenseFactorization.hpp.

virtual int CoinAbcDenseFactorization::updateColumnFT ( CoinIndexedVector &  regionSparse) [inline, virtual]

Updates one column (FTRAN) from unpacked regionSparse Tries to do FT update number returned is negative if no room.

Implements CoinAbcAnyFactorization.

Definition at line 499 of file CoinAbcDenseFactorization.hpp.

virtual int CoinAbcDenseFactorization::updateColumnFTPart1 ( CoinIndexedVector &  regionSparse) [inline, virtual]

Implements CoinAbcAnyFactorization.

Definition at line 501 of file CoinAbcDenseFactorization.hpp.

virtual void CoinAbcDenseFactorization::updateColumnFTPart2 ( CoinIndexedVector &  ) [inline, virtual]

Implements CoinAbcAnyFactorization.

Definition at line 503 of file CoinAbcDenseFactorization.hpp.

virtual void CoinAbcDenseFactorization::updateColumnFT ( CoinIndexedVector &  regionSparseFT,
CoinIndexedVector &  ,
int   
) [inline, virtual]

Implements CoinAbcAnyFactorization.

Definition at line 505 of file CoinAbcDenseFactorization.hpp.

virtual int CoinAbcDenseFactorization::updateColumn ( CoinIndexedVector &  regionSparse) const [virtual]

This version has same effect as above with FTUpdate==false so number returned is always >=0.

Implements CoinAbcAnyFactorization.

virtual int CoinAbcDenseFactorization::updateTwoColumnsFT ( CoinIndexedVector &  regionFT,
CoinIndexedVector &  regionOther 
) [virtual]

does FTRAN on two unpacked columns

Implements CoinAbcAnyFactorization.

virtual int CoinAbcDenseFactorization::updateColumnTranspose ( CoinIndexedVector &  regionSparse) const [virtual]

Updates one column (BTRAN) from unpacked regionSparse.

Implements CoinAbcAnyFactorization.

virtual void CoinAbcDenseFactorization::updateFullColumn ( CoinIndexedVector &  regionSparse) const [inline, virtual]

This version does FTRAN on array when indices not set up.

Implements CoinAbcAnyFactorization.

Definition at line 517 of file CoinAbcDenseFactorization.hpp.

virtual void CoinAbcDenseFactorization::updateFullColumnTranspose ( CoinIndexedVector &  regionSparse) const [inline, virtual]

Updates one column (BTRAN) from unpacked regionSparse.

Implements CoinAbcAnyFactorization.

Definition at line 521 of file CoinAbcDenseFactorization.hpp.

virtual void CoinAbcDenseFactorization::updateWeights ( CoinIndexedVector &  regionSparse) const [virtual]

Updates one column for dual steepest edge weights (FTRAN)

Implements CoinAbcAnyFactorization.

void CoinAbcDenseFactorization::clearArrays ( ) [inline, virtual]

Get rid of all memory.

Reimplemented from CoinAbcAnyFactorization.

Definition at line 532 of file CoinAbcDenseFactorization.hpp.

virtual int* CoinAbcDenseFactorization::indices ( ) const [inline, virtual]

Returns array to put basis indices in.

Implements CoinAbcAnyFactorization.

Definition at line 535 of file CoinAbcDenseFactorization.hpp.

virtual int* CoinAbcDenseFactorization::permute ( ) const [inline, virtual]

Returns permute in.

Implements CoinAbcAnyFactorization.

Definition at line 538 of file CoinAbcDenseFactorization.hpp.

The real work of desstructor.

The real work of constructor.

The real work of copy.

int CoinAbcDenseFactorization::checkPivot ( double  saveFromU,
double  oldPivot 
) const [protected]

Returns accuracy status of replaceColumn returns 0=OK, 1=Probably OK, 2=singular.


Friends And Related Function Documentation

void CoinAbcDenseFactorizationUnitTest ( const std::string &  mpsDir) [friend]

Member Data Documentation

CoinBigIndex CoinAbcDenseFactorization::maximumSpace_ [protected]

Maximum length of iterating area.

Definition at line 557 of file CoinAbcDenseFactorization.hpp.

Use for array size to get multiple of 8.

Definition at line 559 of file CoinAbcDenseFactorization.hpp.


The documentation for this class was generated from the following file:
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Friends Defines