P中值选址问题的整数规划求解-cplex

2023-10-28 21:50

本文主要是介绍P中值选址问题的整数规划求解-cplex,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题介绍

p-中值选址问题是一个常见的选址问题. 问题是给定I个需求结点和J个待选设施地点, 要求选择p个地点建立设施, 使得运输成本最低。

数学模型

在这里插入图片描述

leapms介绍

使用Java+cplex求解问题前,先介绍一种全新且高效的建模工具——Leapms。
Leapms 是一个用于求解整数规划的免费建模语言,具备简洁的建模过程。Leapms 语言设计的原则包括:(1)采用描述性语言形式;(2)尽力与模型的数学表达形式一致。leapms软件应用网站:https://www.cnblogs.com/leapms/
语言开发者:陆教授(yplu@bjtu.edu.cn)

数据定义

//    数据参数定义
class DataMedian{//        需求double[] demand={3.1,2.2,4.3,5.0,7.1,8.0,9.9,3.4,4.3,3.3};//        距离矩阵double[][] distance={{73, 30, 15,  8, 67, 34, 82, 50,  9, 12},{89, 85, 90, 56, 79, 51, 52, 72, 51, 52},{26, 99, 60, 47, 47, 21, 20, 30, 42, 27},{97, 99, 89, 60, 96, 43,  2,  7, 45, 34},{27, 46, 34, 54, 61, 97, 12, 55, 39, 23},{73, 46, 81, 12, 15, 44, 46, 76, 48, 36},{6, 60, 31, 47, 41,  8, 34, 69, 57, 23},{46,  5, 45, 37, 14, 75, 72, 12, 15, 88},{42, 10, 93, 36, 19, 63, 71, 42, 94, 62},{62, 44, 66, 11, 88, 81, 52, 42, 81, 43}};//        选址数量int medianNumber=6;//        节点数量int nodeNumber=10;
}

问题建模

