溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python?opencv3機器學(xué)習(xí)之EM算法怎么使用

發(fā)布時間:2022-06-30 09:51:06 來源:億速云 閱讀:189 作者:iii 欄目:開發(fā)技術(shù)

今天小編給大家分享一下python opencv3機器學(xué)習(xí)之EM算法怎么使用的相關(guān)知識點,內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

引言

不同于其它的機器學(xué)習(xí)模型,EM算法是一種非監(jiān)督的學(xué)習(xí)算法,它的輸入數(shù)據(jù)事先不需要進(jìn)行標(biāo)注。相反,該算法從給定的樣本集中,能計算出高斯混和參數(shù)的最大似然估計。也能得到每個樣本對應(yīng)的標(biāo)注值,類似于kmeans聚類(輸入樣本數(shù)據(jù),輸出樣本數(shù)據(jù)的標(biāo)注)。實際上,高斯混和模型GMM和kmeans都是EM算法的應(yīng)用。

在opencv3.0中,EM算法的函數(shù)是trainEM,函數(shù)原型為:

bool trainEM(InputArray samples, OutputArray logLikelihoods=noArray(),OutputArray labels=noArray(),OutputArray probs=noArray())

四個參數(shù):

 samples: 輸入的樣本,一個單通道的矩陣。從這個樣本中,進(jìn)行高斯混和模型估計。

logLikelihoods: 可選項,輸出一個矩陣,里面包含每個樣本的似然對數(shù)值。

labels: 可選項,輸出每個樣本對應(yīng)的標(biāo)注。

probs: 可選項,輸出一個矩陣,里面包含每個隱性變量的后驗概率

這個函數(shù)沒有輸入?yún)?shù)的初始化值,是因為它會自動執(zhí)行kmeans算法,將kmeans算法得到的結(jié)果作為參數(shù)初始化。

這個trainEM函數(shù)實際把E步驟和M步驟都包含進(jìn)去了,我們也可以對兩個步驟分開執(zhí)行,OPENCV3.0中也提供了分別執(zhí)行的函數(shù):

bool trainE(InputArray samples, InputArray means0,
                        InputArray covs0=noArray(),
                        InputArray weights0=noArray(),
                        OutputArray logLikelihoods=noArray(),
                        OutputArray labels=noArray(),
                        OutputArray probs=noArray())
bool trainM(InputArray samples, InputArray probs0,
                        OutputArray logLikelihoods=noArray(),
                        OutputArray labels=noArray(),
                        OutputArray probs=noArray())

 trainEM函數(shù)的功能和kmeans差不多,都是實現(xiàn)自動聚類,輸出每個樣本對應(yīng)的標(biāo)注值。但它比kmeans還多出一個功能,就是它還能起到訓(xùn)練分類器的作用,用于后續(xù)新樣本的預(yù)測。

預(yù)測函數(shù)原型為:

Vec2d predict2(InputArray sample, OutputArray probs) const

sample: 待測樣本

probs : 和上面一樣,一個可選的輸出值,包含每個隱性變量的后驗概率

返回一個Vec2d類型的數(shù),包括兩個元素的double向量,第一個元素為樣本的似然對數(shù)值,第二個元素為最大可能混和分量的索引值。

在本文中,我們用兩個實例來學(xué)習(xí)opencv中的EM算法的應(yīng)用。

一、opencv3.0中自帶的例子

既包括聚類trianEM,也包括預(yù)測predict2

代碼:

