前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >机器学习算法应用中常用技巧-2

机器学习算法应用中常用技巧-2

作者头像
MachineLP
发布2018-01-09 15:08:30
5730
发布2018-01-09 15:08:30
举报
文章被收录于专栏:小鹏的专栏小鹏的专栏

7. 降维-PCA

n_components为降到多少维,用原数据fit后,再用transform转换成降维后的数据。

代码语言:javascript
复制
from sklearn.decomposition import PCA
pca = PCA(n_components = 6)
pca.fit(good_data)
reduced_data = pca.transform(good_data)
reduced_data = pd.DataFrame(reduced_data, columns = ['Dimension 1', 'Dimension 2'])

8. 聚类-选择类别数

用 silhouette coefficient 计算每个数据到中心点的距离,-1 (dissimilar) to 1 (similar) 根据这个系数来评价聚类算法的优劣。

代码语言:javascript
复制
from sklearn.cluster import KMeans
from sklearn.metrics import silhouette_score
cluster = KMeans(n_clusters=2, random_state=0).fit(reduced_data)
preds = cluster.predict(reduced_data)
score = silhouette_score(reduced_data, preds)

选择分数最大的个数作为聚类的类别数。

9. 恢复维度

例如数据,先经过 log,又经过 PCA降维, 要恢复回去,先用 pca.inverse_transform,再用 np.exp

代码语言:javascript
复制
log_centers = pca.inverse_transform(centers)
true_centers = np.exp(log_centers)
true_centers = pd.DataFrame(np.round(true_centers), columns = data.keys())

数据变化:

10. 自定义accuracy

分类问题可以自己写accuracy的函数

代码语言:javascript
复制
def accuracy_score(truth, pred):
    """ Return accuracy score for input truth and prediction"""

    if len(truth)==len(pred):
        return "Accuracy for prediction: {:.2f}%.".format((truth==pred).mean()*100)
    else:
        return "Numbers do not match!"
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017年02月06日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 7. 降维-PCA
  • 8. 聚类-选择类别数
  • 9. 恢复维度
  • 10. 自定义accuracy
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档