Yalmip使用教程(7)-求解器的参数设置

        博客中所有内容均来源于自己学习过程中积累的经验以及对yalmip官方文档的翻译:https://yalmip.github.io/tutorials/

        这篇博客将详细介绍yalmip工具箱中常用的求解器设置选项。

1.求解器的基本设置

        使用sdpsettings函数可以对求解的相关参数进行设置。最常用的设置选项包括求解器的选择(solver)、命令行结果展示的详细程度(verbose)与步骤展示(showprogress)。例如,下面的代码就是将求解器选择为cplex,结果展示的详细程度为0(最少的命令行展示,最大值为3),不显示步骤(showprogress为0):

ops = sdpsettings('solver','cplex','verbose',0,'showprogress',0);

        也可以先对选项结构体进行赋值,然后通过结构体操作修改具体选项的内容,例如:

ops = sdpsettings;
ops.solver = cplex;
ops.verbose = 0;
ops.showprogress = 0;

        Yalmip求解器的参数非常多,如果想要查看完整的参数,可以先定义一个默认的参数选项ops,然后在工作区或者命令行查看该结构体的内容:

>> opsops = 包含以下字段的 struct:solver: ''verbose: 1debug: 0usex0: 0warning: 1cachesolvers: 0showprogress: 0saveduals: 1removeequalities: 0savesolveroutput: 0savesolverinput: 0saveyalmipmodel: 0convertconvexquad: 1assertgpnonnegativity: 1thisisnotagp: 0radius: Infrelax: 0dualize: 0savedebug: 0expand: 1allowmilp: 1allownonconvex: 1shift: 0dimacs: 0beeponproblem: [-5 -4 -3 -2 -1]mosektaskfile: ''bisection: [1×1 struct]bilevel: [1×1 struct]bmibnb: [1×1 struct]bnb: [1×1 struct]cutsdp: [1×1 struct]kkt: [1×1 struct]moment: [1×1 struct]mp: [1×1 struct]mpcvx: [1×1 struct]plot: [1×1 struct]robust: [1×1 struct]sos: [1×1 struct]refiner: [1×1 struct]baron: []bintprog: [1×1 struct]bonmin: []cdcs: [1×1 struct]cdd: [1×1 struct]cbc: [1×1 struct]clp: [1×1 struct]cplex: [1×1 struct]coneprog: []csdp: [1×1 struct]dsdp: [1×1 struct]ecos: []filtersd: [1×1 struct]fmincon: [1×1 struct]fminsearch: [1×1 struct]frlib: [1×1 struct]glpk: [1×1 struct]gurobi: [1×1 struct]ipopt: [1×1 struct]intlinprog: [1×1 optim.options.Intlinprog]knitro: [1×1 struct]linprog: [1×1 struct]lmilab: [1×1 struct]lmirank: [1×1 struct]logdetppa: [1×1 struct]lpsolve: [1×1 struct]lsqnonneg: [1×1 struct]lsqlin: [1×1 struct]kypd: [1×1 struct]kktqp: [1×1 struct]nag: [1×1 struct]mosek: [1×1 struct]nomad: []ooqp: []penbmi: [1×1 struct]penlab: []pensdp: [1×1 struct]pop: [1×1 struct]qpoases: []osqp: []qsopt: [1×1 struct]quadprog: [1×1 struct]quadprogbb: [1×1 struct]scip: [1×1 struct]scs: [1×1 struct]sdpa: [1×1 struct]sdplr: [1×1 struct]sdpt3: [1×1 struct]sdpnal: [1×1 struct]sedumi: [1×1 struct]sparsepop: [1×1 struct]snopt: [1×1 struct]sparsecolo: [1×1 struct]vsdp: [1×1 struct]xpress: []default: [1×1 struct]

2.常用参数详解

2.1 solver

        参数solver表示yalmip在求解优化问题的将调用的求解器,如果没有指定solver参数,yalmip将自动选择已有合适的求解器,yalmip支持的求解器很多,支持的求解器和各个求解器的适用范围可参考官方文档的介绍:

Solvers - YALMIP

2.2 verbose

        参数verbose表示yalmip在求解优化问题时候所展示的细节多少,取值为0时表示不展示求解的细节,取值为3时展示最多的求解细节。

