楼主: dmfang1984
3204 1

请教如何处理异常值,并用插值替换 [推广有奖]

  • 0关注
  • 0粉丝

小学生

14%

还不是VIP/贵宾

-

威望
0
论坛币
0 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
33 点
帖子
2
精华
0
在线时间
7 小时
注册时间
2013-8-12
最后登录
2013-11-27

楼主
dmfang1984 发表于 2013-8-12 10:13:54 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
我的数据有一些异常值,就是明显高于或者低于正常值。我想删去这些异常值,并用最近的上下2个正常值的均值插值填补。

二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:异常值 正常值 如何

异常值1.jpg (169.14 KB)

异常值

异常值

沙发
bakoll 发表于 2015-2-13 15:50:02
下面几种方法可以进行标记异常值
1)使用data 步

proc means data=train nopoint;

var variable;

output out=outlier p25=p25 p75=p75;  /*p25,p75分别是上四分位数,下四分位数*,outlier为离群值即异常值/

run;


data a;

set outlier;

IQR3=3*(p75-p25);/*四分位数差的三倍,即离群值的范围*/

call symputx('IQR3',IQR3);  /*将变量变成宏*/

call symputx('p75',p75);

call symputx('p25',p25);

run;


data outlier1;

set train;

if(&p25-&IQR3)<=&var<=(&p75+&IQR3) then outlier=0;

else outlier=1;    /*观测值在外界之内,将outlier标识为0,在之外,则标识为1*/

run;

2)当变量符合正态分布,可以使用Z记分法来标识

3)Z记分法的改进

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-2 10:44