【问题标题】:What is training and testing in image processing?什么是图像处理中的训练和测试?
【发布时间】:2016-04-07 06:31:23
【问题描述】:

我正在对一些 RGB 图像实施基于 k-means 聚类 方法的颜色量化。然后,我将确定算法的性能。我找到了一些关于培训和测试的信息。据我了解,我应该划分图像样本进行训练和测试。

但我对培训和测试这两个术语感到困惑。这些是什么意思?以及如何使用排名值来实现?

【问题讨论】:

    标签: image-processing classification k-means evaluation training-data


    【解决方案1】:

    训练和测试是机器学习中的两个常见概念。在监督学习的框架中更容易解释训练和测试;你有一个训练数据集,你知道输入数据以及要预测的其他属性。训练包括从训练数据集中学习数据和属性之间的关系,测试包括在数据集的另一部分测试这种关系的预测(因为你知道预测,你可以比较关系的输出和真实属性)。在http://scikit-learn.org/stable/tutorial/basic/tutorial.html

    上可以找到使用这些概念的良好介绍性教程

    然而,聚类是一类无监督学习,也就是说,你只有一些输入数据(这里是像素的 RGB 值,如果我理解得很好),没有任何对应的目标值。因此,您可以运行 k-means 聚类算法来查找具有相似颜色的像素类别,而无需训练和测试算法。

    在图像处理中,训练和测试例如用于对像素进行分类以分割不同的对象。一个常见的例子是使用随机森林分类器:用户选择属于不同感兴趣对象(例如背景和对象)的像素,分类器在这组像素上进行训练,然后将剩余的像素归因于一个分类器的类别。 ilastik (http://ilastik.org/) 是一个执行交互式图像分类和分割的软件示例。

    我不知道您使用的是哪种编程语言,但 k-means 已经在各种库中实现。对于 Python,SciPy (http://docs.scipy.org/doc/scipy/reference/generated/scipy.cluster.vq.kmeans2.html#scipy.cluster.vq.kmeans2) 和 scikit-learn (http://scikit-learn.org/stable/modules/generated/sklearn.cluster.KMeans.html) 都有 K-means 的实现。另请注意,根据您的应用程序,您可能对使用像素值以及像素的空间接近度将像素聚集在一起感兴趣。参见例如 scikit-image 库示例 http://scikit-image.org/docs/dev/auto_examples/plot_rag_mean_color.html

    【讨论】:

      猜你喜欢
      • 2014-01-22
      • 2018-02-25
      • 2020-06-26
      • 2020-10-05
      • 1970-01-01
      • 2013-06-15
      • 2021-03-13
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多