2.3 debug

        参数debug表示yalmip在求解过程中是否采用catch语句处理报错。如果debug参数设置为1,表示yalmip求解过程中报错时将直接显示在命令行(也就是我们在命令行常见的红色文字),如果将debug参数设置为0,yalmip求解过程中如果如果遇到错误将直接使用catch语句对错误进行处理。如果对catch语句用法不太清楚,可以尝试搜索matlab中try-catch语句的用法。

2.4 warning

        参数warning表示yalmip是否在命令行显示警告,取1时表示显示警告,取0时表示不显示警告。

2.5 showprogress

        参数showprogress表示是否展示Yalmip工具箱当前的动作,取1时将进行展示,取0时不展示。该参数和verbose参数类似,但有一定区别。verbose参数的取值表示时求解优化问题时候的细节,showprogress表示是否展示yalmip工具箱的动作,包括对约束条件进行处理,识别优化问题的类型等。

2.6 relax

参数relax表示对非线性约束的处理方式,如果relax设置为1,则将忽略所有非线性和完整性约束,整数变量被松弛为连续变量,非线性变量被视为独立的变量(例如x和x^2将被视为两个独立的变量)。如果设置为2,则仅松弛整数约束,如果设置为3,则仅松弛非线性约束。

2.7 usex0

        参数usex0表示是否在求解优化问题时给定初值。如果将usex0参数设置为1,Yalmip会将变量的当前取值发送给求解器,作为求解时的初值。一般情况下,该参数可以和assign函数搭配使用。

        在求解一些大规模优化问题时,如果已知优化问题的一组可行解,如果可以使用assign函数将这组可行解赋值给优化变量,并将usex0参数设为1,很可能将大大加快求解速度。

3.gurobi求解器的参数详解

        从第一节所展示的ops所有参数可以看到,除了上述常用的参数选项之外,还有一些参数是结构体形式,点开后又有许多二级参数。其中最常用的就是求解器的参数,下面以常用的gurobi求解器为例进行讲解:

        点开ops.gurobi,可以发现又有许多参数:

ops.gurobians = 包含以下字段的 struct:BarIterLimit: 1000BestBdStop: InfBestObjStop: -InfCutoff: InfIterationLimit: InfNodeLimit: InfSolutionLimit: InfTimeLimit: 7200BarConvTol: 1.0000e-08BarQCPConvTol: 1.0000e-06FeasibilityTol: 1.0000e-06IntFeasTol: 1.0000e-05MarkowitzTol: 0.0078MIPGap: 0.0100MIPGapAbs: 1.0000e-10OptimalityTol: 1.0000e-06PSDTol: 1.0000e-06InfUnbdInfo: 0NormAdjust: -1ObjScale: 0PerturbValue: 2.0000e-04Quad: -1ScaleFlag: -1Sifting: -1SiftMethod: -1SimplexPricing: -1BarCorrectors: -1BarHomogeneous: -1BarOrder: -1Crossover: -1CrossoverBasis: 0QCPDual: 0BranchDir: 0ConcurrentJobs: 0ConcurrentMIP: 1DegenMoves: -1Disconnected: -1DistributedMIPJobs: 0Heuristics: 0.0500ImproveStartGap: 0ImproveStartNodes: InfImproveStartTime: InfLazyConstraints: 0MinRelNodes: -1MIPFocus: 0MIQCPMethod: -1NodefileDir: ''NodefileStart: InfNodeMethod: -1NonConvex: -1PartitionPlace: 15PumpPasses: -1RINS: -1SolFiles: ''SolutionNumber: 0StartNodeLimit: -1StartNumber: 0SubMIPNodes: 500Symmetry: -1VarBranch: -1ZeroObjNodes: -1AggFill: -1Aggregate: 1DualReductions: 1PreCrush: 0PreDepRow: -1PreDual: -1PreMIQCPForm: -1PrePasses: -1PreQLinearize: -1Presolve: -1PreSOS1BigM: -1PreSOS2BigM: 0PreSparsify: -1TuneCriterion: -1TuneJobs: 0TuneOutput: 2TuneResults: -1TuneTimeLimit: -1TuneTrials: 3PoolGap: InfPoolSearchMode: 0PoolSolutions: 10BQPCuts: -1Cuts: -1CliqueCuts: -1CoverCuts: -1CutAggPasses: -1CutPasses: -1FlowCoverCuts: -1FlowPathCuts: -1GomoryPasses: -1GUBCoverCuts: -1ImpliedCuts: -1InfProofCuts: -1MIPSepCuts: -1MIRCuts: -1ModKCuts: -1NetworkCuts: -1ProjImpliedCuts: -1RelaxLiftCuts: -1RLTCuts: -1StrongCGCuts: -1SubMIPCuts: -1ZeroHalfCuts: -1WorkerPassword: ''WorkerPool: ''CloudAccessID: ''CloudHost: ''CloudSecretKey: ''CloudPool: ''ComputeServer: ''ServerPassword: ''ServerTimeout: 60CSPriority: 0CSQueueTimeout: -1CSRouter: ''CSGroup: ''CSTLSInsecure: 0CSIdleTimeout: -1JobID: ''CSAPIAccessID: ''CSAPISecret: ''CSAppName: ''CSAuthToken: ''CSBatchMode: 0CSClientLog: 0CSManager: ''TokenServer: ''TSPort: 41954DisplayInterval: 5FeasRelaxBigM: 1000000FuncPieceError: 1.0000e-03FuncPieceLength: 0.0100FuncPieceRatio: -1FuncPieces: 0FuncMaxVal: 1000000IgnoreNames: 0IISMethod: -1JSONSolDetail: 0LogFile: ''LogToConsole: 1Method: -1MultiObjMethod: -1MultiObjPre: -1NumericFocus: 0ObjNumber: 0OutputFlag: 1Record: 0ResultFile: ''ScenarioNumber: 0Seed: 0Threads: 0UpdateMode: 1NoRelHeurWork: 0NoRelHeurTime: 0

        下面将对gurobi中常用的参数选项进行讲解。

