|
Couenne
0.2
|
class for
with
all binary
More...
#include <CouenneExprBinProd.hpp>
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... | |
| expression * | differentiate (int index) |
| differentiation More... | |
| expression * | simplify () |
| 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 exprAux * | standardize (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 and 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 expression * | clone (Domain *d=NULL) const |
| Cloning method. More... | |
| std::string | printOp () const |
| Print operator. More... | |
| CouNumber | operator() () |
| Method to evaluate the expression. More... | |
| expression * | differentiate (int index) |
| differentiation More... | |
| expression * | simplify () |
| 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 expression * | Argument () 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 expression * | Image () 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 expression * | Original () 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 expression * | Copy () 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... | |
class for
with
all binary
Definition at line 21 of file CouenneExprBinProd.hpp.
| Couenne::exprBinProd::exprBinProd | ( | expression ** | , |
| int | |||
| ) |
Constructor.
| Couenne::exprBinProd::exprBinProd | ( | expression * | , |
| expression * | |||
| ) |
Constructor with two arguments.
|
virtual |
return l-2 norm of gradient at given point
Reimplemented from Couenne::exprMul.
|
virtual |
differentiation
Reimplemented from Couenne::expression.
|
virtual |
simplification
Reimplemented from Couenne::exprOp.
|
virtual |
get a measure of "how linear" the expression is:
Reimplemented from Couenne::exprMul.
|
virtual |
Get lower and upper bound of an expression (if any)
Reimplemented from Couenne::exprMul.
Get value of lower and upper bound of an expression (if any)
Reimplemented from Couenne::exprMul.
|
virtual |
reduce expression in standard form, creating additional aux variables (and constraints)
Reimplemented from Couenne::exprMul.
|
virtual |
generate equality between *this and *w
Reimplemented from Couenne::exprMul.
|
inlinevirtual |
code for comparison
Reimplemented from Couenne::exprMul.
Definition at line 61 of file CouenneExprBinProd.hpp.
References Couenne::COU_EXPRMUL.
|
virtual |
implied bound processing
Reimplemented from Couenne::exprMul.
|
virtual |
set up branching object by evaluating many branching points for each expression's arguments
Reimplemented from Couenne::exprMul.
|
virtual |
compute
and
for Violation Transfer algorithm
Reimplemented from Couenne::exprMul.
|
protected |
balanced strategy for branching point selection in products
|
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.
1.8.5