实践Yalmip使用Knitro的一些总结

Posted landiljy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实践Yalmip使用Knitro的一些总结相关的知识,希望对你有一定的参考价值。

Yalmip使用Knitro的一些总结

1.软件

  Knitro 11.0.1  

  Win64(包含安装包和确定机器ID的软件):链接:https://pan.baidu.com/s/14IfxlAdo3myYiAeCGzfSQQ 密码:2k9q

  技术分享图片

图1  Knitro 11.0.1 win64 下载地址

  官网获取地址:https://www.artelys.com/en/optimization-tools/knitro/downloads

  通过学术邮箱可以申请一个月的完整版使用权。技术分享图片

图2 Knitro 的申请

  Yalmip的获取教程见https://www.cnblogs.com/landiljy/p/6776434.html

 

2.Yalmip使用Knitro

  • Yalmip和Knitro都安装好以后,命令行窗口输入yalmiptest,看下是否找到knitro求解器
  • Yalmip中调用knitro。见下面代码
1 options = sdpsettings(‘verbose‘,2,‘solver‘,‘knitro‘,‘savesolveroutput‘,1);%verbose设置显示信息的程度;savesolveroutput默认为0,表示不保存求解结果,设为1表示保存求解结果。
2 sol = optimize(Constraints,F,options);%Constraints为约束;F为目标函数;options为属性。
  • 按照上面步骤设置savesolveroutput=1后,报错。
  • 然后查看了Yalmip调用Knitro求解器的函数文件,发现了问题。方法如下:
  • 按照路径F:MATLAB2014AddToolYALMIP-mastersolverscallknitro.m(红色部分为软件里的路径部分),打开callknitro.m文件。
  • 可以发现图4中保存计算结果的语句中fmin语句有错(没有fmin这个变量)。图3中返回的是fval。
  • 其中这里可以参考:http://blog.sina.com.cn/s/blog_50c154510102wusb.html

技术分享图片

图3  Yalmip调用Knitro的Matlab版本接口

技术分享图片

图4 Yalmip调用Knitro求解器的函数

  • 设置Knitro的参数方法如下:
  • Knitro的Matlab版本的Nlp例子路径:C:Program FilesArtelysKnitro 11.0.1knitromatlab

[x,fval,exitflag,output,lambda,grad,hess] = knitromatlab(@objfun,x0,A,b,Aeq,beq,lb,ub,@constfun,extendedFeatures,[],‘nlp2options.opt‘);%红色字体是参数设置文档

  • 图5中exampleNLP2.m文件是Knitro给的NLP的例子,其中nlp2options.opt是Knitro参数设置文档,具体格式见图6。
  • 图6中加了‘#’的语句,则‘#’后面的语句不执行(即蓝色框)。红色框为一个参数的设置语句(参数详见:https://www.gams.com/latest/docs/S_KNITRO.html#KNITROopttol),后半句为说明这个参数对应Yalmip中的参数名称(即图7中蓝色框部分).
  • 那么我们将nlp2options.opt文件拷贝到我们自己项目的路径下,然后修改callknitro.m文件,具体修改见最后的代码红色字体部分
  • 那么我们以后要修改Knitro的参数,只需要在callknitro.m文件中修改即可。

技术分享图片

 

图5  Knitro的Matlab版本的例子

技术分享图片

图6 Knitro的参数设置文档

技术分享图片

图7 Yalmip中Knitro的参数列表

 

1 solvertime = tic;
2 %自己加的对options的设置---start----2018.06.27
3 model.options.knitro.optionsfile = ‘nlp2options.opt‘;  %参数设置文档
4 %自己加的对options的设置---end----
5 [xout,fval,exitflag,output,lambda] = knitromatlab_mip(funcs.objective,model.x0,model.A,full(model.b),model.Aeq,full(model.beq),model.lb,model.ub,funcs.constraints,model.xType,model.objFnType,model.cineqFnType,model.extendedFeatures,model.options.knitro,model.options.knitro.optionsfile);
6 solvertime = toc(solvertime);

 

 

 

 

以上是关于实践Yalmip使用Knitro的一些总结的主要内容,如果未能解决你的问题,请参考以下文章

课题实践总结

Yalmip+Ipopt+Cplex使用手册

配电网重构基于matlab yalmip求解含sop+二阶锥配电网重构问题含Matlab源码 2264期

电力系统基于matlab YALMIP+CPLEX求解带储能的微电网优化调度问题含Matlab源码 2175期

电力系统基于matlab YALMIP+CPLEX求解带储能的微电网优化调度问题含Matlab源码 2175期

微电网优化基于matlab YALMIP求解微网(光伏+风电+蓄电池+微电网+柴油机)优化调度问题含Matlab源码 2266期