3.1 MIPGap

        MIPGap参数是指gurobi求解器的偏差终止条件。当整数规划的偏差下降到设定值后,优化终止。Gurobi中该参数计算公式如下:

式中,ZP和ZD分别表示目标函数的上界和下界。当ZP=0且ZD≠0时,gap被视为无穷大。

        该参数的默认值为 10^(-4),实际中如果对求解精度要求不是特别高,一般可以设定为 0.05 或者 0.01。修改该参数有两种方法,分别如下:

ops = sdpsettings('solver' , 'gurobi' , 'gurobi.MIPGap' , 0.01);

        或

ops = sdpsettings('solver' , 'gurobi' );
ops .gurobi.MIPGap = 0.01;

        第3节所有提到的参数修改都可采用相同的方式,后面不再赘述。

3.2 TimeLimit

        TimeLimit参数表示gurobi求解器的时间终止条件。当达到规定的运行时间后,优化终止,该参数的单位为秒,默认值为inf(无穷大,即不限制求解时间)。但实际编程过程中,很多时候求解器会一直卡在某个进度,运行一天一夜也没有达到收敛,因此可以考虑对求解器的运行时间进行限制。

3.3 MIPFocus

        MIPFocus参数表示MIP(混合整数规划)问题求解时所采取的策略,其默认值为0,试图在最优值和可行解之间取得平衡,取1时以可行解为优先目标,取2时以得到最优解为目标,取3时以优化边界为目标。

3.4 Presolve

        Presolve参数表示gurobi求解优化问题时预优化的力度。其默认值为-1,表示,自动决定预优化力度。0:关闭预优化;1:保守;2:激进。

3.5 Method

        Method参数表示gurobi求解优化问题时所采用的方法。其默认值为-1,自动决定优化方法。其他选项包括:0-原始单纯形,1-对偶单纯形,2-barrier,3-并发,4-确定性并发。

        其中,并发方法不适用于QP和QCP。只有单纯形和barrier算法可用于连续QP模型。如果选择barrier算法来求解MIQP模型的根,则还需要为节点松弛选择barriel(即设置NodeMethod=2)。只有barrier算法可用于连续QCP模型。但是,如果选择LP松弛来求解MIQCP,也可以选择单纯形算法(方法=0或1)。

        并发优化器在多个线程上同时运行多个解算器,并选择首先完成的解算器。并发运行的解算器可以使用ConcurrentMethod参数进行控制。确定性并发每次都会给出完全相同的结果,而非确定性并发(方式=3)通常更快,但在多次运行时可以产生不同的结果。

        如果LP模型内存紧张,则应考虑使用对偶单纯形法。通常在使用默认设置时选择并发优化器,它比单独使用对偶单纯形消耗更多的内存。

