用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

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja