53-R语言中缺失值处理方法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了53-R语言中缺失值处理方法相关的知识,希望对你有一定的参考价值。

参考技术A

缺失值被认为是预测建模的首要障碍,尽管一些机器学习算法声称能够从根本上解决这个问题,但是谁又能知道究竟在“黑盒子”里能解决得多好。
缺失值填补方法的选择,在很大程度上影响了模型的预测能力。一般处理方法是直接删除相关行,但这样并不好,因为会造成信息丢失。

Hmice是一个多用途的软件包,可用于数据分析、高级图形、缺失值处理、高级表格制作、模型拟合和诊断(线性回归、 Logit模型和cox回归)等。 该软件包包含的功能范围广泛,它提供了两个强大的函数,用于处理缺失值。分别为 impute ()和 aregImpute ()。
impute()函数使用用户定义的统计方法(中间值,最大值,平均值等)来估算缺失值。 默认是使用中位数。另一方面,aregImpute()允许使用加性回归、自举和预测平均匹配进行填补(additive regression, bootstrapping, and predictive mean matching)。
bootstrapping对替代原始数据的样本拟合了一个柔性可加模型(非参数回归方法) ,并利用非缺失值(自变量)对缺失值(因变量)进行了预测。然后,使用预测均值匹配(缺省值)来估算缺失值。

使用平均值填充:

使用随机值填充:

同样,还可以使用min,max,median来估算缺失值。

aregImpute ()自动识别变量类型并相应地处理它们:

输出显示预测缺失值的 R 2 值, 数值越高,预测的数值越好。还可以使用以下命令查看估算值:

画个好看一点的图:

估算缺失值:

pmm:预测均值匹配(PMM)-用于数值变量
logreg: (Logit模型)-二元变量
polyreg(Bayesian polytomous regression):因子变量(>=2个水平)
polr:Proportional odds model(ordered, >= 2 levels)

查看估算的缺失值

由于生成有5个输入数据集,您可以使用 complete ()函数选择任何数据集:

还可以使用5个数据集构建模型,最后将结果合并:

对比一下:

使用生成的6个数据集合并后的回归系数与原始数据的回归系数还是非常接近的。

R语言︱异常值检验离群点分析异常值处理

一、异常值检验

 

异常值大概包括缺失值、离群值、重复值,数据不一致。

 

1、基本函数

 

summary可以显示每个变量的缺失值数量.

 

2、缺失值检验

关于缺失值的检测应该包括:缺失值数量、缺失值比例、缺失值与完整值数据筛选。

 

[plain] view plain copy
 
  1. #缺失值解决方案  
  2. sum(complete.cases(saledata))         #is.na(saledata)  
  3. sum(!complete.cases(saledata))  
  4. mean(!complete.cases(saledata))       #1/201数字,缺失值比例  
  5. saledata[!complete.cases(saledata),]  #筛选出缺失值的数值  



 

3、箱型图检验离群值

 

箱型图的检测包括:四分位数检测(箱型图自带)+1δ标准差上下+异常值数据点。

箱型图有一个非常好的地方是,boxplot之后,结果中会自带异常值,就是下面代码中的sp$out,这个是做箱型图,按照上下边界之外为异常值进行判定的。

上下边界,分别是Q3+(Q3-Q1)、Q1-(Q3-Q1)。

 

 

[plain] view plain copy
 
  1. sp=boxplot(saledata$"销量",boxwex=0.7)  
  2. title("销量异常值检测箱线图")  
  3. xi=1.1  
  4. sd.s=sd(saledata[complete.cases(saledata),]$"销量")  
  5. mn.s=mean(saledata[complete.cases(saledata),]$"销量")  
  6. points(xi,mn.s,col="red",pch=18)  
  7. arrows(xi, mn.s - sd.s, xi, mn.s + sd.s, code = 3, col = "pink", angle = 75, length = .1)  
  8. text(rep(c(1.05,1.05,0.95,0.95),length=length(sp$out)),labels=sp$out[order(sp$out)],  
  9.      sp$out[order(sp$out)]+rep(c(150,-150,150,-150),length=length(sp$out)),col="red")  

 

代码中text函数的格式为text(x,label,y,col);points加入均值点;arrows加入均值上下1δ标准差范围箭头。

 

技术分享图片

箱型图还有等宽与等深分箱法,可见另外一个博客:R语言︱噪声数据处理、数据分组——分箱法(离散化、等级化)

 

4、数据去重

 

