当前位置: 首页 > news >正文

分段线性化问题探析

目录

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:gncon = [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值也就更加精确。

http://www.lryc.cn/news/313205.html

相关文章:

  • 从零学算法2917
  • [HackMyVM] 靶场 Wave
  • 云渲染平台都开始涨价了?2024年性价比高的云渲染平台推荐
  • 搜索-BFS Meteor Shower S(流星雨)
  • RabbitMQ实战:Springboot集成RabbitMQ并验证五种消息模型
  • 配置与管理防火墙
  • 【SpringBoot】-- 实现本地文件/图片上传到服务器生成url地址
  • 计算机基础专升本笔记十四-计算机网络基础(一)
  • 【华为OD机试】转盘寿司【C卷|100分】
  • 使用Node JS获取WI-FI密码
  • 先缓存第二集抖音接入 ,最近加班猛,就分享简单的知识,如何使用:关于使用replace的用法正则表达式
  • 企微hook源码
  • vsphere虚拟机迁移是灰色如何解决
  • swift 闭包捕获列表
  • JavaWeb04-Request,Response
  • 使用 Docker 部署 Fiora 在线聊天室平台
  • Unity Samples和帧动画的问题
  • 几何工具的使用
  • sudo command not found
  • 1.【Labview白话系列】Labview数组精讲
  • ANTLR4规则解析生成器(三):遍历语法分析树
  • OpenCV实现目标追踪
  • 【剑指offer--C/C++】JZ6 从尾到头打印链表
  • 算法-买卖股票的最佳时机
  • 【大数据】Flink SQL 语法篇(十):EXPLAIN、USE、LOAD、SET、SQL Hints
  • Java中List接口常见的实现类
  • SPI通信
  • 【动态规划】【数论】【区间合并】3041. 修改数组后最大化数组中的连续元素数目
  • 字节后端实习 一面凉经
  • 倒计时37天