Python实现灰色关联分析与结果可视化的详细代码
目录
代码实现下载数据实现灰色关联分析结果可视化参考文章之前在比赛的时候需要用Python实现灰色关联分析,从网上搜了下只有实现两个列之间的,于是我把它改写成了直接想Pandas中的计算工具直接计算person系数那样的形式,可以对整个矩阵进行运算,并给出了可视化效果,效果请见实现
灰色关联分析法
对于两个系统之间的因素,其随时间或不同对象而变化的关联性大小的量度,称为关联度。在系统发展过程中,若两个因素变化的趋势具有一致性,即同步变化程度较高,即可谓二者关联程度较高;反之,则较低。因此,灰色关联分析方法,是根据因素之间发展趋势的相似或相异程度,亦即“灰色关联度”,作为衡量因素间关联程度的一种方法。
简介
灰色系统理论提出了对各子系统进行灰色关联度分析的概念,意图透过一定的方法,去寻求系统中各子系统(或因素)之间的数值关系。因此,灰色关联度分析对于一个系统发展变化态势提供了量化的度量,非常适合动态历程分析。
计算步骤
确实参考数列与比较数列对参考数列与比较数列进行无量纲化处理计算关联系数,求关联度此处我给出的是第三步的实现方式,无量纲化请自己处理.数据使用UCI的红酒质量数据集.
代码实现
下载数据
import pandas as pd import numpy as np import matplotlib.pyplot as plt %matplotlib inline # 定义下载数据的函数 def ReadAndSaveDataByPandas(target_url = None,file_save_path = None ,save=False): if target_url !=None: target_url = ("http://archive.ics.uci.edu/ml/machine-learning-databases/wine-quality/winequality-red.csv") if file_save_path != None: file_save_path = "/home/fonttian/Data/UCI/Glass/glass.csv" wine = pd.read_csv(target_url, header=0, sep=";") if save == True: wine.to_csv(file_save_path, index=False) return wine # 从硬盘读取数据进入内存 wine = pd.read_csv("/home/font/Data/UCI/WINE/wine.csv") wine.head()
实现灰色关联分析
import pandas as pd from numpy import * def GRA_ONE(DataFrame,m=0): gray= DataFrame #读取为df格式 gray=(gray - gray.min()) / (gray.max() - gray.min()) #标准化 std=gray.iloc[:,m]#为标准要素 ce=gray.iloc[:,0:]#为比较要素 n=ce.shape[0] m=ce.shape[1]#计算行列 #与标准要素比较,相减 a=zeros([m,n]) for i in range(m): for j in range(n): a[i,j]=abs(ce.iloc[j,i]-std[j]) #取出矩阵中最大值与最小值 c=amax(a) d=amin(a) #计算值 result=zeros([m,n]) result[i,j]=(d+0.5*c)/(a[i,j]+0.5*c) #求均值,得到灰色关联值 result2=zeros(m) result2[i]=mean(result[i,:]) RT=pd.DataFrame(result2) return RT def GRA(DataFrame): list_columns = [str(s) for s in range(len(DataFrame.columns)) if s not in [None]] df_local = pd.DataFrame(columns=list_columns) for i in range(len(DataFrame.columns)): df_local.iloc[:,i] = GRA_ONE(DataFrame,m=i)[0] return df_local
data_wine_gra = GRA(wine) # data_wine_gra.to_csv(path+"GRA.csv") 存储结果到硬盘 data_wine_gra
Empty DataFrame Columns: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11] Index: []
结果可视化
# 灰色关联结果矩阵可视化 import seaborn as sns %matplotlib inline def ShowGRAHeatMap(DataFrame): import matplotlib.pyplot as plt import seaborn as sns %matplotlib inline colormap = plt.cm.RdBu plt.figure(figsize=(14,12)) plt.title("Pearson Correlation of Features", y=1.05, size=15) sns.heatmap(DataFrame.astype(float),linewidths=0.1,vmax=1.0, square=True, cmap=colormap, linecolor="white", annot=True) plt.show() ShowGRAHeatMap(data_wine_gra)
参考文章
百度百科 灰色关联分析法简书 Python实现灰色关联到此这篇关于Python实现灰色关联分析与结果可视化的文章就介绍到这了,更多相关Python灰色关联分析内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
X 关闭
X 关闭
- 15G资费不大降!三大运营商谁提供的5G网速最快?中国信通院给出答案
- 2联想拯救者Y70发布最新预告:售价2970元起 迄今最便宜的骁龙8+旗舰
- 3亚马逊开始大规模推广掌纹支付技术 顾客可使用“挥手付”结账
- 4现代和起亚上半年出口20万辆新能源汽车同比增长30.6%
- 5如何让居民5分钟使用到各种设施?沙特“线性城市”来了
- 6AMD实现连续8个季度的增长 季度营收首次突破60亿美元利润更是翻倍
- 7转转集团发布2022年二季度手机行情报告:二手市场“飘香”
- 8充电宝100Wh等于多少毫安?铁路旅客禁止、限制携带和托运物品目录
- 9好消息!京东与腾讯续签三年战略合作协议 加强技术创新与供应链服务
- 10名创优品拟通过香港IPO全球发售4100万股 全球发售所得款项有什么用处?