评价模型TOPSIS与熵权法MATLAB代码

news/2024/10/9 10:14:49

函数代码

function topsis_example(data, data_types, up_OK, down_OK, upper_bounds, lower_bounds,middle)% 数据预处理[num_objects, num_attributes] = size(data);normalized_data = zeros(num_objects, num_attributes);% 1. 根据数据类型进行正向化处理for i = 1:num_attributesswitch data_types(i)case 1 % 效益型normalized_data(:, i) = (data(:, i) - min(data(:, i))) / (max(data(:, i)) - min(data(:, i)));case 2 % 成本型normalized_data(:, i) = (max(data(:, i)) - data(:, i)) / (max(data(:, i)) - min(data(:, i)));case 3 % 区间型for j =1: num_objectsif data(j,i)>=down_OK(i) && data(j,i)<=up_OK(i)normalized_data(j,i)=1;elseif data(j,i)>up_OK(i) && data(j,i)<= upper_bounds(i)normalized_data(j,i) = 1-(data(j,i) - up_OK(i)) /( upper_bounds(i)-up_OK(i)) ;elseif data(j,i)< down_OK(i) && data(j,i)>= lower_bounds(i)normalized_data(j,i) =1- (down_OK(i) - data(j,i))/( down_OK(i) - lower_bounds(i) );elsenormalized_data(j,i)=0;endendcase 4 % 中间型(可以根据需要自定义)M = max(abs(data(:,i)-middle(i)));normalized_data(:, i) = 1- abs(data(:,i)-middle(i)) / M;otherwiseerror('Unsupported data type: %d', data_types(i));endenddisp('处理好之后 ')disp(normalized_data)% 2. 熵权法计算权重entropy = zeros(1, num_attributes);for j = 1:num_attributesp_j = normalized_data(:, j) / sum(normalized_data(:, j)); % 概率分布p_j(p_j == 0) = []; % 去除零值entropy(j) = -sum(p_j .* log(p_j));endentropy=entropy/log(num_objects);disp('e')disp(entropy)% 计算权重weights = (1 - entropy) / sum(1 - entropy);% weights=[0.2,0.3,0.4,0.1];   %尝试人工赋权disp('weights')disp(weights)% 将数据乘以权重normalized_data=weights .* normalized_data ;disp('乘以权重之后')disp(normalized_data)% 3. TOPSIS方法计算最终评分ideal_solution = max(normalized_data);anti_ideal_solution = min(normalized_data);disp('最优解')disp(ideal_solution)disp('最差解')disp(anti_ideal_solution)% 计算到理想解和反理想解的距离distance_to_ideal = sqrt(sum((normalized_data - ideal_solution).^2, 2));        %sum(,2)计算一行的和distance_to_anti_ideal = sqrt(sum((normalized_data - anti_ideal_solution).^2, 2));disp('到正理想解的距离')disp(distance_to_ideal)disp('到负理想解的距离')disp(distance_to_anti_ideal)% 计算最终评分scores = distance_to_anti_ideal ./ (distance_to_ideal + distance_to_anti_ideal);% 显示最终评分disp('最终得分为');disp(scores);
end

示例代码

