当前位置:网站首页>机器学习——特征选择
机器学习——特征选择
2022-07-30 12:29:00 【小羊星球】
机器学习——特征选择
一、读取数据
0、导入一些必需的包
import pandas as pd
import numpy as np
1、加载本地数据
data = pd.read_excel('./L_roudoukou_data_LSTM_CNN.xlsx', index_col=0, nrows=5)
2、检查数据是否包含缺失值
print(np.isnan(df).any()) # L12输出True,说明数据里有空值,用0填充。
3、分配标签和特征
names = ['label', 'L1', 'L2', 'L3', 'L4', 'L5', 'L6', 'L7', 'L8', 'L9', 'L10', 'L11', 'L12']
dataframe = pd.read_csv("./L_roudoukou_data_LSTM_CNN.csv", names=names) # 读取数据集
dataframe.head()
array = dataframe.values
**注:不要选到标签栏,否则XY就会包含字符串类型,后面无法计算。**
X = array[1:, 1:13] # 选取前1~13列为特征变量,就是要筛选的特征。
Y = array[1:, 0] # 选取label为目标变量,就是标签。
# print(X[0:5, :]) # 打印前5行特征
# print(Y[0:5]) # 打印前5行标签
二、特征选择
1. 过滤方法
1.1. 信息增益(mutual_info_classif互信息)
from sklearn.feature_selection import mutual_info_classif
import matplotlib.pyplot as plt
importances = mutual_info_classif(X, Y)
feat_importances = pd.Series(importances, df.columns[0:len(df.columns)-1])
feat_importances.plot(kind='barh', color='teal')
plt.savefig('./mutual_info_classif.png')
plt.show()
plt.close()
2. 包装方法
2.1 递归特征消除法,
# from sklearn.feature_selection import RFE # 导入RFE库
# from sklearn.linear_model import LogisticRegression # 导入逻辑回归库
# model = LogisticRegression() # 设置算法为逻辑回归
# rfe = RFE(model, 5) # 选择5个最佳特征变量,并进行RFE
# fit = rfe.fit(X, Y) # 进行RFE递归
# print(fit.n_features_) # 打印最优特征变量数
# print(fit.support_) # 打印选择的最优特征变量
# # print(fit.ranking_) # 特征消除排序
这里输出[False False False False False True False True True False True True],说明L6,L8,L9,L11,L12,比较好。
3. 嵌入方法
3.1 基于树模型的特征选择,
from sklearn.ensemble import ExtraTreesClassifier # 导入ExtraTrees
model = ExtraTreesClassifier() # 设置ExtraTrees
model.fit(X, Y)
print(model.feature_importances_) # 得到特征变量的重要性值
输出[0.08752002 0.08456882 0.09494643 0.05386247 0.05954704 0.14586148
0.05104781 0.05556901 0.11572619 0.06029772 0.06241888 0.12863414],从高到低:L6\L12\L9\L3\L1\L2\L11\L10\L5\L8\L4\L7。
三、总结
三种方法比较后,L6最好。
边栏推荐
- 【MySQL系列】-B+树索引和HASH索引有什么区别
- I built another wheel: GrpcGateway
- 从“校园贷”到“直播带货”,追风少年罗敏一直行走在风口浪尖
- Lake storehouse which electricity (2) of the project: project using technology and version and the environment
- WinForm枚举容器中的控件,实现控件统一事件处理机制
- 物理服务器与虚拟机:主要区别和相似之处
- A tutorial on how to build a php environment under win
- PyQt5快速开发与实战 8.2 绘图 && 8.3 QSS的UI美化
- 湖仓一体电商项目(二):项目使用技术及版本和基础环境准备
- Apifox generates interface documentation tutorial and operation steps
猜你喜欢
随机推荐
ES6 Set与Map是什么,如何使用
Scala基础:数组(Array)、映射(Map)、元组(Tuple)、集合(List)
智能指针实现猜想
DOM常用方法以及项目
JS事件的相关特性以及原理
unity初学6——简易的UI制作(血条制作)和音频加入以及NPC的对话气泡(2d)
关于香港高防IP需要关注的几个问题
奇异值分解(SVD)原理与在降维中的应用(附带例题讲解)(纯理论)
维护数千规模MySQL实例,数据库灾备体系构建指南
腰部外骨骼机器人线性自抗扰控制器参数优化
【Kaggle比赛常用trick】K折交叉验证、TTA
【河北工业大学】考研初试复试资料分享
PyQt5快速开发与实战 8.4 设置窗口背景 && 8.5 不规则窗口的显示
MySQL中的select,from, join, on where groupby等执行顺序
Based on MySQL database, Redis cache, MQ message middleware, ES high availability scheme of search engine parsing
dbaplus丛书丨《MySQL DBA工作笔记》限量签名版来了!
RTSP/Onvif协议视频平台EasyNVR服务一键升级功能的使用教程
Js - 内置对象
我又造了个轮子:GrpcGateway
[SCTF2019]Flag Shop