Couenne  0.2
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Public Member Functions | Protected Member Functions | List of all members
Couenne::exprBinProd Class Reference

class for $ \prod_{i=1}^n f_i(x) $ with $ f_i(x) $ all binary More...

#include <CouenneExprBinProd.hpp>

Inheritance diagram for Couenne::exprBinProd:
Couenne::exprMul Couenne::exprOp Couenne::expression

Public Member Functions

 exprBinProd (expression **, int)
 Constructor. More...
 
 exprBinProd (expression *, expression *)
 Constructor with two arguments. More...
 
CouNumber gradientNorm (const double *x)
 return l-2 norm of gradient at given point More...
 
expressiondifferentiate (int index)
 differentiation More...
 
expressionsimplify ()
 simplification More...
 
virtual int Linearity ()
 get a measure of "how linear" the expression is: More...
 
virtual void getBounds (expression *&, expression *&)
 Get lower and upper bound of an expression (if any) More...
 
virtual void getBounds (CouNumber &lb, CouNumber &ub)
 Get value of lower and upper bound of an expression (if any) More...
 
virtual exprAuxstandardize (CouenneProblem *p, bool addAux=true)
 reduce expression in standard form, creating additional aux variables (and constraints) More...
 
void generateCuts (expression *w, OsiCuts &cs, const CouenneCutGenerator *cg, t_chg_bounds *=NULL, int=-1, CouNumber=-COUENNE_INFINITY, CouNumber=COUENNE_INFINITY)
 generate equality between *this and *w More...
 
virtual enum expr_type code ()
 code for comparison More...
 
bool impliedBound (int, CouNumber *, CouNumber *, t_chg_bounds *, enum Couenne::expression::auxSign=Couenne::expression::AUX_EQ)
 implied bound processing More...
 
virtual CouNumber selectBranch (const CouenneObject *obj, const OsiBranchingInformation *info, expression *&var, double *&brpts, double *&brDist, int &way)
 set up branching object by evaluating many branching points for each expression's arguments More...
 
virtual void closestFeasible (expression *varind, expression *vardep, CouNumber &left, CouNumber &right) const
 compute $y^{lv}$ and $y^{uv}$ for Violation Transfer algorithm More...
 
- Public Member Functions inherited from Couenne::exprMul
 exprMul (expression **, int)
 Constructor. More...
 
 exprMul (expression *, expression *)
 Constructor with two arguments. More...
 
virtual expressionclone (Domain *d=NULL) const
 Cloning method. More...
 
std::string printOp () const
 Print operator. More...
 
CouNumber operator() ()
 Method to evaluate the expression. More...
 
expressiondifferentiate (int index)
 differentiation More...
 
expressionsimplify ()
 simplification More...
 
- Public Member Functions inherited from Couenne::exprOp
virtual enum nodeType Type () const
 Node type. More...
 
 exprOp (expression **arglist, int nargs)
 Constructor. More...
 
 exprOp (expression *arg0, expression *arg1)
 Constructor with two arguments (for convenience) More...
 
virtual ~exprOp ()
 Destructor. More...
 
 exprOp (const exprOp &e, Domain *d=NULL)
 Copy constructor: only allocate space for argument list, which will be copied with clonearglist() More...
 
expression ** ArgList () const
 return argument list More...
 
virtual void ArgList (expression **al)
 set arglist (used in deleting nodes without deleting children) More...
 
int nArgs () const
 return number of arguments More...
 
virtual void print (std::ostream &out=std::cout, bool=false) const
 I/O. More...
 
virtual enum pos printPos () const
 print position (PRE, INSIDE, POST) More...
 
virtual int DepList (std::set< int > &deplist, enum dig_type type=ORIG_ONLY)
 fill in the set with all indices of variables appearing in the expression More...
 
expression ** clonearglist (Domain *d=NULL) const
 clone argument list (for use with clone method) More...
 
int shrink_arglist (CouNumber, CouNumber)
 compress argument list More...
 
