MATLAB调用LINGO程序并交换数据

思路

第一次写文章完全不熟练…在做比赛时想要用列生成解决混合整数规划问题,一开始在python上写,约束的种类非常多,debug时非常痛苦,稍微修改下约束工作量都很大。做了大概一周后还是想用lingo。lingo书写约束和修改约束非常舒适,而且能顺便测试有没有写错的地方,很节省时间。
主要思路是:
1、用lingo完成模型建立和求解,并将数据输出到excel表格中,方便运行中读取和后续模型计算使用;
2、用matlab调用lingo脚本,借助excel获得lingo的计算结果,处理计算结果后写入excel,用于后续迭代。
需要解决的两个关键问题:
1、按要求调用lingo脚本;
2、计算结果顺利传递。

一、lingo脚本调用

这一部分是为了在MATLAB中通过命令的形式运行lingo代码。

主要方法:
1、将lingo模型(.lg4文件)变成lingo命令脚本文件(.ltf文件)格式。
可以在lingo窗口的File-New中找到。变量、约束不变,文件结尾加一行 GO 即可(不加封号)。开头处加一行 SET TERSEO 1 可以避免在后面matlab窗口中输出冗长的结果。新加这类语句都不需要加封号。还有很多其他命令可以参考谢金星老师的11580405《优化建模与LINDOLINGO软件》这本书。

2、.bat批处理文件
根据lingo安装的位置和命令脚本文件的位置写批处理文件。用Notepad可以在新建文件处找到。具体写法参考Matlab调用Lingo脚本文件的方法中的方法二。

3、获得执行命令
例如上述文章中dos(‘C:\Users\10096\Desktop\test.bat’),可直接添加在matlab代码中运行

二、lingo接收数据与输出数据

lingo中自带文件输出函数。这里我选择了EXCEL作为数据交换的媒介,但matlab操作EXCEL比较慢,导致效率不高。lingo也可以向txt文件输出数据,也许可以提高速度,有试过的兄弟麻烦留个言分享下。

lingo自带函数@ole用于和EXCEL交换数据,这一部分有很多资料。主要的方法就是在EXCEL表格中先定义和变量数量对应的输出位置的名称,选中输出位置的表格后,右键定义名称。之后再@ole函数中写好文件位置和定义的名称就行。

我在调试时发现@ole函数的文件路径写错了,但由于文件再lingo程序运行时被打开,并没有影响lingo书写和读取数据。lingo输出结果时需要EXCEL表格在内存中,而且不会自动保存。这一点在后面写matlab代码时要特别注意。

三、matlab代码

这里遇到最大的问题是lingo读取数据后不自动关闭保存文件,这导致lingo程序运行后,EXCEL文件被lingo锁定,matlab自带的xlswrite和xlsread都不能正常使用。我这里的解决办法就是先在matlab中打开excel表格,运行lingo程序后,在matlab中保存数据并关闭表格。这样操作后xlswrite和xlsread就不会出问题了。

有关在matlab中操作excel的函数参考matlab和Excel的交互 非xlsread和xlswrite(1-Excel基础)

主要代码结构:

try
    Excel=actxGetRunningServer('Excel.Application');%如果Excel 服务器已经打开,返回其句柄
catch
    Excel=actxserver('Excel.Application');%如果Excel服务器没有打开,则创建一个Excel服务器,并返回句柄
end

Workbook = Excel.Workbooks.Open('C:\Users\LENVOLE1\Desktop\matlab_lingo\lingo_excel.xlsx');%打开excel表格
dos('C:\Users\LENVOLE1\Desktop\matlab_lingo\test.bat');%运行lingo程序
invoke(Workbook,'save');%保存lingo运行结果
invoke(Workbook,'close');%关闭excel表格
X = xlsread('C:\Users\LENVOLE1\Desktop\matlab_lingo\lingo_excel.xlsx', 'XXout', 'A2:EG2');%此时读取数据正常
xlswrite('C:\Users\LENVOLE1\Desktop\matlab_lingo\lingo_excel.xlsx',AA,'A','B2'); 

Excel.Quit; % 关闭 Excel
Excel.delete; % 删除对象

目前这个解决办法看起来挺憨憨的…有兄弟有好方法麻烦留言嗷!

最后

现在看这个问题也不是很麻烦,但是当时自己试着做时真的很搞心态,希望能节省大家一点时间。祝一切顺利!

  • 5
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
Matlab可以通过Lindo API接口调用Lingo求解器进行优化问题求解。下面是一个简单的例子。 首先,需要确保已经安装了Lingo和Lindo API,并且将Lindo API添加到系统环境变量中。然后,在Matlab中,可以按照以下步骤进行操作: 1. 定义优化问题 在Matlab中,可以使用优化工具箱中的“optimproblem”函数定义优化问题。例如,假设我们需要最小化目标函数“2x + 3y”,并且有以下约束条件: ``` x + y >= 10 x >= 0 y >= 0 ``` 可以这样定义优化问题: ``` % 定义变量 x = optimvar('x', 'LowerBound', 0); y = optimvar('y', 'LowerBound', 0); % 定义目标函数和约束条件 f = 2*x + 3*y; c1 = x + y >= 10; % 创建优化问题对象 problem = optimproblem('Objective', f, 'Constraints', c1); ``` 2. 定义Lindo API选项 在Matlab中,可以使用“optimoptions”函数定义Lindo API选项。例如: ``` % 定义Lindo API选项 options = optimoptions('linprog', 'LindoLibrary', 'LindoAPI'); ``` 这里使用了“linprog”选项,因为Lingo是一种线性规划求解器。如果需要使用Lindo API调用其他求解器,需要相应地修改选项。 3. 调用Lindo API求解器 在Matlab中,可以使用“linprog”函数调用Lindo API求解器求解优化问题。例如: ``` % 调用Lindo API求解器 [x, fval, exitflag, output] = linprog(problem, [], [], [], [], [], [], options); ``` 其中,第一个参数是优化问题对象,后面的参数为空表示不需要输入其他信息。求解结果包括最优解“x”、最优目标值“fval”、求解器退出标志“exitflag”和输出信息“output”。 需要注意的是,Lindo API接口的具体使用方法可能因版本而异,需要参考Lindo API文档进行详细操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值