This assignment asks you to implement and evaluate four algorithms for the imputation of missing values using two provided datasets. You will also evaluate and compare quality of the imputed values by comparing them with the corresponding values in the complete dataset.
Datasets
There are three datasets: the original dataset without missing values and two derived datasets where the missing values were introduced at two different amounts:
- csv file is the complete dataset. It includes 9 features (including the class/predicted features) and 8795 objects.
- csv and dataset_missing20.csv files include the same dataset with 5% and 20% of missing values, respectively.
You will impute the missing values in each of the latter two datasets and compare these imputed values to the true/correct values that are available in the dataset_complete.csv file to evaluate and compare quality of different imputation algorithms. The three files are in the comma separated value (CSV) format. The first line in each file defines the names of features and the remaining lines include the values of the corresponding 8795 objects. The first 8 features are numeric and continuous with values in [0, 1] interval. The last, class feature is symbolic and binary with values Yes and No. The missing values are represented by ?. There are no missing values in the class feature.
Algorithms for missing data imputation
You will implement four algorithms for the imputation of missing values and apply each of them on the corresponding two datasets that have missing values: dataset_missing05.csv and dataset_missing20.csv.
Algorithm 1. Mean imputation
Missing value for a specific feature and object is imputed with the mean value computed using the complete values of this feature.
Example
F1 | F2 | F3 | Class |
0.40256 | 0.14970 | ? | No |
0.41139 | 0.30140 | ? | Yes |
0.24752 | 0.32148 | 0.11169 | No |
0.24609 | ? | 0.13986 | Yes |
? | 0.58306 | 0.08910 | No |
Object 1
Object 2 Object 3 Object 4
Object 5
To impute the missing value for feature F3 from object 1, we compute the mean of all complete values of F3: mean = (0.11169 + 0.13986 + 0.0891) / 3 = 0.11355.
F1 | F2 | F3 | Class |
0.40256 | 0.14970 | 0.11355 | No |
0.41139 | 0.30140 | ? | Yes |
0.24752 | 0.32148 | 0.11169 | No |
0.24609 | ? | 0.13986 | Yes |
? | 0.58306 | 0.08910 | No |
Object 1
Object 2 Object 3 Object 4
Object 5
The imputed values must not be used to compute the means. This means that all missing values for a given feature are imputed with the same mean value.
F1 | F2 | F3 | Class |
0.40256 | 0.14970 | 0.11355 | No |
0.41139 | 0.30140 | 0.11355 | Yes |
0.24752 | 0.32148 | 0.11169 | No |
0.24609 | ? | 0.13986 | Yes |
? | 0.58306 | 0.08910 | No |
Object 1
Object 2 Object 3 Object 4
Object 5
Algorithm 2. Conditional mean imputation
Missing value for a specific feature and object is imputed with the mean value computed using the complete values of this feature for objects that satisfy a condition defined by the class feature. For instance, a missing value for an object 1 for which class = No is imputed based on the mean value computed using all objects for which class = No.
Example
F1 | F2 | F3 | Class |
0.40256 | 0.14970 | ? | No |
0.41139 | 0.30140 | ? | Yes |
0.24752 | 0.32148 | 0.11169 | No |
0.24609 | ? | 0.13986 | Yes |
? | 0.58306 | 0.08910 | No |
Object 1
Object 2
Object 3
Object 4
Object 5
For object 1 for which class = No, the missing value for the feature F3 is imputed as meanNo = (0.11169 + 0.0891) / 2 = 0.10039
For object 2 for which class = Yes, the missing value for the feature F3 is imputed as meanYes = 0.13986 / 1 = 0.13986 The two imputed values are
F1 | F2 | F3 | Class |
0.40256 | 0.14970 | 0.10039 | No |
0.41139 | 0.30140 | 0.13986 | Yes |
0.24752 | 0.32148 | 0.11169 | No |
0.24609 | ? | 0.13986 | Yes |
? | 0.58306 | 0.08910 | No |
Object 1
Object 2
Object 3
Object 4
Object 5
Algorithm 3. Hot deck imputation
Missing values for features that have missing values in a given object are imputed with the values for the same features copied from another, the most similar object. First, similarity of a given object that has missing values with every other object in the dataset is computed using the Euclidean distance. The object with the smallest distance is assumed to be the most similar and its values are used for the imputation. If that object is missing some of the values that should be imputed then the second most similar object is used to impute the remaining missing values, and so on. In other words, you should use the first complete value that you find by screening objects by their increasing values of the distance.
Given two objects x , , , , and y , , , , , , the Euclidean distance is
calculated as x, y where and are values of feature i for objects x and y,
respectively, is the number of features (excluding the class future), and is the number of features that do not have missing values in either of the two objects. In other words, the distance is computed using the m features that have complete values. Note that you must not use the class feature in the calculation of the distance.
Example
F1 | F2 | F3 | Class |
0.40256 | 0.14970 | ? | No |
0.41139 | 0.30140 | ? | Yes |
0.24752 | 0.32148 | 0.11169 | No |
0.24609 | ? | 0.13986 | Yes |
? | 0.58306 | 0.08910 | No |
Object 1
Object 2 Object 3 Object 4
Object 5
To impute missing value for feature F3 from object 1, we compute distances to every other object
1, 2 0.40256 0.41139 0.1497 0.3014 /2 0.0760
1, 3 0.40256 0.24752 0.1497 0.32148 /2 0.1157
1, 4 0.40256 0.24609 /1 0.1565
1, 5 0.1497 0.58306 /1 0.4334
Since object 2 that is the most similar to object 1 has a missing value for the feature F3, the second nearest object 3 is used and the missing value is imputed as follows
F1 | F2 | F3 | Class |
0.40256 | 0.14970 | 0.11169 | No |
0.41139 | 0.30140 | ? | Yes |
0.24752 | 0.32148 | 0.11169 | No |
0.24609 | ? | 0.13986 | Yes |
? | 0.58306 | 0.08910 | No |
Object 1
Object 2 Object 3 Object 4
Object 5
The imputed values must not be used to compute the distances. In other words, all missing values for each feature are imputed based on the distances that use the dataset before the imputation. This ensures that the errors inherent in the imputed values are not propagated to compute the imputation.
Algorithm 4. Conditional hot deck imputation
Missing values for features with missing values in a given object are imputed with the values for the same features copied from another, most similar object that satisfies a condition defined by the class feature. For instance, a missing value for an object 1 for which class = No is imputed based on similarity only to the objects for which class = No. The calculation of the similarities follows the unconditional hot deck imputation.
Example
F1 | F2 | F3 | Class |
0.40256 | 0.14970 | ? | No |
0.41139 | 0.30140 | ? | Yes |
0.24752 | 0.32148 | 0.11169 | No |
0.24609 | ? | 0.13986 | Yes |
? | 0.58306 | 0.08910 | No |
Object 1
Object 2
Object 3
Object 4
Object 5
To impute missing value for feature F3 from object 1, we first compute the two distances to the objects that share the same value of the class feature
1, 3 0.40256 0.24752 0.1497 0.32148 /2 0.1157
1, 5 0.1497 0.58306 /1 0.4334
The missing value is imputed with the value for the same feature F3 from the closest object 3 as follows.
F1 | F2 | F3 | Class |
0.40256 | 0.14970 | 0.11169 | No |
0.41139 | 0.30140 | ? | Yes |
0.24752 | 0.32148 | 0.11169 | No |
0.24609 | ? | 0.13986 | Yes |
? | 0.58306 | 0.08910 | No |
Object 1
Object 2
Object 3
Object 4
Object 5
Like for the unconditional hot deck imputation, the imputed values must not be used to compute the distances.
Calculation of the imputation error
You will use the two datasets that were imputed with the four methods to calculate the corresponding eight imputation errors. You will evaluate quality of these imputations based on the Mean Absolute Error (MAE) between the imputed values and the corresponding complete values that are available in the dataset_complete.csv file. This dataset should be used only to calculate MAE values, not to perform the imputations. The MAE values should be used to judge and compare the quality of each imputation.
Given the imputed values x , , , , computed from a dataset that has missing values and the corresponding complete values t , , , , , in the complete dataset, MAE is defined as
1
| |
where is the total number of missing values, is a the imputed value in the dataset that has missing values, and are values for the same object and same feature in the two datasets, and | | denotes the absolute value.
F1 | F2 | F3 | F4 | Class |
0.40256 | 0.14970 | 0.16870 | ? | No |
0.41139 | 0.30140 | 0.47033 | ? | Yes |
0.24752 | 0.32148 | 0.41167 | 0.11169 | No |
0.24609 | ? | ? | 0.13986 | Yes |
? | 0.58306 | 0.52568 | 0.08910 | No |
Example Incomplete dataset
Object 1
Object 2 Object 3 Object 4
Object 5
F1 | F2 | F3 | F4 | Class |
0.40256 | 0.14970 | 0.16870 | 0.11355 | No |
0.41139 | 0.30140 | 0.47033 | 0.11355 | Yes |
0.24752 | 0.32148 | 0.41167 | 0.11169 | No |
0.24609 | 0.33891 | 0.39409 | 0.13986 | Yes |
0.32689 | 0.58306 | 0.52568 | 0.08910 | No |
Dataset where values were imputed using Object 1
Object 2
the unconditional Object 3 mean imputation Object 4
Object 5
F1 | F2 | F3 | F4 | Class |
0.40256 | 0.14970 | 0.16870 | 0 | No |
0.41139 | 0.30140 | 0.47033 | 0.14175 | Yes |
0.24752 | 0.32148 | 0.41167 | 0.11169 | No |
0.24609 | 0.21359 | 0.24071 | 0.13986 | Yes |
0.70541 | 0.58306 | 0.52568 | 0.08910 | No |
Complete dataset
Object 1
Object 2 Object 3 Object 4
Object 5
Given the above imputation, the MAE is calculated as follows.
|0.11355 0| |0.11355 0.14175| |0.33891 0.21359|
|0.39409 0.24071| |0.32689 0.70541| 0.1598
The MAE values must be computed with precision of four digits after the decimal point.
The imputed values must be computed with precision of five digits after the decimal point.
Implementation
Your code must perform imputation, display the eight values of MAE on the screen and save the eight imputed datasets in the csv format. The imputed datasets should be named as follows: Vnumber_missing05_imputed_mean.csv
Vnumber_missing05_imputed_mean_conditional.csv
Vnumber_missing05_imputed_hd.csv
Vnumber_missing05_imputed_hd_conditional.csv
Vnumber_ missing20_imputed_mean.csv
Vnumber_missing20_imputed_mean_conditional.csv
Vnumber_missing20_imputed_hd.csv
Vnumber_missing20_imputed_hd_conditional.csv
where Vnumber is your V number, e.g., V12345678_missing01_imputed_mean.csv
The MAE values should be displayed on the screen in the following format
MAE_05_mean = 0.1234
MAE_05_mean_conditional = 0.5678
MAE_05_hd = 0.1234
MAE_05_hd_conditional = 0.5678
MAE_20_mean = 0.1234
MAE_20_mean_conditional = 0.5678
MAE_20_hd = 0.1234
MAE_20_hd_conditional = 0.5678
You must use Java or Python3 to implement all computations including loading the datasets from the csv files, coding the four imputation methods, calculation of the MAE values, printing the MAE values on the screen, and saving of the eight imputed datasets. You may use multiple classes and functions, but they must be included in a single source code (.java or .py) file. This java/python file must successfully compile and produce the above mentioned outputs. Make sure to use appropriate data types to ensure the required precision of results. If you use Java then make sure that the program can be run using the following commands: javac a2.java java a2
This means that your main class should be named a2 and you should not specify a package in your code. If you use Python3 then make sure that the program can be run using the following command: python a2.py
In both cases the program should expect that the three input csv files are located in the same working directory from which the code is run.
Reviews
There are no reviews yet.