Q1
dirty_iris <- read.csv("https://raw.githubusercontent.com/edwindj/datacleaning/master/data/dirty_iris.csv")
sum(is.na(dirty_iris$Petal.Length))
## [1] 19
Q2
cc <- sum(complete.cases(dirty_iris))
percent_complete <- (cc / nrow(dirty_iris))
cc
## [1] 96
percent_complete
## [1] 0.64
Q3
numeric_columns <- sapply(dirty_iris, is.numeric)
nan_values <- sapply(dirty_iris[, numeric_columns], function(x) sum(is.nan(x)))
inf_values <- sapply(dirty_iris[, numeric_columns], function(x) sum(x == Inf))
neg_inf_values <- sapply(dirty_iris[, numeric_columns], function(x) sum(x == -Inf))
nan_values
## Sepal.Length Sepal.Width Petal.Length Petal.Width
## 0 0 0 0
inf_values
## Sepal.Length Sepal.Width Petal.Length Petal.Width
## NA NA NA NA
neg_inf_values
## Sepal.Length Sepal.Width Petal.Length Petal.Width
## NA NA NA NA
Q4
str(dirty_iris)
## 'data.frame': 150 obs. of 5 variables:
## $ Sepal.Length: num 6.4 6.3 6.2 5 5.7 5.3 6.4 5.9 5.8 4.8 ...
## $ Sepal.Width : num 3.2 3.3 NA 3.4 2.6 NA 2.7 3 2.7 3.1 ...
## $ Petal.Length: num 4.5 6 5.4 1.6 3.5 NA 5.3 5.1 4.1 1.6 ...
## $ Petal.Width : num 1.5 2.5 2.3 0.4 1 0.2 NA 1.8 1 0.2 ...
## $ Species : chr "versicolor" "virginica" "virginica" "setosa" ...
dirty_iris[is.nan(as.matrix(dirty_iris))] <- NA
dirty_iris[is.infinite(as.matrix(dirty_iris))] <- NA
Q5
# Logical vectors for each condition
v1 <- dirty_iris$Sepal.Width <= 0
v1
## [1] FALSE FALSE NA FALSE FALSE NA FALSE FALSE FALSE FALSE FALSE FALSE
## [13] FALSE FALSE FALSE TRUE NA FALSE FALSE NA FALSE NA FALSE FALSE
## [25] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [37] FALSE FALSE FALSE FALSE NA FALSE NA FALSE FALSE FALSE NA FALSE
## [49] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [61] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [73] FALSE NA FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [85] FALSE FALSE FALSE FALSE FALSE FALSE FALSE NA FALSE FALSE FALSE FALSE
## [97] FALSE NA FALSE FALSE FALSE FALSE FALSE FALSE FALSE NA FALSE FALSE
## [109] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE NA FALSE FALSE FALSE
## [121] FALSE FALSE FALSE FALSE FALSE FALSE FALSE NA FALSE TRUE FALSE FALSE
## [133] NA FALSE FALSE FALSE FALSE FALSE FALSE FALSE NA NA FALSE FALSE
## [145] FALSE FALSE FALSE FALSE FALSE FALSE
v2 <- dirty_iris$Sepal.Length > 30
v2
## [1] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [13] FALSE FALSE NA FALSE FALSE FALSE NA FALSE FALSE FALSE FALSE FALSE
## [25] NA FALSE FALSE TRUE FALSE NA FALSE FALSE FALSE FALSE FALSE FALSE
## [37] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [49] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE NA FALSE FALSE
## [61] FALSE FALSE FALSE FALSE FALSE FALSE FALSE NA FALSE FALSE FALSE FALSE
## [73] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [85] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [97] FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [109] FALSE FALSE FALSE FALSE FALSE NA FALSE FALSE FALSE FALSE NA NA
## [121] FALSE FALSE FALSE FALSE TRUE FALSE FALSE FALSE FALSE FALSE FALSE FALSE
## [133] FALSE FALSE FALSE FALSE FALSE NA FALSE FALSE FALSE FALSE FALSE FALSE
## [145] FALSE FALSE FALSE FALSE FALSE FALSE
Q6
dirty_iris$Sepal.Width[is.na(dirty_iris$Sepal.Width)] <- 0
dirty_iris$Sepal.Width[dirty_iris$Sepal.Width < 0] <- abs(dirty_iris$Sepal.Width[dirty_iris$Sepal.Width < 0])
print(dirty_iris$Sepal.Width)
## [1] 3.2 3.3 0.0 3.4 2.6 0.0 2.7 3.0 2.7 3.1 3.5 2.7 3.0 2.8 3.9
## [16] 3.0 0.0 3.2 4.0 0.0 3.6 0.0 2.8 3.3 3.0 3.2 3.1 29.0 3.2 2.8
## [31] 3.2 3.2 2.8 2.9 2.9 3.0 3.0 2.2 2.5 3.0 0.0 2.7 0.0 2.7 4.2
## [46] 2.8 0.0 3.2 3.0 3.4 2.6 3.1 2.7 3.4 3.3 3.8 3.8 2.9 2.8 2.8
## [61] 2.3 2.8 3.0 3.3 3.0 2.5 2.5 3.2 3.5 3.5 3.0 3.1 3.5 0.0 2.8
## [76] 2.5 3.5 3.0 3.8 3.8 2.6 3.4 2.9 3.7 3.0 3.8 2.9 2.9 2.9 2.5
## [91] 3.2 0.0 3.4 2.7 2.2 3.1 2.3 0.0 3.0 2.8 3.4 3.6 2.7 3.0 3.7
## [106] 0.0 3.0 3.0 2.8 3.4 3.4 3.4 3.4 3.3 3.1 2.6 0.0 3.1 3.0 2.8
## [121] 3.0 2.3 3.2 4.1 30.0 2.9 3.2 0.0 3.6 0.0 2.5 3.1 0.0 3.3 3.0
## [136] 3.0 3.2 3.0 3.1 2.2 0.0 0.0 3.0 2.9 2.5 3.1 3.0 3.5 3.1 2.6
Q7
# Mean
dirty_iris$Sepal.Width[is.na(dirty_iris$Sepal.Width)] <- mean(dirty_iris$Sepal.Width, na.rm = TRUE)
# Median
dirty_iris$Petal.Length[is.na(dirty_iris$Petal.Length)] <- median(dirty_iris$Petal.Length, na.rm = TRUE)
# Linear regression
# couldnt do it :(
# kNN imputation
library(VIM)
## Loading required package: colorspace
## Loading required package: grid
## VIM is ready to use.
## Suggestions and bug-reports can be submitted at: https://github.com/statistikat/VIM/issues
##
## Attaching package: 'VIM'
## The following object is masked from 'package:datasets':
##
## sleep
dirty_iris_imputed <- kNN(dirty_iris, k = 5)
dirty_iris$Petal.Width <- dirty_iris_imputed$Petal.Width
sum(is.na(dirty_iris$Petal.Width))
## [1] 0
summary(dirty_iris$Petal.Width)
## Min. 1st Qu. Median Mean 3rd Qu. Max.
## 0.100 0.300 1.300 Inf 1.875 Inf