Minepy—使用python计算最大互信息系数(MIC)

2024-02-23 12:48

本文主要是介绍Minepy—使用python计算最大互信息系数(MIC),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MIC 即:Maximal Information Coefficient 最大互信息系数。

https://blog.csdn.net/qtlyx/article/details/50780400

MIC可以用来衡量线性或非线性的相互关系。

 


算法对比

 

https://zhuanlan.zhihu.com/p/53092905


MIC算法可以通过python的minpy包来实现。

python 安装 minepy

安装命令:

pip install minepy

安装报错,提示没有C++编译器

https://www.cnblogs.com/xiaoxineryi/p/12405063.html

从Unofficial Windows Binaries for Python Extension Packages(这个网站包含了很多Python扩展包的非官方Windows二进制文件)下载对应的minepy.whl

 

安装命令

pip install whl路径

安装报错,

ERROR: minepy-1.2.4-cp38-cp38-win_amd64.whl is not a supported wheel on this platform


需要选择和自己Python版本对应的版本

查询python支持的whl格式

from pip._internal import pep425tagsprint(pep425tags.get_supported())
#打印支持的whl版本>>>[('cp37', 'cp37m', 'win_amd64'), ('cp37', 'none', 'win_amd64'), ('py3', 'none', 'win_amd64'), ('cp37', 'none', 'any'), ('cp3', 'none', 'any'), ('py37', 'none', 'any'), ('py3', 'none', 'any'), ('py36', 'none', 'any'), ('py35', 'none', 'any'), ('py34', 'none', 'any'), ('py33', 'none', 'any'), ('py32', 'none', 'any'), ('py31', 'none', 'any'), ('py30', 'none', 'any')]

下载适合的whl版本,安装成功


使用minpy

https://s0minepy0readthedocs0io.icopy.site/en/1.2.2/python.html

import numpy as npimport pandas as pdfrom minepy import MINEinpath = r'D:\Python\input_data\abc.xlsx'outpath = r'D:\Python\output_data\abc-MIC系数.xlsx'data_df = pd.read_excel(inpath)depend_names = ['变量A','变量B','变量C']output_mic = pd.DataFrame(columns=['变量1','变量2','MIC系数'])for var1 in depend_names:for var2 in depend_names:x = data_df[var1]y = data_df[var2]mine = MINE(alpha = 0.6, c = 15)mine.compute_score(x, y)print(mine.mic())out_dict = {'变量1': var1,'变量2': var2,'MIC系数': mine.mic(),}output_mic = output_mic.append(out_dict, ignore_index=True)output_mic.to_excel(outpath)


 

 

 

这篇关于Minepy—使用python计算最大互信息系数(MIC)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/738686

相关文章

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Python的time模块一些常用功能(各种与时间相关的函数)

《Python的time模块一些常用功能(各种与时间相关的函数)》Python的time模块提供了各种与时间相关的函数,包括获取当前时间、处理时间间隔、执行时间测量等,:本文主要介绍Python的... 目录1. 获取当前时间2. 时间格式化3. 延时执行4. 时间戳运算5. 计算代码执行时间6. 转换为指

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Python正则表达式语法及re模块中的常用函数详解

《Python正则表达式语法及re模块中的常用函数详解》这篇文章主要给大家介绍了关于Python正则表达式语法及re模块中常用函数的相关资料,正则表达式是一种强大的字符串处理工具,可以用于匹配、切分、... 目录概念、作用和步骤语法re模块中的常用函数总结 概念、作用和步骤概念: 本身也是一个字符串,其中