Python实现灰色关联分析与结果可视化的详细代码


Posted in Python onMarch 25, 2022

之前在比赛的时候需要用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()

Python实现灰色关联分析与结果可视化的详细代码

实现灰色关联分析

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: []

Python实现灰色关联分析与结果可视化的详细代码

结果可视化

# 灰色关联结果矩阵可视化
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灰色关联分析内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python实现的阳历转阴历(农历)算法
Apr 25 Python
python采用requests库模拟登录和抓取数据的简单示例
Jul 05 Python
python实现在sqlite动态创建表的方法
May 08 Python
在pandas中一次性删除dataframe的多个列方法
Apr 10 Python
Python + selenium + requests实现12306全自动抢票及验证码破解加自动点击功能
Nov 23 Python
python制作mysql数据迁移脚本
Jan 01 Python
python xpath获取页面注释的方法
Jan 14 Python
PyCharm 配置远程python解释器和在本地修改服务器代码
Jul 23 Python
pytorch-神经网络拟合曲线实例
Jan 15 Python
解决python Jupyter不能导入外部包问题
Apr 15 Python
解决python3.6用cx_Oracle库连接Oracle的问题
Dec 07 Python
Python控制台输出俄罗斯方块的方法实例
Apr 17 Python
聊聊基于pytorch实现Resnet对本地数据集的训练问题
pycharm安装深度学习pytorch的d2l包失败问题解决
利用For循环遍历Python字典的三种方法实例
Mar 25 #Python
Python装饰器详细介绍
Mar 25 #Python
python中数组和列表的简单实例
Mar 25 #Python
Python if else条件语句形式详解
python中的getter与setter你了解吗
Mar 24 #Python
You might like
Windows下XDebug 手工配置与使用说明
2010/07/11 PHP
yii实现使用CUploadedFile上传文件的方法
2015/12/28 PHP
php安装扩展mysqli的实现步骤及报错解决办法
2017/09/23 PHP
PHP 图片合成、仿微信群头像的方法示例
2019/10/25 PHP
php设计模式之抽象工厂模式分析【星际争霸游戏案例】
2020/01/23 PHP
Javascript-Mozilla和IE中的一个函数直接量的问题
2007/01/09 Javascript
番茄的表单验证类代码修改版
2008/07/18 Javascript
JS检测输入字符是否包含非法字符的示例代码
2014/02/11 Javascript
用IE重起计算机或者关机的示例代码
2014/03/10 Javascript
JQuery EasyUI 日期控件如何控制日期选择区间
2014/05/05 Javascript
了不起的node.js读书笔记之例程分析
2014/12/22 Javascript
使用canvas实现仿新浪微博头像截取上传功能
2015/09/02 Javascript
JavaScript的React Web库的理念剖析及基础上手指南
2016/05/10 Javascript
微信小程序实战之自定义抽屉菜单(7)
2017/04/18 Javascript
Bootstrap Table使用整理(四)之工具栏
2017/06/09 Javascript
bmob js-sdk 在vue中的使用教程
2018/01/21 Javascript
JS实现简单日历特效
2020/01/03 Javascript
微信小程序实现菜单左右联动
2020/05/19 Javascript
vue axios请求成功却进入catch的原因分析
2020/09/08 Javascript
前端性能优化建议
2020/09/17 Javascript
[15:23]教你分分钟做大人:虚空假面
2014/10/30 DOTA
python深度优先搜索和广度优先搜索
2018/02/07 Python
详解python配置虚拟环境
2019/04/08 Python
Python CVXOPT模块安装及使用解析
2019/08/01 Python
浅谈python的elementtree模块处理中文注意事项
2020/03/06 Python
浅谈pytorch中torch.max和F.softmax函数的维度解释
2020/06/28 Python
PyCharm+Miniconda3安装配置教程详解
2021/02/16 Python
html5 sessionStorage会话存储_动力节点Java学院整理
2017/07/06 HTML / CSS
HTML5实现可缩放时钟代码
2017/08/28 HTML / CSS
Perry Ellis官网:美国男士品味服装
2016/12/09 全球购物
Europcar葡萄牙:葡萄牙汽车和货车租赁
2017/10/13 全球购物
澳大利亚领先的在线美容商店:Facial Co
2017/10/22 全球购物
如何通过jdbc调用存储过程
2012/04/19 面试题
青年文明号创建承诺
2014/03/31 职场文书
民政局2016年“六一”儿童节慰问活动总结
2016/04/06 职场文书
python flask框架快速入门
2021/05/14 Python