用MATLAB实现topsis评价法

2023-11-21 22:40
文章标签 matlab 实现 评价 topsis

本文主要是介绍用MATLAB实现topsis评价法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近将topsis评价方法用matlab实现了,就此分享一下具体操作方法,以供大家参考纠正。

1 将topsis的评价流程及函数方程列出

1.1 对各评价对象的参数矩阵进行同向化处理。

一般选择正向化处理,下面列举一些网络上其他博主的公式,以供参考使用。

1.1.1 极大型指标正向化

极大型指标所指意思为,这个指标越大越好,例如(升学率,毕业率等)

Xp=\frac{X-Xmin}{Xmax-Xmin}

X:各极大型属性指标的参数;

Xmax:X参数中的最大参数;

Xmin:X参数中的最小参数;

1.1.2 极小型指标正向化

同极大型指标,即此指标越小越好,例如(挂科率)

Xp=\frac{Xmax-X}{Xmax-Xmin}

公式中各变量意义同1.1.1

1.1.3 中间值型指标正向化

中间值型指标所指意思是,此指标取其中某一个值是最好的,例如(黄金比例)

Xp=1-\frac{\left | X-Xbest \right |}{\left | X-Xbest \right |max}

Xbest:此指标最优值;

1.1.4 区间型指标正向化

区间型指标所指意思为,此指标在某一个区间是最好的,例如(人的体温)

设最优区间[a,b],参数M为

M=max\left \{ a-min\left \{X \right \} ,max\left \{ X \right \}-b\right \}

Xp=\left\{\begin{matrix} 1-\frac{1-X}{M} &X<a \\ 1& a\leqslant X\leqslant b\\ 1-\frac{X-b}{M}& X>b \end{matrix}\right.

将所有指标的参数都进行了同向化处理后,得到一个m×n的同向化矩阵。

1.2 对同向化举证进行归一化处理

Z=\frac{Xp}{\sqrt{\sum_{i=1}^{n}Xp^{2}}}

Z:归一化处理后的m×n矩阵;

1.3 每个参数在Z中所对应的最大值和最小值

Zmax=[max(Z(:,1)),max(Z(:,2)),max(Z(:,3)),max(Z(:,4)),...,max(Z(:,n))];

Zmin=[min(Z(:,1)),min(Z(:,2)),min(Z(:,3)),min(Z(:,4)),...,min(Z(:,n))];

得到两个最大值和最小值向量Zmax和Zmin。

1.4 计算各评价指标的权重

根据专家经验列出一个各评价指标的重要程度矩阵,计算各指标权重ωj。

具体方法可根据AHP(层次分析法)中求权重的方法,这里不列出。

1.5 计算各指标与最优,最差方案的接近程度

Dplus\; i =\sqrt{\sum_{j=1}^{n}\omega j(Zmax\; j-Zij)^{2})}

Dminus\; i =\sqrt{\sum_{j=1}^{n}\omega j(Zmin\; j-Zij)^{2})}

Dplus:指标与最优方案的接近程度;

Dminus:指标与最差方案的接近程度;

ωj:各指标权重;

j:矩阵列数;

i:矩阵行数;

1.6 计算各评价对象与最优方案的接近程度

Si=\frac{Dminus}{Dplus+Dminus}

Si:接近程度向量;

Si越趋近于1,代表此方案越优秀。

2 topsis程序

