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 静态全局变量 静态全局变量声明在…

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

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

排序算法(C++)

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

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

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

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

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

Amazon云计算AWS(二)

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

短剧出海的优势分析

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

山景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键吸取周边相近颜色松开单机…

导航时间与坐标转换

前言: 该章节代码均在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(下一跳地址)。回车即可生效

LeetCode刷题 | Day 1 最大子序列求和(Largest K Subsequence Sum)

LeetCode刷题 | Day 1 最大子序列求和(Largest K Subsequence Sum) 文章目录 LeetCode刷题 | Day 1 最大子序列求和(Largest K Subsequence Sum)前言一、题目概述二、解题方法2.1 贪心思路2.1.1 思路讲解2.1.2 伪代码 + 逐步输出示例2.1.3 Python代码如下2.1.4 C++代码如下…

用WebStorm和VS Code断点调试Vue

大家好,我是咕噜铁蛋!。今天,我想和大家分享一下如何在WebStorm和VS Code这两款流行的开发工具中,使用断点调试Vue.js项目。Vue.js作为前端三大框架之一,以其轻量级和组件化的特性,受到了广大开发者的喜爱。…

客观评价一下GPT-4o

评价GPT-4o(即OpenAI发布的升级版语言模型),以下是上大学网(www.sdaxue.com)从技术能力与创新性、性能与效率、功能实用性与用户体验等几个维度进行评价,不周之出,请大家指正。 技术能力与创新性…

PTA字符串str1在第i个位置插入字符串str2

字符串str1在第i个位置插入字符串str2&#xff0c;如在字符串1234567890第2位插入ABC。 输入格式: 1234567890 ABC 2 输出格式: 12ABC34567890 #include<stdio.h> #include<string.h> int main() {char s1[100],s2[100];int w;scanf("%s%s%d",s1,s2,…

专业FBA海运货代是什么?为什么用FBA?

一、专业FBA海运货代概述 专业FBA海运货代是专门为卖家提供海运货物进入亚马逊仓库服务的一种行业。FBA&#xff0c;全称Fulfilled by Amazon&#xff0c;即亚马逊代发货服务&#xff0c;是亚马逊为卖家提供的一种物流服务。卖家将货物发往亚马逊并寄存在其仓库&#xff0c;商…

Java的冷知识你知道吗?

1、方法参数不能超过255个 在Java中&#xff0c;方法的参数数量是有限制的&#xff0c;最多不能超过255个。这个知识点可能对于大多数程序员来说并不常用&#xff0c;因此即使是经验丰富的Java开发者也可能不清楚这一点。2、Java中的自动装箱与拆箱 自动装箱是Java 5引入的新特…