Matlab学习系列19.-熵值法确定权重

合集下载
相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

19.熵值法确定权重

一、基本原理

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

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

二、熵值法步骤

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

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

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

正向指标:

X ij min {勺公2),...,人)}

X ij

max{X ij,X2j,...,X nj} min {勺公?」,…,x j

负向指标:

max{X ij,X2j,...,X nj} X j

X j

max{X jj,X2j,...,X nj} m in {勺必),…,x^}

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

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

X ij

P j —, i 1,2..., n, j 1,2..., m

X ij

i 1

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

n

e j k P ij ln( p j)

i 1

其中,k=1/ln(n)>0.满足e j >0;

5. 计算信息熵冗余度:

d j 1

e j;

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

d j

W j —, j 1,2,...,m

d j

j 1

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

m

s W j p ij, i 1,2,...n

j 1

三、Matlab实现

按上述算法步骤,编写Matlab函数:shang.m

function [s,w]=sha ng(x)

%函数shang(), 实现用熵值法求各指标(列)的权重及各数据行的得分

%x为原始数据矩阵,一行代表一个国家,每列对应一个指标

%s返回各行得分,W返回各列权重

[n,m]=size(x); % n=23 个国家,m=5 个指标

%%数据的归一化处理

% Matlab2010b,2011a,b 版本都有bug,需如下处理.其它版本直接用[X,ps]=mapmi nm ax(x',0,1); 即可

[X,ps]=mapmi nm ax(x');

ps.ymi n=0.002; %归一化后的最小值

ps.ymax=0.996; %归一化后的最大值

ps.yrange=ps.ymax-ps.ymin; %归一化后的极差,若不调整该值,

则逆运算会出错

X=mapmi nm ax(x',ps);

% mapminmax('reverse',xx,ps); % 反归一化,回到原数据

X=X'; %为归一化后的数据,23行(国家),5列(指标)

%%计算第j个指标下,第i个记录占该指标的比重p(i,j)

for i=1: n

for j=1:m

p(i,j)=X(i,j)/sum(X(:,j));

end

end

%%计算第j个指标的熵值e(j)

k=1/log( n);

for j=1:m

e(j)=-k*sum(p(:,j).*log(p(:,j)));

end

d=o nes(1,m)-e; %计算信息熵冗余度

w=d./sum(d); % 求权值w

s=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

相关文档
最新文档