声明:转载自https://blog.csdn.net/u013713294/article/details/53407087/?utm_medium=distribute.pc_relevant.none-task-blog-baidujs_title-0&spm=1001.2101.3001.4242

一、基本原理

在信息论中,熵是对不确定性的一种度量。信息量越大,不确定性就越小,熵也就越小;信息量越小,不确定性越大,熵也越大。

根据熵的特性,可以通过计算熵值来判断一个事件的随机性及无序程度,也可以用熵值来判断某个指标的离散程度,指标的离散程度越大,该指标对综合评价的影响(权重)越大,其熵值越小。

二、熵值法步骤

1. 选取 n个国家, m个指标,则 为第 i个国家的第 j个指标的数值( i=1, 2…,  n;  j=1,2,…,  m);

2. 指标的归一化处理:异质指标同质化

由于各项指标的计量单位并不统一,因此在用它们计算综合指标前,先要对它们进行标准化处理,即把指标的绝对值转化为相对值,并令 ,从而解决各项不同质指标值的同质化问题。而且,由于正向指标和负向指标数值代表的含义不同(正向指标数值越高越好,负向指标数值越低越好),因此,对于高低指标我们用不同的算法进行数据标准化处理。其具体方法如下:

正向指标:

负向指标:

为第 i个国家的第 j个指标的数值( i=1, 2…,  n;  j=1, 2,…,  m)。为了方便起见,归一化后的数据仍记为 ;

3. 计算第 j项指标下第 i个国家占该指标的比重:

4. 计算第 j项指标的熵值:

其中 . 满足 ;

5. 计算信息熵冗余度:

6. 计算各项指标的权值:

7. 计算各国家的综合得分:

