代码 | 自适应大邻域搜索系列之(5) - ALNS_Iteration_Status和ALNS_Parameters的代码解析...

本文主要是介绍代码 | 自适应大邻域搜索系列之(5) - ALNS_Iteration_Status和ALNS_Parameters的代码解析...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码 | 自适应大邻域搜索系列之(5) - ALNS_Iteration_Status和ALNS_Parameters的代码解析

前言

上一篇推文说了,后面的代码难度直线下降,各位小伙伴可以放去n的100次方心了。今天讲讲一些细枝末节,就是前面一直有提到的参数和一些状态的记录代码。这个简单啦,小编也不作过多解释了。大家直接看代码都能看懂,不过小编还是会把逻辑结构给大家梳理出来的。好了,开始干活。

01 ALNS_Iteration_Status

这个类,咳咳,不是抽象类了哈。主要用来记录ALNS迭代过程中的一些中间变量和状态等。主要是成员变量,成员函数都是简单的getter(获取成员变量的接口)或者setter(设置成员变量的接口)。所以这里就把成员变量贴出来好了,各个变量记录的内容注释也写得很详细,小编就不做多赘述以免扰乱了大家看代码的心。

private://! Id of the iteration corresponding to this status.size_t iterationId;//! Number of iteration since the last improvement of the BKSsize_t nbIterationWithoutImprovement;//! Number of iteration since the last improvement of the BKS//! or the last reload of the best known solution.size_t nbIterationWithoutImprovementSinceLastReload;//! Number of iterations since the last improvement of the current//! solution.size_t nbIterationWithoutImprovementCurrent;//! Number of iterations without transition.size_t nbIterationWithoutTransition;//! Indicate if a new best solution has been obtained.State newBestSolution;//! Indicate if the new solution has been accepted as the//! current solution.State acceptedAsCurrentSolution;//! Indicate if the new solution is already known.State alreadyKnownSolution;//! Indicate if the new solution improve the current solution.State improveCurrentSolution;//! Indicate if a local search operator has been used.State localSearchUsed;//! Indicate if solution has been improved by local search.State improveByLocalSearch;//! Indicate if the solution has already been repaired.State alreadyRepaired;//! Indicate if the new solution has already been destroyed.State alreadyDestroyed;};

02 ALNS_Parameters

该类是ALNS运行过程中的一些参数设置,和上面的ALNS_Iteration_Status差不多,主要功能集中在成员变量上,成员函数都是简单的getter(获取成员变量的接口)或者setter(设置成员变量的接口)。照例把成员变量贴出来吧~

public://! Enumeration representing the various kind of stopping criteria.//! MAX_IT: the maximum number of iterations.//! MAX_RT: the maximum run time.//! MAX_IT_NO_IMP: the maximum number of iterations without improvement.//! ALL: a mix of the MAX_IT, MAX_RT and MAX_IT_NO_IMP.enum StoppingCriteria {MAX_IT,MAX_RT,MAX_IT_NO_IMP,ALL};//! An enumeration listing a set of packaged AcceptanceModule Implementation.enum AcceptanceCriterioKind {SA};
protected://! Maximum number of iterations performed by the ALNS.size_t maxNbIterations;//! Maximum running time of the ALNS.double maxRunningTime;//! Maximum number of iterations without any improvement.size_t maxNbIterationsNoImp;//! Which stopping criterion should be used.StoppingCriteria stopCrit;//! Indicate if noise should be used.bool noise;//! Indicate after how many iterations should the scores of//! the operators be recomputed.size_t timeSegmentsIt;//! Indicate the number of iterations that should be performed//! before reinitialization of the scores of the operators.size_t nbItBeforeReinit;//! score adjustment parameter in case the last remove-insert//! operation resulted in a new global best solutionint sigma1;//! score adjustment parameter in case that the last remove-insert//! operation resulted in a solution that has not been accepted before and//! the objective value is better than the objective value of current solutionint sigma2;//! score adjustment parameter in case that the last remove-insert//! operation resulted in a solution that has not been accepted before and such//! that the score objective value is worse than the one of current solution but//! the solution was accepted.int sigma3;//! reaction factor 0 <= rho <= 1 for the update of the weights of the//! operators.double rho;//! The minimum possible weight for an operator.double minimumWeight;//! The maximum possible weight for an operator.double maximumWeight;//! Indicates the probability of using noised operators.double probabilityOfNoise;//! Kind of acceptance criterion used.AcceptanceCriterioKind acKind;//! patht to the configuration file of the acceptance criterion.std::string acPath;//! path to the file where the global stats have to be saved.std::string statsGlobPath;//! path to the file where the operators stats have to be saved.std::string statsOpPath;//! Indicate every each iteration logging is done. 不懂看后面。int logFrequency;//! A set of forbidden operators. 不懂看后面。std::vector<std::string> forbidenOperators;//! A set of forbidden local search operators. 不懂看后面。std::vector<std::string> forbidenLsOperators;//! The minimum percentage of the solution destroyed by the destroy operators.int minDestroyPerc;//! The maximum percentage of the solution destroyed by the destroy operators.int maxDestroyPerc;//! Indicate after how many iterations without improvement//! does the best known solution is reloaded.size_t reloadFrequency;//! Indicate if local search should be used.bool performLocalSearch;//! When the optimization process start, the parameters//! should not be modified. lock is set to true when the//! optimization begin. If the setter of the value//! of one parameter is called while lock is true, an//! error is raised.bool lock;};

不过有几个变量大家看了注释可能还不太明白是干嘛用的。在这里再解释一下。

logFrequency,隔多少次迭代输出一下当前的信息。直接给大家上两个图让大家心领神会一下:

  1. logFrequency = 1
    1240

  2. logFrequency = 100
    1240

懂了吧。

forbidenOperators是禁止的某些repair和destroy方法的集合,学过禁忌搜索的都知道这意味着什么,有些repair和destroy方法效果太差劲了,所以我们把它们给ban掉。

forbidenLsOperators和forbidenOperators差不多,不过它是禁止的某些LocalSearch方法的集合,效果太差嘛。。。

03 再论ALNS_Parameters

关于ALNS_Parameters它的大部分成员函数是简单的getter(获取成员变量的接口)或者setter(设置成员变量的接口)。但其CPP文件中,还有一个函数是从xml文件读取相应参数的。代码就不具体介绍了,主要是xml文件操作的一些api的使用,有现成的lib库,感兴趣的同学了解一下。

至于为什么用xml文件呢?其实直接把参数写死在程序里面也是可以的,不过读取xml文件获取相应的参数更符合标准,在实际生产中也更方便实用而已。
1240

04 小结

至此,整一个ALNS模块已经讲得差不多了,不知道大家都看懂了没有。看不懂的话可以多看几遍,很多地方也只是小编个人的理解,不一定正确,如果你觉得你有更好的想法,也可以联系小编一起讨论。

后面再出多几篇估计就差不多了。把判断接受准则讲讲,把局部搜索讲讲就差不多可以了。最后谢谢大家一路过来的支持哈。

代码及相关内容可关注公众号。更多精彩尽在微信公众号【程序猿声】
微信公众号

posted @ 2019-05-10 20:25 短短的路走走停停 阅读( ...) 评论( ...) 编辑 收藏

这篇关于代码 | 自适应大邻域搜索系列之(5) - ALNS_Iteration_Status和ALNS_Parameters的代码解析...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/161495

相关文章

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