Visual Studio(VS2017/VS2019) C++ 配置 CPLEX 教程

简介: Visual Studio(VS2017/VS2019) C++ 配置 CPLEX 教程

一、涉及软件


Visual Studio 2017、Visual Studio 2019

CPLEX 12.9.0



二、配置效果


1、可以实现C++调用CPLEX求解线性规划,混合整数规划等;

2、可以在debug和release两种模式下进行调试或者运行代码





三、配置步骤


1、首先选择代码运行的环境


20210701105646394.png


(1)、将平台设置为x64或者(活动)x64,此处一定需要修改!不能使用x32平台模式


(2)、配置的设置可以根据需要自行选择release模式或者debug模式(作者建议两种都进行配置一下,方便后续使用)





2、打开项目的属性项


20210701101229166.png




3、修改C/C++附加包含目录


20210701101622924.png


这里找到CPLEX的安装目录(根据自己的安装目录进行修改),如本人的是:


(注:下述若不做特殊说明,均需要将目录替换为自己的目录,若安装时没进行修改,从IBM/ILOG/…的目录同下述目录应该相同)


//CPLEX安装目录
D:\Program Files\IBM\ILOG\CPLEX_Studio129\concert\include
D:\Program Files\IBM\ILOG\CPLEX_Studio129\cplex\include


将上述两项加入到附加目录之中,点击确定,效果如下:

20210701102357509.png




4、修改C/C++预处理器中的预处理器定义项

20210701102638816.png


添加下述命令到预处理器定义中(此处无需进行修改,直接复制粘贴就好):

NDEBUG
_CONSOLE
IL_STD




5、修改C/C++代码生成中的运行库

20210701102950615.png

将此处的改为多线程DLL(/MD)或者多线程调试DLL(/MDd)




6、修改链接器常规项中的“附加库目录项”

20210701104452281.png


将下述两个目录添加到“附加库目录项”中,目录地址同上述CPLEX安装目录相同

D:\Program Files\IBM\ILOG\CPLEX_Studio129\concert\lib\x64_windows_vs2017\stat_mda
D:\Program Files\IBM\ILOG\CPLEX_Studio129\cplex\lib\x64_windows_vs2017\stat_mda



7、修改链接器输入中的“附加依赖项”

20210701105221893.png

将下述两个目录添加到“附加库目录项”中,目录地址同上述CPLEX安装目录相同

D:\Program Files\IBM\ILOG\CPLEX_Studio129\concert\lib\x64_windows_vs2017\stat_mda\concert.lib
D:\Program Files\IBM\ILOG\CPLEX_Studio129\cplex\lib\x64_windows_vs2017\stat_mda\cplex1290.lib
D:\Program Files\IBM\ILOG\CPLEX_Studio129\cplex\lib\x64_windows_vs2017\stat_mda\ilocplex.lib


8、 点击确定,点击应用,大功告成!





四、运行测试代码


1、下面给出CPLEX官方测试文档中的cutstock代码进行测试

#include <ilcplex/ilocplex.h>
ILOSTLBEGIN
#define RC_EPS 1.0e-6
static void readData(const char* filename, IloNum& rollWidth,
  IloNumArray& size, IloNumArray& amount);
static void report1(IloCplex& cutSolver, IloNumVarArray Cut,
  IloRangeArray Fill);
static void report2(IloAlgorithm& patSolver,
  IloNumVarArray Use,
  IloObjective obj);