%初始矩阵
A=[4.69,6.59,51,11.94;2.03,7.86,19,6.46;9.11,6.31,46,8.91;8.61,7.05,46,26.43;7.13,6.5,50,23.57;2.39,6.77,38,24.62;7.69,6.79,38,6.01;9.3,6.81,27,31.57;5.45,7.62,5,18.46;6.19,7.27,17,7.51;7.93,7.53,9,6.52;4.4,7.28,17,25.3;7.46,8.24,23,14.42;2.01,6.4,23,17.91;7.73,6.14,52,15.72;6.35,7.58,25,29.46;8.29,8.41,39,12.02;3.54,7.27,54,3.16;7.44,6.26,8,28.41];
%提取1至4列
B=A(:,1);
C=A(:,2);
D=A(:,3);
E=A(:,4);
%找出1,3,4列最大值和最小值
MAX1=max(B);MAX3=max(D);MAX4=max(E);
MIN1=min(B);MIN3=min(D);MIN4=min(E);
%第2列的最优值为7
BEST=7;
%第4列的最优区间[10,20]
a=10;b=20;
M=max(a-MIN4,MAX4-b);
%矩阵正向化,其中的BP、CP、DP、EP代表每一个指标的参数正向化后的向量
BP=(B-MIN1)/(MAX1-MIN1);
CP=1-((abs(C-BEST))/(max(abs(C-BEST))));
DP=(MAX3-D)/(MAX3-MIN3);
%计算EP
e1=((E<a).*E);
e2=(E>=a&E<=b);
e3=((E>b).*E);
for i=1:length(e1)if e1(i)~=0e1(i)=1-((a-e1(i))/M);end
end
for i=1:length(e3)if e3(i)~=0e3(i)=1-((e3(i)-b)/M);end
end
EP=e1+e2+e3;
%得到正向化矩阵AP
AP=[BP,CP,DP,EP];
%对AP矩阵进行归一化处理,得到矩阵Z
Z=AP./((sum(AP.^2)).^(1/2));
%Z中每一列的最大值和最小值(计算最优方案和最劣方案)
ZMAX=[max(Z(:,1)),max(Z(:,2)),max(Z(:,3)),max(Z(:,4))];
ZMIN=[min(Z(:,1)),min(Z(:,2)),min(Z(:,3)),min(Z(:,4))];
%计算权重,假设其4个因素的重要程度判断矩阵为VERDICT
VERDICT=[1,1,7,5;1,1,7,5;1/7,1/7,1,1/3;1/5,1/5,3,1];
n=4;
%几何平均计算各行向量的权重
Mn=prod(VERDICT,2); 
Mnn=Mn.^(1/n);
%进行归一化
%得到权重Wn
Wn=Mnn/sum(Mnn);
%计算判断矩阵的最大特征值
Aw=VERDICT*Wn;
H=Aw./Wn;
Lambdamax=(1/n)*sum(H);
CI=(Lambdamax-n)/(n-1);
RI=[0,0,0.52,0.89,1.12,1.26,1.36,1.41,1.46,1.49,1.52,1,54,1.56,1.58,1.59];
CR=CI/RI(n);
if    CR<0.1disp('CR<0.1,该矩阵的一致性可以接受')
elsedisp('CR>=0.1,该矩阵的一致性不可接受,需要修改')
end
%计算各评价对象与最优方案、最劣方案的接近程度
%先将Wn列向量转化为行向量,方便计算
Wn=reshape(Wn,1,4);
%将Wn、ZMAX、ZMIN向量复制,形成一个与Z矩阵同行列的矩阵,方便计算
repmat(Wn,19,1);
repmat(ZMAX,19,1);
repmat(ZMIN,19,1);
Dplus=(sum((Wn.*((ZMAX-Z).^2)),2)).^0.5;
Dminus=(sum((Wn.*((ZMIN-Z).^2)),2)).^0.5;
%计算各评价对象与最优方案的贴近程度
Si=Dminus./(Dplus+Dminus)
%Si越趋近于1越优秀

对于matlab的语言,我也只是会粗浅的运用,其中不对的地方望大家纠正。

关于topsis评价法的相关流程和公式,多为参考的网上其他博主的文章,matlab中的代码是自己敲的,此文章的目的为让自己再熟悉一下topsis评价法,也为初学matlab编程的朋友做一个参考。

3 期望

对于topsis方法中,计算各指标与最优,最差方案的接近程度的方法,我是避开了调用矩阵中的元素来作为变量,直接生成一个以矩阵和向量为变量的函数,然后用循环来得出最后的Dplus和Dminus,用的将向量复制成一个同类型矩阵,然后对应元素做运算,我总感觉这样有点low。

希望得到大神指导,如何使向量中的元素作为变量参与函数计算,并进行循环,最后得到一个结果向量。

4 参考文章

https://zhuanlan.zhihu.com/p/37738503

https://yucohny.blog.csdn.net/article/details/113242618?spm=1001.2014.3001.5506

这篇关于用MATLAB实现topsis评价法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

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

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

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import