热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

多目标优化系列(五)IBEA

Indicator-BasedSelectioninMultiobjectiveSearch中文名:基于指标的多目标选择由于这篇文章描述较为简单,所以我

Indicator-Based Selection in Multiobjective Search
中文名:基于指标的多目标选择

由于这篇文章描述较为简单,所以我们直接展开正题。

正文


思想

这里写图片描述

对于上图的问题,我们怎么判断A集合和B集合(如果最小为最优)的优劣性。该文运用了下图中的指标

这里写图片描述
首先该指标代表的前两幅图,而右边的两幅图则又是另一种指标。
我们对该指标描述一下,从上图中第一幅图看,假设A点即X1,B点即X2,对与垂直方向,

f(A)f(B)>0
对于水平方向:

f&#xff08;A&#xff09;f&#xff08;B&#xff09;<0
因为

ϵ >&#61;fi(x1)-fi(x2),for i in {1&#xff0c;&#xff0c;&#xff0c;n}&#xff0c;这是代表

ϵ 对每一个fi(x)均需满足&#xff0c; ,所以

ϵ 应大于最大正差距&#xff0c;即垂直方向上的值&#xff08;该值是大于0 的&#xff09;。又因为我们要最小化该值&#xff0c;所以

I 应取最大的正差距,即该图中A与B的水平方向上的差值。

我们分析一下该指标,当A->B,即I&#xff08;A&#xff0c;B&#xff09;&#xff08;可理解为A移向B&#xff09;存在某一维度与优化方向相同时&#xff0c;该即为

I正值&#xff0c;否则为负值&#xff08;代表A只支配B&#xff09;&#xff0c;

算法

这里写图片描述
这里写图片描述

为了方便起见&#xff0c;我先把原始算法在这里展示一下&#xff0c;然后用中文翻译&#xff1a;

  • 约定&#xff1a;α表示种群大小&#xff0c;N表示最大迭代次数&#xff0c;

  • step1: 产生初始种群P&#xff0c;种群大小为α&#xff0c;当前迭代此时m&#61;0

  • step2: 适应度计算&#xff0c;根据一下公式计算P里个体的使用度&#xff0c;例如x1&#xff08;k为比例缩放因子&#xff0c;参数&#xff09;
    这里写图片描述

  • step3: 对每一代P&#xff0c;执行如下运算&#xff08;缩减&#xff09;&#xff0c;直到种群大小为α

    1. 选择适应度最小的解
    2. 从种群中去掉该解
    3. 更新剩余解的适应度值
      这里写图片描述
  • step4: 终止条件判断

  • step5: p’ 为p 的复制&#xff0c;

  • step6: 用交叉变异作用在p’上&#xff0c;p&#61;p’&#43;p&#xff0c;m&#61;m&#43;1&#xff0c;转step2。

[1]基于加法ε~&#43;指标的多目标优化方法研究&#xff08;知网&#xff09;


推荐阅读
  • 利用决策树预测NBA比赛胜负的Python数据挖掘实践
    本文通过使用2013-14赛季NBA赛程与结果数据集以及2013年NBA排名数据,结合《Python数据挖掘入门与实践》一书中的方法,展示如何应用决策树算法进行比赛胜负预测。我们将详细讲解数据预处理、特征工程及模型评估等关键步骤。 ... [详细]
  • 在维护公司项目时,发现按下手机的某个物理按键后会激活相应的服务,并在屏幕上模拟点击特定坐标点。本文详细介绍了如何使用ADB Shell Input命令来模拟各种输入事件,包括滑动、按键和点击等。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 使用Pandas高效读取SQL脚本中的数据
    本文详细介绍了如何利用Pandas直接读取和解析SQL脚本,提供了一种高效的数据处理方法。该方法适用于各种数据库导出的SQL脚本,并且能够显著提升数据导入的速度和效率。 ... [详细]
  • 深入解析Android自定义View面试题
    本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 计算机网络复习:第五章 网络层控制平面
    本文探讨了网络层的控制平面,包括转发和路由选择的基本原理。转发在数据平面上实现,通过配置路由器中的转发表完成;而路由选择则在控制平面上进行,涉及路由器中路由表的配置与更新。此外,文章还介绍了ICMP协议、两种控制平面的实现方法、路由选择算法及其分类等内容。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • Ralph的Kubernetes进阶之旅:集群架构与对象解析
    本文深入探讨了Kubernetes集群的架构和核心对象,详细介绍了Pod、Service、Volume等基本组件,以及更高层次的抽象如Deployment、StatefulSet等,帮助读者全面理解Kubernetes的工作原理。 ... [详细]
  • 解决Element UI中Select组件创建条目为空时报错的问题
    本文介绍如何在Element UI的Select组件中使用allow-create属性创建新条目,并处理创建条目为空时出现的错误。我们将详细说明filterable属性的必要性,以及default-first-option属性的作用。 ... [详细]
  • 作为一名专业的Web前端工程师,掌握HTML和CSS的命名规范是至关重要的。良好的命名习惯不仅有助于提高代码的可读性和维护性,还能促进团队协作。本文将详细介绍Web前端开发中常用的HTML和CSS命名规范,并提供实用的建议。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 中科院学位论文排版指南
    随着毕业季的到来,许多即将毕业的学生开始撰写学位论文。本文介绍了使用LaTeX排版学位论文的方法,特别是针对中国科学院大学研究生学位论文撰写规范指导意见的最新要求。LaTeX以其精确的控制和美观的排版效果成为许多学者的首选。 ... [详细]
author-avatar
tingting
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有