VIKOR方法

简介

VIKOR方法是一种多标准决策(MCDM)或多标准决策分析方法。它最初由 Serafim Opricovic 开发,用于解决具有冲突和不可通约(不同单位)标准的决策问题,假设冲突解决可以接受妥协,决策者想要一个最接近理想的解决方案,并根据符合所有既定标准。 VIKOR 对备选方案进行排名,并确定最接近理想的名为折衷的解决方案。

折衷解决方案的思想是由 Po-Lung Yu 于 1973 年[1]和 Milan Zeleny 在 MCDM 中引入的。[2]

S. Opricovic 在他的博士学位中发表了 VIKOR 的基本思想。 1979年发表论文,1980年发表应用。[3] VIKOR这个名字出现于1990年[4],来自塞尔维亚语:VIseKriterijumska Optimizacija I Kompromisno Resenje,意思是:多标准优化和妥协解决方案,发音:vikor。真正的应用是在1998年提出的。[5] 2004年的论文为VIKOR方法的国际认可做出了贡献。[6](经济学领域被引用次数最多的论文,《科学观察》,2009 年 4 月)。

MCDM 问题表述如下:从 J 个可行替代方案 A1、A2、...AJ 集合中确定多准则意义上的最佳(折衷)解决方案,并根据 n 个准则函数集合进行评估。输入数据是性能(决策)矩阵的元素 fij,其中 fij 是替代 Aj 的第 i个准则函数的值。

案例

VIKOR方法是一种用于解决多标准决策问题的技术,特别是在有多重冲突标准时。它的目的是通过综合各种标准,找到一个接近理想解的解决方案。为了更好地理解这个概念,我们可以用一个简单的例子来说明。

示例:选择最佳手机

假设你要买一部新手机,有以下几个评价标准:

  1. 价格(越低越好)
  2. 电池寿命(越长越好)
  3. 相机质量(越高越好)
  4. 内存容量(越大越好)

你正在比较三款手机:A、B和C。

  1. 构建决策矩阵:首先,列出每个手机在各个标准上的表现。
scss
复制代码
手机   价格(元)  电池寿命(小时)  相机质量(分)  内存容量(GB)
A     3000     20             8         128
B     3500     22             9         256
C     4000     18             7         512
  1. 确定理想解和反理想解
    • 理想解是每个标准的最佳值。
    • 反理想解是每个标准的最差值。

例如:

    • 价格:理想解 = 3000,反理想解 = 4000
    • 电池寿命:理想解 = 22,反理想解 = 18
    • 相机质量:理想解 = 9,反理想解 = 7
    • 内存容量:理想解 = 512,反理想解 = 128
  1. 计算每个选项与理想解和反理想解的距离: 使用公式计算每个手机的综合距离。
  2. 综合评价: 通过VIKOR公式计算每个手机的综合得分,并按得分排序。得分越低,表示该选项越接近理想解。

步骤

方法案例

VIKOR方法是一种用于解决多标准决策问题(MCDM)的技术,特别适用于在冲突标准下选择和排序多个可选方案。VIKOR方法的全称是“VlseKriterijumska Optimizacija I Kompromisno Resenje”,来源于塞尔维亚语,意思是“多标准优化和妥协解决方案”。VIKOR的核心思想是通过多标准综合评价,寻找一个妥协解,该解能够平衡多个评价标准,尽可能接近理想解。

VIKOR方法的步骤
  1. 构建决策矩阵决策矩阵列出所有候选方案在各个评价标准下的表现。
方案   标准1  标准2  ...  标准n
A     f1A    f2A   ...  fnA
B     f1B    f2B   ...  fnB
C     f1C    f2C   ...  fnC

其中,fij 表示方案 i 在标准 j 下的表现。

  1. 确定理想解和反理想解
    • 理想解(𝑓∗):每个标准的最佳值,记为𝑓𝑗∗。
    • 反理想解(𝑓−):每个标准的最差值,记为𝑓𝑗−。

对于每个标准j:

f_j^* = max(fij)(如果是收益型标准,例如:越大越好)
f_j^- = min(fij)(如果是成本型标准,例如:越小越好)
  1. 计算每个方案的S值和R值
    • S值:综合距离,表示方案i与理想解之间的综合距离。
S_i = ∑ ( w_j * (f_j^* - f_ij) / (f_j^* - f_j^-) )         // w_j 是标准 j 的权重。
    • R值:个体最大距离,表示方案 i 在最不利标准下与理想解的距离。
R_i = max ( w_j * (f_j^* - f_ij) / (f_j^* - f_j^-) )
  1. 计算每个方案的Q值Q值是综合考虑S值和R值的指标,通过VIKOR公式计算:
Q_i = v * (S_i - S^*) / (S^- - S^*) + (1 - v) * (R_i - R^*) / (R^- - R^*)

