【求解器】调用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
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
65 1
|
2天前
|
安全 Java 编译器
深入理解Java中synchronized三种使用方式:助您写出线程安全的代码
`synchronized` 是 Java 中的关键字,用于实现线程同步,确保多个线程互斥访问共享资源。它通过内置的监视器锁机制,防止多个线程同时执行被 `synchronized` 修饰的方法或代码块。`synchronized` 可以修饰非静态方法、静态方法和代码块,分别锁定实例对象、类对象或指定的对象。其底层原理基于 JVM 的指令和对象的监视器,JDK 1.6 后引入了偏向锁、轻量级锁等优化措施,提高了性能。
12 3
|
27天前
|
Java
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
50 24
|
9天前
|
前端开发 Java 测试技术
java日常开发中如何写出优雅的好维护的代码
代码可读性太差,实际是给团队后续开发中埋坑,优化在平时,没有那个团队会说我专门给你一个月来优化之前的代码,所以在日常开发中就要多注意可读性问题,不要写出几天之后自己都看不懂的代码。
48 2
|
24天前
|
Java 编译器 数据库
Java 中的注解(Annotations):代码中的 “元数据” 魔法
Java注解是代码中的“元数据”标签,不直接参与业务逻辑,但在编译或运行时提供重要信息。本文介绍了注解的基础语法、内置注解的应用场景,以及如何自定义注解和结合AOP技术实现方法执行日志记录,展示了注解在提升代码质量、简化开发流程和增强程序功能方面的强大作用。
64 5
|
24天前
|
存储 算法 Java
Java 内存管理与优化:掌控堆与栈,雕琢高效代码
Java内存管理与优化是提升程序性能的关键。掌握堆与栈的运作机制,学习如何有效管理内存资源,雕琢出更加高效的代码,是每个Java开发者必备的技能。
49 5
|
26天前
|
Java API 开发者
Java中的Lambda表达式:简洁代码的利器####
本文探讨了Java中Lambda表达式的概念、用途及其在简化代码和提高开发效率方面的显著作用。通过具体实例,展示了Lambda表达式如何在Java 8及更高版本中替代传统的匿名内部类,使代码更加简洁易读。文章还简要介绍了Lambda表达式的语法和常见用法,帮助开发者更好地理解和应用这一强大的工具。 ####
|
29天前
|
Java API Maven
商汤人像如何对接?Java代码如何写?
商汤人像如何对接?Java代码如何写?
38 5
|
1月前
|
XML 安全 Java
Java反射机制:解锁代码的无限可能
Java 反射(Reflection)是Java 的特征之一,它允许程序在运行时动态地访问和操作类的信息,包括类的属性、方法和构造函数。 反射机制能够使程序具备更大的灵活性和扩展性
47 5
Java反射机制:解锁代码的无限可能
|
1月前
|
Java
在Java中实现接口的具体代码示例
可以根据具体的需求,创建更多的类来实现这个接口,以满足不同形状的计算需求。希望这个示例对你理解在 Java 中如何实现接口有所帮助。
42 1