【综合评价分析】熵权算法确定权重 原理+完整MATLAB代码+详细注释+操作实列

这篇具有很好参考价值的文章主要介绍了【综合评价分析】熵权算法确定权重 原理+完整MATLAB代码+详细注释+操作实列。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【综合评价分析】熵权算法确定权重 原理+完整MATLAB代码+详细注释+操作实列

文章目录

1. 熵权法确定指标权重

(1)构造评价矩阵 Ymn

(2)评价矩阵标准化处理

(3)计算指标信息熵值 Mj

(4)计算各指标权重 Nj

2.完整代码

2.1 熵权法(正向化指标)

2.2熵权法(负向化指标)

3.运行演示

3.1复制代码,建立函数

3.2 导入data数据集

3.3 运行指令

3.4 运行结果

3.5 结构体 result变量

3.5.1 归一化

3.5.2 熵值

3.5.3 权重

3.6 熵权法(负向化指标)

4.总结


 采用熵权法进行客观权重计算的步骤为:

①根据评价等级对指标重要性进行打分,然后构建评价矩阵;

②将评价矩阵进行归一化处理,得到归一化评价矩阵;

③根据信息熵计算公式,计算各个指标 的信息熵;

④根据熵权计算公式,计算各个指标的客观权重值 。

1. 熵权法确定指标权重

(1)构造评价矩阵 Ymn

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

(2)评价矩阵标准化处理

       采用线性比例变换法将评价矩阵进行初等变换,得到归一化矩阵进而解决不同指标值的同质化问题,其中正向指标与负向指标数值不同,但绝对值越大越好凹,例如计算指标的重要性与权重值的关系,权重值越大,则代表重要性越强,所以选择正向指标。

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

式中:yij ——评价矩阵原始值。

归一化:计算第 j 项指标下第 i 个样本值占该指标的比重 qij。

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

 式中:m——总样本数。

(3)计算指标信息熵值 Mj

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

(4)计算各指标权重 Nj

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

2.完整代码

2.1 熵权法(正向化指标)

%data是n个对象、m个评价指标 n行m列数据
%data是唯一需要从外界输入的数据
function  result=SQ(data);
R = data;
[rows,cols]=size(R);   % 输入矩阵的大小,rows为行数(对象个数),cols为列数(指标个数)

Rmin = min(R);         %矩阵中最小行
Rmax = max(R);         %矩阵中最大行
A = max(R) - min(R);   %分母 矩阵中最大行减最小行

y = R - repmat(Rmin,rows,1);      %分子 R矩阵每一行减去最小行
for j = 1 : cols                  %该循环用于正向指标标准化处理 分子/分母
     y(:,j) = y(:,j)/A(j);
end

S = sum(y,1);                     %列之和(用于列归一化)

for i = 1 : cols                  %该循环用于列的归一化
    Y(:,i) = y(:,i)/S(i); 
end

Y;                                %打印矩阵正向指标标准化处理结果

k=1/log(rows);                    % 求k
lnYij1=zeros(rows,cols);           % 初始化lnYij1
% 计算lnYij1
for i=1:rows                         %循环遍历取对数
    for j=1:cols
        if Y(i,j)==0;
            lnYij1(i,j)=0;
        else
            lnYij1(i,j)=log(Y(i,j));  %log取对数
        end
    end
end
ej1=-k*(sum(Y.*lnYij1,1));             % 计算正向指标标准化熵值ej1

weights1=(1-ej1)/(cols-sum(ej1));  %正向指标权重weights1


%结构体定义
result(1).guiyihua = Y;            %矩阵归一化结果赋给result
result(1).shangzhi = ej1;          %熵值赋给result
result(1).weight = weights1;       %权重赋给result

2.2熵权法(负向化指标)

%data是n个对象、m个评价指标 n行m列数据
%data是唯一需要从外界输入的数据
function  result=SQfuxiang(data);
R = data;
[rows,cols]=size(R);   % 输入矩阵的大小,rows为行数(对象个数),cols为列数(指标个数)

Rmin = min(R);         %矩阵中最小行
Rmax = max(R);         %矩阵中最大行
A = max(R) - min(R);   %分母 矩阵中最大行减最小行

y1 = repmat(Rmax,rows,1) - R;     %分子 最大行减去R矩阵每一行

for j = 1 : cols                  %该循环用于负向指标标准化处理 分子/分母
     y1(:,j) = y1(:,j)/A(j);
end
S = sum(y1,1);                    %列之和(用于列归一化)
for i = 1 : cols                  %该循环用于列的归一化
    Y1(:,i) = y1(:,i)/S(i); 
end
Y1;                               %打印矩阵负向指标标准化处理结果

k=1/log(rows);                    % 求k
lnYij2=zeros(rows,cols);           % 初始化lnYij2
% 计算lnYij1
for i=1:rows                         %循环遍历取对数
    for j=1:cols
        if Y1(i,j)==0;
            lnYij2(i,j)=0;
        else
            lnYij2(i,j)=log(Y1(i,j));  %log取对数
        end
    end
end
ej2=-k*(sum(Y1.*lnYij2,1));             % 计算负向指标标准化熵值ej2

weights2=(1-ej2)/(cols-sum(ej2));  %负向指标权重weights2

%结构体定义
result(1).guiyihua = Y1;            %矩阵归一化结果赋给result
result(1).shangzhi = ej2;           %熵值赋给result
result(1).weight = weights2;        %权重赋给result

3.运行演示

3.1复制代码,建立函数

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

默认函数名保存即可

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

3.2 导入data数据集

%data是n个对象、m个评价指标 n行m列数据
%data是唯一需要从外界输入的数据

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

以下列子所用数据集为

     5     3     7     3
     6     7     6     4
     9     4     7     5
    10     6     9     2
     6     4     8     6
     7     2     8     3
     5     4     5     3
     9     5     9     2