3.6 ImproveStartTime和ImproveStartGap

        ImproveStartTime和ImproveStartGap参数分别表示是否在一定时间或达到一定精度后改变gurobi的寻优策略,其中ImproveStartTime参数的单位为秒。ImproveStartTime和ImproveStartGap参数的默认值为inf和0,表示求解过程中不更改gurobi的寻优策略。如果将ImproveStartTime参数修改为10,表示gurobi求解器在运行10秒后将目标转为寻找可行解;同理,如果将ImproveStartGap参数修改为0.05,表示收敛精度达到0.05后将目标转为寻找可行解。

3.7 NoRelHeurTime和NoRelHeurWork

        NoRelHeurTime和NoRelHeurWork参数分别表示gurobi在求解MIP问题时采用NoRel启发式算法的时间和工作量。其中NoRelHeurTime参数的单位为秒,NoRelHeurWork参数的单位为1。对于求解困难的混合整数规划问题,可以考虑使用这两个参数。两个参数主要的不同之处在于NoRelHeurTime所求结果具有不确定性,而NoRelHeurWork所得结果是具有确定性的。

3.6 Heuristics

        Heuristics参数表示gurobi在求解优化问题时采用启发式算法的时间占比,其单位为1。默认值是0.05,表示gurobi求解过程中大约有5%的时间采用启发式方法。如果手中有一个很难找到初始可行解的混合整数规划问题,可以尝试增加Heuristics参数的取值。

3.7其他求解器参数设置

        对于其他常用的cplex,mosek等求解器,也有许多参数选项,某些时候可以通过设置求解器参数提高求解效率,其中各自的参数选项均可从各自的使用手册上找到对应的含义和用法,此处不再赘述。

        Cplex求解器参数选项文档:

List of CPLEX parameters - IBM Documentation

        Mosek求解器参数选项文档:

15.5 Parameters (alphabetical list sorted by type) — MOSEK Optimizer API for C 10.1.28

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/795541.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java学习day6-集合

集合指一组用于储存和操作数据的类和接口,提供各种数据结构和算法,以在程序中高效地管理和操作数据 特点:与数组相比,集合可以自动扩容,只需向其中添加元素即可(与Cvector类似);数组…

软考之零碎片段记录(七)+复习巩固(二)

一、上新 1. 有向图 从顶点A到顶点B的边,不等于从B到A的边。 2. 广度优先 遍历开始节点(第一层)的邻节点(从左至右顺序),邻接点设为第二层根据1中遍历邻接点从左往右的顺序遍历。 bilibili视频《广度优…

《C++程序设计》阅读笔记【5-引用】

🌈个人主页:godspeed_lucip 🔥 系列专栏:《C程序设计》阅读笔记 本文对应的PDF源文件请关注微信公众号程序员刘同学,回复C程序设计获取下载链接。 1 引用1.1 概念1.2 和引用相关的操作1.2.1 什么能被引用 1.3 用引用传…

WebKit结构揭秘:探秘网页渲染的魔法之源

一、WebKit之心:渲染引擎的魔力 WebKit的渲染引擎是其核心所在,它犹如一位技艺高超的魔法师,将HTML、CSS和JavaScript的魔法咒语转化为绚丽的网页画面。它解析代码,绘制页面,让网页内容跃然屏上,展现出无尽…

ROS 2边学边练(15)-- 写一个简单的服务(C++)

前言 此篇我们即将编写一个简单的服务(service)通信例子,客户端节点向服务端节点发出请求(.srv文件中规定了通信的数据结构格式),服务端节点收到请求后将结果回复给客户端节点,一问一答&#xf…

Unity类银河恶魔城学习记录12-4 p126 Item Tooltip源代码

Alex教程每一P的教程原代码加上我自己的理解初步理解写的注释,可供学习Alex教程的人参考 此代码仅为较上一P有所改变的代码 【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili UI.cs using System.Collections; using System.Collections.Generic; usi…

【面经】interrupt()、interrupted()和isInterrupted()的区别与使用

📝个人主页:五敷有你 🔥系列专栏:面经 ⛺️稳中求进,晒太阳 interrupt方法 如果打断线程正在sleep,wait,join会导致被打断的线程抛出InterruptedException,并清除打断标记。如…

Redis的配置文件详解

单位:Redis配置对大小写不敏感! 注意这里:任何写法都可,不区分大小写。 units are case insensitive so 1GB 1Gb 1gB are all the same.包含:搭建Redis集群时,可以使用includes包含其他配置文件网络&…