public class PMedianDemo {//    定义数据DataMedian data;public PMedianDemo(DataMedian data){this.data=data;}//    定义cplex内部对象IloCplex model;//    定义变量public IloNumVar[] x;public IloNumVar[][] y;//    求解函数public void solve() throws IloException {if(model.solve()==false){
//            模型不可解System.out.println("模型不可解");return;}else{System.out.println("目标值:"+model.getObjValue());System.out.println("=========选择变量===========");for(int i=0;i<data.nodeNumber;i++){if(model.getValue(x[i])!=0) {System.out.println("变量值x[" + (i + 1) + "]:" + model.getValue(x[i]));}}System.out.println("=========分配关系===========");for(int i=0;i<data.nodeNumber;i++){for(int j=0;j<data.nodeNumber;j++) {if (model.getValue(y[i][j]) != 0) {System.out.println("变量值y[" + (i + 1) + "]["+(j+1)+"]:" + model.getValue(y[i][j]));}}}}}//    根据数学模型建立求解模型public void BuildModel() throws IloException{
//        modelmodel = new IloCplex();model.setOut(null);
//        variablesx = new IloNumVar[data.nodeNumber];y = new IloNumVar[data.nodeNumber][data.nodeNumber];
//        定义cplex变量x和y的数据类型及取值范围for(int i=0;i<data.nodeNumber;i++){x[i]=model.numVar(0,1, IloNumVarType.Int,"x["+i+"]");}for(int i=0;i<data.nodeNumber;i++){for(int j=0;j<data.nodeNumber;j++) {y[i][j] = model.numVar(0, 1, IloNumVarType.Int, "y[" + i + "]["+j+"]");}}
//        设置目标函数IloNumExpr obj = model.numExpr();for(int i=0;i<data.nodeNumber;i++){for(int j=0;j<data.nodeNumber;j++) {double odjTem=data.demand[i]*data.distance[i][j];obj = model.sum(obj, model.prod(odjTem,y[i][j]));}}model.addMinimize(obj);
//        添加约束1for(int i=0;i<data.nodeNumber;i++) {IloNumExpr expr1 = model.numExpr();for(int j=0;j<data.nodeNumber;j++){expr1=model.sum(expr1,y[i][j]);}model.addEq(expr1,1);}
//        添加约束2for(int i=0;i<data.nodeNumber;i++) {for(int j=0;j<data.nodeNumber;j++){model.addLe(y[i][j],x[j]);}}
//        添加约束3IloNumExpr expr3 = model.numExpr();for(int j=0;j<data.nodeNumber;j++){expr3=model.sum(expr3,x[j]);}model.addEq(expr3,data.medianNumber);}

问题求解

public static void main(String[] args)throws IloException{DataMedian data =new DataMedian();PMedianDemo lp=new PMedianDemo(data);lp.BuildModel();lp.solve();}

求解结果

在这里插入图片描述
在这里插入图片描述

=======================================
今天到此为止,后续记录其他cplex技术的学习过程。
以上学习笔记,如有侵犯,请立即联系并删除!

这篇关于P中值选址问题的整数规划求解-cplex的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/296183

相关文章

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Idea插件MybatisX失效的问题解决

《Idea插件MybatisX失效的问题解决》:本文主要介绍Idea插件MybatisX失效的问题解决,详细的介绍了4种问题的解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、重启idea或者卸载重装MyBATis插件(无需多言)二、检查.XML文件与.Java(该文件后缀Idea可能会隐藏

Nginx 访问 /root/下 403 Forbidden问题解决

《Nginx访问/root/下403Forbidden问题解决》在使用Nginx作为Web服务器时,可能会遇到403Forbidden错误,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录解决 Nginx 访问 /root/test/1.html 403 Forbidden 问题问题复现Ng

Python的pip在命令行无法使用问题的解决方法

《Python的pip在命令行无法使用问题的解决方法》PIP是通用的Python包管理工具,提供了对Python包的查找、下载、安装、卸载、更新等功能,安装诸如Pygame、Pymysql等Pyt... 目录前言一. pip是什么?二. 为什么无法使用?1. 当我们在命令行输入指令并回车时,一般主要是出现以

Nginx部署React项目时重定向循环问题的解决方案

《Nginx部署React项目时重定向循环问题的解决方案》Nginx在处理React项目请求时出现重定向循环,通常是由于`try_files`配置错误或`root`路径配置不当导致的,本文给大家详细介... 目录问题原因1. try_files 配置错误2. root 路径错误解决方法1. 检查 try_f

Python解决雅努斯问题实例方案详解

《Python解决雅努斯问题实例方案详解》:本文主要介绍Python解决雅努斯问题实例方案,雅努斯问题是指AI生成的3D对象在不同视角下出现不一致性的问题,即从不同角度看物体时,物体的形状会出现不... 目录一、雅努斯简介二、雅努斯问题三、示例代码四、解决方案五、完整解决方案一、雅努斯简介雅努斯(Janu

MySQL索引失效问题及解决方案

《MySQL索引失效问题及解决方案》:本文主要介绍MySQL索引失效问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql索引失效一、概要二、常见的导致MpythonySQL索引失效的原因三、如何诊断MySQL索引失效四、如何解决MySQL索引失

一文教你如何解决Python开发总是import出错的问题

《一文教你如何解决Python开发总是import出错的问题》经常朋友碰到Python开发的过程中import包报错的问题,所以本文将和大家介绍一下可编辑安装(EditableInstall)模式,可... 目录摘要1. 可编辑安装(Editable Install)模式到底在解决什么问题?2. 原理3.

Redis中的数据一致性问题以及解决方案

《Redis中的数据一致性问题以及解决方案》:本文主要介绍Redis中的数据一致性问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Redis 数据一致性问题的产生1. 单节点环境的一致性问题2. 网络分区和宕机3. 并发写入导致的脏数据4. 持

vscode不能打开终端问题的解决办法

《vscode不能打开终端问题的解决办法》:本文主要介绍vscode不能打开终端问题的解决办法,问题的根源是Windows的安全软件限制了PowerShell的运行,而VSCode默认使用Powe... 遇到vscode不能打开终端问题,一直以为是安全软件限制问题,也没搜到解决方案,因为影响也不大,就没有管