分段线性化问题探析

目录

1 使用0-1变量将分段函数转换为线性约束

2 连续函数采用分段线性化示例

3 matlab程序测试

4 matlab测试结果说明

5 分段线性化应用


使用0-1变量将分段函数转换为线性约束

连续函数采用分段线性化示例

matlab程序测试

clc;clear all;
gn=10;tn=1;
x_pf=sdpvar(1, tn,'full');
Pgone=8;
gw1=sdpvar(gn+1,tn,'full');
gz1=binvar(gn, tn,'full');
gl1=10/gn;
for i=1:1
gl2(i,:)=0:gl1:10;
end
con=[];
con = [con, x_pf(1,:)==gl2(1,:).^2*gw1];
con = [con, gw1(1,:)<=gz1(1,:)];
for i=2:gn
    con = [con, gw1(i,:)<=gz1(i-1,:)+gz1(i,:)];
end
con = [con, gw1(gn+1,:)<=gz1(gn,:)];
con = [con, sum(gw1)==ones(1,tn)];
con = [con, sum(gz1)==ones(1,tn)];
con = [con, Pgone(1,:)==gl2(1,:)*gw1];
​
con = [con, gw1>=0];
f=1;
ops=sdpsettings('solver','cplex');
result=optimize(con,f,ops);

matlab测试结果说明

在上述测试程序中,Pgone是平方之前的变量,x_pf是平方项,为了测试运算效果,目标函数采用定值,这样就能验证约束是不是严格限制,上述程序将Pgone取值为8,最终得到x_pf得64,将Pgone改成5,则x_pf得25,可以看出,此分段线性化模型严格约束。

大家在测试过程中,可以调节gn的值,该值代表的是分段数量,调节该值能够发现,随着分段数量增多,分段线性化的精度也会越来越高,如,当Pgone=5,gn=3时,x_pf=27.78,随着gn增大,x_pf值也就更加精确。

  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值