权重系数(灰色关联法)python

本文介绍了一种基于Python的数据处理方法,通过均值化处理、关联系数计算及排序来对比不同年份的数据变化。首先对数据进行归一化处理,接着计算各个样本与基准样本之间的差值,并进一步计算最大差和最小差。通过设定的系数计算出各比较队列与参考队列间的关联系数,并最终完成关联系数的排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import pandas as pd
import numpy as np

x = pd.DataFrame([[2000,0.732,0.836,0.628,0.743], [2001,0.758,0.883,0.688,0.787], [2002,0.859,0.914,0.781,0.929],[2003,1.0125,1.0440,1.0237,0.9847],[2004,1.2356,1.1069,1.2833,1.2363],[2005,1.4013,1.2152,1.5405,1.3182]])

x=pd.read_excel(‘D:\date\winequality\winequality-red1.xlsx’)

x=df.iloc[:,1:].T

1、数据均值化处理

x_mean=x.mean(axis=1)
for i in range(x.index.size):
x.iloc[i,:] = x.iloc[i,:]/x_mean[i]

x.iloc[i,:] = x.iloc[i,:]/x_mean[i]

2、提取参考队列和比较队列

ck=x.iloc[0,:]
cp=x.iloc[1:,:]

比较队列与参考队列相减

t=pd.DataFrame()
for j in range(cp.index.size):
temp=pd.Series(cp.iloc[j,:]-ck)
t=t.append(temp,ignore_index=True)

#求最大差和最小差
mmax=t.abs().max().max()
mmin=t.abs().min().min()
rho=0.5

#3、求关联系数
ksi=((mmin+rhommax)/(abs(t)+rhommax))

#4、求关联度
r=ksi.sum(axis=1)/ksi.columns.size

#5、关联度排序,得到结果r3>r2>r1
result=r.values
print(result)
result.shape

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值