virtual bool isInteger ()
 is this expression integer? More...
 
virtual int compare (exprOp &)
 compare with other generic exprOp More...
 
virtual int rank ()
 used in rank-based branching variable choice More...
 
virtual void fillDepSet (std::set< DepNode *, compNode > *dep, DepGraph *g)
 fill in dependence structure update dependence set with index of this variable More...
 
virtual void replace (exprVar *, exprVar *)
 replace variable with other More...
 
virtual void realign (const CouenneProblem *p)
 empty function to redirect variables to proper variable vector More...
 
- Public Member Functions inherited from Couenne::expression
 expression ()
 Constructor. More...
 
 expression (const expression &e, Domain *d=NULL)
 Copy constructor. More...
 
virtual ~expression ()
 Destructor. More...
 
virtual int Index () const
 Return index of variable (only valid for exprVar and exprAux) More...
 
virtual expressionArgument () const
 return argument (when applicable, i.e., with univariate functions) More...
 
virtual expression ** ArgPtr ()
 return pointer to argument (when applicable, i.e., with univariate functions) More...
 
virtual expressionImage () const
 return pointer to corresponding expression (for auxiliary variables only) More...
 
virtual void Image (expression *image)
 set expression associated with this auxiliary variable (for compatibility with exprAux) More...
 
virtual CouNumber Value () const
 value (empty) More...
 
virtual const expressionOriginal () const
 If this is an exprClone of a exprClone of an expr???, point to the original expr??? instead of an exprClone – improve computing efficiency. More...
 
virtual int dependsOn (int *ind, int n, enum dig_type type=STOP_AT_AUX)
 dependence on variable set: return cardinality of subset of the set of indices in first argument which occur in expression. More...
 
int dependsOn (int singleton, enum dig_type type=STOP_AT_AUX)
 version with one index only More...
 
virtual bool isDefinedInteger ()
 is this expression defined as an integer? More...
 
virtual enum convexity convexity () const
 either CONVEX, CONCAVE, AFFINE, or NONCONVEX More...
 
virtual int compare (expression &)
 compare expressions More...
 
virtual int compare (exprCopy &)
 compare copies of expressions More...
 
virtual bool impliedBound (int, CouNumber *, CouNumber *, t_chg_bounds *, enum auxSign=expression::AUX_EQ)
 does a backward implied bound processing on every expression, including exprSums although already done by Clp (useful when repeated within Couenne). More...
 
virtual int Multiplicity ()
 multiplicity of a variable More...
 
virtual void linkDomain (Domain *d)
 empty function to update domain pointer More...
 
virtual bool isBijective () const
 indicating if function is monotonically increasing More...
 
virtual CouNumber inverse (expression *vardep) const
 compute the inverse function More...
 
virtual bool isaCopy () const
 return true if this is a copy of something (i.e. an exprCopy) More...
 
virtual expressionCopy () const
 return copy of this expression (only makes sense in exprCopy) More...
 

Protected Member Functions

CouNumber balancedMul (const OsiBranchingInformation *info, int index, int wind)
 balanced strategy for branching point selection in products More...
 
virtual bool isCuttable (CouenneProblem *problem, int index) const
 can this expression be further linearized or are we on its concave ("bad") side More...
 
- Protected Member Functions inherited from Couenne::exprMul
int impliedBoundMul (CouNumber wl, CouNumber wu, std::vector< CouNumber > &xl, std::vector< CouNumber > &xu, std::vector< std::pair< int, CouNumber > > &nl, std::vector< std::pair< int, CouNumber > > &nu)
 inferring bounds on factors of a product More...
 
CouNumber balancedMul (const OsiBranchingInformation *info, int index, int wind)
 balanced strategy for branching point selection in products More...
 

Additional Inherited Members

- Public Types inherited from Couenne::expression
enum  auxSign { AUX_UNDEF =-2, AUX_LEQ =-1, AUX_EQ, AUX_GEQ }
 "sign" of the constraint defining an auxiliary. More...
 
