




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第一个例子:importmatplotlib.pyplotaspltimportnumpyasnpfromsklearn.model_selectionimporttrain_test_splitfromsklearn.decompositionimportPCAfromsklearn.pipelineimportmake_pipelinefromsklearn.preprocessingimportFunctionTransformerdef_generate_vector(shift=0.5,noise=15):returnnp.arange(1000)+(np.random.rand(1
2、000)-shift)*noisedefgenerate_dataset():"""Thisdatasetistwolineswithaslope1,whereonehasayoffsetof100"""returnnp.vstack(np.vstack(_generate_vector(),_generate_vector()+100,).T,np.vstack(_generate_vector(),_generate_vector(),).T,),np.hstack(np.zeros(1000),np.ones(1000)defa
3、ll_but_first_column(X):returnX:,1:defdrop_first_component(X,y):"""CreateapipelinewithPCAandthecolumnselectoranduseittotransformthedataset."""pipeline=make_pipeline(PCA(),FunctionTransformer(all_but_first_column),)X_train,X_test,y_train,y_test=train_test_split(X,y)pipeli
4、ne.fit(X_train,y_train)returnpipeline.transform(X_test),y_testif_name_='_main_':X,y=generate_dataset()Iw=0plt.figure()plt.scatter(X:,0,X:,1,c=y,lw=lw)plt.figure()X_transformed,y_transformed=drop_first_component(*generate_dataset()plt.scatter(X_transformed:,0,np.zeros(len(X_transformed),c=y_t
5、ransformed,lw=lw,s=60)plt.show()第二个例子:from_future_importprint_functionprint(_doc_)# Codesource:ThomasUnterthiner# License:BSD3clauseimportmatplotlib.pyplotaspltimportnumpyasnpfromsklearn.preprocessingimportStandardScaler,RobustScaler# Createtrainingandtestdatanp.random.seed(42)n_datapoints=100Cov=0.
6、9,0.0,0.0,20.0mu1=100.0,-3.0mu2=101.0,-3.0X1=np.random.multivariate_normal(mean=mu1,cov=Cov,size=n_datapoints)X2=np.random.multivariate_normal(mean=mu2,cov=Cov,size=n_datapoints)Y_train=np.hstack(-1*n_datapoints,1*n_datapoints)X_train=np.vstack(X1,X2)X1=np.random.multivariate_normal(mean=mu1,cov=Cov
7、,size=n_datapoints)X2=np.random.multivariate_normal(mean=mu2,cov=Cov,size=n_datapoints)Y_test=np.hstack(-1*n_datapoints,1*n_datapoints)X_test=np.vstack(X1,X2)X_train0,0=-1000#afairlylargeoutlier# Scaledatastandard_scaler=StandardScaler()Xtr_s=standard_scaler.fit_transform(X_train)Xte_s=standard_scal
8、er.transform(X_test)robust_scaler=RobustScaler()Xtr_r=robust_scaler.fit_transform(X_train)Xte_r=robust_scaler.transform(X_test)# Plotdatafig,ax=plt.subplots(1,3,figsize=(12,4)ax0.scatter(X_train:,0,X_train:,1,color=np.where(Y_train>0,'r','b')ax1.scatter(Xtr_s:,0,Xtr_s:,1,color=np.
9、where(Y_train>0,'r','b')ax2.scatter(Xtr_r:,0,Xtr_r:,1,color=np.where(Y_train>0,'r','b')ax0.set_title("Unscaleddata")ax1.set_title("Afterstandardscaling(zoomedin)")ax2.set_title("Afterrobustscaling(zoomedin)")# forthescaleddata,wezoo
10、mintothedatacenter(outliercan'tbeseen!)forainax1:a.set_xlim(-3,3)a.set_ylim(-3,3)plt.tight_layout()plt.show()# Classifyusingk-NNfromsklearn.neighborsimportKNeighborsClassifierknn=KNeighborsClassifier()knn.fit(Xtr_s,Y_train)acc_s=knn.score(Xte_s,Y_test)print("Testsetaccuracyusingstandardscal
11、er:%.3f"%acc_s)knn.fit(Xtr_r,Y_train)acc_r=knn.score(Xte_r,Y_test)print("Testsetaccuracyusingrobustscaler:%.3f"%acc_r)Scikit-learnPreprocessing预处理本文主要是对照scikit-learn的preprocessing章节结合代码简单的回顾下预处理技术的几种方法,主要包括标准化、数据最大最小缩放处理、正则化、特征二值化和数据缺失值处理。内容比较简单,仅供参考!首先来回顾一下下面要用到的基本知识。一、知识回顾均值公式:x=nl2
12、_i=1nxi方差公式:s2=1n2_i=1n(xi-x2)0-范数,向量中非零元素的个数。1-范数:|X|二屋1n|xi|2-范数:|X|_2=(i=1nx2i)12p-范数的计算公式:|X|p=(|x1|p+|x2|p+|xn|p)1p数据标准化:当单个特征的样本取值相差甚大或明显不遵从高斯正态分布时,标准化表现的效果较差。实际操作中,经常忽略特征数据的分布形状,移除每个特征均值,划分离散特征的标准差,从而等级化,进而实现数据中心化。二、标准化(Standardization),或者去除均值和方差进行缩放公式为:(X-X_mean)/X_std计算时对每个属性/每列分别进行.将数据按其属性
13、(按列进行)减去其均值,然后除以其方差。最后得到的结果是,对每个属性/每列来说所有数据都聚集在0附近,方差值为1。首先说明下sklearn中preprocessing库里面的scale函数使用方法:sklearn.preprocessing.scale(X,axis=0,with_mean=True,with_std=True,copy=True)根据参数的不同,可以沿任意轴标准化数据集。参数解释:X:数组或者矩阵axis:int类型,初始值为0,axis用来计算均值means和标准方差standarddeviations.如果是0,则单独的标准化每个特征(列),如果是1,则标准化每个观测样本
14、(行)。with_mean:boolean类型,默认为True,表示将数据均值规范到0with_std:boolean类型,默认为True,表示将数据方差规范到1一个简单的例子假设现在我构造一个数据集X,然后想要将其标准化。下面使用不同的方法来标准化X:方法一:使用sklearn.preprocessing.scale()函数方法说明:X.mean(axis=0)用来计算数据X每个特征的均值;X.std(axis=0)用来计算数据X每个特征的方差;preprocessing.scale(X)直接标准化数据X。将代码整理到一个文件中:fromsklearnimportpreprocessingi
15、mportnumpyasnpX=np.array(1.,-1.,2.,2.,0.,0.,0.,1.,-1.)# calculatemeanX_mean=X.mean(axis=0)# calculatevarianceX_std=X.std(axis=0)# standardizeXX1=(X-X_mean)/X_std#usefunctionpreprocessing.scaletostandardizeXX_scale=preprocessing.scale(X)最后X_scale的值和X1的值是一样的,前面是单独的使用数学公式来计算,主要是为了形成一个对比,能够更好的理解scale()方
16、法。方法2:sklearn.preprocessing.StandardScaler类该方法也可以对数据X进行标准化处理,实例如下:fromsklearnimportpreprocessingimportnumpyasnpX=np.array(1.,-1.,2.,2.,0.,0.,0.,1.,-1.)scaler=preprocessing.StandardScaler()X_scaled=scaler.fit_transform(X)这两个方法得到最后的结果都是一样的。、将特征的取值缩小到一个范围(如0到1)除了上述介绍的方法之外,另一种常用的方法是将属性缩放到一个指定的最大值和最小值类来实
17、现。(通常是1-0)之间,这可以通过preprocessing.MinMaxScaler使用这种方法的目的包括:1、对于方差非常小的属性可以增强其稳定性;2、维持稀疏矩阵中为0的条目。卜面将数据缩至0-1之间,采用MinMaxScaler函数fromsklearnimportpreprocessingimportnumpyasnpX=np.array(1.,-1.,2.,2.,0.,0.,0.,1.,-1.min_max_scaler=preprocessing.MinMaxScaler()X_minMax=min_max_scaler.fit_transform(X)最后输出:array(0
18、.51.0.测试用例:,0.0.51.>>>X_test=np.array(,0.33333333,0.-3.,-1.,4.>>>X_test_minmax=min_max_scaler.transform(X_test)>>>X_test_minmaxarray(-1.5,0.,1.66666667注意:这些变换都是对列进行处理。feature_range=(min,max),当然,在构造类对象的时候也可以直接指定最大最小值的范围:此时应用的公式变为:X_std=(X-X.min(axis=0)/(X.max(axis=0)-X.min(
19、axis=0)X_minmax=X_std/(X.max(axis=0)-X.min(axis=0)+X.min(axis=0)四、正则化(Normalization)正则化的过程是将每个样本缩放到单位范数(每个样本的范数为1),如果要使用如二次型(点积)或者其它核方法计算两个样本之间的相似性这个方法会很有用。该方法是文本分类和聚类分析中经常使用的向量空间模型(VectorSpaceModel)的基础.Normalization主要思想是对每个样本计算其p-范数,然后对该样本中每个元素除以该范数,这样处理的结果是使得每个处理后样本的p-范数(l1-norm,l2-norm)等于1。方法1:使用
20、sklearn.preprocessing.normalize()函数>>>X=1.,-1.,2.,.2.,0.,0.,.0.,1.,-1.>>>X_normalized=preprocessing.normalize(X,norm='12')>>>X_normalizedarray(0.40.,-0.40.,0.81.,L.,6.,6.,0.,0.70.,-0.70.)方法2:sklearn.preprocessing.StandardScaler类>>>normalizer=preprocessing.
21、Normalizer().fit(X)#fitdoesnothing>>>normalizerNormalizer(copy=True,norm='l2')然后使用正则化实例来转换样本向量:>>>normalizer.transform(X)array(0.40.,-0.40.,0.81.,1.,0.,0.,0.,0.70.,-0.70.)>>>normalizer.transform(-1.,1.,0.)array(-0.70.,0.70.,0.)两种方法都可以,效果是一样的。五、二值化(Binarization)特征的二
22、值化主要是为了将数据特征转变成boolean变量。在sklearn中,sklearn.preprocessing.Binarizer函数可以实现这一功能。实例如下:>>>X=1.,-1.,2.,.2.,0.,0.,.0.,1.,-1.>>>binarizer=preprocessing.Binarizer().fit(X)#fitdoesnothing>>>binarizerBinarizer(copy=True,threshold=0.0)>>>binarizer.transform(X)array(1.,0.,1.1,
23、1.,0.,0.,0.,1.,0.)Binarizer函数也可以设定一个阈值,结果数据值大于阈值的为1,小于阈值的为0,实例代码如下:>>>binarizer=preprocessing.Binarizer(threshold=1.1)>>>binarizer.transform(X)array(0.,0.,1.,1.,0.,0.,0.,0.,0.六、缺失值处理由于不同的原因,许多现实中的数据集都包含有缺失值,要么是空白的,要么使用NaNs或者其它的符号替代。这些数据无法直接使用scikit-learn分类器直接训练,所以需要进行处理。幸运地是,sklearn中的Imputer类提供了一些基本的方法来处理缺失值,如使用均值、中位值或者缺失值所在列中频繁出现的值来替换。下面是使用均值来处理的实例:> >>importnumpyasnp> >>fromsklearn.pre
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025浙江台州温岭市交通旅游集团有限公司下属温岭市交通设计院有限公司面向社会招聘1人考试模拟试题及答案解析
- 2025台州临海市花园水力发电有限公司公开招聘合同制工作人员2人考试参考题库及答案解析
- 成都市锦江区塔子山幼儿园公开招聘员额教师(1人)考试参考试题及答案解析
- 2025山东东营市春晖小学招聘劳务派遣教师3人备考模拟试题及答案解析
- 2025四川省医学科技教育中心行政事业业务辅助岗招聘1人考试模拟试题及答案解析
- 2025湖南中南大学湘雅三医院编外科研助理招聘3人考试模拟试题及答案解析
- 2025河北省煤田地质局事业单位选聘88人考试模拟试题及答案解析
- 2025中国中检云南公司滇东片区文山公司招聘1人备考模拟试题及答案解析
- 2025年大庆肇源县社区卫生服务中心公开招聘医学毕业生7人备考考试试题及答案解析
- 2025四川成都市武侯区簇锦社区卫生服务中心社会招聘编外专业技术人员4人备考模拟试题及答案解析
- ZJ50J钻机配置清单(带刹)
- 建筑系馆-深圳大学建筑系馆
- 2022年江门市新会区自然资源局事业单位招聘考试笔试试题及答案解析
- 珊瑚礁生态系统
- GB 28241-2012液压机安全技术要求
- 东亚文化之都
- 医疗保险学导论课件
- 八大员培训计划
- 晨检午检体温记录表
- 四年级上册语文习题课件-4 繁 星|部编版(共14张PPT)
- 数独题目高级50题(后附答案)
评论
0/150
提交评论