运筹优化学习09:一个示例带你入门如何使用C++、C#、Java、Python、Matlab调用Cplex(上)

简介: 运筹优化学习09:一个示例带你入门如何使用C++、C#、Java、Python、Matlab调用Cplex

1 C++调用Cplex的在VS2010中的配置及示例代码演示

1.1 cplex在vs2010中的配置

  • 正常建立一个控制台项目
  • 在【项目--属性】下,作如下设置:
  • 【C/C++】--【常规】--【附加库目录】,添加如下两个库目录:
你的安装位置\concert\include
你的安装位置\cplex\include
  • 【C/C++】--【预处理器】--【预处理器定义】,粘贴如下内容:
WIN32
NDEBUG
_CONSOLE
_LIB
IL_STD
  • 【连接器】--【附加库目录】,选中如下两个路径:

你的安装路径\concert\lib\x86_windows_vs2010\stat_mda

你的安装路径\cplex\lib\x86_windows_vs2010\stat_mda

  • 【连接器】--【附加依赖项】,复制以下内容:
concert.lib
cplex1261.lib
ilocplex.lib

1.2 测试示例

1.2.1 测试用例

gif.png

1.2.2 测试代码

//**************************************************************//
// the test version of Cplex with C++
// time 2019-09-28
// author A & R
//*************************************************************//
#include <ilcplex/ilocplex.h>
#include<cstdlib>
#include<iostream>
ILOSTLBEGIN //#define ILOSTLBEGIN using namespace std;
int main(int argc, char **argv)
{
  IloEnv env;//construct an Cplex environment env, which belongs to a handle class IloEnv;
  try{
  IloModel model(env);// define the varies "env"
  IloNumVarArray vars(env);// define the varies vars(env), the x1, x2, x3 can be expressed with vars(0), vars(1), vars(2)
  // define the bounds of varies
  vars.add(IloNumVar(env, 0.0, 40.0));
  vars.add(IloNumVar(env));
  vars.add(IloNumVar(env));
  //objective to optimize:
  model.add(IloMaximize(env, vars[0]+2*vars[1]+3*vars[2]));//opjective: Maximize the x1+2*x2+3*x3;
  //subject to:
  model.add(-vars[0]+vars[1]+vars[2]<=20);
  model.add(vars[0]-3*vars[1]+vars[2]<=30);
  //expection processing, refer to "C++ try&catch"
  IloCplex cplex(model);
  if(!cplex.solve()){
  env.error()<<"Failed to optimize LP."<<endl;
  throw(-1);
  }
  IloNumArray vals(env);
  env.out() << "solution status = "<< cplex.getStatus() << endl;
  env.out() << "Solution value=" << cplex.getObjective() << endl;
  cplex.getValues(vals, vars);
  env.out() << "Values = " << vals << endl;
  }
  // cathch functions, refer to "C++ try&catch"
  catch(IloException&e){
  cerr << "Concert exception caught:" << e << endl;
  }
  catch(...){
  cerr << "Unknown exception caught" << endl;
  }
  env.end();
  //return 0;
  system("PAUSE");
  return EXIT_SUCCESS;
}

1.2.3 运行结果

20190928110724786.png


2 C#调用Cplex在VS2010下的配置

2.1 C#配置Cplex

这个配置比较简单,直接添加两个引用即可


你的Cplex安装目录\cplex\bin\x86_win32\ILOG.CPLEX.dll"

你的Cplex安装目录\cplex\bin\x86_win32\ILOG.Concert.dll"


2.2 算例测试及代码

