-215
opencv
assertion_error
ai_generated
true
cv2.error: OpenCV(4.9.0) /tmp/opencv-4.9.0/modules/core/src/kmeans.cpp:245: error: (-215:断言失败) N >= K 在函数 'cv::kmeans' 中
cv2.error: OpenCV(4.9.0) /tmp/opencv-4.9.0/modules/core/src/kmeans.cpp:245: error: (-215:Assertion failed) N >= K in function 'cv::kmeans'
ID: opencv/kmeans-n-less-than-k
95%修复率
88%置信度
1证据数
2024-01-10首次发现
版本兼容性
| 版本 | 状态 | 引入 | 弃用 | 备注 |
|---|---|---|---|---|
| 4.8.0 | active | — | — | — |
| 4.9.0 | active | — | — | — |
| 4.10.0 | active | — | — | — |
| 5.0.0 | active | — | — | — |
根因分析
提供给 k-means 的数据点数量 (N) 少于请求的聚类数量 (K),导致无法进行聚类。
English
The number of data points (N) provided to k-means is less than the requested number of clusters (K), making clustering impossible.
官方文档
https://docs.opencv.org/4.x/d5/d38/group__core__cluster.html#ga9a34e5b5b9e6a8c6f8b0e0d5c5a5b5a解决方案
-
Reduce K to be less than or equal to N: `k = min(k, len(data))` before calling kmeans.
-
Collect more data points to ensure N >= K, e.g., by increasing the sample size in data acquisition.
-
Add a check before kmeans: `if len(samples) < k: raise ValueError('Not enough samples for k-means')`.
无效尝试
常见但无效的做法:
-
80% 失败
Duplicating points creates artificial clusters and does not solve the fundamental issue of insufficient unique data.
-
95% 失败
More iterations do not help when N < K; the algorithm cannot proceed with fewer points than clusters.
-
90% 失败
The assertion fails before any distance computation; the error is in the input validation.