lingo中怎么给有约束条件的0-1变量赋值,怎么实现if语句
展开全部
1.
sets:
x/1..m/;
y/1..4/;
matrix(x,y):b;!定义矩阵b
endsets
data:
!可以这里对需要赋值的数组或矩阵赋值;
enddata
!下面是针对你的问题所需要的语句;
@for(x(i):@sum(y(j):b(i,j))=1);
@for(matrix(i,j):@bin(b));
2.
Lingo似乎不能实现你要求的那种if语句,Lingo主要是针对成员集合生成约束条件,不能进行判断;
3.
约束条件可以给中间变量赋值,比如要将矩阵x与w的乘积赋值给矩阵y,可以用下面的代码:
@for(PX(i,j):y(i,j)=@sum(s(k):x(i,k)*w(k,j)))
sets:
x/1..m/;
y/1..4/;
matrix(x,y):b;!定义矩阵b
endsets
data:
!可以这里对需要赋值的数组或矩阵赋值;
enddata
!下面是针对你的问题所需要的语句;
@for(x(i):@sum(y(j):b(i,j))=1);
@for(matrix(i,j):@bin(b));
2.
Lingo似乎不能实现你要求的那种if语句,Lingo主要是针对成员集合生成约束条件,不能进行判断;
3.
约束条件可以给中间变量赋值,比如要将矩阵x与w的乘积赋值给矩阵y,可以用下面的代码:
@for(PX(i,j):y(i,j)=@sum(s(k):x(i,k)*w(k,j)))
TableDI
2024-07-18 广告
2024-07-18 广告
VLOOKUP是Excel中用于垂直查找的函数,其基本用法包括四个参数:1. 查找值:即在数据表首列中需要搜索的值。2. 数据表:包含查找值的单元格区域或数组。3. 返回值所在列数:指定返回查询区域中第几列的值。4. 查找方式:选择精确匹配...
点击进入详情页
本回答由TableDI提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询