首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >addDivisionEquality with Java google or-tools CP-SAT

addDivisionEquality with Java google or-tools CP-SAT
EN

Stack Overflow用户
提问于 2020-06-14 20:56:39
回答 1查看 123关注 0票数 1

我需要使用google CP-SAT solver添加以下约束

(x+y+z)/(x+y+z+k) < 10

addDivisionEquality方法签名是:

代码语言:javascript
复制
Constraint addDivisionEquality (IntVar target, IntVar num, IntVar denom)    

哪里

代码语言:javascript
复制
IntVar target = model.newIntVar(0, 10, "(x+y+z)/(x+y+z+k)");

但现在我需要将分子和分母定义为IntVar类型,而它们是多个intVars的总和。

Java包提供了一个名为SumOfVariables的类来对intVars求和,但是addDivisionEquality方法需要IntVar。我希望它得到的是LinearExpr

如何将分子和分母定义为IntVar类型?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-14 21:22:53

代码语言:javascript
复制
IntVar numerator = model.newIntVar(0, 10, "(x+y+z)");
model.addEquality(target, LinearExpr.sum(new IntVar[] {x, y, z}));

我是这么说的

代码语言:javascript
复制
model.addLessThan(LinearExpr.sum(new IntVar[] {x, y, z}), 
                  LinearExpr.scalProd(new IntVar[] {x, y, z, k}, new int[] {10, 10, 10, 10}));

要简单得多。

最后,如果所有变量都是正的,

代码语言:javascript
复制
(x + y + z) / (x + y + z + k) is always <= 1
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62372841

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档