251#define CONSHDLR_NAME "indicator"
252#define CONSHDLR_DESC "indicator constraint handler"
253#define CONSHDLR_SEPAPRIORITY 10
254#define CONSHDLR_ENFOPRIORITY -100
255#define CONSHDLR_CHECKPRIORITY -6000000
256#define CONSHDLR_SEPAFREQ 10
257#define CONSHDLR_PROPFREQ 1
258#define CONSHDLR_EAGERFREQ 100
260#define CONSHDLR_MAXPREROUNDS -1
261#define CONSHDLR_DELAYSEPA FALSE
262#define CONSHDLR_DELAYPROP FALSE
263#define CONSHDLR_NEEDSCONS TRUE
265#define CONSHDLR_PRESOLTIMING SCIP_PRESOLTIMING_FAST
266#define CONSHDLR_PROP_TIMING SCIP_PROPTIMING_BEFORELP
270#define EVENTHDLR_BOUND_NAME "indicatorbound"
271#define EVENTHDLR_BOUND_DESC "bound change event handler for indicator constraints"
273#define EVENTHDLR_LINCONSBOUND_NAME "indicatorlinconsbound"
274#define EVENTHDLR_LINCONSBOUND_DESC "bound change event handler for lincons of indicator constraints"
276#define EVENTHDLR_RESTART_NAME "indicatorrestart"
277#define EVENTHDLR_RESTART_DESC "force restart if absolute gap is 1 or enough binary variables have been fixed"
281#define CONFLICTHDLR_NAME "indicatorconflict"
282#define CONFLICTHDLR_DESC "replace slack variables and generate logicor constraints"
283#define CONFLICTHDLR_PRIORITY 200000
286#define LINCONSUPGD_PRIORITY +100000
289#define DEFAULT_BRANCHINDICATORS FALSE
290#define DEFAULT_GENLOGICOR FALSE
291#define DEFAULT_ADDCOUPLING TRUE
292#define DEFAULT_MAXCOUPLINGVALUE 1e4
293#define DEFAULT_ADDCOUPLINGCONS FALSE
294#define DEFAULT_SEPACOUPLINGCUTS TRUE
295#define DEFAULT_SEPACOUPLINGLOCAL FALSE
296#define DEFAULT_SEPACOUPLINGVALUE 1e4
297#define DEFAULT_SEPAALTERNATIVELP FALSE
298#define DEFAULT_SEPAPERSPECTIVE FALSE
299#define DEFAULT_SEPAPERSPLOCAL TRUE
300#define DEFAULT_MAXSEPANONVIOLATED 3
301#define DEFAULT_TRYSOLFROMCOVER FALSE
302#define DEFAULT_UPGRADELINEAR FALSE
303#define DEFAULT_USEOTHERCONSS FALSE
304#define DEFAULT_USEOBJECTIVECUT FALSE
305#define DEFAULT_UPDATEBOUNDS FALSE
306#define DEFAULT_MAXCONDITIONALTLP 0.0
307#define DEFAULT_MAXSEPACUTS 100
308#define DEFAULT_MAXSEPACUTSROOT 2000
309#define DEFAULT_REMOVEINDICATORS FALSE
310#define DEFAULT_GENERATEBILINEAR FALSE
311#define DEFAULT_SCALESLACKVAR FALSE
312#define DEFAULT_NOLINCONSCONT FALSE
313#define DEFAULT_TRYSOLUTIONS TRUE
314#define DEFAULT_ENFORCECUTS FALSE
315#define DEFAULT_DUALREDUCTIONS TRUE
316#define DEFAULT_ADDOPPOSITE FALSE
317#define DEFAULT_CONFLICTSUPGRADE FALSE
318#define DEFAULT_FORCERESTART FALSE
319#define DEFAULT_RESTARTFRAC 0.9
320#define DEFAULT_USESAMESLACKVAR FALSE
324#define OBJEPSILON 0.001
325#define SEPAALTTHRESHOLD 10
326#define MAXROUNDINGROUNDS 1
342 unsigned int linconsactive:1;
343 unsigned int implicationadded:1;
344 unsigned int slacktypechecked:1;
349struct SCIP_ConshdlrData
378 int maxroundingrounds;
402 int maxsepanonviolated;
431struct SCIP_ConflicthdlrData
452#define SCIP_CALL_PARAM(x) do \
454 SCIP_RETCODE _restat_; \
455 if ( (_restat_ = (x)) != SCIP_OKAY && (_restat_ != SCIP_PARAMETERUNKNOWN) ) \
457 SCIPerrorMessage("[%s:%d] Error <%d> in function call\n", __FILE__, __LINE__, _restat_); \
498 lincons = consdata->lincons;
513 nlocvars = nvarslincons;
533 vars[0] = consdata->binvar;
549 else if( nlocvars == 1 )
570 vars[0] = consdata->slackvar;
586 else if( nlocvars == 1 )
627 assert( 0 <= consdata->nfixednonzero && consdata->nfixednonzero <= 2 );
628 assert( consdata->linconsactive );
645 ++(consdata->nfixednonzero);
646#ifdef SCIP_MORE_DEBUG
647 SCIPdebugMsg(
scip,
"Changed lower bound of variable <%s> from %g to %g (nfixednonzero: %d).\n",
657 ++(consdata->nfixednonzero);
658#ifdef SCIP_MORE_DEBUG
659 SCIPdebugMsg(
scip,
"Changed upper bound of variable <%s> from %g to %g (nfixednonzero: %d).\n",
669 --(consdata->nfixednonzero);
670#ifdef SCIP_MORE_DEBUG
671 SCIPdebugMsg(
scip,
"Changed lower bound of variable <%s> from %g to %g (nfixednonzero: %d).\n",
681 --(consdata->nfixednonzero);
682#ifdef SCIP_MORE_DEBUG
683 SCIPdebugMsg(
scip,
"Changed upper bound of variable <%s> from %g to %g (nfixednonzero: %d).\n",
694 assert( 0 <= consdata->nfixednonzero && consdata->nfixednonzero <= 2 );
697 conshdlrdata->boundhaschanged =
TRUE;
717#ifdef SCIP_MORE_DEBUG
725 conshdlrdata->linconsboundschanged =
TRUE;
753 assert( conshdlrdata->forcerestart );
776 if ( conshdlrdata->performedrestart )
780 ++(conshdlrdata->nbinvarszero);
788 if ( conshdlrdata->nbinvarszero > (
int) ((
SCIP_Real) conshdlrdata->ninitconss * conshdlrdata->restartfrac) )
791 "Forcing restart, since %d binary variables among %d have been fixed.\n", conshdlrdata->nbinvarszero, conshdlrdata->ninitconss);
795 if ( conshdlrdata->objindicatoronly )
799 conshdlrdata->performedrestart =
TRUE;
811 if ( ! conshdlrdata->objindicatoronly )
828 conshdlrdata->performedrestart =
TRUE;
878 assert( bdchginfos !=
NULL || nbdchginfos == 0 );
901 for (
i = 0;
i < nbdchginfos; ++
i)
933 if ( haveslack &&
i == nbdchginfos )
940 SCIPdebugMsg(
scip,
"Found conflict involving slack variables that can be remodelled.\n");
950 for (
i = 0;
i < nbdchginfos; ++
i)
966 for (j = 0; j < nconss; ++j)
973 if ( slackvar ==
var )
1001 if (
i == nbdchginfos )
1057 if ( *value == newvalue )
1112#ifdef SCIP_ENABLE_IISCHECK
1155 for (
c = 0;
c < nconss; ++
c)
1182 lincons = consdata->lincons;
1187 slackvar = consdata->slackvar;
1209 linvals[0] = scalar;
1239 for (v = 0; v < nlinvars; ++v)
1246 if (
var == slackvar )
1259 newvars[nnewvars++] =
var;
1277 for (v = 0; v < nnewvars; ++v)
1291 for (v = nnewvars - 1; v >= 0; --v)
1303 for (v = 0; v < nlinvars; ++v)
1310 if (
var == slackvar )
1315 matval[cnt] = sign * linvals[v];
1340 if ( conshdlrdata->useotherconss )
1347 for (
c = 0;
c < nconss; ++
c)
1391 for (v = 0; v < nlinvars; ++v)
1407 newvars[nnewvars++] =
var;
1425 for (v = 0; v < nnewvars; ++v)
1439 for (v = nnewvars - 1; v >= 0; --v)
1450 for (v = 0; v < nlinvars; ++v)
1458 matval[cnt] = linvals[v];
1536 assert( conshdlrdata->naddlincons <= conshdlrdata->maxaddlincons );
1538 if ( num > conshdlrdata->maxaddlincons )
1544 conshdlrdata->maxaddlincons = newsize;
1546 assert( num <= conshdlrdata->maxaddlincons );
1592 conshdlrdata->nrows = 1;
1634 for (j = 0; j < nCols; ++j)
1639 for (j = 0; j < nconss; ++j)
1647 ind = consdata->colindex;
1652 covered[ind] =
TRUE;
1661 for (j = 0; j < nCols; ++j)
1700 int* indices =
NULL;
1710 for (j = 0; j < nconss; ++j)
1718 if ( consdata->colindex >= 0 )
1724 obj[cnt] = 1.0 - val;
1725 indices[cnt++] = consdata->colindex;
1752 int* indices =
NULL;
1762 for (j = 0; j < nconss; ++j)
1770 if ( consdata->colindex >= 0 )
1773 indices[cnt++] = consdata->colindex;
1801 int* indices =
NULL;
1814 for (j = 0; j < nconss; ++j)
1822 if ( consdata->colindex >= 0 )
1826 indices[cnt] = consdata->colindex;
1893 int* indices =
NULL;
1906 for (j = 0; j < nconss; ++j)
1916 if ( consdata->colindex >= 0 )
1918 indices[cnt] = consdata->colindex;
1958 altlp = conshdlrdata->altlp;
1959 lbhash = conshdlrdata->lbhash;
1960 ubhash = conshdlrdata->ubhash;
1968 for (v = 0; v <
nvars; ++v)
1994 conshdlrdata->scaled =
FALSE;
2022 altlp = conshdlrdata->altlp;
2023 lbhash = conshdlrdata->lbhash;
2024 ubhash = conshdlrdata->ubhash;
2032 for (v = 0; v <
nvars; ++v)
2094 lbhash = conshdlrdata->lbhash;
2095 ubhash = conshdlrdata->ubhash;
2103 for (v = 0; v <
nvars; ++v)
2117 assert( 0 <= col && col < nCols );
2135 assert( 0 <= col && col < nCols );
2164 if ( ! conshdlrdata->scaled )
2175 altlp = conshdlrdata->altlp;
2185 for (j = 0; j < cnt; ++j)
2189 sum = -
REALABS(sum) / ((double) cnt);
2197 conshdlrdata->scaled =
TRUE;
2250 if ( conshdlrdata->altlp ==
NULL )
2264 assert( nrows == conshdlrdata->nrows );
2287 matval[cnt++] = sign * rhscoef;
2291 for (v = 0; v <
nvars; ++v)
2302 if (
var != slackvar )
2308 if ( ind < INT_MAX )
2316 matind[cnt] = (conshdlrdata->nrows)++;
2319 newrowsslack[nnewrows++] =
TRUE;
2322 matval[cnt++] = sign * vals[v];
2336 matind[cnt] = (conshdlrdata->nrows)++;
2339 newrowsslack[nnewrows++] =
FALSE;
2340 newvars[nnewvars++] =
var;
2343 matval[cnt++] = sign * vals[v];
2356 for (
i = 0;
i < nnewrows; ++
i)
2358 if ( newrowsslack[
i] )
2388 for (v = 0; v < nnewvars; ++v)
2397 matbeg[nnewcols] = cnt;
2401 matval[cnt++] = -val;
2406 matval[cnt++] = -1.0;
2407 obj[nnewcols] = 0.0;
2410 ++conshdlrdata->nlbbounds;
2414 SCIPdebugMsg(
scip,
"Added column for lower bound (%f) of variable <%s> to alternative polyhedron (col: %d).\n",
2423 matbeg[nnewcols] = cnt;
2427 matval[cnt++] = val;
2432 matval[cnt++] = 1.0;
2433 obj[nnewcols] = 0.0;
2436 ++conshdlrdata->nubbounds;
2440 SCIPdebugMsg(
scip,
"Added column for upper bound (%f) of variable <%s> to alternative polyhedron (col: %d).\n",
2454 assert( cnt == ncols + nnewcols + 1 );
2466 conshdlrdata->scaled =
FALSE;
2520 SCIPdebugMsg(
scip,
"Slack variable is aggregated (scalar: %f, constant: %f).\n", scalar, constant);
2530 linvals[0] = scalar;
2553 SCIP_CALL(
addAltLPColumn(
scip, conshdlr, conshdlrdata, slackvar, nlinvars, linvars, linvals, linrhs, objcoef, 1.0,
TRUE, colindex) );
2558 SCIP_CALL(
addAltLPColumn(
scip, conshdlr, conshdlrdata, slackvar, nlinvars, linvars, linvals, linrhs, objcoef, 1.0,
FALSE, colindex) );
2564 SCIP_CALL(
addAltLPColumn(
scip, conshdlr, conshdlrdata, slackvar, nlinvars, linvars, linvals, linlhs, objcoef, -1.0,
FALSE, colindex) );
2623 for (j = 0; j < nrowcols; ++j)
2633 SCIP_CALL(
addAltLPColumn(
scip, conshdlr, conshdlrdata,
NULL, nrowcols, rowvars, rowvals, rowrhs, objcoef, 1.0,
TRUE, colindex) );
2638 SCIP_CALL(
addAltLPColumn(
scip, conshdlr, conshdlrdata,
NULL, nrowcols, rowvars, rowvals, rowrhs, objcoef, 1.0,
FALSE, colindex) );
2644 SCIP_CALL(
addAltLPColumn(
scip, conshdlr, conshdlrdata,
NULL, nrowcols, rowvars, rowvals, rowlhs, objcoef, -1.0,
FALSE, colindex) );
2676 if ( conshdlrdata->objcutindex >= 0 )
2680 if ( ! conshdlrdata->objothervarsonly )
2684 SCIPdebugMsg(
scip,
"Add objective cut to alternative LP (obj. bound: %g).\n", conshdlrdata->objupperbound);
2691 for (v = 0; v <
nvars; ++v)
2703 objvars[nobjvars] =
var;
2704 objvals[nobjvars++] =
objval;
2709 SCIP_CALL(
addAltLPColumn(
scip, conshdlr, conshdlrdata,
NULL, nobjvars, objvars, objvals, conshdlrdata->objupperbound, 0.0, 1.0,
FALSE, &conshdlrdata->objcutindex) );
2710 assert( conshdlrdata->objcutindex >= 0 );
2711 conshdlrdata->objaltlpbound = conshdlrdata->objupperbound;
2741 if ( conshdlrdata->altlp !=
NULL )
2748 if ( consdata->colindex >= 0 )
2752 consdata->colindex = -1;
2756 conshdlrdata->scaled =
FALSE;
2775 if ( ! conshdlrdata->useobjectivecut )
2778 if ( conshdlrdata->altlp ==
NULL )
2790 if (
SCIPisLT(
scip, objbnd, conshdlrdata->objupperbound) )
2791 conshdlrdata->objupperbound = objbnd;
2798 if (
SCIPisLT(
scip, conshdlrdata->objupperbound, conshdlrdata->objaltlpbound) )
2800 SCIPdebugMsg(
scip,
"Update objective bound to %g.\n", conshdlrdata->objupperbound);
2803 if ( conshdlrdata->objcutindex < 0 )
2817 conshdlrdata->objaltlpbound = conshdlrdata->objupperbound;
2897 if ( maxcondition > 0.0 )
2901 if ( condition !=
SCIP_INVALID && condition > maxcondition )
2903 SCIPdebugMsg(
scip,
"Estimated condition number of basis matrix (%e) exceeds maximal allowance (%e).\n", condition, maxcondition);
2911 SCIPdebugMsg(
scip,
"Estimated condition number of basis matrix (%e) is below maximal allowance (%e).\n", condition, maxcondition);
2915 SCIPdebugMsg(
scip,
"Estimated condition number of basis matrix not available.\n");
2973 *infeasible =
FALSE;
3010 int nnonviolated = 0;
3030 assert( nconss <= nCols );
3061 SCIPdebugMsg(
scip,
" size: %4d produced possible cover with indicator variable objective value %f.\n", *size, *value);
3064 if ( conshdlrdata->trysolfromcover )
3074 if ( heurindicator ==
NULL )
3091 for (j = 0; j < nconss; ++j)
3098 ind = consdata->colindex;
3115 if ( val < candval )
3127 if ( candidate < 0 )
3133 assert( candidate >= 0 );
3134 assert( ! S[candidate] );
3138 switch ( conshdlrdata->normtype )
3153 SCIPerrorMessage(
"Invalid efficacy norm parameter '%c'.\n", conshdlrdata->normtype);
3158 SCIPdebugMsg(
scip,
" size: %4d, add var. %4d (obj: %-6g, alt-LP sol: %-8.4f); IIS size: %4d, eff.: %g.\n",
3162 S[candidate] =
TRUE;
3174#ifdef SCIP_ENABLE_IISCHECK
3180 if ( conshdlrdata->updatebounds )
3195 for (j = 0; j < nconss; ++j)
3201 ind = consdata->colindex;
3217 assert( cnt == sizeIIS );
3221 SCIP_CALL(
SCIPcreateConsLogicor(
scip, &cons, name, cnt,
vars,
FALSE,
TRUE,
TRUE,
TRUE,
TRUE, isLocal,
FALSE,
TRUE, removable,
FALSE) );
3223 SCIP_CALL(
SCIPcreateConsLogicor(
scip, &cons,
"", cnt,
vars,
FALSE,
TRUE,
TRUE,
TRUE,
TRUE, isLocal,
FALSE,
TRUE, removable,
FALSE) );
3232 switch ( enfosepatype )
3275 for (j = 0; j < nconss; ++j)
3281 ind = consdata->colindex;
3322 if ( nnonviolated > conshdlrdata->maxsepanonviolated )
3324 SCIPdebugMsg(
scip,
"Stop separation after %d non violated IISs.\n", nnonviolated);
3328 while (step < nconss);
3344 const char* consname,
3365 if ( activeone || binvar ==
NULL )
3366 binvarinternal = binvar;
3375 (*consdata)->nfixednonzero = 0;
3376 (*consdata)->colindex = -1;
3377 (*consdata)->linconsactive = linconsactive;
3378 (*consdata)->binvar = binvarinternal;
3379 (*consdata)->slackvar = slackvar;
3380 (*consdata)->activeone = activeone;
3381 (*consdata)->lessthanineq = lessthanineq;
3382 (*consdata)->lincons = lincons;
3383 (*consdata)->implicationadded =
FALSE;
3384 (*consdata)->slacktypechecked =
FALSE;
3385 (*consdata)->varswithevents =
NULL;
3386 (*consdata)->eventtypes =
NULL;
3387 (*consdata)->nevents = 0;
3395 if ( binvarinternal !=
NULL )
3399 (*consdata)->binvar =
var;
3414 if ( conshdlrdata->forcerestart )
3422 ++((*consdata)->nfixednonzero);
3428 (*consdata)->slackvar =
var;
3431 if ( linconsactive )
3435 ++((*consdata)->nfixednonzero);
3446 SCIPdebugMsg(
scip,
"Added column for <%s> to alternative LP with column index %d.\n", consname, (*consdata)->colindex);
3454 if ( (*consdata)->nfixednonzero > 0 )
3456 SCIPdebugMsg(
scip,
"Constraint <%s> has %d variables fixed to be nonzero.\n", consname, (*consdata)->nfixednonzero);
3485 for (
c = 0;
c < nconss; ++
c)
3497 if ( ub <= conshdlrdata->maxcouplingvalue )
3514 !conshdlrdata->removeindicators, !conshdlrdata->removeindicators,
FALSE) );
3520 if ( conshdlrdata->removeindicators )
3573 SCIPdebugMsg(
scip,
"The problem is infeasible: binary and slack variable are fixed to be nonzero.\n");
3614 SCIPdebugMsg(
scip,
"The problem is infeasible: binary and slack variable are fixed to be nonzero.\n");
3620 SCIPdebugMsg(
scip,
"Fix binary variable to 0 and delete indicator constraint.\n");
3638 if ( dualreductions )
3644 binvar = consdata->binvar;
3704 var = consdata->binvar;
3709 if (
var != consdata->binvar && ! negated )
3714 assert( conshdlrdata->eventhdlrbound !=
NULL );
3721 if ( conshdlrdata->forcerestart )
3723 assert( conshdlrdata->eventhdlrrestart !=
NULL );
3725 conshdlrdata->eventhdlrrestart, (
SCIP_EVENTDATA*) conshdlrdata, -1) );
3734 consdata->binvar =
var;
3745 if (
var == consdata->slackvar )
3764 var = consdata->slackvar;
3777 assert( conshdlrdata->eventhdlrbound !=
NULL );
3788 consdata->slackvar =
var;
3790 else if (
var == consdata->binvar )
3798 SCIPdebugMsg(
scip,
"Slack variable <%s> is aggregated to negated indicator variable <%s> -> constraint redundant.\n",
3812 SCIPdebugMsg(
scip,
"Slack variable <%s> is aggregated to the indicator variable <%s> -> fix indicator variable to 0.\n",
3867 if ( ! consdata->linconsactive )
3881 if ( consdata->nfixednonzero > 1 )
3883 SCIPdebugMsg(
scip,
"The node is infeasible, both the slack variable and the binary variable are fixed to be nonzero.\n");
3908 if ( consdata->nfixednonzero == 1 )
3918 SCIPdebugMsg(
scip,
"Binary variable <%s> is fixed to be nonzero, fixing slack variable <%s> to 0.\n",
3935 SCIPdebugMsg(
scip,
"Slack variable <%s> is fixed to be nonzero, fixing binary variable <%s> to 0.\n",
3959 if ( addopposite && consdata->linconsactive )
3996 slackvar = consdata->slackvar;
4003 for (j = 0; j < nlinvars; ++j)
4005 if ( linvars[j] != slackvar )
4008 allintegral =
FALSE;
4011 vals[
nvars++] = linvals[j];
4055 if ( dualreductions )
4061 binvar = consdata->binvar;
4149 for (j = 0; j < nlinconsvars; ++j)
4155 val = linconsvals[j];
4158 var = linconsvars[j];
4162 if (
var == consdata->slackvar )
4179 maxactivity += val *
bound;
4191 newub = (maxactivity - rhs) / (-1.0 * coeffslack);
4200 SCIPdebugMsg(
scip,
"Adjusting upper bound of slack variable <%s> to %g for indicator constraint <%s>.\n",
4262 lp = conshdlrdata->altlp;
4270 if ( conshdlrdata->updatebounds )
4285 for (j = 0; j < nconss; ++j)
4309 SCIP_CALL(
extendToCover(
scip, conshdlr, conshdlrdata, lp,
sol, enfosepatype, conshdlrdata->removable, genlogicor, nconss, conss, S, &size, &value, &error,
cutoff, &nCuts) );
4313 if ( nCuts == 0 && error )
4379 for (
c = 0;
c < nconss; ++
c)
4391 if ( ! consdata->linconsactive )
4393 someLinconsNotActive =
TRUE;
4413 binvar = consdata->binvar;
4421 if ( valSlack > maxSlack )
4423 maxSlack = valSlack;
4438 if ( (someLinconsNotActive || conshdlrdata->enforcecuts) && conshdlrdata->sepaalternativelp )
4446 conshdlrdata->niiscutsgen += ngen;
4453 conshdlrdata->niiscutsgen += ngen;
4479 if ( ! conshdlrdata->branchindicators )
4489 binvar = consdata->binvar;
4490 slackvar = consdata->slackvar;
4554 if ( *nGen >= maxsepacuts )
4562 lp = conshdlrdata->altlp;
4572 if ( conshdlrdata->updatebounds )
4590 for (threshold = conshdlrdata->roundingmaxthres;
4591 rounds < conshdlrdata->maxroundingrounds && threshold >= conshdlrdata->roundingminthres && *nGen < maxsepacuts && ! (*
cutoff);
4592 threshold -= conshdlrdata->roundingoffset )
4607 for (j = 0; j < nconss; ++j)
4639 if ( binvarval > binvarnegval )
4657 if ( size == nconss )
4664 if ( size == oldsize )
4666 SCIPdebugMsg(
scip,
"Skipping computation: size support has not changed.\n");
4672 SCIPdebugMsg(
scip,
" Vars with value 1: %d 0: %d and fractional: %d.\n", nvarsone, nvarszero, nvarsfrac);
4680 nconss, conss, S, &size, &value, &error,
cutoff, &nCuts) );
4760 if ( *nGen >= maxsepacuts )
4771 for (
c = 0;
c < nconss; ++
c)
4782 slackvar = consdata->slackvar;
4784 lincons = consdata->lincons;
4787 binvar = consdata->binvar;
4822 cutval = binval * ypart;
4824 for (j = 0; j < nlinvars; ++j)
4834 if ( linvars[j] == slackvar )
4837 if ( conshdlrdata->sepapersplocal )
4856 finitebound =
FALSE;
4861 linval = signfactor * linvals[j];
4865 dout += linval * lb;
4870 dout += linval * ub;
4874 xpart = linval * xval;
4877 if (
SCIPisGT(
scip, binval * din, binval * dout + xpart) )
4880 cutval += binval * din;
4888 cutval += binval * dout + xpart;
4890 cutvars[cnt] = linvars[j];
4891 cutvals[cnt++] = linval;
4895 if ( ! finitebound )
4905 cutvars[cnt] = binvar;
4906 cutvals[cnt] = ypart;
4910 (void)
SCIPsnprintf(name, 50,
"persp%d", conshdlrdata->nperspcutsgen + *nGen);
4923 if ( *nGen >= maxsepacuts )
4971 maxsepacuts = conshdlrdata->maxsepacutsroot;
4973 maxsepacuts = conshdlrdata->maxsepacuts;
4976 if ( conshdlrdata->sepacouplingcuts )
4983 for (
c = 0;
c < nusefulconss && ncuts < maxsepacuts; ++
c)
4998 if ( conshdlrdata->sepacouplinglocal )
5009 if ( ub <= conshdlrdata->sepacouplingvalue )
5047 SCIPdebugMsg(
scip,
"Number of separated coupling inequalities: %d.\n", ncuts);
5056 SCIPdebugMsg(
scip,
"Separating inequalities for indicator constraints.\n");
5064 SCIPdebugMsg(
scip,
"Separated %d cuts from indicator constraints.\n", ncuts - noldcuts);
5068 else if ( ncuts > noldcuts )
5070 conshdlrdata->niiscutsgen += ncuts;
5073 if ( conshdlrdata->genlogicor )
5085 SCIPdebugMsg(
scip,
"Separating inequalities based on perspective formulation.\n");
5093 SCIPdebugMsg(
scip,
"Separated %d cuts from perspective formulation.\n", ncuts - noldcuts);
5095 if ( ncuts > noldcuts )
5097 conshdlrdata->nperspcutsgen += ncuts;
5117 conshdlrdata->linconsevents =
FALSE;
5118 conshdlrdata->linconsboundschanged =
TRUE;
5119 conshdlrdata->boundhaschanged =
TRUE;
5120 conshdlrdata->removable =
TRUE;
5121 conshdlrdata->scaled =
FALSE;
5122 conshdlrdata->altlp =
NULL;
5123 conshdlrdata->nrows = 0;
5124 conshdlrdata->varhash =
NULL;
5125 conshdlrdata->slackhash =
NULL;
5126 conshdlrdata->lbhash =
NULL;
5127 conshdlrdata->ubhash =
NULL;
5128 conshdlrdata->nlbbounds = 0;
5129 conshdlrdata->nubbounds = 0;
5130 conshdlrdata->nslackvars = 0;
5131 conshdlrdata->objcutindex = -1;
5134 conshdlrdata->roundingminthres = 0.1;
5135 conshdlrdata->roundingmaxthres = 0.6;
5137 conshdlrdata->roundingoffset = 0.1;
5138 conshdlrdata->addedcouplingcons =
FALSE;
5139 conshdlrdata->ninitconss = 0;
5140 conshdlrdata->nbinvarszero = 0;
5141 conshdlrdata->performedrestart =
FALSE;
5142 conshdlrdata->objindicatoronly =
FALSE;
5143 conshdlrdata->objothervarsonly =
FALSE;
5144 conshdlrdata->minabsobj = 0.0;
5145 conshdlrdata->normtype =
'e';
5146 conshdlrdata->niiscutsgen = 0;
5147 conshdlrdata->nperspcutsgen = 0;
5172 int maxabsvalidx = -1;
5194 if ( ! conshdlrdata->upgradelinear )
5198 for (j = 0; j <
nvars; ++j)
5214 secabsval = maxabsval;
5238 minactivity += val * lb;
5247 maxactivity += val * ub;
5251 assert( maxabsval >= 0.0 );
5252 assert( 0 <= maxabsvalidx && maxabsvalidx <
nvars );
5267 for (j = 0; j <
nvars; ++j)
5317 if ( upgdlhs || upgdrhs )
5323 assert( ! upgdlhs || ! upgdrhs );
5330 for (l = 0; l <
nvars; ++l)
5332 if (
vars[l] == indvar )
5334 indconsvars[cnt] =
vars[l];
5336 indconsvals[cnt] = -vals[l];
5338 indconsvals[cnt] = vals[l];
5342 if ( indneglhs || indnegrhs )
5425 if ( conshdlrdata->trysolutions && conshdlrdata->heurtrysol ==
NULL )
5449 if ( conshdlrdata->binvarhash !=
NULL )
5452 if ( conshdlrdata->binslackvarhash !=
NULL )
5456 for (
i = 0;
i < nconss;
i++)
5461 if ( consdata->varswithevents !=
NULL )
5466 for (j = 0; j < consdata->nevents; ++j)
5473 consdata->nevents = 0;
5480 conshdlrdata->maxaddlincons = 0;
5481 conshdlrdata->naddlincons = 0;
5482 conshdlrdata->nrows = 0;
5506 if ( conshdlrdata->maxaddlincons > 0 )
5512 conshdlrdata->naddlincons = 0;
5513 conshdlrdata->maxaddlincons = 0;
5542 conshdlrdata->boundhaschanged =
TRUE;
5546 if ( conshdlrdata->sepaalternativelp )
5553 for (
c = 0;
c < nconss; ++
c)
5569 ++conshdlrdata->nslackvars;
5572 if ( conshdlrdata->genlogicor )
5575 int logicorsepafreq;
5580 if ( logicorconshdlr ==
NULL )
5582 SCIPerrorMessage(
"Logicor constraint handler not included, cannot generate constraints.\n");
5587 if ( (sepafreq != -1 || conshdlrdata->enforcecuts) && logicorsepafreq != 1 )
5589 SCIPwarningMessage(
scip,
"For better performance set parameter 'constraints/logicor/sepafreq' to 1 if 'constraints/included/genlogicor' is true.\n");
5595 conshdlrdata->objothervarsonly =
TRUE;
5596 for (
c = 0;
c < nconss; ++
c)
5612 conshdlrdata->objothervarsonly =
FALSE;
5615 if ( ! consdata->linconsactive )
5622 if ( conshdlrdata->sepaalternativelp && consdata->colindex < 0 )
5649 SCIP_CALL(
SCIPcreateNlRow(
scip, &nlrow,
SCIPconsGetName(conss[
c]), 0.0, 0,
NULL,
NULL, quadexpr, 0.0, 0.0,
SCIP_EXPRCURV_UNKNOWN) );
5664 if ( conshdlrdata->sepaalternativelp )
5671 if ( conshdlrdata->naddlincons > 0 )
5673 for (
c = 0;
c < conshdlrdata->naddlincons; ++
c)
5675 cons = conshdlrdata->addlincons[
c];
5694 SCIPdebugMsg(
scip,
"Added %d additional columns to alternative LP.\n", cnt);
5701 if ( conshdlrdata->useotherconss )
5703 const char* conshdlrname;
5711 for (
c = 0;
c < nallconss; ++
c)
5733 SCIPdebugMsg(
scip,
"Added %d additional columns from linear constraints to alternative LP.\n", cnt);
5739 if ( conshdlrdata->forcerestart )
5746 assert( conshdlrdata->eventhdlrrestart !=
NULL );
5752 conshdlrdata->nbinvarszero = 0;
5758 conshdlrdata->objindicatoronly =
FALSE;
5763 for (j = 0; j <
nvars; ++j)
5767 for (
c = 0;
c < nconss; ++
c)
5792 if ( probindex < 0 )
5796 covered[probindex] =
TRUE;
5800 for (j = 0; j <
nvars; ++j)
5811 if (
REALABS(
obj) < conshdlrdata->minabsobj )
5825 conshdlrdata->objindicatoronly =
TRUE;
5827 assert( conshdlrdata->eventhdlrrestart !=
NULL );
5853 if ( conshdlrdata->sepaalternativelp )
5855 if ( conshdlrdata->slackhash !=
NULL )
5864 if ( conshdlrdata->altlp !=
NULL )
5886 for (
c = 0;
c < nconss; ++
c)
5895 consdata->colindex = -1;
5921#ifdef SCIP_MORE_DEBUG
5936 if ( conshdlrdata->binslackvarhash !=
NULL )
5949 if ( conshdlrdata->sepaalternativelp )
5960 if ( (*consdata)->linconsactive )
5962 assert( conshdlrdata->eventhdlrbound !=
NULL );
5968 if ( conshdlrdata->forcerestart )
5970 assert( conshdlrdata->eventhdlrrestart !=
NULL );
5976 if ( conshdlrdata->linconsevents && (*consdata)->linconsactive && (*consdata)->varswithevents !=
NULL )
5983 for (j = 0; j < (*consdata)->nevents; ++j)
5991 (*consdata)->nevents = 0;
5992 assert( (*consdata)->varswithevents ==
NULL );
6036 assert( conshdlrdata->eventhdlrbound !=
NULL );
6038#ifdef SCIP_MORE_DEBUG
6048 if ( sourcedata->slackvar ==
NULL )
6055 if ( sourcedata->lincons ==
NULL )
6067 sourcedata->binvar,
TRUE, sourcedata->lessthanineq, sourcedata->slackvar, sourcedata->lincons, sourcedata->linconsactive) );
6068 consdata->activeone = sourcedata->activeone;
6085 if ( sourcedata->linconsactive )
6093 if ( conshdlrdata->sepaalternativelp )
6095 if ( conshdlrdata->binvarhash ==
NULL )
6129 for (
c = 0;
c < nconss; ++
c)
6154 consdata->lincons = translincons;
6162 conshdlrdata->addedcouplingcons =
FALSE;
6184 SCIPdebug(
int oldnfixedvars = *nfixedvars; )
6185 SCIPdebug(
int oldndelconss = *ndelconss; )
6202 if ( nrounds == 0 || nnewfixedvars > 0 || nnewchgbds > 0 || nnewaggrvars > 0 )
6207 for (
c = 0;
c < nconss; ++
c)
6222#ifdef SCIP_MORE_DEBUG
6227 if ( ! consdata->linconsactive )
6236 if ( ! consdata->implicationadded )
6245 consdata->implicationadded =
TRUE;
6254 if ( ! consdata->slacktypechecked )
6256 consdata->slacktypechecked =
TRUE;
6271 slackvar = consdata->slackvar;
6274 for (j = 0; j <
nvars; ++j)
6276 if (
vars[j] == slackvar )
6277 foundslackvar =
TRUE;
6285 if ( j ==
nvars && foundslackvar )
6303 SCIPdebugMsg(
scip,
"Cannot change type of slack variable (<%s>) to IMPLINT, since global bound is non-integral: (%g, %g).\n",
6325 noReductions = nnewfixedvars == 0 && nnewaggrvars == 0 && nnewchgvartypes == 0 && nnewchgbds == 0
6326 && nnewdelconss == 0 && nnewchgcoefs == 0 && nnewchgsides == 0;
6329 if ( noReductions && *
result !=
SCIP_SUCCESS && conshdlrdata->addcouplingcons && ! conshdlrdata->addedcouplingcons )
6339 *nupgdconss += ngen;
6340 if ( conshdlrdata->removeindicators )
6343 conshdlrdata->addedcouplingcons =
TRUE;
6346 SCIPdebug(
SCIPdebugMsg(
scip,
"Presolved %d constraints (fixed %d variables, removed 0 variables, and deleted %d constraints).\n",
6347 nconss, *nfixedvars - oldnfixedvars, *ndelconss - oldndelconss); )
6372 *infeasible =
FALSE;
6375 if ( ! conshdlrdata->addcoupling )
6379 if ( conshdlrdata->addcouplingcons && conshdlrdata->addedcouplingcons )
6382 SCIPdebugMsg(
scip,
"Handle initial rows for %d indicator constraints.\n", nconss);
6385 for (
c = 0;
c < nconss && !(*infeasible); ++
c)
6396 if ( ! consdata->linconsactive )
6404 if ( ub <= conshdlrdata->maxcouplingvalue )
6415 if ( conshdlrdata->addcouplingcons )
6419 assert( ! conshdlrdata->addedcouplingcons );
6500 if ( solinfeasible )
6528 if ( solinfeasible )
6554 if ( solinfeasible )
6560 if ( objinfeasible )
6603 someLinconsNotActive =
FALSE;
6604 for (
c = 0;
c < nconss; ++
c)
6614 if ( ! consdata->linconsactive )
6616 someLinconsNotActive =
TRUE;
6646 if ( trysol !=
NULL )
6650 changedSol = changedSol || changed;
6662 if ( trysol !=
NULL )
6666 changedSol = changedSol || changed;
6672 if ( someLinconsNotActive )
6679 lp = conshdlrdata->altlp;
6680 assert( conshdlrdata->sepaalternativelp );
6690 if ( conshdlrdata->updatebounds )
6704 for (
c = 0;
c < nconss; ++
c)
6749 if ( trysol !=
NULL && changedSol )
6756 if ( trysol !=
NULL )
6805 if ( !conshdlrdata->linconsevents )
6807 for (
c = 0;
c < nconss; ++
c)
6820 if ( ! consdata->linconsactive )
6842 for (j = 0; j <
nvars; ++j)
6844 if (
vars[j] == consdata->slackvar )
6848 if ( vals[j] > 0.0 )
6851 consdata->varswithevents[consdata->nevents] =
vars[j];
6853 consdata->nevents++;
6858 consdata->varswithevents[consdata->nevents] =
vars[j];
6860 consdata->nevents++;
6865 conshdlrdata->linconsevents =
TRUE;
6869 conshdlrdata->boundhaschanged =
FALSE;
6870 conshdlrdata->linconsboundschanged =
FALSE;
6875 for (
c = 0;
c < nconss; ++
c)
6889#ifdef SCIP_MORE_DEBUG
6934 assert( inferinfo == 0 || inferinfo == 1 || inferinfo == 2 || inferinfo == 3 );
6935 assert( consdata->linconsactive );
6938 if ( inferinfo == 0 )
6941 assert( infervar != consdata->binvar );
6945 else if ( inferinfo == 1 )
6948 assert( infervar != consdata->slackvar );
6954 else if ( inferinfo == 2 )
6967 assert( inferinfo == 3 );
6974 for (j = 0; j < nlinconsvars; ++j)
6976 if ( linconsvals[j] > 0.0 )
7014#ifdef SCIP_MORE_DEBUG
7020 if ( consdata->linconsactive )
7044 for (j = 0; j < nlinvars; ++j)
7093 binvar = consdata->binvar;
7121 const char* consname;
7135#ifdef SCIP_MORE_DEBUG
7150 sourcelincons = sourceconsdata->lincons;
7179 sourceconsdata->lincons = translincons;
7180 sourcelincons = translincons;
7194 sourcebinvar = sourceconsdata->binvar;
7205 sourceslackvar = sourceconsdata->slackvar;
7221 initial, separate, enforce, check,
propagate, local, dynamic, removable, stickingatnode) );
7229 if ( targetlincons !=
NULL )
7242 char binvarname[1024];
7243 char slackvarname[1024];
7244 char linconsname[1024];
7255 nargs = sscanf(str,
" <%1023[^>]> = %d -> <%1023[^>]> = 0 (<%1023[^>]>)", binvarname, &zeroone, slackvarname, linconsname);
7258 if ( nargs != 3 && nargs != 4 )
7265 if ( zeroone != 0 && zeroone != 1 )
7274 if ( binvar ==
NULL )
7286 if ( slackvar ==
NULL )
7297 if ( lincons ==
NULL )
7318 posstr = strstr(slackvarname,
"indslack");
7319 if ( posstr ==
NULL )
7327 (void)
SCIPsnprintf(binvarname, 1023,
"indlin%s", posstr+8);
7330 if ( lincons ==
NULL )
7336 if ( lincons ==
NULL )
7339 (void)
SCIPsnprintf(binvarname, 1023,
"%s", posstr+16);
7342 if( lincons ==
NULL )
7345 name, posstr+8, posstr+9, posstr+16);
7364 initial, separate, enforce, check,
propagate, local, dynamic, removable, stickingatnode) );
7382#ifdef SCIP_MORE_DEBUG
7392 if ( conshdlrdata->altlp !=
NULL )
7394 assert( conshdlrdata->sepaalternativelp );
7396 if ( consdata->colindex >= 0 )
7417#ifdef SCIP_MORE_DEBUG
7424 if ( conshdlrdata->altlp !=
NULL )
7430 assert( conshdlrdata->sepaalternativelp );
7432 if ( consdata->colindex >= 0 )
7468 if ( consdata->binvar !=
NULL )
7473 if ( consdata->slackvar !=
NULL )
7512 if ( consdata->binvar !=
NULL )
7514 if ( consdata->slackvar !=
NULL )
7552 *infeasible =
FALSE;
7558 for (
c = 0;
c < nindconss; ++
c)
7579 if ( score > bestscore )
7636 conshdlrdata->eventhdlrbound =
NULL;
7638 eventExecIndicatorBound,
NULL) );
7639 assert(conshdlrdata->eventhdlrbound !=
NULL);
7642 conshdlrdata->eventhdlrlinconsbound =
NULL;
7644 eventExecIndicatorLinconsBound,
NULL) );
7645 assert(conshdlrdata->eventhdlrlinconsbound !=
NULL);
7648 conshdlrdata->eventhdlrrestart =
NULL;
7650 eventExecIndicatorRestart,
NULL) );
7651 assert( conshdlrdata->eventhdlrrestart !=
NULL );
7653 conshdlrdata->heurtrysol =
NULL;
7657 conshdlrdata->binvarhash =
NULL;
7658 conshdlrdata->binslackvarhash =
NULL;
7666 conshdlrdata->addlincons =
NULL;
7667 conshdlrdata->naddlincons = 0;
7668 conshdlrdata->maxaddlincons = 0;
7673 consEnfolpIndicator, consEnfopsIndicator, consCheckIndicator, consLockIndicator,
7715 conflicthdlrdata->conshdlrdata = conshdlrdata;
7716 conflicthdlrdata->conshdlr = conshdlr;
7717 assert( conflicthdlrdata->conshdlr !=
NULL );
7721 conflictExecIndicator, conflicthdlrdata) );
7727 "constraints/indicator/branchindicators",
7728 "Branch on indicator constraints in enforcing?",
7732 "constraints/indicator/genlogicor",
7733 "Generate logicor constraints instead of cuts?",
7737 "constraints/indicator/addcoupling",
7738 "Add coupling constraints or rows if big-M is small enough?",
7742 "constraints/indicator/maxcouplingvalue",
7743 "maximum coefficient for binary variable in coupling constraint",
7747 "constraints/indicator/addcouplingcons",
7748 "Add initial variable upper bound constraints, if 'addcoupling' is true?",
7752 "constraints/indicator/sepacouplingcuts",
7753 "Should the coupling inequalities be separated dynamically?",
7757 "constraints/indicator/sepacouplinglocal",
7758 "Allow to use local bounds in order to separate coupling inequalities?",
7762 "constraints/indicator/sepacouplingvalue",
7763 "maximum coefficient for binary variable in separated coupling constraint",
7767 "constraints/indicator/sepaperspective",
7768 "Separate cuts based on perspective formulation?",
7772 "constraints/indicator/sepapersplocal",
7773 "Allow to use local bounds in order to separate perspective cuts?",
7777 "constraints/indicator/maxsepanonviolated",
7778 "maximal number of separated non violated IISs, before separation is stopped",
7782 "constraints/indicator/updatebounds",
7783 "Update bounds of original variables for separation?",
7787 "constraints/indicator/maxconditionaltlp",
7788 "maximum estimated condition of the solution basis matrix of the alternative LP to be trustworthy (0.0 to disable check)",
7792 "constraints/indicator/maxsepacuts",
7793 "maximal number of cuts separated per separation round",
7797 "constraints/indicator/maxsepacutsroot",
7798 "maximal number of cuts separated per separation round in the root node",
7802 "constraints/indicator/removeindicators",
7803 "Remove indicator constraint if corresponding variable bound constraint has been added?",
7807 "constraints/indicator/generatebilinear",
7808 "Do not generate indicator constraint, but a bilinear constraint instead?",
7812 "constraints/indicator/scaleslackvar",
7813 "Scale slack variable coefficient at construction time?",
7817 "constraints/indicator/trysolutions",
7818 "Try to make solutions feasible by setting indicator variables?",
7822 "constraints/indicator/enforcecuts",
7823 "In enforcing try to generate cuts (only if sepaalternativelp is true)?",
7827 "constraints/indicator/dualreductions",
7828 "Should dual reduction steps be performed?",
7832 "constraints/indicator/addopposite",
7833 "Add opposite inequality in nodes in which the binary variable has been fixed to 0?",
7837 "constraints/indicator/conflictsupgrade",
7838 "Try to upgrade bounddisjunction conflicts by replacing slack variables?",
7842 "constraints/indicator/restartfrac",
7843 "fraction of binary variables that need to be fixed before restart occurs (in forcerestart)",
7847 "constraints/indicator/useotherconss",
7848 "Collect other constraints to alternative LP?",
7852 "constraints/indicator/useobjectivecut",
7853 "Use objective cut with current best solution to alternative LP?",
7857 "constraints/indicator/trysolfromcover",
7858 "Try to construct a feasible solution from a cover?",
7862 "constraints/indicator/upgradelinear",
7863 "Try to upgrade linear constraints to indicator constraints?",
7867 "constraints/indicator/usesameslackvar",
7868 "Use same slack variable for indicator constraints with common binary variable?",
7873 "constraints/indicator/sepaalternativelp",
7874 "Separate using the alternative LP?",
7878 "constraints/indicator/forcerestart",
7879 "Force restart if absolute gap is 1 or enough binary variables have been fixed?",
7883 "constraints/indicator/nolinconscont",
7884 "Decompose problem (do not generate linear constraint if all variables are continuous)?",
7927 return SCIPcreateConsIndicatorGeneric(
scip, cons, name, binvar,
nvars,
vars, vals, rhs,
TRUE,
TRUE, initial,
7928 separate, enforce, check,
propagate, local, dynamic, removable, stickingatnode);
7986 SCIPerrorMessage(
"Indicator constraint <%s> needs nonnegative number of variables in linear constraint.\n", name);
7992 if ( conshdlr ==
NULL )
8001 if ( conshdlrdata->nolinconscont && ! conshdlrdata->sepaalternativelp )
8003 SCIPerrorMessage(
"constraint handler <%s>: need parameter <sepaalternativelp> to be true if parameter <nolinconscont> is true.\n",
CONSHDLR_NAME);
8007 if ( conshdlrdata->nolinconscont && conshdlrdata->generatebilinear )
8020 for (j = 0; j <
nvars; ++j)
8021 valscopy[j] = -vals[j];
8028 for (j = 0; j <
nvars; ++j)
8030 if ( conshdlrdata->scaleslackvar )
8031 absvalsum +=
REALABS(valscopy[j]);
8035 if ( ! conshdlrdata->scaleslackvar )
8041 if ( activeone || binvar ==
NULL )
8042 binvarinternal = binvar;
8051 if ( binvarinternal !=
NULL )
8054 if ( conshdlrdata->usesameslackvar && conshdlrdata->binslackvarhash ==
NULL )
8059 if ( conshdlrdata->binslackvarhash !=
NULL &&
SCIPhashmapExists(conshdlrdata->binslackvarhash, (
void*) binvarinternal) )
8086 if ( conshdlrdata->binslackvarhash !=
NULL )
8107 if ( conshdlrdata->nolinconscont )
8111 assert( ! conshdlrdata->generatebilinear );
8114 for (j = 0; j <
nvars; ++j)
8127 linconsactive =
FALSE;
8134 if ( linconsactive )
8147 if ( ! lessthanineq )
8155 if ( conshdlrdata->scaleslackvar &&
nvars > 0 )
8171 if ( conshdlrdata->generatebilinear )
8176 SCIP_CALL(
SCIPcreateConsQuadraticNonlinear(
scip, cons, name, 0,
NULL,
NULL, 1, &binvarinternal, &slackvar, &val, 0.0, 0.0,
8183 binvar, activeone, lessthanineq, slackvar, lincons, linconsactive) );
8188 SCIP_CALL(
SCIPcreateCons(
scip, cons, name, conshdlr, consdata, initial, separate, enforce, check,
propagate,
8189 local, modifiable, dynamic, removable, stickingatnode) );
8194 if ( linconsactive )
8201 if ( conshdlrdata->sepaalternativelp )
8203 if ( conshdlrdata->binvarhash ==
NULL )
8312 if ( conshdlr ==
NULL )
8321 if ( conshdlrdata->nolinconscont && ! conshdlrdata->sepaalternativelp )
8323 SCIPerrorMessage(
"constraint handler <%s>: need parameter <sepaalternativelp> to be true if parameter <nolinconscont> is true.\n",
CONSHDLR_NAME);
8331 if ( conshdlrdata->nolinconscont )
8342 for (v = 0; v <
nvars; ++v)
8355 linconsactive =
FALSE;
8363 if ( conshdlrdata->generatebilinear )
8370 binvarinternal = binvar;
8378 SCIP_CALL(
SCIPcreateConsQuadraticNonlinear(
scip, cons, name, 0,
NULL,
NULL, 1, &binvarinternal, &slackvar, &val, 0.0, 0.0,
8385 binvar, activeone,
TRUE, slackvar, lincons, linconsactive) );
8389 SCIP_CALL(
SCIPcreateCons(
scip, cons, name, conshdlr, consdata, initial, separate, enforce, check,
propagate,
8390 local, modifiable, dynamic, removable, stickingatnode) );
8446 enforce, check,
propagate, local, dynamic, removable, stickingatnode);
8556 if ( conshdlr ==
NULL )
8565 if ( conshdlrdata->nolinconscont && ! conshdlrdata->sepaalternativelp )
8567 SCIPerrorMessage(
"constraint handler <%s>: need parameter <sepaalternativelp> to be true if parameter <nolinconscont> is true.\n",
CONSHDLR_NAME);
8584 for (j = 0; j <
nvars; ++j)
8604 binvarinternal = binvar;
8613 if ( conshdlrdata->usesameslackvar && conshdlrdata->binslackvarhash ==
NULL )
8618 if ( conshdlrdata->binslackvarhash !=
NULL &&
SCIPhashmapExists(conshdlrdata->binslackvarhash, (
void*) binvarinternal) )
8645 if ( conshdlrdata->binslackvarhash !=
NULL )
8653 if ( conshdlrdata->nolinconscont )
8661 for (j = 0; j <
nvars; ++j)
8674 linconsactive =
FALSE;
8690 if ( conshdlrdata->generatebilinear )
8695 SCIP_CALL(
SCIPcreateConsQuadraticNonlinear(
scip, cons, name, 0,
NULL,
NULL, 1, &binvarinternal, &slackvar, &val, 0.0, 0.0,
8702 binvar, activeone,
TRUE, slackvar, lincons, linconsactive) );
8706 SCIP_CALL(
SCIPcreateCons(
scip, cons, name, conshdlr, consdata, initial, separate, enforce, check,
propagate,
8707 local, modifiable, dynamic, removable, stickingatnode) );
8761 enforce, check,
propagate, local, dynamic, removable, stickingatnode);
8782 if ( !consdata->lessthanineq )
8813 return consdata->lincons;
8850 consdata->lincons = lincons;
8851 consdata->linconsactive =
TRUE;
8855 if ( conshdlrdata->nolinconscont )
8868 for (v = 0; v <
nvars; ++v)
8881 consdata->linconsactive =
FALSE;
8900 return consdata->activeone;
8917 return consdata->binvar;
8933 binvar = consdata->binvar;
8935 if ( ! consdata->activeone )
8966 if ( consdata->binvar !=
NULL )
8984 if ( ! consdata->activeone )
8987 consdata->binvar =
var;
8994 assert( conshdlrdata->eventhdlrbound !=
NULL );
8995 assert( conshdlrdata->eventhdlrrestart !=
NULL );
8998 if ( consdata->linconsactive )
9004 if ( conshdlrdata->forcerestart )
9011 ++(consdata->nfixednonzero);
9015 if ( ! consdata->activeone )
9017 consdata->binvar = binvar;
9036 return consdata->slackvar;
9092 if ( consdata->linconsactive )
9166 if ( ! consdata->linconsactive )
9169 lincons = consdata->lincons;
9175 slackvar = consdata->slackvar;
9176 binvar = consdata->binvar;
9187 for (v = 0; v < nlinvars; ++v)
9191 if (
var != slackvar )
9194 slackcoef = linvals[v];
9202 assert( slackcoef != 0.0 );
9215 val = (val - sum)/slackcoef;
9218 if ( slackcoef < 0 )
9330 for (
c = 0;
c < nconss; ++
c)
9340 if ( ! consdata->linconsactive )
9344 *changed = *changed || chg;
9371 assert( conshdlrdata->naddlincons+1 <= conshdlrdata->maxaddlincons );
9373 conshdlrdata->addlincons[conshdlrdata->naddlincons++] = lincons;
9404 if ( ! conshdlrdata->sepaalternativelp )
#define CONSHDLR_NEEDSCONS
#define CONSHDLR_SEPAFREQ
#define CONSHDLR_CHECKPRIORITY
#define CONSHDLR_PROP_TIMING
#define CONSHDLR_MAXPREROUNDS
#define CONSHDLR_SEPAPRIORITY
#define CONSHDLR_PROPFREQ
#define DEFAULT_ENFORCECUTS
#define CONSHDLR_PRESOLTIMING
#define CONSHDLR_EAGERFREQ
#define CONSHDLR_ENFOPRIORITY
#define CONSHDLR_DELAYSEPA
#define CONSHDLR_DELAYPROP
#define CONFLICTHDLR_PRIORITY
#define CONFLICTHDLR_NAME
#define CONFLICTHDLR_DESC
static SCIP_RETCODE branchCons(SCIP *scip, SCIP_CONS *cons, SCIP_RESULT *result)
#define DEFAULT_FORCERESTART
#define DEFAULT_TRYSOLUTIONS
#define EVENTHDLR_RESTART_NAME
static SCIP_RETCODE addAltLPRow(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_ROW *row, SCIP_Real objcoef, int *colindex)
#define SCIP_CALL_PARAM(x)
#define DEFAULT_ADDCOUPLINGCONS
#define MAXROUNDINGROUNDS
#define DEFAULT_ADDOPPOSITE
static SCIP_RETCODE checkLPBoundsClean(SCIP *scip, SCIP_LPI *lp, int nconss, SCIP_CONS **conss)
static SCIP_RETCODE propIndicator(SCIP *scip, SCIP_CONS *cons, SCIP_CONSDATA *consdata, SCIP_CONSHDLRDATA *conshdlrdata, SCIP_Bool dualreductions, SCIP_Bool addopposite, SCIP_Bool *cutoff, int *nGen)
static SCIP_RETCODE updateFirstRowGlobal(SCIP *scip, SCIP_CONSHDLRDATA *conshdlrdata)
static SCIP_RETCODE fixAltLPVariables(SCIP *scip, SCIP_LPI *lp, int nconss, SCIP_CONS **conss, SCIP_Bool *S)
static SCIP_RETCODE createVarUbs(SCIP *scip, SCIP_CONSHDLRDATA *conshdlrdata, SCIP_CONS **conss, int nconss, int *ngen)
#define DEFAULT_USEOBJECTIVECUT
static SCIP_RETCODE addAltLPConstraint(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_CONS *lincons, SCIP_VAR *slackvar, SCIP_Real objcoef, int *colindex)
static SCIP_RETCODE extendToCover(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_CONSHDLRDATA *conshdlrdata, SCIP_LPI *lp, SCIP_SOL *sol, SCIP_ENFOSEPATYPE enfosepatype, SCIP_Bool removable, SCIP_Bool genlogicor, int nconss, SCIP_CONS **conss, SCIP_Bool *S, int *size, SCIP_Real *value, SCIP_Bool *error, SCIP_Bool *cutoff, int *nGen)
static SCIP_RETCODE scaleFirstRow(SCIP *scip, SCIP_CONSHDLRDATA *conshdlrdata)
static SCIP_RETCODE separateIISRounding(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_SOL *sol, SCIP_ENFOSEPATYPE enfosepatype, int nconss, SCIP_CONS **conss, int maxsepacuts, SCIP_Bool *cutoff, int *nGen)
static SCIP_Real varGetObjDelta(SCIP_VAR *var)
static SCIP_RETCODE addAltLPColumn(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_CONSHDLRDATA *conshdlrdata, SCIP_VAR *slackvar, int nvars, SCIP_VAR **vars, SCIP_Real *vals, SCIP_Real rhscoef, SCIP_Real objcoef, SCIP_Real sign, SCIP_Bool colfree, int *colindex)
#define DEFAULT_MAXCONDITIONALTLP
static SCIP_RETCODE presolRoundIndicator(SCIP *scip, SCIP_CONSHDLRDATA *conshdlrdata, SCIP_CONS *cons, SCIP_CONSDATA *consdata, SCIP_Bool dualreductions, SCIP_Bool *cutoff, SCIP_Bool *success, int *ndelconss, int *nfixedvars)
#define DEFAULT_SCALESLACKVAR
static SCIP_RETCODE checkAltLPInfeasible(SCIP *scip, SCIP_LPI *lp, SCIP_Real maxcondition, SCIP_Bool primal, SCIP_Bool *infeasible, SCIP_Bool *error)
static SCIP_RETCODE setAltLPObj(SCIP *scip, SCIP_LPI *lp, SCIP_SOL *sol, int nconss, SCIP_CONS **conss)
static SCIP_RETCODE checkIISlocal(SCIP *scip, SCIP_CONSHDLRDATA *conshdlrdata, SCIP_Real *vector, SCIP_Bool *isLocal)
#define DEFAULT_USESAMESLACKVAR
#define DEFAULT_SEPAPERSPLOCAL
static SCIP_RETCODE unfixAltLPVariables(SCIP *scip, SCIP_LPI *lp, int nconss, SCIP_CONS **conss, SCIP_Bool *S)
static SCIP_RETCODE separatePerspective(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_SOL *sol, int nconss, SCIP_CONS **conss, int maxsepacuts, int *nGen)
#define DEFAULT_SEPAPERSPECTIVE
static SCIP_RETCODE enforceCuts(SCIP *scip, SCIP_CONSHDLR *conshdlr, int nconss, SCIP_CONS **conss, SCIP_SOL *sol, SCIP_ENFOSEPATYPE enfosepatype, SCIP_Bool genlogicor, SCIP_Bool *cutoff, int *nGen)
#define DEFAULT_CONFLICTSUPGRADE
static SCIP_RETCODE initAlternativeLP(SCIP *scip, SCIP_CONSHDLR *conshdlr)
#define DEFAULT_MAXCOUPLINGVALUE
#define DEFAULT_SEPACOUPLINGVALUE
static SCIP_RETCODE addSymmetryInformation(SCIP *scip, SYM_SYMTYPE symtype, SCIP_CONS *cons, SYM_GRAPH *graph, SCIP_Bool *success)
#define DEFAULT_REMOVEINDICATORS
#define DEFAULT_UPGRADELINEAR
#define EVENTHDLR_LINCONSBOUND_DESC
#define DEFAULT_MAXSEPACUTSROOT
static SCIP_RETCODE updateObjUpperbound(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_CONSHDLRDATA *conshdlrdata)
static SCIP_RETCODE checkTransferBoolParam(SCIP *scip, SCIP_PARAM *param, const char *name, SCIP_Bool newvalue, SCIP_Bool *value)
#define EVENTHDLR_BOUND_DESC
static SCIP_RETCODE separateIndicators(SCIP *scip, SCIP_CONSHDLR *conshdlr, int nconss, int nusefulconss, SCIP_CONS **conss, SCIP_SOL *sol, SCIP_ENFOSEPATYPE enfosepatype, SCIP_RESULT *result)
static SCIP_RETCODE fixAltLPVariable(SCIP_LPI *lp, int ind)
enum SCIP_enfosepatype SCIP_ENFOSEPATYPE
#define DEFAULT_SEPACOUPLINGLOCAL
#define EVENTHDLR_LINCONSBOUND_NAME
#define DEFAULT_UPDATEBOUNDS
#define DEFAULT_RESTARTFRAC
static SCIP_RETCODE enforceIndicators(SCIP *scip, SCIP_CONSHDLR *conshdlr, int nconss, SCIP_CONS **conss, SCIP_SOL *sol, SCIP_ENFOSEPATYPE enfosepatype, SCIP_Bool genlogicor, SCIP_RESULT *result)
#define DEFAULT_SEPAALTERNATIVELP
static void initConshdlrData(SCIP *scip, SCIP_CONSHDLRDATA *conshdlrdata)
static SCIP_RETCODE unfixAltLPVariable(SCIP_LPI *lp, int ind)
static SCIP_RETCODE consdataEnsureAddLinConsSize(SCIP *scip, SCIP_CONSHDLR *conshdlr, int num)
#define DEFAULT_MAXSEPACUTS
static SCIP_RETCODE setAltLPObjZero(SCIP *scip, SCIP_LPI *lp, int nconss, SCIP_CONS **conss)
#define EVENTHDLR_BOUND_NAME
#define DEFAULT_BRANCHINDICATORS
static SCIP_RETCODE consdataCreate(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_CONSHDLRDATA *conshdlrdata, const char *consname, SCIP_CONSDATA **consdata, SCIP_EVENTHDLR *eventhdlrrestart, SCIP_VAR *binvar, SCIP_Bool activeone, SCIP_Bool lessthanineq, SCIP_VAR *slackvar, SCIP_CONS *lincons, SCIP_Bool linconsactive)
#define DEFAULT_USEOTHERCONSS
#define DEFAULT_DUALREDUCTIONS
static SCIP_RETCODE deleteAltLPConstraint(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_CONS *cons)
#define LINCONSUPGD_PRIORITY
#define DEFAULT_GENERATEBILINEAR
static SCIP_RETCODE addObjcut(SCIP *scip, SCIP_CONSHDLR *conshdlr)
#define DEFAULT_GENLOGICOR
#define DEFAULT_TRYSOLFROMCOVER
#define EVENTHDLR_RESTART_DESC
#define DEFAULT_MAXSEPANONVIOLATED
#define DEFAULT_ADDCOUPLING
#define DEFAULT_SEPACOUPLINGCUTS
static SCIP_RETCODE updateFirstRow(SCIP *scip, SCIP_CONSHDLRDATA *conshdlrdata)
#define DEFAULT_NOLINCONSCONT
constraint handler for indicator constraints
Constraint handler for linear constraints in their most general form, .
Constraint handler for logicor constraints (equivalent to set covering, but algorithms are suited fo...
constraint handler for nonlinear constraints specified by algebraic expressions
Constraint handler for variable bound constraints .
#define SCIP_LONGINT_FORMAT
product expression handler
variable expression handler
SCIP_RETCODE SCIPcreateConsIndicatorGenericLinConsPure(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_VAR *binvar, SCIP_CONS *lincons, SCIP_Bool activeone, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
SCIP_RETCODE SCIPcreateConsIndicatorLinCons(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_VAR *binvar, SCIP_CONS *lincons, SCIP_VAR *slackvar, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
SCIP_RETCODE SCIPincludeLinconsUpgrade(SCIP *scip, SCIP_DECL_LINCONSUPGD((*linconsupgd)), int priority, const char *conshdlrname)
SCIP_RETCODE SCIPcreateConsBasicIndicator(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_VAR *binvar, int nvars, SCIP_VAR **vars, SCIP_Real *vals, SCIP_Real rhs)
SCIP_VAR * SCIPgetBinaryVarIndicatorGeneric(SCIP_CONS *cons)
SCIP_RETCODE SCIPsetSlackVarUb(SCIP *scip, SCIP_CONS *cons, SCIP_Real ub)
SCIP_Real SCIPgetRhsLinear(SCIP *scip, SCIP_CONS *cons)
SCIP_VAR ** SCIPgetVarsLinear(SCIP *scip, SCIP_CONS *cons)
SCIP_RETCODE SCIPaddCoefLinear(SCIP *scip, SCIP_CONS *cons, SCIP_VAR *var, SCIP_Real val)
SCIP_RETCODE SCIPaddRowIndicator(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_ROW *row)
SCIP_Real SCIPgetLhsLinear(SCIP *scip, SCIP_CONS *cons)
SCIP_RETCODE SCIPcreateConsIndicatorGeneric(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_VAR *binvar, int nvars, SCIP_VAR **vars, SCIP_Real *vals, SCIP_Real rhs, SCIP_Bool activeone, SCIP_Bool lessthanineq, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
int SCIPgetNVarsLinear(SCIP *scip, SCIP_CONS *cons)
SCIP_RETCODE SCIPaddLinearConsIndicator(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_CONS *lincons)
SCIP_RETCODE SCIPsetLinearConsIndicator(SCIP *scip, SCIP_CONS *cons, SCIP_CONS *lincons)
SCIP_RETCODE SCIPcreateConsIndicator(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_VAR *binvar, int nvars, SCIP_VAR **vars, SCIP_Real *vals, SCIP_Real rhs, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
SCIP_Real * SCIPgetValsLinear(SCIP *scip, SCIP_CONS *cons)
SCIP_RETCODE SCIPcreateConsIndicatorGenericLinCons(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_VAR *binvar, SCIP_CONS *lincons, SCIP_VAR *slackvar, SCIP_Bool activeone, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
SCIP_RETCODE SCIPcreateConsBasicIndicatorLinCons(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_VAR *binvar, SCIP_CONS *lincons, SCIP_VAR *slackvar)
SCIP_RETCODE SCIPmakeIndicatorsFeasible(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_SOL *sol, SCIP_Bool *changed)
SCIP_VAR * SCIPgetBinaryVarIndicator(SCIP_CONS *cons)
#define SCIP_DECL_LINCONSUPGD(x)
SCIP_VAR * SCIPgetSlackVarIndicator(SCIP_CONS *cons)
SCIP_CONS * SCIPgetLinearConsIndicator(SCIP_CONS *cons)
SCIP_RETCODE SCIPcreateConsLinear(SCIP *scip, SCIP_CONS **cons, const char *name, int nvars, SCIP_VAR **vars, SCIP_Real *vals, SCIP_Real lhs, SCIP_Real rhs, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool modifiable, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
SCIP_RETCODE SCIPcreateConsLogicor(SCIP *scip, SCIP_CONS **cons, const char *name, int nvars, SCIP_VAR **vars, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool modifiable, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
SCIP_RETCODE SCIPsetBinaryVarIndicator(SCIP *scip, SCIP_CONS *cons, SCIP_VAR *binvar)
SCIP_RETCODE SCIPmakeIndicatorFeasible(SCIP *scip, SCIP_CONS *cons, SCIP_SOL *sol, SCIP_Bool *changed)
SCIP_RETCODE SCIPcreateConsVarbound(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_VAR *var, SCIP_VAR *vbdvar, SCIP_Real vbdcoef, SCIP_Real lhs, SCIP_Real rhs, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool modifiable, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
SCIP_RETCODE SCIPcreateConsQuadraticNonlinear(SCIP *scip, SCIP_CONS **cons, const char *name, int nlinvars, SCIP_VAR **linvars, SCIP_Real *lincoefs, int nquadterms, SCIP_VAR **quadvars1, SCIP_VAR **quadvars2, SCIP_Real *quadcoefs, SCIP_Real lhs, SCIP_Real rhs, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool modifiable, SCIP_Bool dynamic, SCIP_Bool removable)
SCIP_RETCODE SCIPcreateConsIndicatorLinConsPure(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_VAR *binvar, SCIP_CONS *lincons, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
SCIP_Bool SCIPisViolatedIndicator(SCIP *scip, SCIP_CONS *cons, SCIP_SOL *sol)
SCIP_RETCODE SCIPaddVarIndicator(SCIP *scip, SCIP_CONS *cons, SCIP_VAR *var, SCIP_Real val)
SCIP_Bool SCIPgetActiveOnIndicator(SCIP_CONS *cons)
SCIP_RETCODE SCIPincludeConshdlrIndicator(SCIP *scip)
SCIP_RETCODE SCIPgetConsCopy(SCIP *sourcescip, SCIP *targetscip, SCIP_CONS *sourcecons, SCIP_CONS **targetcons, SCIP_CONSHDLR *sourceconshdlr, SCIP_HASHMAP *varmap, SCIP_HASHMAP *consmap, const char *name, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool modifiable, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode, SCIP_Bool global, SCIP_Bool *valid)
SCIP_RETCODE SCIPgetVarCopy(SCIP *sourcescip, SCIP *targetscip, SCIP_VAR *sourcevar, SCIP_VAR **targetvar, SCIP_HASHMAP *varmap, SCIP_HASHMAP *consmap, SCIP_Bool global, SCIP_Bool *success)
SCIP_RETCODE SCIPcreateExprVar(SCIP *scip, SCIP_EXPR **expr, SCIP_VAR *var, SCIP_DECL_EXPR_OWNERCREATE((*ownercreate)), void *ownercreatedata)
SCIP_RETCODE SCIPcreateExprProduct(SCIP *scip, SCIP_EXPR **expr, int nchildren, SCIP_EXPR **children, SCIP_Real coefficient, SCIP_DECL_EXPR_OWNERCREATE((*ownercreate)), void *ownercreatedata)
SCIP_Bool SCIPisTransformed(SCIP *scip)
SCIP_STATUS SCIPgetStatus(SCIP *scip)
SCIP_STAGE SCIPgetStage(SCIP *scip)
SCIP_RETCODE SCIPaddVar(SCIP *scip, SCIP_VAR *var)
int SCIPgetNIntVars(SCIP *scip)
SCIP_RETCODE SCIPgetVarsData(SCIP *scip, SCIP_VAR ***vars, int *nvars, int *nbinvars, int *nintvars, int *nimplvars, int *ncontvars)
SCIP_CONS ** SCIPgetConss(SCIP *scip)
int SCIPgetNVars(SCIP *scip)
SCIP_RETCODE SCIPaddCons(SCIP *scip, SCIP_CONS *cons)
SCIP_RETCODE SCIPdelCons(SCIP *scip, SCIP_CONS *cons)
int SCIPgetNConss(SCIP *scip)
SCIP_VAR ** SCIPgetVars(SCIP *scip)
int SCIPgetNOrigVars(SCIP *scip)
int SCIPgetNBinVars(SCIP *scip)
SCIP_Bool SCIPisObjIntegral(SCIP *scip)
SCIP_VAR * SCIPfindVar(SCIP *scip, const char *name)
SCIP_CONS * SCIPfindCons(SCIP *scip, const char *name)
void SCIPhashmapFree(SCIP_HASHMAP **hashmap)
void SCIPhashmapPrintStatistics(SCIP_HASHMAP *hashmap, SCIP_MESSAGEHDLR *messagehdlr)
int SCIPhashmapGetImageInt(SCIP_HASHMAP *hashmap, void *origin)
void * SCIPhashmapGetImage(SCIP_HASHMAP *hashmap, void *origin)
SCIP_RETCODE SCIPhashmapInsert(SCIP_HASHMAP *hashmap, void *origin, void *image)
SCIP_RETCODE SCIPhashmapCreate(SCIP_HASHMAP **hashmap, BMS_BLKMEM *blkmem, int mapsize)
SCIP_Bool SCIPhashmapExists(SCIP_HASHMAP *hashmap, void *origin)
SCIP_RETCODE SCIPhashmapInsertInt(SCIP_HASHMAP *hashmap, void *origin, int image)
SCIP_RETCODE SCIPhashmapSetImageInt(SCIP_HASHMAP *hashmap, void *origin, int image)
SCIP_RETCODE SCIPlpiChgSides(SCIP_LPI *lpi, int nrows, const int *ind, const SCIP_Real *lhs, const SCIP_Real *rhs)
SCIP_Real SCIPlpiInfinity(SCIP_LPI *lpi)
SCIP_Bool SCIPlpiIsInfinity(SCIP_LPI *lpi, SCIP_Real val)
SCIP_Bool SCIPlpiExistsPrimalRay(SCIP_LPI *lpi)
SCIP_RETCODE SCIPlpiAddRows(SCIP_LPI *lpi, int nrows, const SCIP_Real *lhs, const SCIP_Real *rhs, char **rownames, int nnonz, const int *beg, const int *ind, const SCIP_Real *val)
SCIP_RETCODE SCIPlpiWriteLP(SCIP_LPI *lpi, const char *fname)
SCIP_RETCODE SCIPlpiGetBounds(SCIP_LPI *lpi, int firstcol, int lastcol, SCIP_Real *lbs, SCIP_Real *ubs)
int SCIPlpiGetInternalStatus(SCIP_LPI *lpi)
SCIP_RETCODE SCIPlpiChgBounds(SCIP_LPI *lpi, int ncols, const int *ind, const SCIP_Real *lb, const SCIP_Real *ub)
SCIP_Bool SCIPlpiIsPrimalUnbounded(SCIP_LPI *lpi)
SCIP_RETCODE SCIPlpiFree(SCIP_LPI **lpi)
SCIP_RETCODE SCIPlpiGetCoef(SCIP_LPI *lpi, int row, int col, SCIP_Real *val)
SCIP_RETCODE SCIPlpiGetRealSolQuality(SCIP_LPI *lpi, SCIP_LPSOLQUALITY qualityindicator, SCIP_Real *quality)
SCIP_RETCODE SCIPlpiSetIntpar(SCIP_LPI *lpi, SCIP_LPPARAM type, int ival)
SCIP_RETCODE SCIPlpiGetRows(SCIP_LPI *lpi, int firstrow, int lastrow, SCIP_Real *lhs, SCIP_Real *rhs, int *nnonz, int *beg, int *ind, SCIP_Real *val)
SCIP_Bool SCIPlpiIsOptimal(SCIP_LPI *lpi)
SCIP_RETCODE SCIPlpiGetSol(SCIP_LPI *lpi, SCIP_Real *objval, SCIP_Real *primsol, SCIP_Real *dualsol, SCIP_Real *activity, SCIP_Real *redcost)
SCIP_Bool SCIPlpiIsPrimalInfeasible(SCIP_LPI *lpi)
SCIP_RETCODE SCIPlpiSolveDual(SCIP_LPI *lpi)
SCIP_RETCODE SCIPlpiAddCols(SCIP_LPI *lpi, int ncols, const SCIP_Real *obj, const SCIP_Real *lb, const SCIP_Real *ub, char **colnames, int nnonz, const int *beg, const int *ind, const SCIP_Real *val)
SCIP_RETCODE SCIPlpiSolvePrimal(SCIP_LPI *lpi)
SCIP_RETCODE SCIPlpiCreate(SCIP_LPI **lpi, SCIP_MESSAGEHDLR *messagehdlr, const char *name, SCIP_OBJSEN objsen)
SCIP_RETCODE SCIPlpiChgObj(SCIP_LPI *lpi, int ncols, const int *ind, const SCIP_Real *obj)
SCIP_Bool SCIPlpiIsStable(SCIP_LPI *lpi)
SCIP_RETCODE SCIPlpiGetNCols(SCIP_LPI *lpi, int *ncols)
SCIP_RETCODE SCIPlpiGetNRows(SCIP_LPI *lpi, int *nrows)
SCIP_RETCODE SCIPlpiChgCoef(SCIP_LPI *lpi, int row, int col, SCIP_Real newval)
SCIP_RETCODE SCIPdelConsLocal(SCIP *scip, SCIP_CONS *cons)
SCIP_RETCODE SCIPaddConflict(SCIP *scip, SCIP_NODE *node, SCIP_CONS *cons, SCIP_NODE *validnode, SCIP_CONFTYPE conftype, SCIP_Bool iscutoffinvolved)
void SCIPinfoMessage(SCIP *scip, FILE *file, const char *formatstr,...)
void SCIPverbMessage(SCIP *scip, SCIP_VERBLEVEL msgverblevel, FILE *file, const char *formatstr,...)
SCIP_MESSAGEHDLR * SCIPgetMessagehdlr(SCIP *scip)
void SCIPwarningMessage(SCIP *scip, const char *formatstr,...)
SCIP_Real SCIPrelDiff(SCIP_Real val1, SCIP_Real val2)
SCIP_RETCODE SCIPheurPassSolTrySol(SCIP *scip, SCIP_HEUR *heur, SCIP_SOL *sol)
SCIP_RETCODE SCIPheurPassIndicator(SCIP *scip, SCIP_HEUR *heur, int nindconss, SCIP_CONS **indconss, SCIP_Bool *solcand, SCIP_Real obj)
SCIP_Bool SCIPisParamFixed(SCIP *scip, const char *name)
SCIP_RETCODE SCIPaddIntParam(SCIP *scip, const char *name, const char *desc, int *valueptr, SCIP_Bool isadvanced, int defaultvalue, int minvalue, int maxvalue, SCIP_DECL_PARAMCHGD((*paramchgd)), SCIP_PARAMDATA *paramdata)
SCIP_RETCODE SCIPaddRealParam(SCIP *scip, const char *name, const char *desc, SCIP_Real *valueptr, SCIP_Bool isadvanced, SCIP_Real defaultvalue, SCIP_Real minvalue, SCIP_Real maxvalue, SCIP_DECL_PARAMCHGD((*paramchgd)), SCIP_PARAMDATA *paramdata)
SCIP_RETCODE SCIPsetIntParam(SCIP *scip, const char *name, int value)
SCIP_RETCODE SCIPchgBoolParam(SCIP *scip, SCIP_PARAM *param, SCIP_Bool value)
SCIP_RETCODE SCIPaddBoolParam(SCIP *scip, const char *name, const char *desc, SCIP_Bool *valueptr, SCIP_Bool isadvanced, SCIP_Bool defaultvalue, SCIP_DECL_PARAMCHGD((*paramchgd)), SCIP_PARAMDATA *paramdata)
SCIP_RETCODE SCIPgetCharParam(SCIP *scip, const char *name, char *value)
SCIP_BRANCHRULE * SCIPfindBranchrule(SCIP *scip, const char *name)
SCIP_Real SCIPcalcChildEstimate(SCIP *scip, SCIP_VAR *var, SCIP_Real targetvalue)
SCIP_RETCODE SCIPcreateChild(SCIP *scip, SCIP_NODE **node, SCIP_Real nodeselprio, SCIP_Real estimate)
SCIP_VAR * SCIPcolGetVar(SCIP_COL *col)
SCIP_BOUNDTYPE SCIPboundtypeOpposite(SCIP_BOUNDTYPE boundtype)
SCIP_RETCODE SCIPaddConflictLb(SCIP *scip, SCIP_VAR *var, SCIP_BDCHGIDX *bdchgidx)
SCIP_RETCODE SCIPinitConflictAnalysis(SCIP *scip, SCIP_CONFTYPE conftype, SCIP_Bool iscutoffinvolved)
SCIP_CONFLICTHDLRDATA * SCIPconflicthdlrGetData(SCIP_CONFLICTHDLR *conflicthdlr)
SCIP_RETCODE SCIPaddConflictUb(SCIP *scip, SCIP_VAR *var, SCIP_BDCHGIDX *bdchgidx)
const char * SCIPconflicthdlrGetName(SCIP_CONFLICTHDLR *conflicthdlr)
SCIP_Bool SCIPisConflictAnalysisApplicable(SCIP *scip)
SCIP_RETCODE SCIPaddConflictBinvar(SCIP *scip, SCIP_VAR *var)
SCIP_RETCODE SCIPanalyzeConflictCons(SCIP *scip, SCIP_CONS *cons, SCIP_Bool *success)
SCIP_RETCODE SCIPsetConflicthdlrFree(SCIP *scip, SCIP_CONFLICTHDLR *conflicthdlr,)
SCIP_RETCODE SCIPincludeConflicthdlrBasic(SCIP *scip, SCIP_CONFLICTHDLR **conflicthdlrptr, const char *name, const char *desc, int priority, SCIP_DECL_CONFLICTEXEC((*conflictexec)), SCIP_CONFLICTHDLRDATA *conflicthdlrdata)
SCIP_RETCODE SCIPsetConshdlrFree(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrPresol(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_DECL_CONSPRESOL((*conspresol)), int maxprerounds, SCIP_PRESOLTIMING presoltiming)
SCIP_RETCODE SCIPsetConshdlrEnable(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrInitpre(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrSepa(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_DECL_CONSSEPALP((*conssepalp)), SCIP_DECL_CONSSEPASOL((*conssepasol)), int sepafreq, int sepapriority, SCIP_Bool delaysepa)
SCIP_RETCODE SCIPsetConshdlrProp(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_DECL_CONSPROP((*consprop)), int propfreq, SCIP_Bool delayprop, SCIP_PROPTIMING proptiming)
SCIP_RETCODE SCIPsetConshdlrEnforelax(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPincludeConshdlrBasic(SCIP *scip, SCIP_CONSHDLR **conshdlrptr, const char *name, const char *desc, int enfopriority, int chckpriority, int eagerfreq, SCIP_Bool needscons, SCIP_DECL_CONSENFOLP((*consenfolp)), SCIP_DECL_CONSENFOPS((*consenfops)), SCIP_DECL_CONSCHECK((*conscheck)), SCIP_DECL_CONSLOCK((*conslock)), SCIP_CONSHDLRDATA *conshdlrdata)
SCIP_RETCODE SCIPsetConshdlrGetDiveBdChgs(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrDisable(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrParse(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrGetVars(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrPrint(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrGetSignedPermsymGraph(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
int SCIPconshdlrGetNConss(SCIP_CONSHDLR *conshdlr)
const char * SCIPconshdlrGetName(SCIP_CONSHDLR *conshdlr)
SCIP_RETCODE SCIPsetConshdlrCopy(SCIP *scip, SCIP_CONSHDLR *conshdlr, SCIP_DECL_CONSHDLRCOPY((*conshdlrcopy)),)
SCIP_CONSHDLR * SCIPfindConshdlr(SCIP *scip, const char *name)
SCIP_RETCODE SCIPsetConshdlrInit(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrGetPermsymGraph(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrDelete(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrInitsol(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_CONSHDLRDATA * SCIPconshdlrGetData(SCIP_CONSHDLR *conshdlr)
int SCIPconshdlrGetNActiveConss(SCIP_CONSHDLR *conshdlr)
int SCIPconshdlrGetSepaFreq(SCIP_CONSHDLR *conshdlr)
SCIP_RETCODE SCIPsetConshdlrTrans(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrResprop(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrExitsol(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_CONS ** SCIPconshdlrGetConss(SCIP_CONSHDLR *conshdlr)
SCIP_RETCODE SCIPsetConshdlrExit(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrInitlp(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPsetConshdlrGetNVars(SCIP *scip, SCIP_CONSHDLR *conshdlr,)
SCIP_RETCODE SCIPgetConsNVars(SCIP *scip, SCIP_CONS *cons, int *nvars, SCIP_Bool *success)
SCIP_CONSDATA * SCIPconsGetData(SCIP_CONS *cons)
SCIP_RETCODE SCIPenfopsCons(SCIP *scip, SCIP_CONS *cons, SCIP_Bool solinfeasible, SCIP_Bool objinfeasible, SCIP_RESULT *result)
void SCIPconsAddUpgradeLocks(SCIP_CONS *cons, int nlocks)
SCIP_Bool SCIPconsIsDynamic(SCIP_CONS *cons)
SCIP_CONSHDLR * SCIPconsGetHdlr(SCIP_CONS *cons)
SCIP_Bool SCIPconsIsInitial(SCIP_CONS *cons)
SCIP_RETCODE SCIPenfolpCons(SCIP *scip, SCIP_CONS *cons, SCIP_Bool solinfeasible, SCIP_RESULT *result)
SCIP_RETCODE SCIPprintCons(SCIP *scip, SCIP_CONS *cons, FILE *file)
int SCIPconsGetNUpgradeLocks(SCIP_CONS *cons)
SCIP_Bool SCIPconsIsChecked(SCIP_CONS *cons)
SCIP_Bool SCIPconsIsDeleted(SCIP_CONS *cons)
SCIP_RETCODE SCIPsepalpCons(SCIP *scip, SCIP_CONS *cons, SCIP_RESULT *result)
SCIP_Bool SCIPconsIsTransformed(SCIP_CONS *cons)
SCIP_RETCODE SCIPgetConsVars(SCIP *scip, SCIP_CONS *cons, SCIP_VAR **vars, int varssize, SCIP_Bool *success)
SCIP_Bool SCIPconsIsEnforced(SCIP_CONS *cons)
SCIP_Bool SCIPconsIsActive(SCIP_CONS *cons)
SCIP_RETCODE SCIPcreateCons(SCIP *scip, SCIP_CONS **cons, const char *name, SCIP_CONSHDLR *conshdlr, SCIP_CONSDATA *consdata, SCIP_Bool initial, SCIP_Bool separate, SCIP_Bool enforce, SCIP_Bool check, SCIP_Bool propagate, SCIP_Bool local, SCIP_Bool modifiable, SCIP_Bool dynamic, SCIP_Bool removable, SCIP_Bool stickingatnode)
SCIP_Bool SCIPconsIsPropagated(SCIP_CONS *cons)
SCIP_Bool SCIPconsIsLocal(SCIP_CONS *cons)
SCIP_Bool SCIPconsIsEnabled(SCIP_CONS *cons)
SCIP_RETCODE SCIPdisableCons(SCIP *scip, SCIP_CONS *cons)
const char * SCIPconsGetName(SCIP_CONS *cons)
SCIP_RETCODE SCIPresetConsAge(SCIP *scip, SCIP_CONS *cons)
SCIP_Bool SCIPconsIsModifiable(SCIP_CONS *cons)
SCIP_RETCODE SCIPgetTransformedCons(SCIP *scip, SCIP_CONS *cons, SCIP_CONS **transcons)
SCIP_RETCODE SCIPenforelaxCons(SCIP *scip, SCIP_CONS *cons, SCIP_SOL *sol, SCIP_Bool solinfeasible, SCIP_RESULT *result)
SCIP_Bool SCIPconsIsStickingAtNode(SCIP_CONS *cons)
SCIP_RETCODE SCIPsepasolCons(SCIP *scip, SCIP_CONS *cons, SCIP_SOL *sol, SCIP_RESULT *result)
SCIP_RETCODE SCIPreleaseCons(SCIP *scip, SCIP_CONS **cons)
SCIP_Bool SCIPconsIsSeparated(SCIP_CONS *cons)
SCIP_RETCODE SCIPcaptureCons(SCIP *scip, SCIP_CONS *cons)
SCIP_RETCODE SCIPincConsAge(SCIP *scip, SCIP_CONS *cons)
SCIP_Bool SCIPconsIsRemovable(SCIP_CONS *cons)
SCIP_RETCODE SCIPaddPoolCut(SCIP *scip, SCIP_ROW *row)
SCIP_Bool SCIPisEfficacious(SCIP *scip, SCIP_Real efficacy)
SCIP_RETCODE SCIPaddRow(SCIP *scip, SCIP_ROW *row, SCIP_Bool forcecut, SCIP_Bool *infeasible)
SCIP_RETCODE SCIPincludeEventhdlrBasic(SCIP *scip, SCIP_EVENTHDLR **eventhdlrptr, const char *name, const char *desc, SCIP_DECL_EVENTEXEC((*eventexec)), SCIP_EVENTHDLRDATA *eventhdlrdata)
const char * SCIPeventhdlrGetName(SCIP_EVENTHDLR *eventhdlr)
SCIP_EVENTTYPE SCIPeventGetType(SCIP_EVENT *event)
SCIP_RETCODE SCIPcatchVarEvent(SCIP *scip, SCIP_VAR *var, SCIP_EVENTTYPE eventtype, SCIP_EVENTHDLR *eventhdlr, SCIP_EVENTDATA *eventdata, int *filterpos)
SCIP_RETCODE SCIPdropVarEvent(SCIP *scip, SCIP_VAR *var, SCIP_EVENTTYPE eventtype, SCIP_EVENTHDLR *eventhdlr, SCIP_EVENTDATA *eventdata, int filterpos)
SCIP_Real SCIPeventGetOldbound(SCIP_EVENT *event)
SCIP_VAR * SCIPeventGetVar(SCIP_EVENT *event)
SCIP_Real SCIPeventGetNewbound(SCIP_EVENT *event)
SCIP_RETCODE SCIPcatchEvent(SCIP *scip, SCIP_EVENTTYPE eventtype, SCIP_EVENTHDLR *eventhdlr, SCIP_EVENTDATA *eventdata, int *filterpos)
SCIP_RETCODE SCIPdropEvent(SCIP *scip, SCIP_EVENTTYPE eventtype, SCIP_EVENTHDLR *eventhdlr, SCIP_EVENTDATA *eventdata, int filterpos)
SCIP_RETCODE SCIPreleaseExpr(SCIP *scip, SCIP_EXPR **expr)
SCIP_HEUR * SCIPfindHeur(SCIP *scip, const char *name)
#define SCIPfreeBlockMemoryArray(scip, ptr, num)
int SCIPcalcMemGrowSize(SCIP *scip, int num)
#define SCIPallocBufferArray(scip, ptr, num)
#define SCIPfreeBufferArray(scip, ptr)
#define SCIPallocBlockMemoryArray(scip, ptr, num)
#define SCIPreallocBlockMemoryArray(scip, ptr, oldnum, newnum)
#define SCIPfreeBlockMemory(scip, ptr)
#define SCIPfreeBlockMemoryArrayNull(scip, ptr, num)
#define SCIPallocBlockMemory(scip, ptr)
SCIP_RETCODE SCIPaddNlRow(SCIP *scip, SCIP_NLROW *nlrow)
SCIP_Bool SCIPisNLPConstructed(SCIP *scip)
SCIP_RETCODE SCIPreleaseNlRow(SCIP *scip, SCIP_NLROW **nlrow)
SCIP_RETCODE SCIPcreateNlRow(SCIP *scip, SCIP_NLROW **nlrow, const char *name, SCIP_Real constant, int nlinvars, SCIP_VAR **linvars, SCIP_Real *lincoefs, SCIP_EXPR *expr, SCIP_Real lhs, SCIP_Real rhs, SCIP_EXPRCURV curvature)
SCIP_RETCODE SCIPgetDivesetScore(SCIP *scip, SCIP_DIVESET *diveset, SCIP_DIVETYPE divetype, SCIP_VAR *divecand, SCIP_Real divecandsol, SCIP_Real divecandfrac, SCIP_Real *candscore, SCIP_Bool *roundup)
SCIP_Bool SCIPinProbing(SCIP *scip)
SCIP_RETCODE SCIPaddDiveBoundChange(SCIP *scip, SCIP_VAR *var, SCIP_BRANCHDIR dir, SCIP_Real value, SCIP_Bool preferred)
SCIP_Real SCIProwGetLhs(SCIP_ROW *row)
SCIP_RETCODE SCIPcacheRowExtensions(SCIP *scip, SCIP_ROW *row)
int SCIProwGetNNonz(SCIP_ROW *row)
SCIP_COL ** SCIProwGetCols(SCIP_ROW *row)
SCIP_Real SCIProwGetRhs(SCIP_ROW *row)
SCIP_RETCODE SCIPcreateEmptyRowCons(SCIP *scip, SCIP_ROW **row, SCIP_CONS *cons, const char *name, SCIP_Real lhs, SCIP_Real rhs, SCIP_Bool local, SCIP_Bool modifiable, SCIP_Bool removable)
SCIP_RETCODE SCIPflushRowExtensions(SCIP *scip, SCIP_ROW *row)
SCIP_Bool SCIProwIsLocal(SCIP_ROW *row)
SCIP_RETCODE SCIPcreateEmptyRowConshdlr(SCIP *scip, SCIP_ROW **row, SCIP_CONSHDLR *conshdlr, const char *name, SCIP_Real lhs, SCIP_Real rhs, SCIP_Bool local, SCIP_Bool modifiable, SCIP_Bool removable)
SCIP_RETCODE SCIPaddVarToRow(SCIP *scip, SCIP_ROW *row, SCIP_VAR *var, SCIP_Real val)
SCIP_RETCODE SCIPprintRow(SCIP *scip, SCIP_ROW *row, FILE *file)
const char * SCIProwGetName(SCIP_ROW *row)
SCIP_Real SCIPgetRowSolFeasibility(SCIP *scip, SCIP_ROW *row, SCIP_SOL *sol)
SCIP_RETCODE SCIPreleaseRow(SCIP *scip, SCIP_ROW **row)
SCIP_Real SCIProwGetConstant(SCIP_ROW *row)
SCIP_RETCODE SCIPaddVarsToRow(SCIP *scip, SCIP_ROW *row, int nvars, SCIP_VAR **vars, SCIP_Real *vals)
SCIP_Real * SCIProwGetVals(SCIP_ROW *row)
SCIP_RETCODE SCIPcreateSolCopy(SCIP *scip, SCIP_SOL **sol, SCIP_SOL *sourcesol)
void SCIPupdateSolConsViolation(SCIP *scip, SCIP_SOL *sol, SCIP_Real absviol, SCIP_Real relviol)
SCIP_RETCODE SCIPsetSolVal(SCIP *scip, SCIP_SOL *sol, SCIP_VAR *var, SCIP_Real val)
SCIP_Real SCIPgetSolVal(SCIP *scip, SCIP_SOL *sol, SCIP_VAR *var)
SCIP_RETCODE SCIPrestartSolve(SCIP *scip)
SCIP_Real SCIPgetPrimalbound(SCIP *scip)
SCIP_Real SCIPgetUpperbound(SCIP *scip)
SCIP_Real SCIPgetDualbound(SCIP *scip)
int SCIPgetNRuns(SCIP *scip)
SCIP_Longint SCIPgetNConflictConssApplied(SCIP *scip)
SCIP_Bool SCIPisFeasGE(SCIP *scip, SCIP_Real val1, SCIP_Real val2)
SCIP_Real SCIPinfinity(SCIP *scip)
SCIP_Bool SCIPisGE(SCIP *scip, SCIP_Real val1, SCIP_Real val2)
SCIP_Bool SCIPisIntegral(SCIP *scip, SCIP_Real val)
SCIP_Bool SCIPisFeasEQ(SCIP *scip, SCIP_Real val1, SCIP_Real val2)
SCIP_Bool SCIPisPositive(SCIP *scip, SCIP_Real val)
SCIP_Real SCIPfeasCeil(SCIP *scip, SCIP_Real val)
SCIP_Bool SCIPisLE(SCIP *scip, SCIP_Real val1, SCIP_Real val2)
SCIP_Bool SCIPisFeasZero(SCIP *scip, SCIP_Real val)
SCIP_Bool SCIPisInfinity(SCIP *scip, SCIP_Real val)
SCIP_Bool SCIPisFeasLT(SCIP *scip, SCIP_Real val1, SCIP_Real val2)
SCIP_Bool SCIPisFeasNegative(SCIP *scip, SCIP_Real val)
SCIP_Bool SCIPisFeasIntegral(SCIP *scip, SCIP_Real val)
SCIP_Bool SCIPisGT(SCIP *scip, SCIP_Real val1, SCIP_Real val2)
SCIP_Bool SCIPisNegative(SCIP *scip, SCIP_Real val)
SCIP_Real SCIPceil(SCIP *scip, SCIP_Real val)
SCIP_Bool SCIPisEQ(SCIP *scip, SCIP_Real val1, SCIP_Real val2)
SCIP_Real SCIPcutoffbounddelta(SCIP *scip)
SCIP_Bool SCIPisZero(SCIP *scip, SCIP_Real val)
SCIP_Bool SCIPisLT(SCIP *scip, SCIP_Real val1, SCIP_Real val2)
SCIP_Bool SCIPisFeasPositive(SCIP *scip, SCIP_Real val)
SCIP_Bool SCIPinRepropagation(SCIP *scip)
int SCIPgetDepth(SCIP *scip)
SCIP_RETCODE SCIPvarGetProbvarBound(SCIP_VAR **var, SCIP_Real *bound, SCIP_BOUNDTYPE *boundtype)
SCIP_Bool SCIPvarIsDeleted(SCIP_VAR *var)
SCIP_RETCODE SCIPlockVarCons(SCIP *scip, SCIP_VAR *var, SCIP_CONS *cons, SCIP_Bool lockdown, SCIP_Bool lockup)
SCIP_VAR * SCIPvarGetNegatedVar(SCIP_VAR *var)
SCIP_Bool SCIPvarIsActive(SCIP_VAR *var)
SCIP_Bool SCIPvarIsBinary(SCIP_VAR *var)
SCIP_VARSTATUS SCIPvarGetStatus(SCIP_VAR *var)
int SCIPvarGetNLocksUpType(SCIP_VAR *var, SCIP_LOCKTYPE locktype)
SCIP_Real SCIPvarGetUbLocal(SCIP_VAR *var)
SCIP_Bool SCIPdoNotMultaggrVar(SCIP *scip, SCIP_VAR *var)
SCIP_RETCODE SCIPinferVarUbCons(SCIP *scip, SCIP_VAR *var, SCIP_Real newbound, SCIP_CONS *infercons, int inferinfo, SCIP_Bool force, SCIP_Bool *infeasible, SCIP_Bool *tightened)
SCIP_RETCODE SCIPchgVarUb(SCIP *scip, SCIP_VAR *var, SCIP_Real newbound)
SCIP_RETCODE SCIPchgVarUbNode(SCIP *scip, SCIP_NODE *node, SCIP_VAR *var, SCIP_Real newbound)
SCIP_Real SCIPvarGetObj(SCIP_VAR *var)
SCIP_Real SCIPvarGetAggrScalar(SCIP_VAR *var)
SCIP_VARTYPE SCIPvarGetType(SCIP_VAR *var)
SCIP_RETCODE SCIPgetProbvarSum(SCIP *scip, SCIP_VAR **var, SCIP_Real *scalar, SCIP_Real *constant)
SCIP_Real SCIPvarGetUbGlobal(SCIP_VAR *var)
SCIP_RETCODE SCIPaddVarLocksType(SCIP *scip, SCIP_VAR *var, SCIP_LOCKTYPE locktype, int nlocksdown, int nlocksup)
SCIP_RETCODE SCIPunlockVarCons(SCIP *scip, SCIP_VAR *var, SCIP_CONS *cons, SCIP_Bool lockdown, SCIP_Bool lockup)
SCIP_Real SCIPgetVarUbAtIndex(SCIP *scip, SCIP_VAR *var, SCIP_BDCHGIDX *bdchgidx, SCIP_Bool after)
int SCIPvarGetProbindex(SCIP_VAR *var)
const char * SCIPvarGetName(SCIP_VAR *var)
SCIP_VAR * SCIPbdchginfoGetVar(SCIP_BDCHGINFO *bdchginfo)
SCIP_RETCODE SCIPreleaseVar(SCIP *scip, SCIP_VAR **var)
SCIP_Real SCIPadjustedVarUb(SCIP *scip, SCIP_VAR *var, SCIP_Real ub)
SCIP_Bool SCIPvarIsIntegral(SCIP_VAR *var)
SCIP_RETCODE SCIPchgVarType(SCIP *scip, SCIP_VAR *var, SCIP_VARTYPE vartype, SCIP_Bool *infeasible)
SCIP_Real SCIPgetVarSol(SCIP *scip, SCIP_VAR *var)
SCIP_RETCODE SCIPgetNegatedVar(SCIP *scip, SCIP_VAR *var, SCIP_VAR **negvar)
SCIP_RETCODE SCIPaddVarImplication(SCIP *scip, SCIP_VAR *var, SCIP_Bool varfixing, SCIP_VAR *implvar, SCIP_BOUNDTYPE impltype, SCIP_Real implbound, SCIP_Bool *infeasible, int *nbdchgs)
SCIP_Real SCIPvarGetLbLocal(SCIP_VAR *var)
SCIP_Bool SCIPvarIsNegated(SCIP_VAR *var)
SCIP_VAR * SCIPvarGetNegationVar(SCIP_VAR *var)
SCIP_RETCODE SCIPcreateVar(SCIP *scip, SCIP_VAR **var, const char *name, SCIP_Real lb, SCIP_Real ub, SCIP_Real obj, SCIP_VARTYPE vartype, SCIP_Bool initial, SCIP_Bool removable, SCIP_DECL_VARDELORIG((*vardelorig)), SCIP_DECL_VARTRANS((*vartrans)), SCIP_DECL_VARDELTRANS((*vardeltrans)), SCIP_DECL_VARCOPY((*varcopy)), SCIP_VARDATA *vardata)
SCIP_Real SCIPvarGetLbGlobal(SCIP_VAR *var)
SCIP_RETCODE SCIPmarkDoNotMultaggrVar(SCIP *scip, SCIP_VAR *var)
SCIP_RETCODE SCIPfixVar(SCIP *scip, SCIP_VAR *var, SCIP_Real fixedval, SCIP_Bool *infeasible, SCIP_Bool *fixed)
SCIP_RETCODE SCIPinferVarLbCons(SCIP *scip, SCIP_VAR *var, SCIP_Real newbound, SCIP_CONS *infercons, int inferinfo, SCIP_Bool force, SCIP_Bool *infeasible, SCIP_Bool *tightened)
SCIP_Real SCIPgetVarLbAtIndex(SCIP *scip, SCIP_VAR *var, SCIP_BDCHGIDX *bdchgidx, SCIP_Bool after)
SCIP_RETCODE SCIPchgVarLbNode(SCIP *scip, SCIP_NODE *node, SCIP_VAR *var, SCIP_Real newbound)
SCIP_RETCODE SCIPvarGetProbvarBinary(SCIP_VAR **var, SCIP_Bool *negated)
SCIP_BOUNDTYPE SCIPbdchginfoGetBoundtype(SCIP_BDCHGINFO *bdchginfo)
SCIP_Real SCIPbdchginfoGetNewbound(SCIP_BDCHGINFO *bdchginfo)
int SCIPvarGetNLocksDownType(SCIP_VAR *var, SCIP_LOCKTYPE locktype)
SCIP_Bool SCIPallowWeakDualReds(SCIP *scip)
SCIP_RETCODE SCIPgetTransformedVar(SCIP *scip, SCIP_VAR *var, SCIP_VAR **transvar)
SCIP_RETCODE SCIPcaptureVar(SCIP *scip, SCIP_VAR *var)
SCIP_Bool SCIPallowStrongDualReds(SCIP *scip)
SCIP_VAR * SCIPvarGetAggrVar(SCIP_VAR *var)
int SCIPsnprintf(char *t, int len, const char *s,...)
SCIP_RETCODE SCIPaddSymgraphEdge(SCIP *scip, SYM_GRAPH *graph, int first, int second, SCIP_Bool hasval, SCIP_Real val)
SCIP_RETCODE SCIPaddSymgraphOpnode(SCIP *scip, SYM_GRAPH *graph, int op, int *nodeidx)
SCIP_RETCODE SCIPgetSymActiveVariables(SCIP *scip, SYM_SYMTYPE symtype, SCIP_VAR ***vars, SCIP_Real **scalars, int *nvars, SCIP_Real *constant, SCIP_Bool transformed)
int SCIPgetSymgraphVarnodeidx(SCIP *scip, SYM_GRAPH *graph, SCIP_VAR *var)
SCIP_RETCODE SCIPaddSymgraphConsnode(SCIP *scip, SYM_GRAPH *graph, SCIP_CONS *cons, SCIP_Real lhs, SCIP_Real rhs, int *nodeidx)
SCIP_RETCODE SCIPaddSymgraphVarAggregation(SCIP *scip, SYM_GRAPH *graph, int rootidx, SCIP_VAR **vars, SCIP_Real *vals, int nvars, SCIP_Real constant)
int SCIPgetSymgraphNegatedVarnodeidx(SCIP *scip, SYM_GRAPH *graph, SCIP_VAR *var)
SCIPfreeSol(scip, &heurdata->sol))
static SCIP_DIVESET * diveset
handle partial solutions for linear problems with indicators and otherwise continuous variables
assert(minobj< SCIPgetCutoffbound(scip))
static SCIP_Bool propagate
primal heuristic that tries a given solution
interface methods for specific LP solvers
static const char * paramname[]
memory allocation routines
#define BMScopyMemoryArray(ptr, source, num)
BMS_BLKMEM * SCIPblkmem(SCIP *scip)
const char * SCIPparamGetName(SCIP_PARAM *param)
SCIP_PARAMTYPE SCIPparamGetType(SCIP_PARAM *param)
public methods for conflict analysis handlers
public methods for managing constraints
public methods for managing events
public methods for LP management
public methods for message output
#define SCIPdebugPrintCons(x, y, z)
public data structures and miscellaneous methods
public methods for handling parameter settings
public methods for problem variables
public methods for branching rule plugins and branching
public methods for conflict handler plugins and conflict analysis
public methods for constraint handler plugins and constraints
public methods for problem copies
public methods for cuts and aggregation rows
public methods for event handler plugins and event handlers
public methods for primal heuristic plugins and divesets
public methods for the LP relaxation, rows and columns
public methods for memory management
public methods for message handling
public methods for nonlinear relaxation
public methods for numerical tolerances
public methods for SCIP parameter handling
public methods for global and local (sub)problems
public methods for the probing mode
public methods for solutions
public methods for querying solving statistics
public methods for the branch-and-bound tree
public methods for SCIP variables
structs for symmetry computations
methods for dealing with symmetry detection graphs
struct SCIP_Conflicthdlr SCIP_CONFLICTHDLR
#define SCIP_DECL_CONFLICTEXEC(x)
#define SCIP_DECL_CONFLICTFREE(x)
@ SCIP_CONFTYPE_PROPAGATION
struct SCIP_ConflicthdlrData SCIP_CONFLICTHDLRDATA
#define SCIP_DECL_CONSGETSIGNEDPERMSYMGRAPH(x)
#define SCIP_DECL_CONSGETPERMSYMGRAPH(x)
#define SCIP_DECL_CONSENFOLP(x)
#define SCIP_DECL_CONSINITPRE(x)
#define SCIP_DECL_CONSDELETE(x)
struct SCIP_Cons SCIP_CONS
#define SCIP_DECL_CONSEXIT(x)
#define SCIP_DECL_CONSGETVARS(x)
#define SCIP_DECL_CONSINITSOL(x)
#define SCIP_DECL_CONSPRINT(x)
struct SCIP_ConshdlrData SCIP_CONSHDLRDATA
#define SCIP_DECL_CONSSEPALP(x)
#define SCIP_DECL_CONSDISABLE(x)
struct SYM_Graph SYM_GRAPH
#define SCIP_DECL_CONSENFORELAX(x)
#define SCIP_DECL_CONSGETDIVEBDCHGS(x)
#define SCIP_DECL_CONSPROP(x)
#define SCIP_DECL_CONSGETNVARS(x)
#define SCIP_DECL_CONSRESPROP(x)
#define SCIP_DECL_CONSENFOPS(x)
#define SCIP_DECL_CONSPARSE(x)
#define SCIP_DECL_CONSTRANS(x)
#define SCIP_DECL_CONSPRESOL(x)
#define SCIP_DECL_CONSENABLE(x)
#define SCIP_DECL_CONSINITLP(x)
#define SCIP_DECL_CONSLOCK(x)
struct SCIP_Conshdlr SCIP_CONSHDLR
#define SCIP_DECL_CONSCOPY(x)
#define SCIP_DECL_CONSINIT(x)
struct SCIP_ConsData SCIP_CONSDATA
#define SCIP_DECL_CONSCHECK(x)
#define SCIP_DECL_CONSHDLRCOPY(x)
#define SCIP_DECL_CONSEXITSOL(x)
#define SCIP_DECL_CONSFREE(x)
#define SCIP_DECL_CONSSEPASOL(x)
struct SCIP_Eventhdlr SCIP_EVENTHDLR
#define SCIP_EVENTTYPE_BOUNDCHANGED
#define SCIP_EVENTTYPE_GUBCHANGED
#define SCIP_EVENTTYPE_GBDCHANGED
struct SCIP_EventData SCIP_EVENTDATA
#define SCIP_EVENTTYPE_UBTIGHTENED
#define SCIP_DECL_EVENTEXEC(x)
#define SCIP_EVENTTYPE_LBRELAXED
#define SCIP_EVENTTYPE_BESTSOLFOUND
#define SCIP_EVENTTYPE_GLBCHANGED
#define SCIP_EVENTTYPE_LBTIGHTENED
#define SCIP_EVENTTYPE_UBRELAXED
struct SCIP_Expr SCIP_EXPR
struct SCIP_Heur SCIP_HEUR
#define SCIP_DIVETYPE_INTEGRALITY
@ SCIP_BRANCHDIR_DOWNWARDS
enum SCIP_BoundType SCIP_BOUNDTYPE
type definitions for specific LP solvers interface
@ SCIP_LPSOLQUALITY_ESTIMCONDITION
struct SCIP_HashMap SCIP_HASHMAP
struct SCIP_NlRow SCIP_NLROW
struct SCIP_Param SCIP_PARAM
#define SCIP_DECL_PARAMCHGD(x)
enum SCIP_Result SCIP_RESULT
enum SCIP_Retcode SCIP_RETCODE
@ SCIP_STAGE_INITPRESOLVE
@ SCIP_STAGE_TRANSFORMING
enum SYM_Symtype SYM_SYMTYPE
struct SCIP_Node SCIP_NODE
@ SCIP_VARTYPE_CONTINUOUS
@ SCIP_VARSTATUS_MULTAGGR
@ SCIP_VARSTATUS_AGGREGATED
enum SCIP_Vartype SCIP_VARTYPE