$24
In this homework, you will implement a naïve Bayes’ classifier in R, Matlab, or Python. Here are the steps you need to follow:
Read Section 5.7 from the textbook.
You are given a multivariate classification data set, which contains 195 handwritten letters of size 20 pixels × 16 pixels (i.e., 320 pixels). These images are from five distinct classes, namely, A, B, C, D, and E, where we have 39 data points from each class. The figure below shows five sample figures from each class. You are given two data files:
hw01_data_set_images.csv: letter images,
hw01_data_set_labels.csv: corresponding class labels.
Divide the data set into two parts by assigning the first 25 images from each class to the training set and the remaining 14 images to the test set.
Estimate the parameters #$, #&, #', #(, #), +( = 1), +( = 2), +( = 3), +( = 4), and
+( = 5) using the data points you assigned to the training set in the previous step. Your parameter estimations should be similar to the following figures.
print(pcd[,1])
0.00 0.00 0.00 0.04 0.04 0.04 0.16 0.20 ...
print(pcd[,2])
0.04 0.24 0.24 0.20 0.12 0.08 0.12 0.16 ...
print(pcd[,3])
0.00 0.00 0.00 0.00 0.00 0.12 0.20 0.24 ...
print(pcd[,4])
0.12 0.44 0.40 0.16 0.12 0.08 0.08 0.08 ...
print(pcd[,5])
0.00 0.12 0.12 0.08 0.12 0.16 0.12 0.04 ...
Calculate the confusion matrix for the data points in your training set using the parametric classification rule you will develop using the estimated. Your confusion matrix should be similar to the following matrix.
y_hat
y_train
4
5
1
2
3
1
22
0
0
0
0
2
0
18
0
0
0
3
3
5
24
5
13
4
0
1
0
20
0
5
0
1
1
0
12
Calculate the confusion matrix for the data points in your test set using the parametric classification rule you will develop using the estimated parameters. Your confusion matrix should be similar to the following matrix.
y_hat
y_test
3
4
5
1
2
1
9
1
0
1
0
2
1
9
0
0
0
3
4
4
12
6
11
4
0
0
0
7
0
5
0
0
2
0
3
What to submit: You need to submit your source code in a single file (.R file if you are using R,
.m file if you are using Matlab, or .py file if you are using Python) and a short report explaining your approach (.doc, .docx, or .pdf file). You will put these two files in a single zip file named as STUDENTID.zip, where STUDENTID should be replaced with your 7-digit student number.
How to submit: E-mail the zip file you created to vbakir@ku.edu.tr with the subject line Intro2MachineLearningHW01. Please follow the exact style mentioned for the subject line and do not send a zip file named as STUDENTID.zip. Submissions that do not follow these guidelines will not be graded.
Late submission policy: Late submissions will not be graded.
Cheating policy: Very similar submissions will not be graded.