数据去重数据分组合并存在一定区别,去重是纯粹的所有变量都是重复的,而数据分组合并可能是因为一些主键的重复。

数据去重包括重复检测(table、unique函数)以及重复数据处理(unique/duplicated)。

常见的有unique、数据框中duplicated函数,duplicated返回的是逻辑值。

 

 

二、异常值处理

 

常见的异常值处理办法是删除法、替代法(连续变量均值替代、离散变量用众数以及中位数替代)、插补法(回归插补、多重插补)

除了直接删除,可以先把异常值变成缺失值、然后进行后续缺失值补齐。

实践中,异常值处理,一般划分为NA缺失值或者返回公司进行数据修整(数据返修为主要方法)

 

1、异常值识别

利用图形——箱型图进行异常值检测。

 

[plain] view plain copy
 
  1. #异常值识别  
  2. par(mfrow=c(1,2))#将绘图窗口划为1行两列,同时显示两图  
  3. dotchart(inputfile$sales)#绘制单变量散点图,多兰图  
  4. pc=boxplot(inputfile$sales,horizontal=T)#绘制水平箱形图  

代码来自《R语言数据分析与挖掘实战》第四节。

 

2、盖帽法

整行替换数据框里99%以上和1%以下的点,将99%以上的点值=99%的点值;小于1%的点值=1%的点值。

 

技术分享图片

(本图来自CDA DSC,L2-R语言课程,常老师所述)

 

[html] view plain copy
 
  1. #异常数据处理  
  2. q1<-quantile(result$tot_derog, 0.001)        #取得时1%时的变量值  
  3. q99<-quantile(result$tot_derog, 0.999)       #replacement has 1 row, data has 0 说明一个没换  
  4. result[result$tot_derog<q1,]$tot_derog<-q1  
  5. result[result$tot_derog>q99,]$tot_derog<-q99  
  6. summary(result$tot_derog)                    #盖帽法之后,查看数据情况  
  7. fix(inputfile)#表格形式呈现数据  
  8.   
  9. which(inputfile$sales==6607.4)#可以找到极值点序号是啥  

 

 

把缺失值数据集、非缺失值数据集分开。

 

[plain] view plain copy
 
  1. #缺失值的处理  
  2. inputfile$date=as.numeric(inputfile$date)#将日期转换成数值型变量  
  3. sub=which(is.na(inputfile$sales))#识别缺失值所在行数  
  4. inputfile1=inputfile[-sub,]#将数据集分成完整数据和缺失数据两部分  
  5. inputfile2=inputfile[sub,]  

 

3、噪声数据处理——分箱法

将连续变量等级化之后,不同的分位数的数据就会变成不同的等级数据,连续变量离散化了,消除了极值的影响。

 

 

4、异常值处理——均值替换

数据集分为缺失值、非缺失值两块内容。缺失值处理如果是连续变量,可以选择均值;离散变量,可以选择众数或者中位数。

计算非缺失值数据的均值,

然后赋值给缺失值数据。

 

[plain] view plain copy
 
  1. #均值替换法处理缺失,结果转存  
  2. #思路:拆成两份,把缺失值一份用均值赋值,然后重新合起来  
  3. avg_sales=mean(inputfile1$sales)#求变量未缺失部分的均值  
  4. inputfile2$sales=rep(avg_sales,n)#用均值替换缺失  
  5. result2=rbind(inputfile1,inputfile2)#并入完成插补的数据  



 

5、异常值处理——回归插补法

 

 

[plain] view plain copy
 
  1. #回归插补法处理缺失,结果转存  
  2. model=lm(sales~date,data=inputfile1)#回归模型拟合  
  3. inputfile2$sales=predict(model,inputfile2)#模型预测  
  4. result3=rbind(inputfile1,inputfile2)  

 

6、异常值处理——多重插补——mice包

 

注意:多重插补的处理有两个要点:先删除Y变量的缺失值然后插补
   1、被解释变量有缺失值的观测不能填补,只能删除,不能自己乱补;
   2、只对放入模型的解释变量进行插补。

 

比较详细的来介绍一下这个多重插补法。笔者整理了大致的步骤简介如下:

缺失数据集——MCMC估计插补成几个数据集——每个数据集进行插补建模(glm、lm模型)——将这些模型整合到一起(pool)——评价插补模型优劣(模型系数的t统计量)——输出完整数据集(compute)

 

步骤详细介绍:

 

函数mice()首先从一个包含缺失数据的数据框开始,然后返回一个包含多个(默认为5个)完整数据集的对象。