其中:

    • S^* 和 S^- 分别是所有S值中的最小值和最大值。
    • R^* 和 R^- 分别是所有R值中的最小值和最大值。
    • v 是一个在0到1之间的权重,通常取0.5,表示S值和R值的平衡。
  1. 对方案进行排序: 根据S值、R值和Q值对方案进行排序,得到三种排序方式:S排序、R排序和Q排序。最终的排序结果主要根据Q值确定,但同时考虑S值和R值。
  2. 提出妥协方案: 根据Q值的排序,选择Q值最小的方案作为妥协方案。如果有多个方案的Q值接近,还需要通过以下两个条件进行验证:
    • 条件1:Q值最小的方案与第二小方案的Q值差异要显著。
    • 条件2:Q值最小的方案在S排序和R排序中也必须表现良好。
示例:选择最佳手机

假设你要买一部新手机,有以下几个评价标准:

  1. 价格(越低越好)
  2. 电池寿命(越长越好)
  3. 相机质量(越高越好)
  4. 内存容量(越大越好)

你正在比较三款手机:A、B和C。

  1. 构建决策矩阵
手机   价格(元)  电池寿命(小时)  相机质量(分)  内存容量(GB)
A     3000     20             8         128
B     3500     22             9         256
C     4000     18             7         512
  1. 确定理想解和反理想解
理想解:价格 = 3000,电池寿命 = 22,相机质量 = 9,内存容量 = 512
反理想解:价格 = 4000,电池寿命 = 18,相机质量 = 7,内存容量 = 128
  1. 计算每个手机的S值和R值: 假设所有标准的权重均为1:
S_A = (1 * (4000 - 3000) / (4000 - 3000)) + (1 * (22 - 20) / (22 - 18)) + (1 * (9 - 8) / (9 - 7)) + (1 * (512 - 128) / (512 - 128))= 1 + 0.5 + 0.5 + 1= 3R_A = max( (4000 - 3000) / (4000 - 3000), (22 - 20) / (22 - 18), (9 - 8) / (9 - 7), (512 - 128) / (512 - 128) )= max(1, 0.5, 0.5, 1)= 1

类似地计算B和C的S值和R值。

  1. 计算每个手机的Q值: 假设 v = 0.5:
Q_A = 0.5 * (S_A - S^*) / (S^- - S^*) + 0.5 * (R_A - R^*) / (R^- - R^*)= 0.5 * (3 - S^*) / (S^- - S^*) + 0.5 * (1 - R^*) / (R^- - R^*)

类似地计算B和C的Q值。

  1. 对手机进行排序: 根据Q值排序,找出Q值最小的手机。
  2. 提出妥协方案: 验证Q值最小的手机是否符合两个条件,然后确定最终的妥协方案。

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

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

相关文章

C++中static关键字用法总结

在C中,关键字static有多种用途,它可以用于变量、函数。下面是static在不同上下文中的作用和举例。下面从static修饰的变量、函数三方面进行总结。 1、静态变量 静态变量分为全局变量、局部变量、函数中变量两种。 1.1 静态全局变量 静态全局变量声明在…

【文末附gpt升级秘笈】关于论文“7B?13B?175B?解读大模型的参数的论文

论文大纲 引言 简要介绍大模型(深度学习模型)的概念及其在各个领域的应用。阐述参数(Parameters)在大模型中的重要性,以及它们如何影响模型的性能。引出主题:探讨7B、13B、175B等参数规模的大模型。 第一…

前端框架前置知识之Node.js:Node.js入门

前端程序员有必要学 Node.js 吗?要学到什么程度? 小朋友,你是否有很多问号? 对于node.js,不知道你是否和我一样有很多问号? 其实在学习node.js之前,我已经学完了Vue框架,而且已经…

排序算法(C++)

参考C算法,这里面有些写法也值得商榷。 1. 冒泡排序算法 冒泡排序算法代码和思路比较简单,大家如果在面试时被要求实现排序时,可以用这种方法来实现。 该算法里,会统一地遍历待排序的数据,每次比较两个相邻的数据&a…

变现 5w+,一个被严重低估的 AI 蓝海赛道,居然用这个免费的AI绘画工具就能做!

大家好,我是画画的小强,致力于分享各类的 AI 工具,包括 AI 绘画工具、AI 视频工具、AI 写作工具等等。 但单纯地为了学而学,是没有任何意义的。 这些 AI 工具,学会了,用起来,才能发挥出他们的…

Java高级面试精粹:问题与解答集锦(六)

Java 面试问题及答案 1. 请解释Java中的多线程概念,并说明如何实现它? 答案: 多线程是指在Java程序中同时运行多个线程的功能。线程是程序执行的最小单元,Java中的多线程可以通过继承Thread类或实现Runnable接口来实现。 继承Th…