2.2.1 算例代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using ILOG.Concert;
using ILOG.CPLEX;
namespace csCplex
{
    class Program
    {
        static void Main(string[] args)
        {
            try
            {
                //1 先创建一个Cplex空模型
                Cplex cplexModel = new Cplex();
                //2 生成决策变量并赋值
                INumVar[][] deVar = new INumVar[1][];
                double[] lowerBound = { 0.0, 0.0, 0.0};
                double[] upBound = { 40.0, double.MaxValue,double.MaxValue };
                string[] deVarName = { "x1", "x2", "x3"};
                //包含两个变量,下界,上界,变量名称
                INumVar[] X = cplexModel.NumVarArray(3, lowerBound, upBound, deVarName);
                deVar[0] = X;
                //定义模型目标函数的系数
                double[] objCoff = { 1.0, 2.0, 3.0 };
                cplexModel.AddMaximize(cplexModel.ScalProd(X, objCoff));
                //3 添加约束条件
                IRange[][] rng = new IRange[1][];
                rng[0] = new IRange[2];
                //添加小于等于约束
                rng[0][0] = cplexModel.AddLe(
                            cplexModel.Sum(cplexModel.Prod(-1.0, X[0]), cplexModel.Prod(1.0, X[1]),cplexModel.Prod(1.0, X[2])), 
                            20, "约束1");
                rng[0][1] = cplexModel.AddLe(
                            cplexModel.Sum(cplexModel.Prod(1.0, X[0]), cplexModel.Prod(-3.0, X[1]), cplexModel.Prod(1.0, X[2])),
                            30, "约束2");
                //4 导出模型
                cplexModel.ExportModel("C#调用Cplex演示示例模型.lp");
                //5 求解模型
                if (cplexModel.Solve())
                {
                    int nvars = cplexModel.GetValues(deVar[0]).Length;
                    for (int i = 0; i < nvars; i++)
                    {
                        cplexModel.Output().WriteLine("x" + i + "=" + cplexModel.GetValues(deVar[0])[i]);
                    }
                }
                cplexModel.End();
            }
            catch(ILOG.Concert.Exception e)
            {
                System.Console.WriteLine("concert exception:" + e);
            }
            finally
            {
                System.Console.WriteLine("模型求解完毕");
            }
        }
    }
}

2.2.3 运行结果

20190928120332678.png

201909281203529.png


3 Java语言调用Cplex的配置与示例演示

注意java的位数要与Cplex的位数一致,64位与32位不兼容

3.1 配置

  • 添加环境变量

您的Cplex安装路径\cplex\bin\x86_win32\cplex1261.dll

您的Cplex安装路径\cplex\lib\cplex.jar

  • 设置构建路径,【你的java项目,右键】--【Bulid Path】--【Condigure Build Path..】--【Existing Project into Workspce】--【Next】

20190928121841245.png

  • 【Add External jars】,选择你安装位置下的\cplex\lib\cplex.jar

20190928122236347.png

  • 配置库

2019092812334616.png


相关文章
|
6月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
775 7
|
7月前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
530 1
|
6月前
|
Cloud Native 算法 API
Python API接口实战指南:从入门到精通
🌟蒋星熠Jaxonic,技术宇宙的星际旅人。深耕API开发,以Python为舟,探索RESTful、GraphQL等接口奥秘。擅长requests、aiohttp实战,专注性能优化与架构设计,用代码连接万物,谱写极客诗篇。
1276 1
Python API接口实战指南:从入门到精通
|
6月前
|
存储 Java 调度
Python定时任务实战:APScheduler从入门到精通
APScheduler是Python强大的定时任务框架,通过触发器、执行器、任务存储和调度器四大组件,灵活实现各类周期性任务。支持内存、数据库、Redis等持久化存储,适用于Web集成、数据抓取、邮件发送等场景,解决传统sleep循环的诸多缺陷,助力构建稳定可靠的自动化系统。(238字)
1138 1
|
7月前
|
机器学习/深度学习 编解码 数据可视化
【能量算子】评估 EEG 中的瞬时能量:非负、频率加权能量算子(Python&Matlab代码实现)
【能量算子】评估 EEG 中的瞬时能量:非负、频率加权能量算子(Python&Matlab代码实现)
122 6
|
7月前
|
调度 数据库 Python
Python异步编程入门:asyncio让并发变得更简单
Python异步编程入门:asyncio让并发变得更简单
407 5
|
7月前
|
数据采集 存储 XML
Python爬虫入门(1)
在互联网时代,数据成为宝贵资源,Python凭借简洁语法和丰富库支持,成为编写网络爬虫的首选。本文介绍Python爬虫基础,涵盖请求发送、内容解析、数据存储等核心环节,并提供环境配置及实战示例,助你快速入门并掌握数据抓取技巧。
|
7月前
|
大数据 数据处理 数据安全/隐私保护
Python3 迭代器与生成器详解:从入门到实践
简介:本文深入解析Python中处理数据序列的利器——迭代器与生成器。通过通俗语言与实战案例,讲解其核心原理、自定义实现及大数据处理中的高效应用。
365 0
|
7月前
|
XML 前端开发 C#
C#编程实践:解析HTML文档并执行元素匹配
通过上述步骤,可以在C#中有效地解析HTML文档并执行元素匹配。HtmlAgilityPack提供了一个强大而灵活的工具集,可以处理各种HTML解析任务。
340 19
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
383 3

推荐镜像

更多
下一篇
开通oss服务