我一直在尝试使用CPLEX Java实现ILP,并且长期以来一直陷入问题。以下是ILP的一些变量:
IloIntVar above = new IloIntVar[numRect][];
IloIntVar below = new IloIntVar[numRect][];
IloIntVar left = new IloIntVar[numRect][];
IloIntVar right = new IloIntVar[numRect][];
for (int i = 0; i < numRect; i++) {
above[i] = cplex.boolVarArray(numRect);
below[i] = cplex.boolVarArray(numRect);
left[i] = cplex.boolVarArray(numRect);
right[i] = cplex.boolVarArray(numRect);
}
numRect的值为1。在程序结束时,我输出以下值:
for (int i = 0; i < numRect; i++) {
for (int j = i + 1; j < numRect; j++) {
System.out.println(cplex.getValue(left[i][j]));
System.out.println(cplex.getValue(right[i][j]));
System.out.println(cplex.getValue(above[i][j]));
System.out.println(cplex.getValue(below[i][j]));
System.out.println(cplex.getValue(left[i][j]) +
cplex.getValue(right[i][j]) +
cplex.getValue(above[i][j]) +
cplex.getValue(below[i][j]));
}
}
这是我得到的输出:
0.0
0.0
9.313225750491594E-10
0.9999999990686774
1.0
我不明白为什么我会得到双精度值而不是布尔值。任何帮助,将不胜感激。谢谢。
最佳答案
IloBoolVar只是被限制为0或1的IloNumVar。默认情况下,0.00001或0或1之内的任何值都被视为整数。您可以通过设置参数EpInt来更改此设置。该参数可以设置为零,但是您正在引发性能问题。舍入值是最佳做法。实际上,任何时候使用浮点数时,都需要注意这样的舍入问题。