http://blog.csdn.net/ae5555/article/details/49534263python
设置一个方差阈值,没有达到这个方差阈值的特征都会被丢弃。
VarianceThreshold,算法输入只要求特征(X),不须要输入结果(Y)。算法
from sklearn.feature_selection import VarianceThreshold
X=[[feature1,feature2,…],…]
sel=VarianceThreshold(threshold=xx)
print(sel.fit_transform(X))数组
单变量特征提取的原理是分别计算每一个特征的某个统计指标,根据该指标来选取特征。
SelectKBest、SelectPercentile,前者选择排名前k个的特征,后者选择排名在前k%的特征。选择的统计指标须要指定,对于regression问题,使用f_regression指标;对于classification问题,可使用chi2或者f_classif指标。markdown
from sklearn.feature_selection import SelectKBest,chi2
X_new=SelectKBest(chi2,k=2).fit_transform(test_X,test_Y)dom
不单独地检验某个特征的价值,而是检验特征集的价值。对于一个数量为n的特征集合,子集的个数为2的n次方减一。经过指定一个学习算法,经过算法计算全部子集的error,选择error最小的子集做为选取的特征。机器学习
from sklearn.svm import SVC
from sklearn.feature_selection import RFE
//X为样本集合,每一个样本为一个数组,数组元素为各个特征值,Y样本的评分
svc=SVC(kernel=”linear”,C=1)
rfe=RFE(estimator=svc,n_features_to_select=5,step=1)
X_new=rfe.fit_transform(X,Y)
在RFE训练时,增长交叉验证。ide
在线性回归模型中,每个特征表明一个w,若获得的w系数等于或接近0,则说明这些特征不重要。
LinearSVC
参数C控制特征系数稀疏度,C的值越小,选择的特征数越少。工具
from sklearn.svm import LinearSVC
X_new=LinearSVC(C=0.01,penalty=”l1”,dual=False).fit_transform(x,y)post
经过决策树能够计算特征的重要性,抛弃不过重要的特性。性能
from sklearn.ensemble import ExtraTreesClassifier
clf=ExtraTreesClassifier()
X_new=clf.fit(x,y).transform(x)
//各个特征重要性
print(clf.feature_importances)
sklearn.datasets.make_classification用来随机产生一个多分类问题。
n_features=n_informative+n_redundant+n_repeated。
n_clusters_per_class 每一个分类的集群数
import sklearn.datasets
(x,y)=make_classification(n_samples=,
n_features=,
n_informative=,
n_redundant=,
n_repeated=,
n_classes=,
random_state=,
shuffle=False
)
https://study.163.com/provider/400000000398149/index.htm?share=2&shareId=400000000398149( 欢迎关注博主主页,学习python视频资源,还有大量免费python经典文章)