static void report3(IloCplex& cutSolver, IloNumVarArray Cut);
/// MAIN PROGRAM ///
int main(int argc, char **argv)
{
  IloEnv env;
  try {
    IloInt  i, j;
    IloNum      rollWidth;
    IloNumArray amount(env);
    IloNumArray size(env);
    if (argc > 1)
      readData(argv[1], rollWidth, size, amount);
    else
      readData("cutstock.dat",
        rollWidth, size, amount);
    /// CUTTING-OPTIMIZATION PROBLEM ///
    IloModel cutOpt(env);
    IloObjective   RollsUsed = IloAdd(cutOpt, IloMinimize(env));
    IloRangeArray  Fill = IloAdd(cutOpt,
      IloRangeArray(env, amount, IloInfinity));
    IloNumVarArray Cut(env);
    IloInt nWdth = size.getSize();
    for (j = 0; j < nWdth; j++) {
      Cut.add(IloNumVar(RollsUsed(1) + Fill[j](int(rollWidth / size[j]))));
    }
    IloCplex cutSolver(cutOpt);
    /// PATTERN-GENERATION PROBLEM ///
    IloModel patGen(env);
    IloObjective ReducedCost = IloAdd(patGen, IloMinimize(env, 1));
    IloNumVarArray Use(env, nWdth, 0.0, IloInfinity, ILOINT);
    patGen.add(IloScalProd(size, Use) <= rollWidth);
    IloCplex patSolver(patGen);
    /// COLUMN-GENERATION PROCEDURE ///
    IloNumArray price(env, nWdth);
    IloNumArray newPatt(env, nWdth);
    /// COLUMN-GENERATION PROCEDURE ///
    for (;;) {
      /// OPTIMIZE OVER CURRENT PATTERNS ///
      cutSolver.solve();
      report1(cutSolver, Cut, Fill);
      /// FIND AND ADD A NEW PATTERN ///
      for (i = 0; i < nWdth; i++) {
        price[i] = -cutSolver.getDual(Fill[i]);
      }
      ReducedCost.setLinearCoefs(Use, price);
      patSolver.solve();
      report2(patSolver, Use, ReducedCost);
      if (patSolver.getValue(ReducedCost) > -RC_EPS) break;
      patSolver.getValues(newPatt, Use);
      Cut.add(IloNumVar(RollsUsed(1) + Fill(newPatt)));
    }
    cutOpt.add(IloConversion(env, Cut, ILOINT));
    cutSolver.solve();
    cout << "Solution status: " << cutSolver.getStatus() << endl;
    report3(cutSolver, Cut);
  }
  catch (IloException& ex) {
    cerr << "Error: " << ex << endl;
  }
  catch (...) {
    cerr << "Error" << endl;
  }
  env.end();
  return 0;
}
static void readData(const char* filename, IloNum& rollWidth,
  IloNumArray& size, IloNumArray& amount)
{
  ifstream in(filename);
  if (in) {
    in >> rollWidth;
    in >> size;
    in >> amount;
  }
  else {
    cerr << "No such file: " << filename << endl;
    throw(1);
  }
}
static void report1(IloCplex& cutSolver, IloNumVarArray Cut,
  IloRangeArray Fill)
{
  cout << endl;
  cout << "Using " << cutSolver.getObjValue() << " rolls" << endl;
  cout << endl;
  for (IloInt j = 0; j < Cut.getSize(); j++) {
    cout << "  Cut" << j << " = " << cutSolver.getValue(Cut[j]) << endl;
  }
  cout << endl;
  for (IloInt i = 0; i < Fill.getSize(); i++) {
    cout << "  Fill" << i << " = " << cutSolver.getDual(Fill[i]) << endl;
  }
  cout << endl;
}
static void report2(IloAlgorithm& patSolver, IloNumVarArray Use,
  IloObjective obj)
{
  cout << endl;
  cout << "Reduced cost is " << patSolver.getValue(obj) << endl;
  cout << endl;
  if (patSolver.getValue(obj) <= -RC_EPS) {
    for (IloInt i = 0; i < Use.getSize(); i++) {
      cout << "  Use" << i << " = " << patSolver.getValue(Use[i]) << endl;
    }
    cout << endl;
  }
}
static void report3(IloCplex& cutSolver, IloNumVarArray Cut)
{
  cout << endl;
  cout << "Best integer solution uses "
    << cutSolver.getObjValue() << " rolls" << endl;
  cout << endl;
  for (IloInt j = 0; j < Cut.getSize(); j++) {
    cout << "  Cut" << j << " = " << cutSolver.getValue(Cut[j]) << endl;
  }
}


2、首先编译代码,出现下面截图说明配置成功辽

20210701110649913.png


3、给出输入文件信息如下:

115
[25, 40, 50, 55, 70]
[50, 36, 24, 8, 30]




4、运行结果如下:


20210701111039800.png


THE END


谢谢观看,欢迎批评指正













相关文章
|
1天前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤
随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤。通过这些工具,可以显著提升编码效率和代码质量。
10 4
|
4月前
|
编译器 开发工具 C++
【Python】已解决error: Microsoft Visual C++ 14.0 or greater is required. Get it with “Microsoft C++ Build
【Python】已解决error: Microsoft Visual C++ 14.0 or greater is required. Get it with “Microsoft C++ Build
1606 0
|
2月前
|
C++ 内存技术
[转]Visual C++内嵌swf文件并播放
[转]Visual C++内嵌swf文件并播放
|
3月前
|
安全 编译器 C++
Microsoft Visual C++ Redistributable的作用主要体现以及可以删除吗?
这些是Microsoft Visual C++不同版本的Redistributable安装包,用于32位系统,确保相关应用正常运行。它们提供C++运行时环境,简化部署流程,支持第三方库及框架,并确保应用兼容性。定期更新可修复问题并引入新功能。在空间有限或需解决程序冲突时可考虑删除,但需谨慎操作以防影响应用稳定性和兼容性。删除前请确认无应用依赖,并通过控制面板安全卸载。
136 1
Microsoft Visual C++ Redistributable的作用主要体现以及可以删除吗?
|
4月前
|
C++ Windows
FFmpeg开发笔记(三十九)给Visual Studio的C++工程集成FFmpeg
在Windows上使用Visual Studio 2022进行FFmpeg和SDL2集成开发,首先安装FFmpeg至E:\msys64\usr\local\ffmpeg,然后新建C++控制台项目。在项目属性中,添加FFmpeg和SDL2的头文件及库文件目录。接着配置链接器的附加依赖项,包括多个FFmpeg及SDL2的lib文件。在代码中引入FFmpeg的`av_log`函数输出"Hello World",编译并运行,若看到"Hello World",即表示集成成功。详细步骤可参考《FFmpeg开发实战:从零基础到短视频上线》。
127 0
FFmpeg开发笔记(三十九)给Visual Studio的C++工程集成FFmpeg
|
3月前
|
缓存 C++ Windows
Inno setup 脚本判断 Microsoft Visual C++ Redistributable 不同版本区别
Inno setup 脚本判断 Microsoft Visual C++ Redistributable 不同版本区别
|
3月前
|
编译器 C++ 开发者
Visual Studio属性表:在新项目中加入已配置好的C++库
通过以上步骤可以确保Visual Studio中新项目成功地加入了之前已配置好的C++库。这个过程帮助开发者有效地管理多个项目中共享的库文件,提升开发效率。
75 0
|
6月前
Visual Studio 2022 中VLD库如何安装
Visual Studio 2022 中VLD库如何安装
728 1
|
6月前
Visual Studio 2022 中VLD库如何安装
Visual Studio 2022 中VLD库如何安装
697 0
|
5月前
|
IDE 开发工具 C语言
Visual Studio 2017 安装及使用(新手)
Visual Studio 2017 安装及使用(新手)
1087 0