熵权法Python代码实现

前言

熵权法做实证的好像很爱用,matlab的已经实现过了,但是matlab太大了早就删了,所以搞一搞python实现的,操作空间还比较大

代码

数据

import pandas as pd
data = [[100,90,100,84,90,100,100,100,100],
    [100,100,78.6,100,90,100,100,100,100],
    [75,100,85.7,100,90,100,100,100,100],
    [100,100,78.6,100,90,100,94.4,100,100],
   [100,90,100,100,100,90,100,100,80],
    [100,100,100,100,90,100,100,85.7,100],
    [100,100,78.6,100,90,100,55.6,100,100],
    [87.5,100,85.7,100,100,100,100,100,100],
    [100,100,92.9,100,80,100,100,100,100],
    [100,90,100,100,100,100,100,100,100],
    [100,100,92.9,100,90,100,100,100,100]]
data = pd.DataFrame(data)

熵权法代码

from sklearn.preprocessing import MinMaxScaler
import numpy as np

# 需要进行评价的特征(一般列名)
selected_features = list(data.columns.values)

# 对选取的特征进行归一化
scaler = MinMaxScaler()
norm_data = scaler.fit_transform(data[selected_features]) 

#定义熵值法函数、熵值法计算变量的权重
def cal_weight(feature_num,sample_num,value):
    p= np.array([[0.0 for i in range(feature_num)] for i in range(sample_num)])                    

    for i in range(feature_num):
        value[:,i] += 1e-10 # 防止log0
        p[:,i]=(value[:,i])/np.sum(value[:,i],axis=0) # 计算特征值占比
        
    e=-1/np.log(sample_num)*sum(p*np.log(p))  #计算熵值
    g=1-e  # 计算一致性程度
    w=g/sum(g) #计算权重
    return w


f_num = len(selected_features) # 指标个数
s_num = len(data.index.values) # 方案数、评价主体
w = cal_weight(f_num, s_num, norm_data)
w = pd.DataFrame(w,index=selected_features,columns=['weight']) # 计算出的权重
scores = np.dot(data,w).round(2) # 计算综合分数
result = pd.DataFrame(scores,index=data.index.values,columns=['score']).sort_values(by =['score'],ascending = False) # 对球员的分数进行排名

结果

在这里插入图片描述
在这里插入图片描述
matlab结果差不多,可能归一化不一样有点差别。

不过这里指标都是正向的,即越大越好,负向指标、区间指标等还并未兼容,以后要是用到了再说吧。

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-02-11 19:02:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-11 19:02:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-11 19:02:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-11 19:02:01       20 阅读

热门阅读

  1. CM3035 Advanced Web Development

    2024-02-11 19:02:01       24 阅读
  2. Leetcode 90.子集II - Subset II - Python - 回溯法

    2024-02-11 19:02:01       32 阅读
  3. Qt 实现无边框窗口1.0

    2024-02-11 19:02:01       27 阅读
  4. 面试高频知识点:2线程 2.1.6线程之间如何通信

    2024-02-11 19:02:01       28 阅读
  5. 力扣94-二叉树的中序遍历

    2024-02-11 19:02:01       32 阅读
  6. 2.3 Binance_interface APP 现货行情-实时行情

    2024-02-11 19:02:01       31 阅读
  7. 1.1 Binance_interface安装与介绍

    2024-02-11 19:02:01       34 阅读