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

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

系統 1709 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條評論
主站蜘蛛池模板: 国产成人久久精品推最新 | 欲色综合| 狠狠色欧美亚洲综合色黑a 狠狠色视频 | 欧美成人毛片免费视频 | 成人性生交大片免费看午夜a | 亚洲国产成人久久笫一页 | 久久98| 色久悠悠在线观看 | 久久精品国产亚洲欧美 | 亚洲精品一区二区三区四区手机版 | 天天操天天干天天操 | 国产精品一区二区在线播放 | 亚洲性爰视频 | 中文字幕av一区 | 亚洲成人在线观看视频 | 国产精品一区在线播放 | 国产一区二区在线 |播放 | 日日摸夜夜爽日日放碰 | 久久精品国产精品青草不卡 | 日本一本久 | 日一区二区| 91精品国产综合久久欧美 | 99亚洲| 久久高清一级毛片 | 麻豆精品永久免费视频 | 国产全黄一级毛片 | 亚洲一区在线视频观看 | 女人一级一级毛片 | 色成年激情久久综合 | 欧美极品福利视频在线播放 | 99在线观看视频 | 日本欧美高清全视频 | 美国毛片aaa在线播放 | 老子影院午夜理伦手机不卡 | 91天堂97年嫩模在线观看 | 精品视频久久久 | 色综合久久一本首久久 | 国产美女免费观看 | 久久一er精这里有精品 | 久久国产精品-久久精品 | 最近中文字幕无吗高清视频 |