运筹优化学习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


相关文章
|
5天前
|
数据采集 机器学习/深度学习 人工智能
Python编程入门:从基础到实战
【10月更文挑战第24天】本文将带你进入Python的世界,从最基础的语法开始,逐步深入到实际的项目应用。我们将一起探索Python的强大功能和灵活性,无论你是编程新手还是有经验的开发者,都能在这篇文章中找到有价值的内容。让我们一起开启Python的奇妙之旅吧!
|
7天前
|
数据采集 存储 数据库
Python中实现简单爬虫的入门指南
【10月更文挑战第22天】本文将带你进入Python爬虫的世界,从基础概念到实战操作,一步步指导你如何使用Python编写一个简单的网络爬虫。我们将不展示代码示例,而是通过详细的步骤描述和逻辑讲解,帮助你理解爬虫的工作原理和开发过程。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你打开一扇通往数据收集新世界的大门。
|
5天前
|
测试技术 开发者 Python
探索Python中的装饰器:从入门到实践
【10月更文挑战第24天】 在Python的世界里,装饰器是一个既神秘又强大的工具。它们就像是程序的“隐形斗篷”,能在不改变原有代码结构的情况下,增加新的功能。本篇文章将带你走进装饰器的世界,从基础概念出发,通过实际例子,逐步深入到装饰器的高级应用,让你的代码更加优雅和高效。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开一扇通往高效编程的大门。
|
7天前
|
存储 人工智能 数据挖掘
Python编程入门:构建你的第一个程序
【10月更文挑战第22天】编程,这个听起来高深莫测的词汇,实际上就像搭积木一样简单有趣。本文将带你走进Python的世界,用最浅显的语言和实例,让你轻松掌握编写第一个Python程序的方法。无论你是编程新手还是希望了解Python的爱好者,这篇文章都将是你的理想起点。让我们一起开始这段奇妙的编程之旅吧!
13 3
|
6天前
|
机器学习/深度学习 人工智能 算法
机器学习基础:使用Python和Scikit-learn入门
机器学习基础:使用Python和Scikit-learn入门
18 1
|
8天前
|
存储 程序员 开发者
Python编程入门:从零开始掌握基础语法
【10月更文挑战第21天】本文将带你走进Python的世界,通过浅显易懂的语言和实例,让你快速了解并掌握Python的基础语法。无论你是编程新手还是想学习一门新的编程语言,这篇文章都将是你的不二之选。我们将一起探索变量、数据类型、运算符、控制结构、函数等基本概念,并通过实际代码示例加深理解。准备好了吗?让我们开始吧!
|
8天前
|
数据采集 机器学习/深度学习 数据可视化
深入浅出:用Python进行数据分析的入门指南
【10月更文挑战第21天】 在信息爆炸的时代,掌握数据分析技能就像拥有一把钥匙,能够解锁隐藏在庞大数据集背后的秘密。本文将引导你通过Python语言,学习如何从零开始进行数据分析。我们将一起探索数据的收集、处理、分析和可视化等步骤,并最终学会如何利用数据讲故事。无论你是编程新手还是希望提升数据分析能力的专业人士,这篇文章都将为你提供一条清晰的学习路径。
java类模拟客户端调用servlet (httpClient)
最近做项目,用到JAVA普通类调用一个servlet应用,所以把部分代码也贴上来了。
142 0
java类模拟客户端调用servlet (httpClient)
java类模拟客户端调用servlet (httpClient)
198 0
|
7天前
|
监控 安全 Java
在 Java 中使用线程池监控以及动态调整线程池时需要注意什么?
【10月更文挑战第22天】在进行线程池的监控和动态调整时,要综合考虑多方面的因素,谨慎操作,以确保线程池能够高效、稳定地运行,满足业务的需求。
77 38