1. Spectral Clustering
(a) Spectral Clustering on synthesis data
(a.1) change threshold
neighbor = 20, threshold = 0.1
data:image/s3,"s3://crabby-images/eec65/eec65c19a06ed050cc01fabf8e3b264f126b2c64" alt=""
- Almost all the points are labeled as blue Cluster 2. (red < bule)
neighbor = 20, threshold = 0.2
data:image/s3,"s3://crabby-images/0b577/0b5776fca730b843f7bf0e721d48ea1c17dd8c5f" alt=""
- Enlarge the threshold to 0.2, the inner circle is labeled as Cluster 1, the outer ring is labeled more red Cluster 1 than blue Cluster 2. (red > bule)
- We should reduce the threshold.
- And the result is quite like the k-means result.
neighbor = 20, threshold = 0.15
data:image/s3,"s3://crabby-images/ab96e/ab96ed9ae1b5655a5e4c0918ade8cf807510c1ae" alt=""
- A better result.
- The threshold is quite depending on experience. If we can't visualize the data directly, we may get some bad results.
Conclusions:
- If we can't decide the best threshold, we can use "fully connected" to set edge weights so that each weight is larger than 0. Gaussian Kernel Function, like RBF, is usually used to decide the edge weights.
data:image/s3,"s3://crabby-images/ed295/ed295649d3e62931301fde2378c578920ff15c88" alt=""
(a.2) compare with K-means
data:image/s3,"s3://crabby-images/60196/60196862c2ec4ac96cfbb8658af19483d8ff3269" alt=""
- K-means is based on the assumption that each cluster is spherical in vector space so that it can deal with data cluster distributed in spherical but can't handle the data from the problem a.
- Spectral Clustering is based on the graph theory, it can handle the data from the problem a because the data cluster shape in that clustering algorithm is not limited.
- Both Spectral Clustering and K-means need to decide K first.
- Spectral Clustering transforms original data into a new low-dimension vector space by fusing original data features, which makes it more stable than K-means.
- If the graph built by Spectral Clustering is not sparse, or the weight matrix is not sparse, this algorithm will be quite slow.
(b) Spectral Clustering on real-world data
- when k = 3
Algorithm | accuracy | mutual info |
---|---|---|
K-means | 0.572 | -0.365 |
Spectral Clustering | 0.816 | 0.371 |
data:image/s3,"s3://crabby-images/5d4a4/5d4a45bb8bcfe87b1955fbc185fcaf5c1e61b881" alt=""
- when k = 5 (the largest k constructW supports)
Algorithm | accuracy | mutual info |
---|---|---|
K-means | 0.535 | 0.017 |
Spectral Clustering | 0.671 | 0.661 |
data:image/s3,"s3://crabby-images/cbdb5/cbdb56ede5bf8345e307faf2c747510ee1b98e4f" alt=""
2. Principal Component Analysis
(a) hack CAPTCHA system
Below are the 5 original and rotated CAPTCHA samples.
data:image/s3,"s3://crabby-images/b1765/b176541bd5762a96cbb1a41543baab758092e3d7" alt=""
data:image/s3,"s3://crabby-images/71634/71634728bb5bd873f155397c8c4fd0cbbf0537a0" alt=""
data:image/s3,"s3://crabby-images/f4e01/f4e0106a0952227651739f43045982c3dd0d3115" alt=""
data:image/s3,"s3://crabby-images/52901/52901f5bac98c14ea1bf02761d45eb785bd02445" alt=""
data:image/s3,"s3://crabby-images/05b1d/05b1d4a109c35f5287ffe360a9e5828fd0889ff4" alt=""
- Using point coordinates as features is very clever.
- The 1st largest eigenvector is vertical to the long side of the text part because this projecting direction has the largest variance.
- As the principal components are orthogonal, the 2nd largest eigenvector is exactly parallel to the long side. This character can be used to calculate the rotated angle.
(b) apply PCA on face image
(b.i) Eigenface
- 40 largest eigenface
data:image/s3,"s3://crabby-images/89101/891010059da2e7c664387cf642b2bef5d97ed964" alt=""
- 40 smallest eigenface (just have a look)
data:image/s3,"s3://crabby-images/ad2e0/ad2e04cf4f5bd92d6101dee6b2335118ff74ad03" alt=""
(b.ii) Dimensionality reduction test error
- KNN, k = 1
data:image/s3,"s3://crabby-images/40a1b/40a1b2b494995871d05f0dbecf18cfec979b7eb1" alt=""
- KNN, k = 3
data:image/s3,"s3://crabby-images/9ff37/9ff3704af2867f56f359eda002e190db17b9a059" alt=""
- KNN, k = 5
data:image/s3,"s3://crabby-images/80b9f/80b9f25e2f94bbaaf743f535c7dde624b1c3fb04" alt=""
Conclusion:
- The larger k, the larger test error. That's because of the character of KNN, k = 1 is an overfitting condition, more precise on train data. Maybe the train data and test data are quite similar.
(b.iii) Visualized face
data:image/s3,"s3://crabby-images/56253/562532fcc3b1ed836823b9fa3effa6630b8f5617" alt=""
Conclusion:
- When k is smaller, the dimension reduces more, the result image tends to be smoother. In contrast, the larger k means more detailed infomation is reserved, so the result image tends to be sharper.
(b.iv) Apply LDA on this dataset
- KNN, k = 1
data:image/s3,"s3://crabby-images/161c9/161c96bc1e243a215f0510eab4181035ab770dd7" alt=""
- KNN, k = 5
data:image/s3,"s3://crabby-images/610aa/610aa0328ffc87054396b8ae44bca5f9459bf73b" alt=""
- KNN, k = 10
data:image/s3,"s3://crabby-images/cef21/cef21e29ff6adb602c48407b2e77fab3c4261b3e" alt=""
Conclusion:
- LDA has smaller test error than PCA.
- LDA is supervised learning, the LDA function uses training features and ground truth as parameters, paying more attention to the classification labels.
- Though both LDA and PCA project data to low dimension, PCA seeks the largest variance while LDA seeks the largest distance among different class data.
- After dimension reduction, PCA feature dimension can equal the original feature dimension, while LDA feature dimension can only equal the class number of original data.
- LDA can suffer overfitting too. But it's more precise with supervision.
网友评论