opencv码本(codebook)背景模型_第1页
opencv码本(codebook)背景模型_第2页
opencv码本(codebook)背景模型_第3页
opencv码本(codebook)背景模型_第4页
opencv码本(codebook)背景模型_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

/结构体定义 typedef struct CvBGCodeBookElem struct CvBGCodeBookElem* next; int tLastUpdate; int stale; uchar boxMin3; uchar boxMax3; uchar learnMin3; uchar learnMax3; CvBGCodeBookElem; typedef struct CvBGCodeBookModel CvSize size; int t; uchar cbBounds3; uchar modMin3; uchar modMax3; CvBGCodeBookElem* cbmap; CvMemStorage* storage; CvBGCodeBookElem* freeList; CvBGCodeBookModel; CvBGCodeBookModel* cvCreateBGCodeBookModel() CvBGCodeBookModel* model = (CvBGCodeBookModel*)cvAlloc( sizeof(*model) ); memset( model, 0, sizeof(*model) ); model-cbBounds0 = model-cbBounds1 = model-cbBounds2 = 10; model-modMin0 = 3; model-modMax0 = 10; model-modMin1 = model-modMin2 = 1; model-modMax1 = model-modMax2 = 1; model-storage = cvCreateMemStorage(); return model; void cvReleaseBGCodeBookModel( CvBGCodeBookModel* model ) if( model memset( *model, 0, sizeof(*model) ); cvFree( model ); static uchar satTab8u768; #undef SAT_8U #define SAT_8U(x) satTab8u(x) + 255 static void icvInitSatTab() static int initialized = 0; if( !initialized ) for( int i = 0; i 255 ? 255 : v); initialized = 1; void cvBGCodeBookUpdate( CvBGCodeBookModel* model,const CvArr* _image, CvRect roi=cvRect(0,0,0,0), const CvArr* _mask=0 ) CV_FUNCNAME( “cvBGCodeBookUpdate“ ); _BEGIN_; CvMat stub, *image = cvGetMat( _image, CvMat mstub, *mask = _mask ? cvGetMat( _mask, int i, x, y, T; int nblocks; uchar cb0, cb1, cb2; CvBGCodeBookElem* freeList; CV_ASSERT( model if( roi.x = 0 roi.height = image-rows; else CV_ASSERT( (unsigned)roi.x cols if( image-cols != model-size.width | image-rows != model-size.height ) cvClearMemStorage( model-storage ); model-freeList = 0; cvFree( int bufSz = image-cols*image-rows*sizeof(model-cbmap0); model-cbmap = (CvBGCodeBookElem*)cvAlloc(bufSz); memset( model-cbmap, 0, bufSz ); model-size = cvSize(image-cols, image-rows); icvInitSatTab(); cb0 = model-cbBounds0; cb1 = model-cbBounds1; cb2 = model-cbBounds2; T = +model-t; freeList = model-freeList; nblocks = (int)(model-storage-block_size - sizeof(CvMemBlock)/sizeof(*freeList); nblocks = MIN( nblocks, 1024 ); CV_ASSERT( nblocks 0 ); for( y = 0; y data.ptr + image-step*(y + roi.y) + roi.x*3; const uchar* m = mask ? mask-data.ptr + mask-step*(y + roi.y) + roi.x : 0; CvBGCodeBookElem* cb = model-cbmap + image-cols*(y + roi.y) + roi.x; for( x = 0; x next ) if( e-learnMin0 learnMax0 color=#FF0000/此处修改 */color (e-stale)+; e-boxMin0 = MIN(e-boxMin0, p0); e-boxMax0 = MAX(e-boxMax0, p0); e-boxMin1 = MIN(e-boxMin1, p1); e-boxMax1 = MAX(e-boxMax1, p1); e-boxMin2 = MIN(e-boxMin2, p2); e-boxMax2 = MAX(e-boxMax2, p2); / no need to use SAT_8U for updated learnMini if( e-learnMax0 learnMax0+; if( e-learnMin1 l1 ) e-learnMin1-; if( e-learnMax1 learnMax1+; if( e-learnMin2 l2 ) e-learnMin2-; if( e-learnMax2 learnMax2+; found = e; break; /negRun = T - e-tLastUpdate;color=#FF0000/此处修改 *8/color / e-stale = MAX( e-stale, negRun ); /*for( ; e != 0; e = e-next )color=#FF0000/此处修改 * */color negRun = T - e-tLastUpdate; e-stale = MAX( e-stale, negRun ); */ if( !found ) if( !freeList ) freeList = (CvBGCodeBookElem*)cvMemStorageAlloc(model-storage, nblocks*sizeof(*freeList); for( i = 0; i next; e-learnMin0 = l0; e-learnMax0 = h0; e-learnMin1 = l1; e-learnMax1 = h1; e-learnMin2 = l2; e-learnMax2 = h2; e-boxMin0 = e-boxMax0 = p0; e-boxMin1 = e-boxMax1 = p1; e-boxMin2 = e-boxMax2 = p2; /e-tLastUpdate = T; e-stale=1;color=#FF0000/此处修改 * /color e-stale = 0; e-next = *cb; *cb = e; model-freeList = freeList; _END_; int cvBGCodeBookDiff( const CvBGCodeBookModel* model, const CvArr* _image, CvArr* _fgmask, CvRect roi=cvRect(0,0,0,0) int maskCount = -1; CV_FUNCNAME( “cvBGCodeBookDiff“ ); _BEGIN_; CvMat stub, *image = cvGetMat( _image, CvMat mstub, *mask = cvGetMat( _fgmask, int x, y; uchar m0,m1,m2,M0,M1,M2; CV_ASSERT( model if( roi.x = 0 roi.height = image-rows; else CV_ASSERT( (unsigned)roi.x cols m0 = model-modMin0; M0 = model-modMax0; m1 = model-modMin1; M1 = model-modMax1; m2 = model-modMin2; M2 = model-modMax2; maskCount = roi.height*roi.width; for( y = 0; y data.ptr + image-step*(y + roi.y) + roi.x*3; uchar* m = mask-data.ptr + mask-step*(y + roi.y) + roi.x; CvBGCodeBookElem* cb = model-cbmap + image-cols*(y + roi.y) + roi.x; for( x = 0; x next ) if( e-boxMin0 boxMax0 maskCount-; break; _END_; return maskCount; void cvBGCodeBookClearStale( CvBGCodeBookModel* model, int staleThresh, CvRect roi=cvRect(0,0,0,0), const CvArr* _mask=0 ) CV_FUNCNAME( “cvBGCodeBookClearStale“ ); _BEGIN_; CvMat mstub, *mask = _mask ? cvGetMat( _mask, int x, y, T; CvBGCodeBookElem* freeList; CV_ASSERT( model if( roi.x = 0 roi.height = model-size.height; else CV_ASSERT( (unsigned)roi.x cols icvInitSatTab(); freeList = model-freeList; T = model-t; for( y = 0; y data.ptr + mask-step*(y + roi.y) + roi.x : 0; CvBGCodeBookElem* cb =

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论