IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> Cplex教程(C++) -> 正文阅读

[C++知识库]Cplex教程(C++)

Cplex教程(C++)

背景

Cplex是一款十分强大的商用规划求解器,之前本人在求解博弈策略的时候使用过,认为其至少有两大优势。

  • 求解速度十分快,并且听说可以支持上千个变量。
  • 在C++中,与Cplex接口的语法十分简单,几乎就是无脑编写。

但是在使用的过程中我也发现了一些问题,比如有一些较复杂的多次规划,matlab可以求解但是Cplex好像不支持求解?

但是瑕不掩瑜,Cplex依旧是我求解规划的第一选择,下面我来结合官方文档简单介绍一下Cplex的入门使用,进阶的操作方法需要靠读者们自行去钻研啦。这里贴一下Cplex的官方文档,写得十分棒,不需要再去借鉴其他资料了。

Cplex官方文档

环境搭建

本人是在Win系统下搭建Cplex环境的,前前后后花了大概一节操作系统课的时间才完成(yp哥应该不会看到这篇博客)。网上的很多教程都是针对VS2015或者是更早的一些版本搭建的,在借鉴后发现都存在问题。最后,我是参考了一个up主的视频教程才完美搭建的。

Cplex环境搭建视频教程

简单语法介绍

环境创建与关闭

IloEnv env;
env.end();

变量的创建

对于简单变量的创建使用形如下面的语句:

IloNumVarArray vars(env);
//类型可以是 ILOFLOAT、ILOINT 或 ILOBOOL,分别代表连续变量、整数变量或布尔型变量。
vars.add(IloNumVar(env, 0, 40, ILOINT));  // 0 <= x1 <= 40 且 x1为整数
vars.add(IloNumVar(env, -1, 10, ILOINT));

注意用此类语句顺序创建出来的变量在之后的程序中分别表现为***vars[0]、vars[1]、vars[2]***等

对于复杂的变量表达式创建可以参考如下语句:

IloExpr expr(env);
for (int i = 0; i < x.getSize(); ++i)
  expr += vars[i] * x[i];
//这句话创建出来的表达式expr在后面的约束式、目标式中均可以直接使用

声明约束

IloModel model(env);
model.add(-vars[0] + vars[1] + vars[2] <= 20);//subject to -x1 + x2 + x3 <= 20
model.add(vars[0] - 3 * vars[1] + vars[2] <= 30);//x1 - 3 x2 + x3 <=30

声明目标

model.add(IloMaximize(env, vars[0] + 2 * vars[1] + 3 * vars[2])); //maximize x1 + 2 x2 + 3 x3
//很显然这里的Max也可以改为Min

实例介绍

使用之前记得把解决方案改为***Release x64***。

下面这个是Cplex自带的一个实例,可以用来测试一下自己的环境是否已经成功搭建。具体的实现内容,相信结合之前的语法介绍以及零星的一些注释也可以明白程序在求解一个什么形式的规划。

在使用的使用在这个程序上修修改改一般就可以了。

#include <ilcplex/ilocplex.h>
#include <stdio.h>
using namespace std;

ILOSTLBEGIN
int
main(void*) {
	IloEnv env;
	try {
		IloModel model(env);
		IloNumVarArray vars(env);
		vars.add(IloNumVar(env, 0.0, 40.0));  // 0 <= x1 <= 40
		vars.add(IloNumVar(env));  // 0 <= x2
		vars.add(IloNumVar(env));  // 0 <= x3
		model.add(IloMaximize(env, vars[0] + 2 * vars[1] + 3 * vars[2])); //maximize x1 + 2 x2 + 3 x3
		model.add(-vars[0] + vars[1] + vars[2] <= 20);//subject to -x1 + x2 + x3 <= 20
		model.add(vars[0] - 3 * vars[1] + vars[2] <= 30);//x1 - 3 x2 + x3 <=30
		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.getObjValue() << endl;
		cplex.getValues(vals, vars);
		env.out() << "Values = " << vals << endl;
	}
	catch (IloException & e) { cerr << "Concert exception caught: " << e << endl; }
	catch (...) { cerr << "Unknown exception caught" << endl; }
	env.end();
	system("pause");
	return 0;
}
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-09-04 17:19:43  更:2021-09-04 17:21:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/27 20:45:28-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计