#include "stdafx.h"
#include "opencv2/opencv.hpp"
#include <iostream>
using namespace std;
using namespace cv;
using namespace cv::ml;
//使用EM算法實現(xiàn)樣本的聚類及預(yù)測
int main()
{
    const int N = 4;    //分成4類
    const int N1 = (int)sqrt((double)N);
    //定義四種顏色,每一類用一種顏色表示
    const Scalar colors[] =
    {
        Scalar(0, 0, 255), Scalar(0, 255, 0),
        Scalar(0, 255, 255), Scalar(255, 255, 0)
    };
    int i, j;
    int nsamples = 100;   //100個樣本點
    Mat samples(nsamples, 2, CV_32FC1);  //樣本矩陣,100行2列,即100個坐標(biāo)點    
    Mat img = Mat::zeros(Size(500, 500), CV_8UC3);  //待測數(shù)據(jù),每一個坐標(biāo)點為一個待測數(shù)據(jù)
    samples = samples.reshape(2, 0);
    //循環(huán)生成四個類別樣本數(shù)據(jù),共樣本100個,每類樣本25個
    for (i = 0; i < N; i++)
    {
        Mat samples_part = samples.rowRange(i*nsamples / N, (i + 1)*nsamples / N);
        //設(shè)置均值
        Scalar mean(((i%N1) + 1)*img.rows / (N1 + 1),
            ((i / N1) + 1)*img.rows / (N1 + 1));
        //設(shè)置標(biāo)準(zhǔn)差
        Scalar sigma(30, 30);
        randn(samples_part, mean, sigma);  //根據(jù)均值和標(biāo)準(zhǔn)差,隨機生成25個正態(tài)分布坐標(biāo)點作為樣本
    }
    samples = samples.reshape(1, 0);
    // 訓(xùn)練分類器
    Mat labels;  //標(biāo)注,不需要事先知道
    Ptr<EM> em_model = EM::create();
    em_model->setClustersNumber(N);
    em_model->setCovarianceMatrixType(EM::COV_MAT_SPHERICAL);
    em_model->setTermCriteria(TermCriteria(TermCriteria::COUNT + TermCriteria::EPS, 300, 0.1));
    em_model->trainEM(samples, noArray(), labels, noArray());
    //對每個坐標(biāo)點進(jìn)行分類,并根據(jù)類別用不同的顏色畫出
    Mat sample(1, 2, CV_32FC1);
    for (i = 0; i < img.rows; i++)
    {
        for (j = 0; j < img.cols; j++)
        {
            sample.at<float>(0) = (float)j;
            sample.at<float>(1) = (float)i;
            //predict2返回的是double值,用cvRound進(jìn)行四舍五入得到整型
            //此處返回的是兩個值Vec2d,取第二個值作為樣本標(biāo)注
            int response = cvRound(em_model->predict2(sample, noArray())[1]);
            Scalar c = colors[response];  //為不同類別設(shè)定顏色
            circle(img, Point(j, i), 1, c*0.75, FILLED);
        }
    }
    //畫出樣本點
    for (i = 0; i < nsamples; i++)
    {
        Point pt(cvRound(samples.at<float>(i, 0)), cvRound(samples.at<float>(i, 1)));
        circle(img, pt, 2, colors[labels.at<int>(i)], FILLED);
    }
    imshow("EM聚類結(jié)果", img);
    waitKey(0);
    return 0;
}

結(jié)果:

python?opencv3機器學(xué)習(xí)之EM算法怎么使用

二、trainEM實現(xiàn)自動聚類進(jìn)行圖片目標(biāo)檢測

只用trainEM實現(xiàn)自動聚類功能,進(jìn)行圖片中的目標(biāo)檢測

代碼:

#include "stdafx.h"
#include "opencv2/opencv.hpp"
#include &lt;iostream&gt;
using namespace std;
using namespace cv;
using namespace cv::ml;
int main()
{
    const int MAX_CLUSTERS = 5;
    Vec3b colorTab[] =
    {
        Vec3b(0, 0, 255),
        Vec3b(0, 255, 0),
        Vec3b(255, 100, 100),
        Vec3b(255, 0, 255),
        Vec3b(0, 255, 255)
    };
    Mat data, labels;
    Mat pic = imread("d:/woman.png");
    for (int i = 0; i &lt; pic.rows; i++)
    for (int j = 0; j &lt; pic.cols; j++)
    {
        Vec3b point = pic.at&lt;Vec3b&gt;(i, j);
        Mat tmp = (Mat_&lt;float&gt;(1, 3) &lt;&lt; point[0], point[1], point[2]);
        data.push_back(tmp);
    }
    int N =3;  //聚成3類
    Ptr&lt;EM&gt; em_model = EM::create();
    em_model-&gt;setClustersNumber(N);
    em_model-&gt;setCovarianceMatrixType(EM::COV_MAT_SPHERICAL);
    em_model-&gt;setTermCriteria(TermCriteria(TermCriteria::COUNT + TermCriteria::EPS, 300, 0.1));
    em_model-&gt;trainEM(data, noArray(), labels, noArray());
    int n = 0;
    //顯示聚類結(jié)果,不同的類別用不同的顏色顯示
    for (int i = 0; i &lt; pic.rows; i++)
    for (int j = 0; j &lt; pic.cols; j++)
    {
        int clusterIdx = labels.at&lt;int&gt;(n);
        pic.at&lt;Vec3b&gt;(i, j) = colorTab[clusterIdx];
        n++;
    }
    imshow("pic", pic);
    waitKey(0);
    return 0;
}

測試圖片

python?opencv3機器學(xué)習(xí)之EM算法怎么使用

測試結(jié)果:

python?opencv3機器學(xué)習(xí)之EM算法怎么使用

以上就是“python opencv3機器學(xué)習(xí)之EM算法怎么使用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI