Cbc  2.10.10
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Public Member Functions | Protected Attributes | List of all members
CbcNWay Class Reference

Define an n-way class for variables. More...

#include <CbcNWay.hpp>

+ Inheritance diagram for CbcNWay:
+ Collaboration diagram for CbcNWay:

Public Member Functions

 CbcNWay ()
 
 CbcNWay (CbcModel *model, int numberMembers, const int *which, int identifier)
 Useful constructor (which are matrix indices) More...
 
 CbcNWay (const CbcNWay &)
 
virtual CbcObjectclone () const
 Clone. More...
 
CbcNWayoperator= (const CbcNWay &rhs)
 Assignment operator. More...
 
virtual ~CbcNWay ()
 Destructor. More...
 
void setConsequence (int iColumn, const CbcConsequence &consequence)
 Set up a consequence for a single member. More...
 
void applyConsequence (int iSequence, int state) const
 Applies a consequence for a single member. More...
 
virtual double infeasibility (const OsiBranchingInformation *info, int &preferredWay) const
 Infeasibility - large is 0.5 (and 0.5 will give this) More...
 
virtual void feasibleRegion ()
 This looks at solution and sets bounds to contain solution. More...
 
virtual CbcBranchingObjectcreateCbcBranch (OsiSolverInterface *solver, const OsiBranchingInformation *info, int way)
 Creates a branching object. More...
 
int numberMembers () const
 Number of members. More...
 
const int * members () const
 Members (indices in range 0 ... numberColumns-1) More...
 
virtual void redoSequenceEtc (CbcModel *model, int numberColumns, const int *originalColumns)
 Redoes data when sequence numbers change. More...
 
virtual void feasibleRegion ()=0
 For the variable(s) referenced by the object, look at the current solution and set bounds to match the solution. More...
 
virtual double feasibleRegion (OsiSolverInterface *solver, const OsiBranchingInformation *info) const
 Dummy one for compatibility. More...
 
virtual double feasibleRegion (OsiSolverInterface *solver) const
 For the variable(s) referenced by the object, look at the current solution and set bounds to match the solution. More...
 
- Public Member Functions inherited from CbcObject
 CbcObject ()
 
 CbcObject (CbcModel *model)
 
 CbcObject (const CbcObject &)
 
CbcObjectoperator= (const CbcObject &rhs)
 
virtual ~CbcObject ()
 Destructor. More...
 
virtual double infeasibility (int &) const
 
virtual double feasibleRegion (OsiSolverInterface *solver, const OsiBranchingInformation *info) const
 Dummy one for compatibility. More...
 
virtual double feasibleRegion (OsiSolverInterface *solver) const
 For the variable(s) referenced by the object, look at the current solution and set bounds to match the solution. More...
 
virtual OsiBranchingObject * createBranch (OsiSolverInterface *, const OsiBranchingInformation *, int) const
 
virtual OsiBranchingObject * createOsiBranch (OsiSolverInterface *solver, const OsiBranchingInformation *info, int way) const
 Create an Osibranching object and indicate which way to branch first. More...
 
virtual OsiSolverBranch * solverBranch () const
 Create an OsiSolverBranch object. More...
 
virtual CbcBranchingObjectpreferredNewFeasible () const
 Given a valid solution (with reduced costs, etc.), return a branching object which would give a new feasible point in a good direction. More...
 
virtual CbcBranchingObjectnotPreferredNewFeasible () const
 Given a valid solution (with reduced costs, etc.), return a branching object which would give a new feasible point in a bad direction. More...
 
virtual void resetBounds (const OsiSolverInterface *)
 Reset variable bounds to their original values. More...
 
virtual void floorCeiling (double &floorValue, double &ceilingValue, double value, double tolerance) const
 Returns floor and ceiling i.e. More...
 
virtual CbcObjectUpdateData createUpdateInformation (const OsiSolverInterface *solver, const CbcNode *node, const CbcBranchingObject *branchingObject)
 Pass in information on branch just done and create CbcObjectUpdateData instance. More...
 
virtual void updateInformation (const CbcObjectUpdateData &)
 Update object by CbcObjectUpdateData. More...
 
int id () const
 Identifier (normally column number in matrix) More...
 
void setId (int value)
 Set identifier (normally column number in matrix) but 1000000000 to 1100000000 means optional branching object i.e. More...
 
bool optionalObject () const
 Return true if optional branching object i.e. More...
 
int position () const
 Get position in object_ list. More...
 
void setPosition (int position)
 Set position in object_ list. More...
 