每个完整数据集都是通过对原始数据框中的缺失数据进行插补而生成的。 由于插补有随机的成分,因此每个完整数据集都略有不同。

其中,mice中使用决策树cart有以下几个要注意的地方:该方法只对数值变量进行插补,分类变量的缺失值保留,cart插补法一般不超过5k数据集。

 

然后, with()函数可依次对每个完整数据集应用统计模型(如线性模型或广义线性模型) ,

最后, pool()函数将这些单独的分析结果整合为一组结果。最终模型的标准误和p值都将准确地反映出由于缺失值和多重插补而产生的不确定性。

 

 

[plain] view plain copy
 
  1. #多重插补法处理缺失,结果转存  
  2. library(lattice) #调入函数包  
  3. library(MASS)  
  4. library(nnet)  
  5. library(mice) #前三个包是mice的基础  
  6. imp=mice(inputfile,m=4) #4重插补,即生成4个无缺失数据集  
  7. fit=with(imp,lm(sales~date,data=inputfile))#选择插补模型  
  8. pooled=pool(fit)  
  9. summary(pooled)  
  10. result4=complete(imp,action=3)#选择第三个插补数据集作为结果  

 

结果解读:

 

(1)imp对象中,包含了:每个变量缺失值个数信息、每个变量插补方式(PMM,预测均值法常见)、插补的变量有哪些、预测变量矩阵(在矩阵中,行代表插补变量,列代表为插补提供信息的变量, 1和0分别表示使用和未使用);

同时  利用这个代码imp$imp$sales  可以找到,每个插补数据集缺失值位置的数据补齐具体数值是啥。

 

 

[plain] view plain copy
 
  1. > imp$imp$sales  
  2.         1      2      3      4  
  3. 9  3614.7 3393.1 4060.3 3393.1  
  4. 15 2332.1 3614.7 3295.5 3614.7  

 

(2)with对象。插补模型可以多样化,比如lm,glm都是可以直接应用进去,详情可见《R语言实战》第十五章;

(3)pool对象。summary之后,会出现lm模型系数,可以如果出现系数不显著,那么则需要考虑换插补模型;

(4)complete对象。m个完整插补数据集,同时可以利用此函数输出。

 

其他:

mice包提供了一个很好的函数md.pattern(),用它可以对缺失数据的模式有个更好的理解。还有一些可视化的界面,通过VIM、箱型图、lattice来展示缺失值情况。可见博客:在R中填充缺失数据—mice包

 

三、离群点检测

 

离群点检测与第二节异常值主要的区别在于,异常值针对单一变量,而离群值指的是很多变量综合考虑之后的异常值。下面介绍一种基于聚类+欧氏距离的离群点检测方法。

基于聚类的离群点检测的步骤如下:数据标准化——聚类——求每一类每一指标的均值点——每一类每一指标生成一个矩阵——计算欧式距离——画图判断

    1. Data=read.csv(".data.csv",header=T)[,2:4]  
    2. Data=scale(Data)  
    3. set.seed(12)  
    4. km=kmeans(Data,center=3)  
    5. print(km)  
    6. km$centers  #每一类的均值点  
    7.   
    8. #各样本欧氏距离,每一行  
    9. x1=matrix(km$centers[1,], nrow = 940, ncol =3 , byrow = T)  
    10. juli1=sqrt(rowSums((Data-x1)^2))  
    11. x2=matrix(km$centers[2,], nrow = 940, ncol =3 , byrow = T)  
    12. juli2=sqrt(rowSums((Data-x2)^2))  
    13. x3=matrix(km$centers[3,], nrow = 940, ncol =3 , byrow = T)  
    14. juli3=sqrt(rowSums((Data-x3)^2))  
    15. dist=data.frame(juli1,juli2,juli3)  
    16.   
    17. ##欧氏距离最小值  
    18. y=apply(dist, 1, min)  
    19. plot(1:940,y,xlim=c(0,940),xlab="样本点",ylab="欧氏距离")  
    20. points(which(y>2.5),y[which(y>2.5)],pch=19,col="red") 
    21. 原文地址:https://blog.csdn.net/sinat_26917383/article/details/51210793












以上是关于53-R语言中缺失值处理方法的主要内容,如果未能解决你的问题,请参考以下文章

R语言边学边记8-缺失值处理与转换函数

R语言缺失值的处理——回归预测法

R语言-缺失值判断以及处理

数据分析中缺失值的处理

2020-08-05--Pandas-03--缺失值处理

缺失值处理