% 问题代码
data = [0.1, 5, 5000, 4.7; 0.2, 6, 6000, 5.6; 0.4, 7, 7000, 6.7;0.9,10,10000, 2.3;1.2 , 2, 400, 1.8
];data_types = [1, 3, 1, 2];  % 1 效益 ,2成本 ,3 区间  ,4中间
upper_bounds = [NaN, 12, NaN, NaN];   % 区间型的无法忍受的上界
lower_bounds = [NaN, 2, NaN, NaN];    % 区间型的无法忍受的下界
up_OK =[NaN, 6, NaN, NaN];            % 区间型的合适的上界
down_OK=[NaN, 5, NaN, NaN];           % 区间型的合适的下界
middle=[NaN,NaN,NaN,NaN];             % 中间型的合适值topsis_example(data, data_types, up_OK,down_OK,upper_bounds, lower_bounds,middle);%% 测试中间型
data = [1;2;3;4;5;6;
];data_types = [4];  % 1 效益 ,2成本 ,3 区间  ,4中间
upper_bounds = [NaN];   % 区间型的无法忍受的上界
lower_bounds = [NaN];    % 区间型的无法忍受的下界
up_OK =[NaN];            % 区间型的合适的上界
down_OK=[NaN];           % 区间型的合适的下界
middle=[3];             % 中间型的合适值topsis_example(data, data_types, up_OK,down_OK,upper_bounds, lower_bounds,middle);%% 测试效益性
data = [1;2;3;4;5;6;
];data_types = [1];  % 1 效益 ,2成本 ,3 区间  ,4中间
upper_bounds = [NaN];   % 区间型的无法忍受的上界
lower_bounds = [NaN];    % 区间型的无法忍受的下界
up_OK =[NaN];            % 区间型的合适的上界
down_OK=[NaN];           % 区间型的合适的下界
middle=[3];             % 中间型的合适值topsis_example(data, data_types, up_OK,down_OK,upper_bounds, lower_bounds,middle);%% 测试成本型
data = [1;2;3;4;5;6;
];data_types = [2];  % 1 效益 ,2成本 ,3 区间  ,4中间
upper_bounds = [NaN];   % 区间型的无法忍受的上界
lower_bounds = [NaN];    % 区间型的无法忍受的下界
up_OK =[NaN];            % 区间型的合适的上界
down_OK=[NaN];           % 区间型的合适的下界
middle=[3];             % 中间型的合适值topsis_example(data, data_types, up_OK,down_OK,upper_bounds, lower_bounds,middle);%% 测试区间型
data = [1;2;3;4;5;6;
];data_types = [3];  % 1 效益 ,2成本 ,3 区间  ,4中间
upper_bounds = [5.5];   % 区间型的无法忍受的上界
lower_bounds = [1.5];    % 区间型的无法忍受的下界
up_OK =[4];            % 区间型的合适的上界
down_OK=[3];           % 区间型的合适的下界
middle=[nan];             % 中间型的合适值topsis_example(data, data_types, up_OK,down_OK,upper_bounds, lower_bounds,middle);

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

zabbix“专家坐诊”第258期问答

问题一 Q:各位大神 问下这个zabbix通知到企业微信的py脚本可以使吗? A: 这个需要自行测试。 Q:用jconsole连接失败了。 A:那就是没配好, 连接不上,要确保能正常远程连接。问题二 Q:这种是虚拟机内部的jmx配置有问题吗? A:提示被拒绝了,没成功连上,jmx 的要用先测…

图片转绘画效和绘画软件

我收藏的软件:绘画软件: ArtRage Krita 图片转绘画效: Snap Art 4 Impresso Proffffffffffffffffftest red font.

QT5中引入GMSSL库

近来项目中需要使用加密算法,对上/下位机之间的消息进行加密。客户要求使用国密算法库,不能使用国际上通用的AES、RSA等算法。 国密即国家密码局认定的国产密码算法。主要有SM1,SM2,SM3,SM4。密钥长度和分组长度均为128位。 其中SM1没有开源,其他的均开源。 源码编译 开源…

Day2 备战CCF-CSP练习

201403-3Day2 题目描述 请你写一个命令行分析程序,用以分析给定的命令行里包含哪些选项。 每个命令行由若干个字符串组成,它们之间恰好由一个空格分隔。 这些字符串中的第一个为该命令行工具的名字,由小写字母组成,你的程序不用对它进行处理。 在工具名字之后可能会包含若干…

oop实验1

task1:1 // 现代C++标准库、算法库体验2 // 本例用到以下内容:3 // 1. 字符串string, 动态数组容器类vector、迭代器4 // 2. 算法库:反转元素次序、旋转元素5 // 3. 函数模板、const引用作为形参6 7 #include <iostream>8 #include <string>9 #include <vector…

MySQL 官宣:支持读写分离了!!

我们一直在等待的 MySQL 读/写分离功能 现在终于可以使用了! 在规模上,我们在副本之间分配读取,但这必须在应用程序中以某种方式进行管理:指向在某个地方写入并在其他地方读取。 在 MySQL 8.2 中,MySQL Router 现在能够识别读取和写入,并将它们路由到主实例(如果是 Inno…

【一步步开发AI运动小程序】二十、AI运动小程序如何适配相机全屏模式?

引言 受小程序camera组件预览和抽帧图像不一致的特性影响,一直未全功能支持全屏模式,详见本系列文件第四节小程序如何抽帧;随着插件在云上赛事、健身锻炼、AI体测、AR互动场景的深入应用,各开发者迫切的希望能在全屏模式下应用,以便获得更合理的UI布局和更佳的用户体验,经…

实战逆向RUST语言程序

实战为主,近日2024年羊城杯出了一道Rust编写的题目,这里将会以此题目为例,演示Rust逆向该如何去做。关于Rust逆向,其实就是看汇编,考验选手的基础逆向能力。在汇编代码面前,任何干扰都会成为摆设。实战为主,近日2024年羊城杯出了一道Rust编写的题目,这里将会以此题目为…