void setModel (CbcModel *model)
 update model More...
 
CbcModelmodel () const
 Return model. More...
 
int preferredWay () const
 If -1 down always chosen first, +1 up always, 0 normal. More...
 
void setPreferredWay (int value)
 Set -1 down always chosen first, +1 up always, 0 normal. More...
 
virtual void initializeForBranching (CbcModel *)
 Initialize for branching. More...
 

Protected Attributes

int numberMembers_
 data Number of members More...
 
int * members_
 Members (indices in range 0 ... numberColumns-1) More...
 
CbcConsequence ** consequence_
 Consequences (normally NULL) More...
 
- Protected Attributes inherited from CbcObject
CbcModelmodel_
 data More...
 
int id_
 Identifier (normally column number in matrix) More...
 
int position_
 Position in object list. More...
 
int preferredWay_
 If -1 down always chosen first, +1 up always, 0 normal. More...
 

Detailed Description

Define an n-way class for variables.

Only valid value is one at UB others at LB Normally 0-1

Definition at line 15 of file CbcNWay.hpp.

Constructor & Destructor Documentation

◆ CbcNWay() [1/3]

CbcNWay::CbcNWay ( )

◆ CbcNWay() [2/3]

CbcNWay::CbcNWay ( CbcModel model,
int  numberMembers,
const int *  which,
int  identifier 
)

Useful constructor (which are matrix indices)

◆ CbcNWay() [3/3]

CbcNWay::CbcNWay ( const CbcNWay )

◆ ~CbcNWay()

virtual CbcNWay::~CbcNWay ( )
virtual

Destructor.

Member Function Documentation

◆ clone()

virtual CbcObject* CbcNWay::clone ( ) const
virtual

Clone.

Implements CbcObject.

◆ operator=()

CbcNWay& CbcNWay::operator= ( const CbcNWay rhs)

Assignment operator.

◆ setConsequence()

void CbcNWay::setConsequence ( int  iColumn,
const CbcConsequence consequence 
)

Set up a consequence for a single member.

◆ applyConsequence()

void CbcNWay::applyConsequence ( int  iSequence,
int  state 
) const

Applies a consequence for a single member.

◆ infeasibility()

virtual double CbcNWay::infeasibility ( const OsiBranchingInformation *  info,
int &  preferredWay 
) const
virtual

Infeasibility - large is 0.5 (and 0.5 will give this)

Reimplemented from CbcObject.

◆ feasibleRegion() [1/4]

virtual void CbcNWay::feasibleRegion ( )
virtual

This looks at solution and sets bounds to contain solution.

Implements CbcObject.

◆ createCbcBranch()

virtual CbcBranchingObject* CbcNWay::createCbcBranch ( OsiSolverInterface *  solver,
const OsiBranchingInformation *  info,
int  way 
)
virtual

Creates a branching object.

Reimplemented from CbcObject.

◆ numberMembers()

int CbcNWay::numberMembers ( ) const
inline

Number of members.

Definition at line 56 of file CbcNWay.hpp.

◆ members()

const int* CbcNWay::members ( ) const
inline

Members (indices in range 0 ... numberColumns-1)

Definition at line 62 of file CbcNWay.hpp.

◆ redoSequenceEtc()

virtual void CbcNWay::redoSequenceEtc ( CbcModel model,
int  numberColumns,
const int *  originalColumns 
)
virtual

Redoes data when sequence numbers change.

Reimplemented from CbcObject.

◆ feasibleRegion() [2/4]

virtual void CbcObject::feasibleRegion

For the variable(s) referenced by the object, look at the current solution and set bounds to match the solution.

◆ feasibleRegion() [3/4]

virtual double CbcObject::feasibleRegion

Dummy one for compatibility.

◆ feasibleRegion() [4/4]

virtual double CbcObject::feasibleRegion

For the variable(s) referenced by the object, look at the current solution and set bounds to match the solution.

Returns measure of how much it had to move solution to make feasible

Member Data Documentation

◆ numberMembers_

int CbcNWay::numberMembers_
protected

data Number of members

Definition at line 72 of file CbcNWay.hpp.

◆ members_

int* CbcNWay::members_
protected

Members (indices in range 0 ... numberColumns-1)

Definition at line 75 of file CbcNWay.hpp.

◆ consequence_

CbcConsequence** CbcNWay::consequence_
protected

Consequences (normally NULL)

Definition at line 77 of file CbcNWay.hpp.


The documentation for this class was generated from the following file: