楼主: zhjx19
21155 26

[程序分享] 熵值法确定权重原理及Matlab实现 [推广有奖]

  • 7关注
  • 29粉丝

已卖:1043份资源

讲师

76%

还不是VIP/贵宾

-

威望
0
论坛币
4864 个
通用积分
800.0414
学术水平
61 点
热心指数
66 点
信用等级
60 点
经验
5727 点
帖子
119
精华
1
在线时间
911 小时
注册时间
2013-4-26
最后登录
2025-8-1

楼主
zhjx19 发表于 2016-1-14 16:45:44 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币

一、基本原理


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

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


二、熵值法步骤


1. 选取n个国家,m个指标,则\[x_{ij}\]为第i个国家的第j个指标的数值(i=1, 2…, n; j=1,2,…, m);


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


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

正向指标:

\[x'_{ij}=\frac{x_{ij}-\min\{x_{ij},\cdots,x_{nj}\}}{\max\{x_{1j},\cdots,x_{nj}\}-\min\{x_{1j},\cdots,x_{nj}\}}\]

负向指标:

\[x'_{ij}=\frac{\max\{x_{1j},\cdots,x_{nj}\}-x_{ij}}{\max\{x_{1j},\cdots,x_{nj}\}-\min\{x_{ij},\cdots,x_{nj}\}}\]

则\[x'_{ij}\]为第i个国家的第j个指标的数值(i=1, 2…, n; j=1, 2,…, m)。为了方便起见,归一化后的数据仍记为\[x_{ij}\];


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

\[p_{ij}=\dfrac{x_{ij}}{\sum\limits_{i=1}^nx_{ij}}, \qquad i=1,\cdots,n,\,j=1,\cdots,m\]


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

\[e_j=-k\sum\limits_{i=1}^n p_{ij} ln(p_{ij})\]

其中\[k=1/ln(n) > 0\]. 满足\[e_j \geq 0\];


5. 计算信息熵冗余度:

\[d_j=1-e_j\]


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

\[w_j=\dfrac{d_j}{\sum\limits_{j=1}^md_j}\]


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

\[s_i=\sum_{j=1}^mw_j \cdot p_{ij}\]



[code]function [s,w]=shang(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: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=ones(1,m)-e;  % 计算信息熵冗余度

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

s=w*p';         % 求综合得分[\code]


测试程序:

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


二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:matlab实现 MATLAB matla atlab 确定权重 熵值法 权重 Matlab

已有 1 人评分经验 收起 理由
np84 + 100 精彩帖子

总评分: 经验 + 100   查看全部评分

本帖被以下文库推荐

沙发
落尘之木 学生认证  发表于 2016-1-15 23:51:48
参考参考,非常感谢,刚好要用这个模型

藤椅
flyhkboy 发表于 2016-1-28 12:19:40
谢谢分享,学习一下!

板凳
flyhkboy 发表于 2016-1-28 13:59:45
支持,测试了下,可以运行!

报纸
silstar 发表于 2016-5-2 13:14:52
非常感謝!最近正在研究這軟體!!

地板
q714236915 发表于 2016-5-2 20:29:38
silstar 发表于 2016-5-2 13:14
非常感謝!最近正在研究這軟體!!
我怎么运行不了啊 第一次接触Matlab 求教啊 好心人

7
q714236915 发表于 2016-5-2 20:30:50
flyhkboy 发表于 2016-1-28 13:59
支持,测试了下,可以运行!
我怎么运行不了啊 第一次接触Matlab 求教啊 好心人

8
陈信研究员 发表于 2016-5-6 22:31:05
q714236915 发表于 2016-5-2 20:30
我怎么运行不了啊 第一次接触Matlab 求教啊 好心人
可以运行的,需要自己修正下就可以了

9
779309195 发表于 2016-5-8 10:08:59
陈信研究员 发表于 2016-5-6 22:31
可以运行的,需要自己修正下就可以了
你好,这个怎么修正?我的是matlab2014a

10
陈信研究员 发表于 2016-5-8 12:02:07
779309195 发表于 2016-5-8 10:08
你好,这个怎么修正?我的是matlab2014a
就是把其修改为matlab能识别的程序,然后运行啊

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-31 15:33