当前位置:网站首页>机器学习——特征选择
机器学习——特征选择
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最好。
边栏推荐
- 手慢无!阿里亿级流量高并发系统设计核心原理全彩笔记现实开源
- Another blast!Ali's popular MySQL advanced collection is open source, reaching P7
- 常见的云计算安全问题以及如何解决
- Mysql索引结构
- IO/multiplexing (select/poll/epoll)
- 最基础01/完全背包
- int a=8,a=a++,a? int b=8,b=b+1,b?
- Execution order of select, from, join, on where groupby, etc. in MySQL
- [SCTF2019]Flag Shop
- 和数集团:让智慧城市更智慧,让现实生活更美好
猜你喜欢
随机推荐
北上广线下活动丨年底最不可错过的技术聚会都齐了
datax enables hana support and dolphinscheduler enables datax tasks
[SCTF2019]Flag Shop
EasyNVS cloud management platform function reconstruction: support for adding users, modifying information, etc.
第42讲:Scala中泛型类、泛型函数、泛型在Spark中的广泛应用
如何将EasyCVR平台RTSP接入的设备数据迁移到EasyNVR中?
无人艇轨迹跟踪的预设性能抗扰控制研究
I built another wheel: GrpcGateway
智能指针实现猜想
基于柔性人机接口的人机协调运动控制方法
unity初学6——简易的UI制作(血条制作)和音频加入以及NPC的对话气泡(2d)
【Kaggle:UW-Madison GI Tract Image Segmentation】肠胃分割比赛:赛后复盘+数据再理解
Anaconda\Scripts\pip-script.py is not present ? 解决方案
看了这些6G原型样机,我想一觉睡到2030年
Rust 从入门到精通02-安装
京东二面痛遭中间件虐杀,30天学透这套中间件小册,挺进阿里
DOM常用方法以及项目
什么是私有云?您应该知道的 6 个优势
int a=8,a=a++,a? int b=8,b=b+1,b?
爱可可AI前沿推介(7.30)


![[SCTF2019]Flag Shop](/img/26/20e21ec873f41f2633703216453a44.png)