django中,出现ImportError: cannot import name ‘Mapping‘ from ‘collections‘错误

出现这个错误考虑与python版本不兼容的问题。colections 模块中的 mapping 子模块只在 Python 3.3以上版本 中才有,而我的Python版本是3.11,如果django的版本低于3.3,则会出现导入错误。那么如何在不卸载原有django的基础上进行更新版本呢&am…

深入探讨ChatGPT API中的Tokens计算方式和计算库

引言 在现代人工智能应用中,自然语言处理(NLP)技术无疑是最受关注的领域之一。OpenAI推出的ChatGPT,作为一种先进的对话模型,已经在多个领域展示了其强大的语言生成能力。为了更好地使用ChatGPT API,理解其…

Amazon云计算AWS(二)

目录 三、简单存储服务S3(一)S3的基本概念和操作(二)S3的数据一致性模型(三)S3的安全措施 四、非关系型数据库服务SimpleDB和DynamoDB(一)非关系型数据库与传统关系数据库的比较&…

.yaml和.yml的区别

在软件开发和数据管理领域,文件格式的选择常常关乎工作流程的顺畅与效率。在 YAML(YAML Ain’t Markup Language)文件中,“.yaml” 和 “.yml” 两种扩展名一直存在着一些微妙的差异,甚至有些人认为它们代表着不同的含…

短剧出海的优势分析

海外短剧作为一种新兴的内容形式,正以其独特的魅力迅速占领市场,为企业带来了前所未有的商业机遇。本文将深入探讨短剧出海的优势,并为企业和老板们提供实用的操作指南。短剧出海是一个包含多个步骤的复杂过程,短剧出海需要综合考…

山景BP1048固件加密

1.在电脑的USB口插入山景公司的加密狗。 2.打开MVAssistant_BP10xx_V1.8.15(2022.04.19)软件 3.选择芯片型号。 4.选择M4模式 5.code数据选择编译好的固件,const数据选择编译好的提示音 6.输入加密密码 7.点击代码加密 8.导出MVA文件

强化学习 (三) 动态规划

文章目录 迭代法网友认为的迭代策略评估与价值迭代的区别 迭代策略评估的进一步解释附录 传统dp作用有限: 需要完备的环境模型计算的复杂度极高 其它方法都是对dp的近似,近似的出发点是解决上面两个问题。 有一种说法是,强化学习其实就是拟…

时政|志愿者免费看演出

背景 在一些文艺类网络社群里,也时常能够看到“志愿者”招募贴。演出活动招募“志愿者”,既满足了收入有限的年轻人观看演出、近距离接触偶像的愿望,也解决了主办方工作人员短缺的问题,似乎是一种双赢。 问题 “志愿服务”&…

PS系统教程09

修复照片 修饰工具 污点修复画笔工具(J) 主要作用:去除一些污点或者不需要的 【:缩小】:放大 目标:去掉这两个点 修复画笔工具 也就是说我们要有取样点 选择修复画笔工具按住Alt键吸取周边相近颜色松开单机…

Linux运维-服务器系统配置初始化脚本

方案一 ,是一个简化的Linux服务器初始化脚本 下面这个是一个简化的Linux服务器初始化脚本示例,它包括了更新软件包、安装常用工具、配置网络和安全设置等基本步骤:这个脚本提供了一个基本的初始化配置示例,包括软件更新、安装工具…

导航时间与坐标转换

前言: 该章节代码均在Gitee中开源:因为这章是学校作业,所以稍微正经点. 时空位置转换https://gitee.com/Ehundred/navigation-engineering/tree/master/%E5%8D%AB%E6%98%9F%E5%AF%BC%E8%88%AA%E5%8E%9F%E7%90%86/%E5%AF%BC%E8%88%AA%E6%97…

tmux工具使用鼠标滚动窗口及分屏命令

tmux工具使用鼠标滚动窗口及分屏命令 1. tmux source配置文件 长期生效2. 临时生效3. 实现分屏 1. tmux source配置文件 长期生效 vim ~/.tmux.conf echo "set -g mouse on" > ~/.tmux.conf tmux source-file ~/.tmux.conf2. 临时生效 1. 进入到tmux命令窗口 2.…

必看!硬核科普!什么是冻干?可以当主食喂的猫咪冻干分享

冻干猫粮作为近年来备受推崇的高品质选择,吸引了越来越多养猫人的目光。有着丰富养猫经验的我,早已开始采用冻干喂养。新手养猫的人可能会对冻干猫粮感到陌生,并产生疑问:这到底是什么?猫咪冻干可以天天喂吗&#xff1…

如何在自己的电脑上添加静态路由

1.任务栏搜索powershell 选择以管理员身份运行 2.输入 route add -p (永久) 目的网络地址例如192.168.10.0 mask 255.255.255.0(子网掩码)192.168.20.1(下一跳地址)。回车即可生效