关于 elf loader 的编写

可以使用如下命令观看 elf 文件的信息 readelf -a build/ramdisk.img | vim -在编写 elf loader 的时候,实际上只有下图这一部分 “Program Headers” 是有用的 凡是类型为 “LOAD” 的就是需要加载进内存的部分 所以,只要把这些部分加载进内存里&…

数据库不用mmap

你确定你想用 MMAP 实现数据库么?_哔哩哔哩_bilibili MMAP 的随机读与顺序读的性能表现不好,以及对于写主要是不可控的刷入时机以及代码冗余,所以 MMAP 不适合在数据库中使用。 mmap是posix系统调用,它提供由操作系统管理内存映…

(C)1008 数组元素循环右移问题

1008 数组元素循环右移问题&#xff1a; 问题描述 输入样例&#xff1a; 6 2 1 2 3 4 5 6 输出样例&#xff1a; 5 6 1 2 3 4 解决方案&#xff1a; #include<stdio.h> #include<string.h> #include<math.h> int main(){int n,k,flag,y,x,final;int a[10000…

Flutter Boost 3

社区的 issue 没有收敛的趋势。 设计过于复杂&#xff0c;概念太多。这让一个新手看 FlutterBoost 的代码很吃力。 这些问题促使我们重新梳理设计&#xff0c;为了彻底解决这些顽固的问题&#xff0c;我们做一次大升级&#xff0c;我们把这次升级命名为 FlutterBoost 3.0&am…

合理早餐选择,稳定糖尿病血糖。

对于糖尿病患者来说&#xff0c;饮食管理是治疗的重要一环。不合理的早餐选择会导致血糖的波动。很多糖尿病朋友按时吃药&#xff0c;但是血糖就是稳定不住&#xff0c;之前看过一个例子&#xff0c;北京崇文门医院朱学敏主任接诊过一个患者&#xff0c;那个患者按时吃药&#…

LaTeX 空格与换行

任意多个空格与一个空格的功能相同。只有字符后面的空格是有效的&#xff0c;每行最前面的空格被忽略。单个换行被视作一个空格&#xff0c;连续两个换行表示分段。~被称作一种不可打断的空格&#xff0c;排版系统不会在这种空格之间换行。西文的逗号、句号和分号等标点后面应该…

Java | Leetcode Java题解之第8题字符串转换整数atoi

题目&#xff1a; 题解&#xff1a; class Solution {public int myAtoi(String str) {Automaton automaton new Automaton();int length str.length();for (int i 0; i < length; i) {automaton.get(str.charAt(i));}return (int) (automaton.sign * automaton.ans);} …

Android Studio学习10——资源res的使用

一、String,StringArray的使用 一次修改&#xff0c;多出生效 String StringArray 二、color的使用 颜色代码对应表 和上面的相似用法 三、Dimen(尺寸)的使用 用的少&#xff0c;一般直接写尺寸 四、如何写一个drawable作为背景 五、如何写一个可以改变的drawable(按钮按下…

IP地址:是给主机配置的,还是给网卡配置的?

在探索网络的奥秘时&#xff0c;我们经常会遇到一个看似简单但又复杂的问题&#xff1a;IP地址到底是配置在主机上&#xff0c;还是配置在网卡上&#xff1f;为什么我们通常说的是“主机IP地址”呢&#xff1f;让我们一起深入探讨。 1. 网卡与IP地址 &#x1f5a5;️&#x1f…

利用OllyDbg对程序内容进行修改实验

1.双击运行exe文件&#xff0c;出现如下弹窗 2.用ollydbg工具打开该执行文件&#xff0c;页面显示如下 3.在注释窗口执行以下操作 4.双击运行exe文件时&#xff0c;显示”Copied!”所以接下来在注释里找到这个字样&#xff0c;如下&#xff0c;我们需要把对话框中的内容修改为“…

SQL语句学习+牛客基础39SQL

什么是SQL&#xff1f; SQL (Structured Query Language:结构化查询语言) 是用于管理关系数据库管理系统&#xff08;RDBMS&#xff09;。 SQL 的范围包括数据插入、查询、更新和删除&#xff0c;数据库模式创建和修改&#xff0c;以及数据访问控制。 SQL语法 数据库表 一个…

ChatGPT(3.5版本)开放无需注册:算力背后的数据之战悄然打响

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…