- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在对约 100 万个项目(每个表示为一个约 100 个特征向量)运行 k-means 聚类。我已经为各种 k 运行了聚类,现在想用 sklearn 中实现的轮廓分数来评估不同的结果。尝试在没有采样的情况下运行它似乎不可行并且需要很长时间,所以我假设我需要使用采样,即:
metrics.silhouette_score(feature_matrix, cluster_labels, metric='euclidean',sample_size=???)
不过,我不太清楚什么是合适的抽样方法。给定矩阵的大小,是否有关于使用多大样本的经验法则?是取我的分析机可以处理的最大样本更好,还是取更多较小样本的平均值更好?
我之所以这样问,很大程度上是因为我的初步测试(使用 sample_size=10000)产生了一些非常不直观的结果。
我也愿意接受替代性的、更具扩展性的评估指标。
编辑以可视化问题:该图显示,对于不同的样本大小,剪影分数作为聚类数量的函数
并不奇怪的是,增加样本量似乎可以减少噪音。奇怪的是,鉴于我有 100 万个非常异质的向量,2 或 3 是“最佳”簇数。换句话说,不符合直觉的是,当我增加集群的数量时,我会发现剪影分数或多或少单调下降。
最佳答案
其他指标
弯头法:计算每个 K 解释的方差百分比,并选择图开始趋于平稳的 K。 (这里有一个很好的描述 https://en.wikipedia.org/wiki/Determining_the_number_of_clusters_in_a_data_set )。显然,如果你有 k == 个数据点,你可以解释 100% 的方差。问题是解释的方差改进从哪里开始趋于平稳。
信息论:如果您可以计算给定 K 的可能性,则可以使用 AIC、AICc 或 BIC(或任何其他信息论方法)。例如。对于 AICc,它只是平衡了随着 K 的增加和所需参数数量的增加而增加的可能性。在实践中,您所做的就是选择最小化 AICc 的 K。
您可以通过运行替代方法(例如 DBSCAN)来获得大致合适的 K 值,这些方法可以返回对聚类数量的估计。虽然我还没有看到这种方法用于估计 K,但像这样依赖它可能是不可取的。但是,如果 DBSCAN 在这里也为您提供了少量集群,那么您的数据中可能存在您可能不满意的部分(即没有您期望的那么多集群)。
采样多少
看起来你已经从你的情节中回答了这个问题:无论你的采样是什么,你都会得到相同的剪影得分模式。因此,这种模式似乎对抽样假设非常稳健。
关于python - 在 sklearn 中使用 silhouette 分数进行高效的 k-means 评估,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23687247/
入门教程使用内置的梯度下降优化器非常有意义。但是,k均值不仅可以插入梯度下降中。似乎我不得不编写自己的优化程序,但是鉴于TensorFlow原语,我不确定如何执行此操作。 我应该采取什么方法? 最佳答
我想知道 K-Mean 和 K-Means++ 算法之间的区别。如果有人了解 K-Means++ 算法的流程,您能举例说明一下吗?虽然,我了解 K-Mean 算法,但发现如何实现 K-Means++
我有不同的数据帧均值计算值。通常,我想它们应该是一样的。或者有什么区别: daily1 = daily_above_zero['2011-2'].mean() daily1 Out[181]: P_S
我有关于人们每周上类旅行次数的数据。随着行程的距离,我对两个变量之间的关系感兴趣。 (预计频率会随着距离的增加而下降,本质上是一种负相关。)Cor.test 支持这个假设:-0.08993444,p
我了解 k-means 算法步骤。 但是我不确定该算法是否会始终收敛?或者观察总是可以从一个质心切换到另一个质心? 最佳答案 该算法总是收敛(按定义)但 不一定是全局最优 . 算法可能会从质心切换到质
(添加了可重现的示例。) 我对 rnorm 函数有点困惑。 我期待 mean(rnorm(100,mean=0,sd=1))为0;和 sd(rnorm(100,mean=0,sd=1))为 1。但给出
我想计算一个平均值。这是带有示例数据的代码: # sample data Nr <- c(1, 2, 3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17,
我有一个像这样的数据框: Id F M R 7 1 286 907 12 1 286 907 17 1 186 1271 21 1 296 905 30 1
如果我们将 K-means 和顺序 K-means 方法应用于具有相同初始设置的相同数据集,我们会得到相同的结果吗?解释你的理由。 个人认为答案是否定的,顺序K-means得到的结果取决于数据点的呈现
我想使用 MEAN JavaScript 堆栈,但我注意到有两个不同的堆栈,它们有自己的网站和安装方法:mean.js 和 mean.io。所以我开始问自己这个问题:“我用哪一个?”。 所以为了回答这
似乎有多种方法可以安装 Mean Stack (mean.io) 的所有模块。但是,在 c9.io 中执行此操作的最佳方法是什么?我一直在尝试很多事情,但我似乎并没有全部掌握。 c9.io 有专门的
在开发过程中,我希望加载原始(未聚合).js 文件。 Mean.io 文档说: All javascript within public is automatically aggregated wit
我正在尝试添加 angular-material到 mean.io应用。 在我的自定义包中,我使用 bower 来安装 angular-material,现在我有一个 .../public/asset
我只运行以下三行: df = pd.read_hdf('data.h5') print(df.mean()) print(df['derived_3'].mean()) 第一个 print 列出了每一
k-means++算法有助于原始k-means算法的以下两点: 原始的 k-means 算法在输入大小的 super 多项式的最坏情况下运行时间,而 k-means++ 声称是 O(log k)。 与
这两个字段有什么区别? : 每个请求的时间(平均) 每个请求的时间(平均,跨所有并发请求) 它们每个是如何计算的? 示例输出: Time per request: 3953.446 [ms
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 7年前关闭。 Improve this qu
我想看看是否可以根据它们所处理的目标函数来比较两者的性能? 最佳答案 顺便说一句,Fuzzy-C-Means (FCM) 聚类算法也称为Soft K-Means。 目标函数实际上是相同的,唯一的区别是
虽然我看到了很多与此相关的问题,但我并没有真正得到答案,可能是因为我是使用 nltk 集群的新手。我确实需要对聚类新手进行基本解释,特别是关于 NLTK K 均值聚类的向量表示以及如何使用它。我有一个
我在学习mean.io来自 this tutorial video ,它显示了示例包(由 mean package mymodule 创建。它也在 docs 的“包”下进行了描述)。我想帮助了解给定的
我是一名优秀的程序员,十分优秀!