亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

OpenCV學習——物體跟蹤的粒子濾波算法實現之位

系統 1942 0

/*
Computes the likelihood of there being a player at a given location in
an image

@param img image that has been converted to HSV colorspace using bgr2hsv()
@param r row location of center of window around which to compute likelihood
@param c col location of center of window around which to compute likelihood
@param w width of region over which to compute likelihood
@param h height of region over which to compute likelihood
@param ref_histo reference histogram for a player; must have been
normalized with normalize_histogram()

@return Returns the likelihood of there being a player at location
(\a r, \a c) in \a img
*/
float likelihood( IplImage* img, int r, int c,
int w, int h, histogram* ref_histo )
{
IplImage* tmp;
histogram* histo;
float d_sq;

/* extract region around (r,c) and compute and normalize its histogram */
cvSetImageROI( img, cvRect( c - w / 2, r - h / 2, w, h ) );
tmp = cvCreateImage( cvGetSize(img), IPL_DEPTH_32F, 3 );
cvCopy( img, tmp, NULL );
cvResetImageROI( img );
histo = calc_histogram( &tmp, 1 );
cvReleaseImage( &tmp );
normalize_histogram( histo );

/* compute likelihood as e^{\lambda D^2(h, h^*)} */
d_sq = histo_dist_sq( histo, ref_histo );
free( histo );
return exp( -LAMBDA * d_sq );
}

程序首先取出對相關粒子表示的區域,然后計算其直方圖,并且歸一化。將這個直方圖和原來用戶選定區域的直方圖傳入函數histo_dist_sq進行比較,最后返回e^(-Lambda*d_sq)返回,成為這個粒子的權重。

函數histo_dist_sq的實現如下:

/*
Computes squared distance metric based on the Battacharyya similarity
coefficient between histograms.

@param h1 first histogram; should be normalized
@param h2 second histogram; should be normalized

@return Returns a squared distance based on the Battacharyya similarity
coefficient between \a h1 and \a h2
*/
float histo_dist_sq( histogram* h1, histogram* h2 )
{
float* hist1, * hist2;
float sum = 0;
int i, n;

n = h1->n;
hist1 = h1->histo;
hist2 = h2->histo;

/*
According the the Battacharyya similarity coefficient,

D = \sqrt{ 1 - \sum_1^n{ \sqrt{ h_1(i) * h_2(i) } } }
*/
for( i = 0; i < n; i++ )
sum += sqrt( hist1[i]*hist2[i] );
return 1.0 - sum;
}

采用統計學上的巴氏距離 Bhattacharyya distance,根據wiki的描述, Bhattacharyya distance 描述的是兩個離散概率分布的相似性,它通常在分類操作中被用來度量不同類型的可分離性,也就是說這個距離算式就是評定相似度的。嚴格定義為:

For discrete probability distributions p and q over the same domain X, it is defined as:

where:

is the Bhattacharyya coefficient .

該程序中的算式和這個式子略有差別。

OpenCV學習——物體跟蹤的粒子濾波算法實現之位置可能性確定


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产成人香蕉在线视频网站 | 亚洲成人99 | 国产91在线播放边 | 欧美伦理一区 | 一本一道 | 国产精品香蕉在线观看不卡 | 99精品国产免费久久国语 | 午夜精品在线视频 | 亚洲国产高清一区二区三区 | 久久久久国产一级毛片高清版 | 色精品一区二区三区 | 欧美成人精品高清在线播放 | 一级午夜视频 | 国产精品久久久久aaaa | 天天操天天干天天舔 | 日本天天谢天天要天天爱 | 成人精品视频一区二区在线 | 亚洲国产精品综合福利专区 | www国产 | 欧美在线综合 | 成人a区 | 波多野结衣中文丝袜字幕 | 日韩在线中文 | 亚洲欧美日韩另类 | 亚洲天天做夜夜做天天欢人人 | 亚洲欧美日韩在线一区 | 99热这里只精品99re66 | 九九热精品在线视频 | 成人黄色免费 | 国产精品综合在线 | 精品综合 | 久久国产影院 | 午夜私人影院在线观看 | 国产xxx视频 | 久久国产综合 | 国产欧美精品区一区二区三区 | 九九免费精品视频在这里 | 日韩一区二区三区视频 | 中文字幕免费在线观看 | 久久91亚洲精品中文字幕 | 国产成人a在一区线观看高清 |