【求解器】调用Gurobi求解LP问题(Java代码示例)

简介: 【求解器】调用Gurobi求解LP问题(Java代码示例)

@[toc]


问题

在这里插入图片描述

代码

import gurobi.*;
/**
 * @Author:WSKH
 * @ClassName:TestGurobi
 * @ClassType:
 * @Description:
 * @Date:2022/6/5/11:38
 * @Email:1187560563@qq.com
 * @Blog:https://blog.csdn.net/weixin_51545953?type=blog
 */
public class TestGurobi{
    public static void main(String[] args) {
        try {
            // 创建环境
            GRBEnv grbEnv = new GRBEnv("grbEnv");
            // 创建模型
            GRBModel grbModel = new GRBModel(grbEnv);
            // 声明CONTINUOUS连续变量
            GRBVar x1 = grbModel.addVar(-10, 50, -10, GRB.CONTINUOUS, "x1");
            GRBVar x2 = grbModel.addVar(0, Double.MAX_VALUE, 0, GRB.CONTINUOUS, "x2");
            GRBVar x3 = grbModel.addVar(5, 5, 5, GRB.CONTINUOUS, "x3");
            // 声明变量数组
            GRBVar[] grbVars = {x1, x2, x3};
            // 声明约束
            // 约束1:x1+2*x2+x3<=100
            GRBLinExpr expr1 = new GRBLinExpr();
            expr1.addTerms(new double[]{1,2,1},grbVars);
            grbModel.addConstr(expr1,GRB.LESS_EQUAL,100,"expr1");
            // 约束2:x1+x2-2x3>=10
            GRBLinExpr expr2 = new GRBLinExpr();
            expr2.addTerms(new double[]{1,1,-2},grbVars);
            grbModel.addConstr(expr2,GRB.GREATER_EQUAL,10,"expr2");
            // 目标函数:x1+2*x2+3*x3
            GRBLinExpr target = new GRBLinExpr();
            target.addTerms(new double[]{1,2,3},grbVars);
            grbModel.setObjective(target,GRB.MAXIMIZE);
            // 开始求解
            grbModel.optimize();
            // 输出求解结果
            System.out.println("最优解为:"+grbModel.get(GRB.DoubleAttr.ObjVal));
            System.out.println("x1 = "+x1.get(GRB.DoubleAttr.X));
            System.out.println("x2 = "+x2.get(GRB.DoubleAttr.X));
            System.out.println("x3 = "+x3.get(GRB.DoubleAttr.X));
            // 处理模型和环境
            grbModel.dispose();
            grbEnv.dispose();
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}

求解结果

Set parameter Username
Academic license - for non-commercial use only - expires 2022-08-03
Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)
Thread count: 6 physical cores, 12 logical processors, using up to 12 threads
Optimize a model with 2 rows, 3 columns and 6 nonzeros
Model fingerprint: 0x5c13f6c7
Coefficient statistics:
  Matrix range     [1e+00, 2e+00]
  Objective range  [1e+00, 3e+00]
  Bounds range     [5e+00, 5e+01]
  RHS range        [1e+01, 1e+02]
Presolve removed 2 rows and 3 columns
Presolve time: 0.00s
Presolve: All rows and columns removed
Iteration    Objective       Primal Inf.    Dual Inf.      Time
       0    1.1000000e+02   0.000000e+00   0.000000e+00      0s

Solved in 0 iterations and 0.00 seconds (0.00 work units)
Optimal objective  1.100000000e+02
最优解为:110.0
x1 = 50.0
x2 = 22.5
x3 = 5.0
目录
相关文章
|
1月前
|
Java 开发工具
【Azure Storage Account】Java Code访问Storage Account File Share的上传和下载代码示例
本文介绍如何使用Java通过azure-storage-file-share SDK实现Azure文件共享的上传下载。包含依赖引入、客户端创建及完整示例代码,助你快速集成Azure File Share功能。
331 4
|
1月前
|
Java 数据处理 API
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
232 115
|
1月前
|
安全 Java 编译器
为什么你的Java代码需要泛型?类型安全的艺术
为什么你的Java代码需要泛型?类型安全的艺术
171 98
|
1月前
|
Java 编译器 API
java最新版和java8的区别,用代码展示
java最新版和java8的区别,用代码展示
224 43
|
1月前
|
安全 Java 容器
告别空指针噩梦:Optional让Java代码更优雅
告别空指针噩梦:Optional让Java代码更优雅
347 94
|
1月前
|
安全 Java 容器
告别繁琐判空:Optional让你的Java代码更优雅
告别繁琐判空:Optional让你的Java代码更优雅
|
2月前
|
IDE Java 关系型数据库
Java 初学者学习路线(含代码示例)
本教程为Java初学者设计,涵盖基础语法、面向对象、集合、异常处理、文件操作、多线程、JDBC、Servlet及MyBatis等内容,每阶段配核心代码示例,强调动手实践,助你循序渐进掌握Java编程。
384 3
|
2月前
|
安全 Java 应用服务中间件
Spring Boot + Java 21:内存减少 60%,启动速度提高 30% — 零代码
通过调整三个JVM和Spring Boot配置开关,无需重写代码即可显著优化Java应用性能:内存减少60%,启动速度提升30%。适用于所有在JVM上运行API的生产团队,低成本实现高效能。
268 3
|
2月前
|
Java
java入门代码示例
本文介绍Java入门基础,包含Hello World、变量类型、条件判断、循环及方法定义等核心语法示例,帮助初学者快速掌握Java编程基本结构与逻辑。
395 0

热门文章

最新文章