Class: IntVar
Remarks
Integer variable represents an unknown (integer) value that solver has to find.
The value of the integer variable can be constrained using mathematical expressions, such as Model.plus, Model.times, Model.le, Model.sum.
OptalCP solver focuses on scheduling problems and concentrates on IntervalVar variables. Therefore, interval variables should be the primary choice for modeling in OptalCP. However, integer variables can be used for other purposes, such as counting or indexing. In particular, integer variables can be helpful for cumulative expressions with variable heights; see Model.pulse, Model.stepAtStart, Model.stepAtEnd, and Model.stepAt.
The integer variable can be optional. In this case, the solver can make the variable absent, which is usually interpreted as the fact that the solver does not use the variable at all. Functions Model.presence and IntExpr.presence can constrain the presence of the variable.
Integer variables can be created using the function Model.intVar.
Example
In the following example we create three integer variables x, y and z.
Variables x and y are present, but variable z is optional.
Each variable has a different range of possible values.
let model = CP.Model;
let x = model.intVar({ name: "x", range: [1, 3] });
let y = model.intVar({ name: "y", range: [0, 100] });
let z = model.intVar({ name: "z", range: [10, 20], optional: true });
Extends
Accessors
max
Get Signature
get max():
null|number
The maximum value of the integer variable's domain.
Remarks
Gets or sets the maximum value of the integer variable's domain.
The initial value is set during construction by Model.intVar.
If the variable is absent, the getter returns None.
Note: This property reflects the variable's domain in the model (before the solve), not in the solution.
The value must be in the range IntVarMin to IntVarMax.
See
Example
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intVar({ min: 5, max: 10, name: "x" });
console.log(x.max); // 10
x.max = 8;
console.log(x.max); // 8
Returns
null | number
Set Signature
set max(
value:number):void
Parameters
| Parameter | Type |
|---|---|
value | number |
Returns
void
min
Get Signature
get min():
null|number
The minimum value of the integer variable's domain.
Remarks
Gets or sets the minimum value of the integer variable's domain.
The initial value is set during construction by Model.intVar.
If the variable is absent, the getter returns None.
Note: This property reflects the variable's domain in the model (before the solve), not in the solution.
The value must be in the range IntVarMin to IntVarMax.
See
Example
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intVar({ min: 5, max: 10, name: "x" });
console.log(x.min); // 5
x.min = 7;
console.log(x.min); // 7
Returns
null | number
Set Signature
set min(
value:number):void
Parameters
| Parameter | Type |
|---|---|
value | number |
Returns
void
name
Get Signature
get name():
undefined|string
The name assigned to this model element.
Remarks
The name is optional and primarily useful for debugging purposes. When set, it helps identify the element in solver logs, error messages, and when inspecting solutions.
Names can be assigned to any model element including variables, expressions, and constraints.
Example
import * as CP from "optalcp";
const model = new CP.Model();
// Name a variable at creation
const task = model.intervalVar({ length: 10, name: "assembly" });
// Or set name later
const x = model.intVar({ min: 0, max: 100 });
x.name = "quantity";
console.log(task.name); // "assembly"
console.log(x.name); // "quantity"
Returns
undefined | string
Set Signature
set name(
value:string):void
Parameters
| Parameter | Type |
|---|---|
value | string |
Returns
void
Inherited from
optional
Get Signature
get optional():
null|boolean
The presence status of the integer variable.
Remarks
Gets or sets the presence status of the integer variable using a tri-state value:
True/true: The variable is optional - the solver decides whether it is present or absent in the solution.False/false: The variable is present - it must have a value in the solution.None/null: The variable is absent - it will be omitted from the solution.
Note: This property reflects the presence status in the model (before the solve), not in the solution.
See
Example
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intVar({ min: 0, max: 10, name: "x" });
const y = model.intVar({ min: 0, max: 10, optional: true, name: "y" });
console.log(x.optional); // false (present by default)
console.log(y.optional); // true (optional)
// Make x optional
x.optional = true;
console.log(x.optional); // true
// Make y absent
y.optional = null;
console.log(y.optional); // null
Returns
null | boolean
Set Signature
set optional(
value:null|boolean):void
Parameters
| Parameter | Type |
|---|---|
value | null | boolean |
Returns
void
Constructors
new IntVar()
new IntVar():
IntVar
Returns
Inherited from
Methods
abs()
abs():
IntExpr
Creates an integer expression which is absolute value of the expression.
Returns
The resulting integer expression
Remarks
If the expression has value absent, the resulting expression also has value absent.
Same as Model.abs.
Inherited from
div()
Returns integer division of the expression arg. The division rounds towards zero.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The second integer expression. |
Returns
The resulting integer expression
Remarks
If the expression or arg has value absent, then the resulting expression has also value absent.
Same as Model.div.
Inherited from
eq()
Create an equality constraint.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The expression or constant to compare against. |
Returns
A boolean expression that is true when self equals rhs.
Remarks
Returns a BoolExpr representing self == other.
If either operand has value absent, the result is also absent.
See
- IntExpr.ne for inequality comparison.
- Model.eq for the Model-centric style.
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intVar({ min: 0, max: 10, name: "x" });
const y = model.intVar({ min: 0, max: 10, name: "y" });
// IntExpr.eq(IntExpr)
model.enforce(x.eq(y));
// IntExpr.eq(constant)
model.enforce(x.eq(5));
Inherited from
ge()
Create a greater-than-or-equal constraint.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The expression or constant to compare against. |
Returns
A boolean expression that is true when self is greater than or equal to rhs.
Remarks
Returns a BoolExpr representing self >= other.
If either operand has value absent, the result is also absent.
See
- IntExpr.gt for strict greater-than comparison.
- IntExpr.le for less-than-or-equal comparison.
- Model.ge for the Model-centric style.
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intVar({ min: 0, max: 10, name: "x" });
const y = model.intVar({ min: 0, max: 10, name: "y" });
// IntExpr.ge(IntExpr)
model.enforce(x.ge(y));
// IntExpr.ge(constant)
model.enforce(x.ge(5));
Inherited from
gt()
Create a greater-than constraint.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The expression or constant to compare against. |
Returns
A boolean expression that is true when self is greater than rhs.
Remarks
Returns a BoolExpr representing self > other.
If either operand has value absent, the result is also absent.
See
- IntExpr.ge for greater-than-or-equal comparison.
- IntExpr.lt for less-than comparison.
- Model.gt for the Model-centric style.
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intVar({ min: 0, max: 10, name: "x" });
const y = model.intVar({ min: 0, max: 10, name: "y" });
// IntExpr.gt(IntExpr)
model.enforce(x.gt(y));
// IntExpr.gt(constant)
model.enforce(x.gt(5));
Inherited from
guard()
guard(
absentValue:number):IntExpr
Creates an expression that replaces value absent by a constant.
Parameters
| Parameter | Type | Default value | Description |
|---|---|---|---|
absentValue | number | 0 | The value to use when the expression is absent. |
Returns
The resulting integer expression
Remarks
The resulting expression is:
- equal to the expression if the expression is present
- and equal to
absentValueotherwise (i.e. when the expression is absent).
The default value of absentValue is 0.
The resulting expression is never absent.
Same as Model.guard.
Inherited from
identity()
identity(
rhs:number|IntExpr):Constraint
Constrains two expressions to be identical, including their presence status.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The second integer expression. |
Returns
Constraint
The constraint object
Remarks
Identity is different than equality. For example, if x is absent, then x == 0 is absent, but x.identity(0) is false.
Same as Model.identity.
Inherited from
inRange()
inRange(
lb:number,ub:number):BoolExpr
Creates Boolean expression lb ≤ this ≤ ub.
Parameters
| Parameter | Type | Description |
|---|---|---|
lb | number | The lower bound of the range. |
ub | number | The upper bound of the range. |
Returns
The resulting Boolean expression
Remarks
If the expression has value absent, then the resulting expression has also value absent.
Use Model.enforce to add this expression as a constraint to the model.
Same as Model.inRange.
Inherited from
le()
Create a less-than-or-equal constraint.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The expression or constant to compare against. |
Returns
A boolean expression that is true when self is less than or equal to rhs.
Remarks
Returns a BoolExpr representing self <= other.
If either operand has value absent, the result is also absent.
See
- IntExpr.lt for strict less-than comparison.
- IntExpr.ge for greater-than-or-equal comparison.
- Model.le for the Model-centric style.
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intVar({ min: 0, max: 10, name: "x" });
const y = model.intVar({ min: 0, max: 10, name: "y" });
// IntExpr.le(IntExpr)
model.enforce(x.le(y));
// IntExpr.le(constant)
model.enforce(x.le(5));
Inherited from
lt()
Create a less-than constraint.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The expression or constant to compare against. |
Returns
A boolean expression that is true when self is less than rhs.
Remarks
Returns a BoolExpr representing self < other.
If either operand has value absent, the result is also absent.
See
- IntExpr.le for less-than-or-equal comparison.
- IntExpr.gt for greater-than comparison.
- Model.lt for the Model-centric style.
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intVar({ min: 0, max: 10, name: "x" });
const y = model.intVar({ min: 0, max: 10, name: "y" });
// IntExpr.lt(IntExpr)
model.enforce(x.lt(y));
// IntExpr.lt(constant)
model.enforce(x.lt(5));
Inherited from
max2()
Creates an integer expression which is the maximum of the expression and arg.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The second integer expression. |
Returns
The resulting integer expression
Remarks
If the expression or arg has value absent, then the resulting expression has also value absent.
Same as Model.max2. See Model.max for n-ary maximum.
Inherited from
maximize()
maximize():
Objective
Creates a maximization objective for this expression.
Returns
An Objective that maximizes this expression.
Remarks
Creates an objective to maximize the value of this integer expression. A model can have at most one objective. New objective replaces the old one.
This is a fluent-style alternative to Model.maximize that allows creating objectives directly from expressions.
Example
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intervalVar({start: [0, 100], length: 10, name: "x"});
// Fluent style - maximize the start of x
x.start().maximize();
// Equivalent Model.maximize() style:
model.maximize(x.start());
See
- Model.maximize for Model-centric maximization.
- IntExpr.minimize for minimization.
Inherited from
min2()
Creates an integer expression which is the minimum of the expression and arg.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The second integer expression. |
Returns
The resulting integer expression
Remarks
If the expression or arg has value absent, then the resulting expression has also value absent.
Same as Model.min2. See Model.min for the n-ary minimum.
Inherited from
minimize()
minimize():
Objective
Creates a minimization objective for this expression.
Returns
An Objective that minimizes this expression.
Remarks
Creates an objective to minimize the value of this integer expression. A model can have at most one objective. New objective replaces the old one.
This is a fluent-style alternative to Model.minimize that allows creating objectives directly from expressions.
Example
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intervalVar({length: 10, name: "x"});
const y = model.intervalVar({length: 20, name: "y"});
// Fluent style - minimize the end of y
y.end().minimize();
// Equivalent Model.minimize() style:
model.minimize(y.end());
See
- Model.minimize for Model-centric minimization.
- IntExpr.maximize for maximization.
Inherited from
minus()
Returns subtraction of the expression and arg.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The second integer expression. |
Returns
The resulting integer expression
Remarks
If the expression or arg has value absent, then the resulting expression has also value absent.
Same as Model.minus.
Inherited from
ne()
Create an inequality constraint.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The expression or constant to compare against. |
Returns
A boolean expression that is true when self does not equal rhs.
Remarks
Returns a BoolExpr representing self != other.
If either operand has value absent, the result is also absent.
See
- IntExpr.eq for equality comparison.
- Model.ne for the Model-centric style.
import * as CP from "optalcp";
const model = new CP.Model();
const x = model.intVar({ min: 0, max: 10, name: "x" });
const y = model.intVar({ min: 0, max: 10, name: "y" });
// IntExpr.ne(IntExpr)
model.enforce(x.ne(y));
// IntExpr.ne(constant)
model.enforce(x.ne(5));
Inherited from
neg()
neg():
IntExpr
Returns negation of the expression.
Returns
The resulting integer expression
Remarks
If the expression has value absent then the resulting expression has also value absent.
Same as Model.neg.
Inherited from
plus()
Returns addition of the expression and the argument.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The second integer expression. |
Returns
The resulting integer expression
Remarks
If the expression or arg has value absent, then the resulting expression has also value absent.
Same as Model.plus.
Inherited from
presence()
presence():
BoolExpr
Returns an expression which is true if the expression is present and false when it is absent.
Returns
The resulting Boolean expression
Remarks
The resulting expression is never absent.
Same as Model.presence.
Inherited from
times()
Returns multiplication of the expression and arg.
Parameters
| Parameter | Type | Description |
|---|---|---|
rhs | number | IntExpr | The second integer expression. |
Returns
The resulting integer expression
Remarks
If the expression or arg has value absent, then the resulting expression has also value absent.
Same as Model.times.
Inherited from
Properties
| Property | Modifier | Type | Inherited from |
|---|---|---|---|
__floatExprBrand | readonly | "FloatExpr" | IntExpr.__floatExprBrand |
__intExprBrand | readonly | "IntExpr" | IntExpr.__intExprBrand |