使用Python OpenCV进行最大似然像素分类

我想基于给定数量类别的输入训练样本,对RGB图像进行像素分类。例如,我有4个类别,每个类别包含(r,g,b)像素,因此目标是将图像分割成四个部分。

我发现Python OpenCV2中有期望最大化算法,可以完成这项工作。但遗憾的是,我没有找到任何教程或材料来解释(因为我是初学者)如何使用该算法。

您能推荐任何可以作为起点的教程吗?

更新…下面代码的另一种方法:

  **def getsamples(img):    x, y, z = img.shape    samples = np.empty([x * y, z])    index = 0    for i in range(x):        for j in range(y):             samples[index] = img[i, j]             index += 1    return samplesdef EMSegmentation(img, no_of_clusters=2):    output = img.copy()    colors = np.array([[0, 11, 111], [22, 22, 22]])    samples = getsamples(img)    #em = cv2.ml.EM_create()    em = cv2.EM(no_of_clusters)    #em.setClustersNumber(no_of_clusters)    #em.trainEM(samples)    em.train(samples)    x, y, z = img.shape    index = 0    for i in range(x):        for j in range(y):            result = em.predict(samples[index])[0][1]            #print(result)            output[i][j] = colors[result]            index = index + 1    return outputimg = cv2.imread('00.jpg')smallImg = small = cv2.resize(img, (0,0), fx=0.5, fy=0.5) output = EMSegmentation(img)smallOutput = cv2.resize(output, (0,0), fx=0.5, fy=0.5) cv2.imshow('image', smallImg)cv2.imshow('EM', smallOutput)cv2.waitKey(0)cv2.destroyAllWindows()**

回答:

将C++转换为Python 来源

输入图片说明

import cv2import numpy as npdef getsamples(img):    x, y, z = img.shape    samples = np.empty([x * y, z])    index = 0    for i in range(x):        for j in range(y):            samples[index] = img[i, j]            index += 1    return samplesdef EMSegmentation(img, no_of_clusters=2):    output = img.copy()    colors = np.array([[0, 11, 111], [22, 22, 22]])    samples = getsamples(img)    em = cv2.ml.EM_create()    em.setClustersNumber(no_of_clusters)    em.trainEM(samples)    means = em.getMeans()    covs = em.getCovs()  # 已知错误:https://github.com/opencv/opencv/pull/4232    x, y, z = img.shape    distance = [0] * no_of_clusters    for i in range(x):        for j in range(y):            for k in range(no_of_clusters):                diff = img[i, j] - means[k]                distance[k] = abs(np.dot(np.dot(diff, covs[k]), diff.T))            output[i][j] = colors[distance.index(max(distance))]    return outputimg = cv2.imread('dinosaur.jpg')output = EMSegmentation(img)cv2.imshow('image', img)cv2.imshow('EM', output)cv2.waitKey(0)cv2.destroyAllWindows()

Related Posts

使用LSTM在Python中预测未来值

这段代码可以预测指定股票的当前日期之前的值,但不能预测…

如何在gensim的word2vec模型中查找双词组的相似性

我有一个word2vec模型,假设我使用的是googl…

dask_xgboost.predict 可以工作但无法显示 – 数据必须是一维的

我试图使用 XGBoost 创建模型。 看起来我成功地…

ML Tuning – Cross Validation in Spark

我在https://spark.apache.org/…

如何在React JS中使用fetch从REST API获取预测

我正在开发一个应用程序,其中Flask REST AP…

如何分析ML.NET中多类分类预测得分数组?

我在ML.NET中创建了一个多类分类项目。该项目可以对…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注