CbcLotsizeBranchingObject Class Reference

Lotsize branching object. More...

#include <CbcBranchLotsize.hpp>

Inheritance diagram for CbcLotsizeBranchingObject:

Inheritance graph
[legend]
Collaboration diagram for CbcLotsizeBranchingObject:

Collaboration graph
[legend]
List of all members.

Public Member Functions

 CbcLotsizeBranchingObject ()
 Default constructor.
 CbcLotsizeBranchingObject (CbcModel *model, int variable, int way, double value, const CbcLotsize *lotsize)
 Create a lotsize floor/ceiling branch object.
 CbcLotsizeBranchingObject (CbcModel *model, int variable, int way, double lowerValue, double upperValue)
 Create a degenerate branch object.
 CbcLotsizeBranchingObject (const CbcLotsizeBranchingObject &)
 Copy constructor.
CbcLotsizeBranchingObjectoperator= (const CbcLotsizeBranchingObject &rhs)
 Assignment operator.
virtual CbcBranchingObjectclone () const
 Clone.
virtual ~CbcLotsizeBranchingObject ()
 Destructor.
virtual double branch (bool normalBranch=false)
 Sets the bounds for the variable according to the current arm of the branch and advances the object state to the next arm.
virtual void print (bool normalBranch)
 Print something about branch - only if log level high.

Protected Attributes

double down_ [2]
 Lower [0] and upper [1] bounds for the down arm (way_ = -1).
double up_ [2]
 Lower [0] and upper [1] bounds for the up arm (way_ = 1).

Detailed Description

Lotsize branching object.

This object can specify a two-way branch on an integer variable. For each arm of the branch, the upper and lower bounds on the variable can be independently specified.

Variable_ holds the index of the integer variable in the integerVariable_ array of the model.

Definition at line 148 of file CbcBranchLotsize.hpp.


Constructor & Destructor Documentation

CbcLotsizeBranchingObject::CbcLotsizeBranchingObject (  ) 

Default constructor.

CbcLotsizeBranchingObject::CbcLotsizeBranchingObject ( CbcModel model,
int  variable,
int  way,
double  value,
const CbcLotsize lotsize 
)

Create a lotsize floor/ceiling branch object.

Specifies a simple two-way branch. Let value = x*. One arm of the branch will be is lb <= x <= valid range below(x*), the other valid range above(x*) <= x <= ub. Specify way = -1 to set the object state to perform the down arm first, way = 1 for the up arm.

CbcLotsizeBranchingObject::CbcLotsizeBranchingObject ( CbcModel model,
int  variable,
int  way,
double  lowerValue,
double  upperValue 
)

Create a degenerate branch object.

Specifies a `one-way branch'. Calling branch() for this object will always result in lowerValue <= x <= upperValue. Used to fix in valid range

CbcLotsizeBranchingObject::CbcLotsizeBranchingObject ( const CbcLotsizeBranchingObject  ) 

Copy constructor.

virtual CbcLotsizeBranchingObject::~CbcLotsizeBranchingObject (  )  [virtual]

Destructor.


Member Function Documentation

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

Assignment operator.

virtual CbcBranchingObject* CbcLotsizeBranchingObject::clone (  )  const [virtual]

Clone.

Implements CbcBranchingObject.

virtual double CbcLotsizeBranchingObject::branch ( bool  normalBranch = false  )  [virtual]

Sets the bounds for the variable according to the current arm of the branch and advances the object state to the next arm.

Implements CbcBranchingObject.

virtual void CbcLotsizeBranchingObject::print ( bool  normalBranch  )  [virtual]

Print something about branch - only if log level high.

Reimplemented from CbcBranchingObject.


Member Data Documentation

double CbcLotsizeBranchingObject::down_[2] [protected]

Lower [0] and upper [1] bounds for the down arm (way_ = -1).

Definition at line 197 of file CbcBranchLotsize.hpp.

double CbcLotsizeBranchingObject::up_[2] [protected]

Lower [0] and upper [1] bounds for the up arm (way_ = 1).

Definition at line 199 of file CbcBranchLotsize.hpp.


The documentation for this class was generated from the following file:
Generated on Thu May 15 22:00:00 2008 by  doxygen 1.4.7