亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? particles.c

?? This distribution contains source code for a simple object tracking program using particle filterin
?? C
字號:
/*  Functions for object tracking with a particle filter    @author Rob Hess  @version 1.0.0-20060310*/#include "defs.h"#include "utils.h"#include "particles.h"/*************************** Function Definitions ****************************//*  Creates an initial distribution of particles at specified locations      @param regions an array of regions describing player locations around    which particles are to be sampled  @param histos array of histograms describing regions in \a regions  @param n the number of regions in \a regions  @param p the total number of particles to be assigned    @return Returns an array of \a p particles sampled from around regions in    \a regions*/particle* init_distribution( CvRect* regions, histogram** histos, int n, int p){  particle* particles;  int np;  float x, y;  int i, j, width, height, k = 0;    particles = malloc( p * sizeof( particle ) );  np = p / n;  /* create particles at the centers of each of n regions */  for( i = 0; i < n; i++ )    {      width = regions[i].width;      height = regions[i].height;      x = regions[i].x + width / 2;      y = regions[i].y + height / 2;      for( j = 0; j < np; j++ )	{	  particles[k].x0 = particles[k].xp = particles[k].x = x;	  particles[k].y0 = particles[k].yp = particles[k].y = y;	  particles[k].sp = particles[k].s = 1.0;	  particles[k].width = width;	  particles[k].height = height;	  particles[k].histo = histos[i];	  particles[k++].w = 0;	}    }  /* make sure to create exactly p particles */  i = 0;  while( k < p )    {      width = regions[i].width;      height = regions[i].height;      x = regions[i].x + width / 2;      y = regions[i].y + height / 2;      particles[k].x0 = particles[k].xp = particles[k].x = x;      particles[k].y0 = particles[k].yp = particles[k].y = y;      particles[k].sp = particles[k].s = 1.0;      particles[k].width = width;      particles[k].height = height;      particles[k].histo = histos[i];      particles[k++].w = 0;      i = ( i + 1 ) % n;    }  return particles;}/*  Samples a transition model for a given particle    @param p a particle to be transitioned  @param w video frame width  @param h video frame height  @param rng a random number generator from which to sample  @return Returns a new particle sampled based on <EM>p</EM>'s transition    model*/particle transition( particle p, int w, int h, gsl_rng* rng ){  float x, y, s;  particle pn;    /* sample new state using second-order autoregressive dynamics */  x = A1 * ( p.x - p.x0 ) + A2 * ( p.xp - p.x0 ) +    B0 * gsl_ran_gaussian( rng, TRANS_X_STD ) + p.x0;  pn.x = MAX( 0.0, MIN( (float)w - 1.0, x ) );  y = A1 * ( p.y - p.y0 ) + A2 * ( p.yp - p.y0 ) +    B0 * gsl_ran_gaussian( rng, TRANS_Y_STD ) + p.y0;  pn.y = MAX( 0.0, MIN( (float)h - 1.0, y ) );  s = A1 * ( p.s - 1.0 ) + A2 * ( p.sp - 1.0 ) +    B0 * gsl_ran_gaussian( rng, TRANS_S_STD ) + 1.0;  pn.s = MAX( 0.1, s );  pn.xp = p.x;  pn.yp = p.y;  pn.sp = p.s;  pn.x0 = p.x0;  pn.y0 = p.y0;  pn.width = p.width;  pn.height = p.height;  pn.histo = p.histo;  pn.w = 0;  return pn;}/*  Normalizes particle weights so they sum to 1    @param particles an array of particles whose weights are to be normalized  @param n the number of particles in \a particles*/void normalize_weights( particle* particles, int n ){  float sum = 0;  int i;  for( i = 0; i < n; i++ )    sum += particles[i].w;  for( i = 0; i < n; i++ )    particles[i].w /= sum;}/*  Re-samples a set of particles according to their weights to produce a  new set of unweighted particles    @param particles an old set of weighted particles whose weights have been    normalized with normalize_weights()  @param n the number of particles in \a particles    @return Returns a new set of unweighted particles sampled from \a particles*/particle* resample( particle* particles, int n ){  particle* new_particles;  int i, j, np, k = 0;  qsort( particles, n, sizeof( particle ), &particle_cmp );  new_particles = malloc( n * sizeof( particle ) );  for( i = 0; i < n; i++ )    {      np = cvRound( particles[i].w * n );      for( j = 0; j < np; j++ )	{	  new_particles[k++] = particles[i];	  if( k == n )	    goto exit;	}    }  while( k < n )    new_particles[k++] = particles[0]; exit:  return new_particles;}/*  Compare two particles based on weight.  For use in qsort.  @param p1 pointer to a particle  @param p2 pointer to a particle  @return Returns -1 if the \a p1 has lower weight than \a p2, 1 if \a p1    has higher weight than \a p2, and 0 if their weights are equal.*/int particle_cmp( void* p1, void* p2 ){  particle* _p1 = (particle*)p1;  particle* _p2 = (particle*)p2;  if( _p1->w > _p2->w )    return -1;  if( _p1->w < _p2->w )    return 1;  return 0;}/*  Displays a particle on an image as a rectangle around the region specified  by the particle    @param img the image on which to display the particle  @param p the particle to be displayed  @param color the color in which \a p is to be displayed*/void display_particle( IplImage* img, particle p, CvScalar color ){  int x0, y0, x1, y1;  x0 = cvRound( p.x - 0.5 * p.s * p.width );  y0 = cvRound( p.y - 0.5 * p.s * p.height );  x1 = x0 + cvRound( p.s * p.width );  y1 = y0 + cvRound( p.s * p.height );    cvRectangle( img, cvPoint( x0, y0 ), cvPoint( x1, y1 ), color, 1, 8, 0 );}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人毛片在线观看| 成人一区二区三区| 国产精品久久久久久久久晋中| 日韩一级在线观看| 精品国产91亚洲一区二区三区婷婷 | 91高清视频在线| 99精品一区二区三区| 成人av免费在线| 成人av电影免费在线播放| 成人一区二区视频| 国产精品一品二品| 大尺度一区二区| 91热门视频在线观看| 在线视频欧美精品| 欧美人妇做爰xxxⅹ性高电影| 欧美精品v国产精品v日韩精品| 欧美三级韩国三级日本三斤| 9191久久久久久久久久久| 欧美一二三区精品| 久久女同互慰一区二区三区| 国产精品美女久久久久久| 亚洲欧美日韩国产综合| 午夜精品成人在线| 国产精品白丝av| 色欧美日韩亚洲| 欧美肥妇bbw| 久久这里只有精品首页| 亚洲国产精华液网站w| 亚洲国产欧美在线| 国产主播一区二区三区| 99热这里都是精品| 777欧美精品| 国产精品女主播av| 天天操天天色综合| 波多野结衣的一区二区三区| 欧美高清性hdvideosex| 国产喷白浆一区二区三区| 亚洲亚洲人成综合网络| 久久不见久久见中文字幕免费| 床上的激情91.| 91精品国产乱| 成人欧美一区二区三区黑人麻豆| 视频一区欧美精品| 99视频超级精品| 精品三级在线看| 一区二区在线观看不卡| 麻豆成人久久精品二区三区红| 成人av在线播放网址| 在线成人av网站| 最新中文字幕一区二区三区| 免费成人在线影院| 在线观看亚洲成人| 国产精品福利一区| 精品午夜一区二区三区在线观看| 91久久精品国产91性色tv| 精品sm捆绑视频| 免费成人深夜小野草| 欧美亚洲国产一区在线观看网站 | 精品午夜一区二区三区在线观看| 色综合欧美在线| 国产精品水嫩水嫩| 国产美女视频一区| 欧美电视剧在线看免费| 日韩高清不卡在线| 欧美精品一卡二卡| 亚洲一区av在线| 色综合视频在线观看| 国产精品久久久久久久久免费桃花| 精品一区二区三区视频在线观看 | 久久久综合视频| 麻豆国产精品视频| 欧美一区二区日韩一区二区| 午夜伊人狠狠久久| 欧美精品日韩精品| 亚洲va天堂va国产va久| 欧美在线高清视频| 午夜视频在线观看一区| 欧美视频在线一区二区三区| 亚洲欧美日韩成人高清在线一区| av福利精品导航| 17c精品麻豆一区二区免费| 成人激情开心网| 亚洲精品欧美综合四区| 色综合中文字幕国产 | 首页综合国产亚洲丝袜| 欧美性猛交xxxx乱大交退制版| 国产精品久久看| 一本大道久久a久久综合婷婷| 中文字幕视频一区| 欧美三区免费完整视频在线观看| 亚洲午夜免费福利视频| 欧美日韩一区不卡| 青草国产精品久久久久久| 精品国产乱码久久久久久老虎| 激情综合色丁香一区二区| 国产亚洲精品中文字幕| www.欧美色图| 亚洲国产另类av| 欧美成人高清电影在线| 国产成人av自拍| 亚洲精品视频一区二区| 7777精品伊人久久久大香线蕉| 麻豆精品一二三| 国产精品私人自拍| 欧美狂野另类xxxxoooo| 国产成人精品免费| 亚洲香肠在线观看| 久久影院电视剧免费观看| 色伊人久久综合中文字幕| 奇米888四色在线精品| 久久久精品免费观看| 欧美午夜电影网| 国产成人高清在线| 亚洲国产成人精品视频| 中文字幕不卡一区| 91精品一区二区三区在线观看| 成人一区在线观看| 日韩成人精品在线| 亚洲欧美aⅴ...| 久久嫩草精品久久久精品一| 色一情一乱一乱一91av| 国产剧情av麻豆香蕉精品| 一区二区三区免费网站| 国产片一区二区| 日韩一区二区免费在线电影| 色综合 综合色| 国产精品1024久久| 日本三级亚洲精品| 亚洲午夜国产一区99re久久| 久久精品人人做人人爽人人| 91精品久久久久久蜜臀| 91丨porny丨最新| 国产aⅴ综合色| 麻豆精品国产91久久久久久| 亚洲夂夂婷婷色拍ww47| 最新高清无码专区| 国产清纯白嫩初高生在线观看91 | 99精品国产99久久久久久白柏| 日韩精品亚洲一区| 一区二区高清免费观看影视大全 | 亚洲在线一区二区三区| 亚洲欧洲日产国码二区| 久久久蜜桃精品| 欧美成人一级视频| 日韩免费看的电影| 欧美精品在线观看一区二区| 在线视频一区二区三| 色综合色综合色综合色综合色综合 | 欧美日韩精品系列| 99久久久精品| 丁香桃色午夜亚洲一区二区三区| 天堂午夜影视日韩欧美一区二区| 国产精品麻豆一区二区| 中文字幕第一页久久| 国产精品理论片| 亚洲国产高清不卡| 自拍偷拍欧美激情| 樱花草国产18久久久久| 亚洲香肠在线观看| 奇米影视在线99精品| 久久国产精品无码网站| 久久97超碰色| 懂色av中文一区二区三区| 国产精品18久久久久久久久久久久| 精品伊人久久久久7777人| 精品一区二区精品| 国产91色综合久久免费分享| 国产成a人亚洲精| 一本一道波多野结衣一区二区| 一本色道a无线码一区v| 欧美三级日韩三级国产三级| 欧美精品 国产精品| 精品国产一二三| 欧美激情在线看| 亚洲综合色自拍一区| 奇米色777欧美一区二区| 国产一区二区三区在线观看免费| 国产麻豆欧美日韩一区| 99re视频精品| 这里只有精品电影| 久久免费看少妇高潮| 一区二区三区蜜桃| 精品午夜久久福利影院| 9人人澡人人爽人人精品| 欧美日韩一卡二卡三卡| 久久精品亚洲精品国产欧美kt∨| 国产精品高潮呻吟久久| 日本女人一区二区三区| 国产91色综合久久免费分享| 欧美亚洲日本国产| 日本一区二区成人| 午夜影视日本亚洲欧洲精品| 国产精品一区二区你懂的| 色哟哟亚洲精品| 久久综合九色欧美综合狠狠| 有码一区二区三区| 国产成人日日夜夜| 欧美一区二区私人影院日本| 国产精品久久久久国产精品日日| 日韩高清一区在线|