91av视频/亚洲h视频/操亚洲美女/外国一级黄色毛片 - 国产三级三级三级三级

  • 大小: 135KB
    文件類型: .rar
    金幣: 2
    下載: 0 次
    發(fā)布日期: 2021-06-12
  • 語言: C/C++
  • 標簽: EM算法??mfc??

資源簡介

vs2010環(huán)境下編寫的VC++代碼,EM算法直觀實現(xiàn)GMM。 效果參照:http://blog.csdn.net/hzq20081121107/article/details/19505619

資源截圖

代碼片段和文件信息

#include?“StdAfx.h“
#include?
#include?“ClassGMM.h“

#define?PI?acos(-1.0)


ClassGMM::ClassGMM(void)
{
numSample=0;
numClass=0;
pGM=NULL;
pSampleNode=NULL;
}


ClassGMM::~ClassGMM(void)
{
if(pGM!=NULL)
{
????delete?[]pGM;
pGM=NULL;
}
if(pSampleNode!=NULL)
{
????delete?[]pSampleNode;
pSampleNode=NULL;
}
}


void?ClassGMM::clear(void)
{
numSample=0;
numClass=0;
if(pGM!=NULL)
{
delete?[]pGM;
pGM=NULL;
}
if(pSampleNode!=NULL)
{
delete?[]pSampleNode;
pSampleNode=NULL;
}
}

//EM迭代?nTimes
int?ClassGMM::EM(int?nTimes)
{
int?ijk;
//開辟空間
float?**ppR;
ppR=new?float*?[numSample];
for(i=0;i {
????ppR[i]=new?float[numClass];
}


while(--nTimes>=0)
{
//計算r(ik),用ppR[ik]表示
for(i=0;i {
float?*piKN;
piKN=new?float[numClass];//
float?sum_piKN=0;
for(k=0;k {
piKN[k]=pGM[k].piK*getGaussRatio(pGM[k].upGM[k].sigmapSampleNode[i].x);
sum_piKN+=piKN[k];
}
for(k=0;k {
ppR[i][k]=piKN[k]/sum_piKN;
}
delete?[]piKN;
}
//利用r(ik)求高斯參數(shù),Nk,piK,u,sigma,
//Nk
for(k=0;k {
pGM[k].Nk=0;
for(i=0;i {
pGM[k].Nk?+=?ppR[i][k];
}
}
//piK
float?sumNK=0;
for(k=0;k {
sumNK+=pGM[k].Nk;
}
for(k=0;k {
pGM[k].piK=pGM[k].Nk/sumNK;
}
//u
for(k=0;k {
pGM[k].u=0;
for(i=0;i {
pGM[k].u+=pSampleNode[i].x*ppR[i][k];
}
pGM[k].u/=pGM[k].Nk;
}
//sigma
for(k=0;k {
float?sum_temp=0;
for(i=0;i {
sum_temp+=ppR[i][k]*(pSampleNode[i].x-pGM[k].u)*(pSampleNode[i].x-pGM[k].u);
}
sum_temp/=pGM[k].Nk;
pGM[k].sigma=sqrt(sum_temp);
}
}
//銷毀空間
for(i=0;i {
delete?[]ppR[i];
}
delete?[]ppR;

return?0;
}

//求高斯概率密度
float?ClassGMM::getGaussRatio(float?u??float?sigma??float?x)
{
double?fenMu=sqrt(2*PI)*sigma;
double?zhiShu=-(x-u)*(x-u)/(2*sigma*sigma);
double?fenZi=exp(zhiShu);
return?fenZi/fenMu;
}

?屬性????????????大小?????日期????時間???名稱
-----------?---------??----------?-----??----

?????文件???????2233??2014-02-14?15:53??GMM_test2\GMM_test\ClassGMM.cpp

?????文件????????391??2014-02-14?16:04??GMM_test2\GMM_test\ClassGMM.h

?????文件?????106512??2014-02-19?21:35??GMM_test2\GMM_test\GMM_test.aps

?????文件???????2019??2014-01-20?14:55??GMM_test2\GMM_test\GMM_test.cpp

?????文件????????454??2014-01-20?14:55??GMM_test2\GMM_test\GMM_test.h

?????文件??????10542??2014-02-19?21:35??GMM_test2\GMM_test\GMM_test.rc

?????文件???????6012??2014-02-14?11:10??GMM_test2\GMM_test\GMM_test.vcxproj

?????文件???????2177??2014-02-14?11:10??GMM_test2\GMM_test\GMM_test.vcxproj.filters

?????文件????????143??2014-01-20?14:55??GMM_test2\GMM_test\GMM_test.vcxproj.user

?????文件???????6800??2014-02-19?21:34??GMM_test2\GMM_test\GMM_testDlg.cpp

?????文件???????1098??2014-02-19?21:25??GMM_test2\GMM_test\GMM_testDlg.h

?????文件???????3160??2014-01-20?14:55??GMM_test2\GMM_test\ReadMe.txt

?????文件??????67777??2009-08-31?02:31??GMM_test2\GMM_test\res\GMM_test.ico

?????文件????????672??2014-01-20?14:55??GMM_test2\GMM_test\res\GMM_test.rc2

?????文件???????1822??2014-01-20?16:50??GMM_test2\GMM_test\resource.h

?????文件????????141??2014-01-20?14:55??GMM_test2\GMM_test\stdafx.cpp

?????文件???????1632??2014-01-20?14:55??GMM_test2\GMM_test\stdafx.h

?????文件????????234??2014-01-20?14:55??GMM_test2\GMM_test\targetver.h

?????文件????????891??2014-01-20?14:55??GMM_test2\GMM_test.sln

????..A..H.?????29184??2014-02-19?21:44??GMM_test2\GMM_test.suo

?????目錄??????????0??2014-02-13?17:26??GMM_test2\GMM_test\res

?????目錄??????????0??2014-02-26?21:02??GMM_test2\GMM_test

?????目錄??????????0??2014-02-26?21:02??GMM_test2

-----------?---------??----------?-----??----

???????????????243894????????????????????23


評論

共有 條評論