glm - обнаружение и удаление выбросов в R - PullRequest
0 голосов
/ 27 апреля 2018

Я построил бинарную логистическую модель. Переменная ответа является двоичной. Есть 4 регрессора - 2 двоичных и 2 целых числа. Я хочу найти выбросы и удалить их. Для этого я создал несколько сюжетов:

  par(mfrow = c(2,2))
  plot(hat.ep,rstudent.ep,col="#E69F00", main="hat-values versus studentized residuals",
       xlab="Hat value", ylab="Studentized residual")
  dffits.ep <- dffits(model_logit)
  plot(id,dffits.ep,type="l", col="#E69F00", main="Index Plot",
       xlab="Identification", ylab="Diffits")
  cov.ep <- covratio(model_logit)
  plot(id,cov.ep,type="l",col="#E69F00",  main="Covariance Ratio",
       xlab="Identification", ylab="Covariance Ratio")
  cook.ep <- cooks.distance(model_logit)
  plot(id,cook.ep,type="l",col="#E69F00", main="Cook's Distance",
       xlab="Identification", ylab="Cook's Distance")

enter image description here

По графикам есть выброс. Как я могу определить, какое наблюдение является выбросом?

Я пытался:

>   outlierTest(model_logit)
No Studentized residuals with Bonferonni p < 0.05
Largest |rstudent|:
     rstudent unadjusted p-value Bonferonni p
1061 1.931043           0.053478           NA

Существуют ли другие функции для обнаружения выбросов?

1 Ответ

0 голосов
/ 03 июля 2018

Ну, этот ответ приходит довольно поздно. Я не уверен, что вы нашли ответ или нет. Продолжая далее, в отсутствие минимального воспроизводимого примера я попытаюсь ответить на вопрос, используя несколько фиктивных данных и две пользовательские функции. Для данной непрерывной переменной выбросами являются те наблюдения, которые находятся за пределами 1.5*IQR, где IQR, «интервал между квартилями», представляет собой разницу между 75-м и 25-м квартилями. Я также рекомендую вам увидеть этот пост , содержащий гораздо лучшие решения, чем мой грубый ответ.

> df <- data.frame(X = c(NA, rnorm(1000), runif(20, -20, 20)), Y = c(runif(1000),rnorm(20, 2), NA), Z = c(rnorm(1000, 1), NA, runif(20)))
> head(df)
         X      Y      Z
1       NA 0.8651 0.2784
2 -0.06838 0.4700 2.0483
3 -0.18734 0.9887 1.8353
4 -0.05015 0.7731 2.4464
5  0.25010 0.9941 1.3979
6 -0.26664 0.6778 1.1277

> boxplot(df$Y) # notice the outliers above the top whisker

boxplot with outliers

Теперь я создам пользовательскую функцию для обнаружения выбросов, а другая функция заменит значения выбросов на NA.

# this function will return the indices of the outlier values
> findOutlier <- function(data, cutoff = 3) {
  ## Calculate the sd
  sds <- apply(data, 2, sd, na.rm = TRUE)
  ## Identify the cells with value greater than cutoff * sd (column wise)
  result <- mapply(function(d, s) {
    which(d > cutoff * s)
  }, data, sds)
  result
}

# check for outliers
> outliers <- findOutlier(df)

# custom function to remove outliers
> removeOutlier <- function(data, outliers) {
  result <- mapply(function(d, o) {
    res <- d
    res[o] <- NA
    return(res)
  }, data, outliers)
  return(as.data.frame(result))
}

> filterData<- removeOutlier(df, outliers)
> boxplot(filterData$Y)

boxplot with outlier removed

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...