3.3 运行指令

result=SQ(data)                      

result=SQfuxiang(data)           

3.4 运行结果

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

3.5 结构体 result变量

 熵权法matlab代码,python,算法,深度学习,matlab,机器学习

3.5.1 归一化

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

3.5.2 熵值

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

3.5.3 权重

熵权法matlab代码,python,算法,深度学习,matlab,机器学习

3.6 熵权法(负向化指标)

运行指令换成

result=SQfuxiang(data)     

即可

运行结果就不再过多赘述。

4.总结

 采用熵权法进行客观权重计算的步骤为:

①根据评价等级对指标重要性进行打分,然后构建评价矩阵;

②将评价矩阵进行归一化处理,得到归一化评价矩阵;

③根据信息熵计算公式,计算各个指标 的信息熵;

④根据熵权计算公式,计算各个指标的客观权重值 。

本文包括了熵权算法法确定权重原理+完整MATLAB代码+详细注释+操作实列。文章来源地址https://www.toymoban.com/news/detail-812489.html

到了这里,关于【综合评价分析】熵权算法确定权重 原理+完整MATLAB代码+详细注释+操作实列的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 评价模型(一) 层次分析法(AHP),熵权法,TOPSIS分析 及其对应 PYTHON 实现代码和例题解释

    数学建模系列文章: 以下是个人在准备数模国赛时候的一些模型算法和代码整理,有空会不断更新内容: 评价模型(一)层次分析法(AHP),熵权法,TOPSIS分析 及其对应 PYTHON 实现代码和例题解释 评价模型(二)主成分分析、因子分析、二者对比及其对应 PYTHON 实现代码和例

    2024年02月08日
    浏览(22)
  • 综合评价算法 | Matlab实现基于TOPSIS法的综合评价算法

    效果一览 文章概述 综合评价算法 | Matlab实现基于TOPSIS法的综合评价算法 研究内容 C.L.Hwang 和 K.Yoon 于1981年首次提出 TOPSIS (Technique for Order Preference by Similarity to an Ideal Solution)。TOPSIS 法是一种常用的组内综合评价方法,能充分利用原始数据的信息,其结果能精确地反映各评价方

    2024年02月12日
    浏览(57)
  • 熵权法计算权重

    基于信息论的熵值法是根据各指标所含信息有序程度的差异性来确定指标权重的客观赋权方法,仅依赖于数据本身的离散程度。 熵用于度量不确定性,指标的离散程度越大(不确定性越大)则熵值越大,表明指标值提供的信息量越多,则该指标的权重也应越大。 熵权法多用

    2024年02月04日
    浏览(20)
  • 熵值法综合评价分析流程

    熵值法综合评价分析流程 当前有一份数据,是各品牌车各个维度的得分情况,现在想要使用熵值法进行综合评价,得到各品牌车的综合得分,从而进行车型优劣对比,为消费者提供购车依据。 数据如下(数据虚构,无实际意义): 使用熵值法进行分析,需要对数据进行处理

    2024年02月02日
    浏览(13)
  • 数学建模【模糊综合评价分析】

    一、模糊综合评价分析简介 提到模糊综合评价分析,就先得知道模糊数学。1965年美国控制论学家L.A.Zadeh发表的论文“Fuzzy sets”标志着模糊数学的诞生。 模糊数学又称Fuzzy数学,是研究和处理模糊性现象的一种数学理论和方法。模糊性数学发展的主流是在它的应用方面。由于

    2024年03月20日
    浏览(19)
  • 数学建模:模糊综合评价分析

    🔆 文章首发于我的个人博客:欢迎大佬们来逛逛 构成综合评价类问题的五个要素: 被评价对象 评价指标 权重系数 综合评价模型 评价者 综合评价的一般步骤: 确定综合评价的目的(分类?排序?实现程度) 建立评价指标体系 对指标数据进行 预处理 :一致化和无量纲化

    2024年02月09日
    浏览(16)
  • 数学建模—评价模型—灰色关联度分析Vs灰色综合评价

            黑色系统:只明确系统和环境的关系,内部未知         白色系统:内部结构、元素、组成、实现机理已知         灰色系统:部分明确系统与环境见关系、系统结构、实现过程。 灰色系统实例:(1)社会经济系统(企业收入、相关因素) 灰色系统理论

    2024年02月04日
    浏览(21)
  • 模糊综合评价-----层次分析法AHP

    文首先读: ​ 最近有个课题需要用到模糊综合评价,笔者也是收集了各方资料,最后发现某乎上的一篇文章,简单、系统、详细的同时不乏简单易懂和深度见解,这边link给出,读者可以自己尝试阅读,必有不少收获。 ​ 之后发现其中需要用到层次分析法的时候,大佬是一

    2023年04月09日
    浏览(13)
  • 数学建模常用算法—模糊综合评价

    目录 模型的含义 模型的数学概念 模型的建立与求解 matlab代码实现 今天给大家讲解一下国赛中常用到的评价模型,模糊综合评价法。 模糊综合评价法是一种基于模糊数学的综合评价方法。该综合评价法根据模糊数学的隶属度理论把定性评价转化为定量评价,即用模糊数学对

    2023年04月12日
    浏览(15)
  • topsis算法模型和熵权法使用原理详解

    topsis模型原理: 1.topsis模型介绍 TOPSIS法(Technique for Order Preference by Similarity to Ideal Solution) 可翻译为逼近理想解排序法,国内常简称为优劣解距离法 TOPSIS 法是一种常用的综合评价方法,其能充分利用原始数据的信息, 其结果能精确地反映各评价方案之间的差距。 2.适用范围

    2024年02月04日
    浏览(20)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包