- Protected Attributes inherited from Couenne::exprOp
expression ** arglist_
 argument list is an array of pointers to other expressions More...
 
int nargs_
 number of arguments (cardinality of arglist) More...
 

Detailed Description

class for $ \prod_{i=1}^n f_i(x) $ with $ f_i(x) $ all binary

Definition at line 21 of file CouenneExprBinProd.hpp.

Constructor & Destructor Documentation

Couenne::exprBinProd::exprBinProd ( expression **  ,
int   
)

Constructor.

Couenne::exprBinProd::exprBinProd ( expression ,
expression  
)

Constructor with two arguments.

Member Function Documentation

CouNumber Couenne::exprBinProd::gradientNorm ( const double *  x)
virtual

return l-2 norm of gradient at given point

Reimplemented from Couenne::exprMul.

expression* Couenne::exprBinProd::differentiate ( int  index)
virtual

differentiation

Reimplemented from Couenne::expression.

expression* Couenne::exprBinProd::simplify ( )
virtual

simplification

Reimplemented from Couenne::exprOp.

virtual int Couenne::exprBinProd::Linearity ( )
virtual

get a measure of "how linear" the expression is:

Reimplemented from Couenne::exprMul.

virtual void Couenne::exprBinProd::getBounds ( expression *&  ,
expression *&   
)
virtual

Get lower and upper bound of an expression (if any)

Reimplemented from Couenne::exprMul.

virtual void Couenne::exprBinProd::getBounds ( CouNumber lb,
CouNumber ub 
)
virtual

Get value of lower and upper bound of an expression (if any)

Reimplemented from Couenne::exprMul.

virtual exprAux* Couenne::exprBinProd::standardize ( CouenneProblem p,
bool  addAux = true 
)
virtual

reduce expression in standard form, creating additional aux variables (and constraints)

Reimplemented from Couenne::exprMul.

void Couenne::exprBinProd::generateCuts ( expression w,
OsiCuts &  cs,
const CouenneCutGenerator cg,
t_chg_bounds = NULL,
int  = -1,
CouNumber  = -COUENNE_INFINITY,
CouNumber  = COUENNE_INFINITY 
)
virtual

generate equality between *this and *w

Reimplemented from Couenne::exprMul.

virtual enum expr_type Couenne::exprBinProd::code ( )
inlinevirtual

code for comparison

Reimplemented from Couenne::exprMul.

Definition at line 61 of file CouenneExprBinProd.hpp.

References Couenne::COU_EXPRMUL.

bool Couenne::exprBinProd::impliedBound ( int  ,
CouNumber ,
CouNumber ,
t_chg_bounds ,
enum Couenne::expression::auxSign  = Couenne::expression::AUX_EQ 
)
virtual

implied bound processing

Reimplemented from Couenne::exprMul.

virtual CouNumber Couenne::exprBinProd::selectBranch ( const CouenneObject obj,
const OsiBranchingInformation *  info,
expression *&  var,
double *&  brpts,
double *&  brDist,
int &  way 
)
virtual

set up branching object by evaluating many branching points for each expression's arguments

Reimplemented from Couenne::exprMul.

virtual void Couenne::exprBinProd::closestFeasible ( expression varind,
expression vardep,
CouNumber left,
CouNumber right 
) const
virtual

compute $y^{lv}$ and $y^{uv}$ for Violation Transfer algorithm

Reimplemented from Couenne::exprMul.

CouNumber Couenne::exprBinProd::balancedMul ( const OsiBranchingInformation *  info,
int  index,
int  wind 
)
protected

balanced strategy for branching point selection in products

virtual bool Couenne::exprBinProd::isCuttable ( CouenneProblem problem,
int  index 
) const
inlineprotectedvirtual

can this expression be further linearized or are we on its concave ("bad") side

Reimplemented from Couenne::exprMul.

Definition at line 89 of file CouenneExprBinProd.hpp.


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