注:对正逆指标归一化的时候如果采用的方法不一样,正指标归一化得到的值会大一些,逆指标的归一化得到的值会小一些,然后算权重,逆指标对应的权重也会相应的小,从而逆指标对应的得分也小些,就相当于对逆指标进行了处理。如果对正逆指标归一化采用的方法一样,为了体现逆指标的不利影响,最后应该总分减去逆指标的得分的。两种方法不同,但都是为了体现逆指标对综合得分的不利影响。

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

 function [s,w] = entropy(x)% 函数shang.m, 实现用熵值法求各指标(列)的权重及各数据行的得分% x为原始数据矩阵, 一行代表一个国家, 每列对应一个指标% s返回各行得分, w返回各列权重[n,m]=size(x); % n=23个国家, m=5个指标%% 数据的归一化处理% Matlab2010b,2011a,b版本都有bug,需如下处理. 其它版本直接用[X,ps]=mapminmax(x',0,1);即可[X,ps]=mapminmax(x');ps.ymin=0.002; % 归一化后的最小值ps.ymax=0.996; % 归一化后的最大值ps.yrange=ps.ymax-ps.ymin; % 归一化后的极差,若不调整该值, 则逆运算会出错X=mapminmax(x',ps);% mapminmax('reverse',xx,ps); % 反归一化, 回到原数据X=X';  % X为归一化后的数据, 23行(国家), 5列(指标)%% 计算第j个指标下,第i个记录占该指标的比重p(i,j)for i=1:nfor j=1:mp(i,j)=X(i,j)/sum(X(:,j));endend%% 计算第j个指标的熵值e(j)k=1/log(n);for j=1:me(j)=-k*sum(p(:,j).*log(p(:,j)));endd=ones(1,m)-e;  % 计算信息熵冗余度w=d./sum(d);    % 求权值ws=w*p';         % 求综合得分

测试程序:

data.txt  数据如下:
114.6 1.1 0.71 85.0 346 
55.3 0.96 0.4 69.0 300
132.4 0.97 0.54 73.0 410 
152.1 1.04 0.49 77.0 433
103.5 0.96 0.66 67.0 385 
81.0 1.08 0.54 96.0 336
179.3 0.88 0.59 89.0 446 
29.8 0.83 0.49 120.0 289
92.7 1.15 0.44 154.0 300 
248.6 0.79 0.5 147.0 483
115.0 0.74 0.65 252.0 453 
64.9 0.59 0.5 167.0 402
163.6 0.85 0.58 220.0 495 
95.7 1.02 0.48 160.0 384
139.5 0.70 0.59 217.0 478 
89.9 0.96 0.39 105.0 314
76.7 0.95 0.51 162.0 341 
121.8 0.83 0.60 140.0 401
42.1 1.08 0.47 110.0 326 
78.5 0.89 0.44 94.0 280
77.8 1.19 0.57 91.0 364 
90.0 0.95 0.43 89.0 301
100.6 0.82 0.59 83.0 456

执行代码:
[code] x=load('data.txt');  %  读入数据

[s,w]=shang(x) [\code]

运行结果:
s =

Columns 1 through 9

0.0431    0.0103   0.0371    0.0404    0.0369    0.0322   0.0507    0.0229    0.0397

Columns 10 through 18

0.0693    0.0878   0.0466    0.0860    0.0503    0.0800   0.0234    0.0456    0.0536

Columns 19 through 23

0.0272    0.0181   0.0364    0.0202    0.0420

w =

0.1660    0.0981   0.1757    0.3348    0.2254

转自:http://www.ilovematlab.cn/thread-452528-1-1.html

熵值法确定权重算法及Matlab实现相关推荐

  1. matlab 值法确定各指标权重,Matlab学习系列19. 熵值法确定权重

    19. 熵值法确定权重 一.基本原理 在信息论中,熵是对不确定性的一种度量.信息量越大,不确定性就越小,熵也就越小:信息量越小,不确定性越大,熵也越大. 根据熵的特性,可以通过计算熵值来判断一个事件的 ...

  2. 【人因工程】熵值法求权重正反向化的分析

    目录 一.问题提出 二.问题分析 1. 第一步: 2. 第二步 3. 第三步 三.进一步分析 总结 一.问题提出 所需数据集见链接: 人因工程熵值法求权重正反向化的分析配套数据-数据集文档类资源-CS ...

  3. Python实现熵值法确定权重

    该文为转载文章,无排版,链接直达 Python实现熵值法确定权重 本文从以下四个方面,介绍用Python实现熵值法确定权重: 一. 熵值法介绍 二. 熵值法实现 三. Python实现熵值法示例1 四 ...

  4. 熵值法计算权重有异常值_指标权重确定方法 1-熵值法

    在信息论中,熵是对不确定性或随机性的一种度量,不确定性越大,熵值就越大,不确定性越小,熵值就越小.不确定性越大,表明随机性越大,数据越离散,则包含的信息就越大,在确定权重的时候往往就越小. 熵值法确定 ...

  5. 手把手教你用熵值法计算权重

    由于对数据要求少,且容易计算,熵值法一直是备受欢迎的权重计算方法. 今天的文章,将带大家一起梳理熵值法计算权重的步骤以及如何应用到综合评价研究中. 一.研究背景 研究案例是利用熵值法来对各企业的财务状 ...

  6. excel熵值法计算权重_指标权重确定方法 1-熵值法

    在信息论中,熵是对不确定性或随机性的一种度量,不确定性越大,熵值就越大,不确定性越小,熵值就越小.不确定性越大,表明随机性越大,数据越离散,则包含的信息就越大,在确定权重的时候往往就越小. 熵值法确定 ...

  7. matlab:熵值法确定权重

    前言 课题的模型需要给数据的各个属性进行分配权重,原本想使用AHP层次分析法求每个属性的权重,但因为这个算法主观因素偏重,而且我有用大量的数据,完全可以从数据中学习,最终选择了信息熵确定权重的方法. ...

  8. 熵值法确定权重(matlab附代码)

    文章目录 一.基本原理 二.计算过程 三.实例 一.基本原理 ​ 熵值法是一种客观赋权法,是根据各项指标观测值所提供的信息的大小来确定指标权重. ​ 在信息论中,熵是对不确定性信息的一种度量.信息量月 ...

  9. excel熵值法计算权重_熵值法的Excel基本步骤

    各位亲们,前天从盐城回来,我收拾收拾就开始忙着补上上个星期拖的更了.本期主要内容主要是对盐城滨海湿地野外采样的总结,在论文写作中指标权重的赋予,以及分享几套宁波大学特有的PPT模板. 从7月28日-8 ...

  10. excel熵值法计算权重_SPSS主成分分析 | 指标权重值计算真的不难!(上)

    一 指标权重计算确定的困惑 相信很多写过或者正在写指标处理类论文的朋友都曾对如何计算指标权重充满困惑,到底是用熵值法,还是主成分分析法?或者其他各种看起来奥妙无穷却难以上手操作的神奇方法?好不容易确定 ...

最新文章

  1. slam for dummies
  2. 相对友好的 AVL Tree 教程
  3. mysql handlers,2 Handlers
  4. 转 已知两点坐标和半径求圆心坐标程序C++
  5. 雷林鹏分享:YAF 在Nginx环境下的Rewrite规则
  6. 今天携程出事了:让我们来学习下http的响应码
  7. [bzoj1025] [SCOI2009]游戏
  8. php 获取url中的参数
  9. 乌班图服务器系统升级,快速从Ubuntu 20.10升级到Ubuntu 21.04的方法
  10. 数论基础及其代码实现
  11. MDK3358平台QT示例-ADS1110温度采集示例
  12. 嵌入式软件工程师成长---所需要看的书籍
  13. 动态规划之《高楼扔鸡蛋》问题详解 LeetCode 887.鸡蛋掉落
  14. 2019年新能源汽车补贴政策,赶紧了解车牌识别!
  15. qt 子线程(多线程)更新gui的几种方法
  16. python一只青蛙一次可以_Python面试题系列之11 变态青蛙跳
  17. 基于深度学习的SDN家庭网关加密网络流量分类
  18. obs studio_使用OBS Studio实时进行Linux视频编辑
  19. 十大畅销经济学类书籍
  20. Socket的用法——普通Socket

热门文章

  1. app不走系统代理?如何抓包?
  2. 效率直接起飞的PPT技巧,你知道吗
  3. 联发科MTK工程模式(中文对照版本)和测试模式指令
  4. tp6 支付宝沙箱支付
  5. 【JS-05】javascript检测ie版本
  6. HDFS副本存放机制
  7. Android Studio应用Freeline光速编译APK
  8. matlab设置图片背景透明_MATLAB设置图片背景透明,和设定大小,适合论文中使用...
  9. springCloud 2020.x 版本变化,移除eureka以外的Netflix组件
  10. java获取本年、本月、本周、本日开始时间结束时间