Description
Please use Google Classroom to upload your submission by the deadline mentioned above. Your submission should comprise of a single le (PDF/ZIP), named <Your Roll No> Assign4, with all your solutions.
For late submissions, 10% is deducted for each day (including weekend) late after an assign-ment is due. Note that each student begins the course with 7 grace days for late submission of assignments. Late submissions will automatically use your grace days balance, if you have any left. You can see your balance on the CS6510 Marks and Grace Days document.
You have to use Python for the programming questions.
Please read the department plagiarism policy. Do not engage in any form of cheating – strict penalties will be imposed for both givers and takers. Please talk to instructor or TA if you have concerns.
Questions: Theory
(No programming required)
1. Hierarchical Clustering (4 marks): Given below is the distance matrix for 6 data points
-
x1
x2
x3
x4
x5
x6
x1
0
x2
0.12
0
x3
0.51
0.25
0
x4
0.84
0.16
0.14
0
x5
0.28
0.77
0.70
0.45
0
x6
0.34
0.61
0.93
0.20
0.67
0
1
-
-
Draw a dendrogram for the nal result of hierarchical clustering with complete link. [1 mark ]
-
-
-
Change two values from the matrix so that the answer to the last two questions is same. [2 marks]
-
-
Principal Component Analysis (4 marks): Suppose each data point x is an M-
dimensional vector of the form x = a k = (0; :::; 0; a; 0; :::)T , where a is in the kth slot, and k,a are random variables. k is uniformly distributed over 1; ; M and P (a) is arbitrary.
-
-
Calculate the covariance matrix. [1 mark ]
-
-
-
Show that it has one eigenvector of form (1; :::; 1) and that the other eigenvectors all have the same eigenvalue. [2 marks]
-
-
-
Discuss whether PCA is a good way to select features for this problem. [1 mark ]
-
(Hint: Use expectation to compute the covariance matrix: C = E[(x E[x])(x E[x])T ]. You should get C of the form Cij = + i;j for some , .)
Questions: Programming
-
Clustering (7 marks): DBSCAN, as we discussed in class, is a density-based clustering algorithm. In this problem, you need to implement your own DBSCAN algorithm. You can read more about it from paper that proposed this method [link].
-
-
Use the Kmeans clustering algorithm from sklearn and nd the number of clusters in dataset1 shared with you. Plot the data points with di erent colors for di erent clusters. [1 mark ]
-
-
-
Implement your own DBSCAN algorithm on the same dataset and plot the data points. [3 marks]
-
-
-
What di erences do you see between the DBSCAN and k-means methods, and why? [1 mark ]
-
-
-
Consider the dataset2 (also shared with you) with three clusters. Use (a) and (b) for dataset2, and compare the performance. List your observations clearly, and make conclusions on pros and cons of DBSCAN and k-means. [2 marks]
-
-
Dimensionality Reduction (5 marks):
-
-
For this problem, you will study Principal Component Analysis on the Iris dataset. The Iris dataset contains classi cations of iris plants based on four features: sepal length, sepal width, petal length, and petal width. There are three classes of iris plants on this dataset: Iris Setosa, Iris Versicolor, and Iris Virginica. You can download the dataset from http://archive.ics.uci.edu/ml/machine-learning-databases/iris/iris. data. Use the rst and second principal components to plot this dataset in 2 dimensions (you can use in-built methods for this). Use di erent colors for each of the three classes in your plot. Share your observations in your report. [1.5 marks]
-
2
-
Now, use sklearn’s inbuilt t-SNE function to visualize the same data. Include these in your plots, and compare the plots with the PCA plots. Do you see any di erences/sim-ilarities? Share them in your report. [1.5 marks]
-
Now, compare PCA and t-SNE on the SwissRoll dataset (you can use the inbuilt sklearn function to generate this dataset using http://scikit-learn.org/stable/ modules/generated/sklearn.datasets.make_swiss_roll.html. Now, what do you see? Share your observations and inferences in your report. [2 marks]
OPTIONAL QUESTIONS
(No submission required; for your own practice and learning)
-
Show mathematically that k-means is equivalent to a GMM obtained using Expectation Maximization when the component assignment prior is uniform, and when each component has the same covariance.
-
(For the mathematically inclined) Suppose we approximately represent each point of the dataset as a linear combination of its k nearest neighbors. Let (Wk)ij be the weight of point xj in the expansion of xi minimizing the squared representation error.
-
-
Prove that Mk(xi; xj) = ((IWk)T (IWk))ij is a positive semide nite kernel on the domain X = fx1; ; xng.
-
Let be the largest eigenvalue of (IWk)T (IW k). Prove that the LLE kernel KkLLE(xi; xj) = ( 1)I + WkT + W kWkT Wk)ij is positive semide nite on fx1; ; xng.
-
-
-
Prove that kernel PCA using the LLE kernel provides the LLE embedding coe cients for a ddimensional embedding as the coe cient eigenvectors 2; ; d+1. Note that if the eigenvectors are normalized, then dimension i will be scaled by 1i=2; i = 1; ; d.
-
-
-
Prove that the pseudo-inverse of M is positive semide nite.
-
-
-
Prove that performing kernel PCA on M+(pseudo-inverse of M)is equivalent to LLE up to scaling factors.
-
3