java中的linearnumexpr,java - Cplex中的上限和下限等于0.0(在cplex中) - 堆栈内存溢出...

我有一个正在进行的循环,有时UpperBound和Lower Bound为0.0那个时候我不想在行下面执行。

Test[index]=cplex.numVar(0.0, upperBound);

我可以跳过它,但是在Test [index]中将保存null,因为具有下面代码的下一个方法将给出null指针异常。

constraint.addTerm(RezCapZZ[index ], 1);

不执行UB和LB等于0.0怎么办? 需要找到一种方法,使第二种方法不会引发空指针异常。

我之所以这样做,是因为我们需要节省不必要的cplex 0计算的内存。

第一种方法:

for (int y = 0; y < 3; y++) {

for (int r = 0; r < 3; r++) {

for (int oc = 0; oc < 3; oc++) {

for(int dc=0; dc < 3 ;dc++){

UB= 0.0;

int index = y*3*3*3 + r*3*3 + oc*3 + dc;

Test[index] = cplex.numVar(0.0, UB);

System.out.println("Value of Test is : " + Test[index]);

}

}

}

}

这里Test [index]的类型为IloNumVar [] Test = new IloNumVar [3 * 3 * 3 * 3];

第二种方法:

for (int l = 0; l < 3; l++) {

for (int y = 0; y < 3; y++) {

for (int r = 0; r < 3; r++) {

for(int oc=0; oc< 3 ; oc++){

index = l*3*3*3 + y*3*3 + r*3 + oc;

**constraint.addTerm(Test[index ], 1);**

}

}

}

}

这里约束是IloLinearNumExpr约束= cplex.linearNumExpr();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值