【转自:OpenCV ——背景建模之CodeBook(1)-(2)- Mr.Easy - 博客园  http://t.cn/Ainx0SXH  http://t.cn/AinxH427】

1. CodeBook的来源

先考虑平均背景的建模方法。该方法是针对每一个像素,累积若干帧的像素值,然后计算平均值和方差,以此来建立背景模型,相当于模型的每一个像素含有两个特征值,这两个特征值只是单纯的统计量,没有记录该像素值的历史起伏,即没有考虑时间序列和噪声干扰,不具备鲁棒性,因此建模时不能有运动前景的部分,要求光线保持不变。
  如果我们考虑到时间起伏序列建模,比如利用60帧图像建模,对于每一个像素点会产生60个像素值,分别给他们加上60个相关的权值,或者进一步统计不同像素值出现的频次或者距离,以此来排除噪声,这样能够模拟复杂的背景,但是会带来巨大的内存消耗。
  如果我们对该像素值起伏的动态范围进行压缩,压缩的依据是像素值之间的大小距离,即当前观测值与历史的记录值对比,如果两个值接近,就归为一类,也就是隶属同一个码元(CodeWord),如果差别过大,就以当前观测值新建一个码元,因为背景的变化情况远小于前景,所以压缩之后我们就得到了只含有若个码元的一个编码本(CodeBook),这个编码本不仅能够模拟复杂背景,同时大大减少内存消耗。此外,对每个码元的更新频率进行监督,剔除那些频率低的(误跑进来的动态前景),不仅排除了噪声,同时也允许有移动前景的背景当做学习资料。这便是CodeBook的核心思想。
2. CodeBook的实现
  CodeBook执行前景分割主要分为三个过程,即背景建模、清除陈旧码元、前景分割,分别对应如下三个函数updateCodeBook(), clearStaleEntries(), backgroudDiff()。
2.1 结构及主要参数
  CodeBook算法为当前图像的每一个像素建立一个CodeBook(CB)结构,每个CodeBook结构又由多个码元CodeWord(CW)组成。
  CB和CW的形式如下:
  CB={CW1,CW2,…CWn,t}
  CW={learnHigh[],learnLow[],max[],min[],t_last_updata,stale}
  其中n为一个CB中所包含的CW的数目,当n太小时,退化为简单背景,当n较大时可以对复杂背景进行建模。CW是一个6元组结构,在整个算法流程中,主要包括以下参数:
  maxMod[]:用训练好的背景模型进行前景分割时的调节量,判断点是否小于max[] + maxMod[]);
  minMod[]:用训练好的背景模型进行前景分割时的调节量,判断点是否小于min[] -minMod[]);
  cbBounds[]:训练背景模型时用到,相当于控制模型的增长速率,更新learnHigh[]和learnLow[]。
  learnHigh[]:背景的学习上界限,当新像素进来时判断其是否属于该码元;
  learnLow[]:背景的学习下界限,当新像素进来时判断其是否属于该码元;
  max[]: 背景学习中不断更新,记录当前码元的最大值,在前景分割时,与MaxMod[]配合,判断像素是前景还是背景;
  min[]: 背景学习中不断更新,记录当前码元的最小值,在前景分割时,与MinMod[]配合,判断像素是前景还是背景;
  此外,为了剔除陈旧码元,给每个CB和CW都加入了若干时间标签,比如CB的t,记录CB更新的次数,CW的t_last_updata和stale,t_last_updata记录了该CW上次更新的时间,stale记录了CW的搁浅时间,stale=t-l_last_updata。
2.2 背景建模
  遍历每一个像素,假设针对某个像素I(x,y),遍历其对应的CodeBook的每一个码元,分通道检测learnHighI(x,y)learnLow?如果满足条件,则更新该码元的t_last_updata,若max<I(x,y),更新max=I(x,y), 若min>I(x,y), 更新min=I(x, y),若learnHigh<I(x,y)+cbBounds,缓慢增加学习上限learnHigh+1, 若learnLow>I(x,y)-cbBounds,降低学习下线learnLow-1。
  如果不满足条件,则创建一个新的码元,learnHign=I(x,y)+cbBounds,learnLow=I(x,y)-cbBounds, max=min=I(x,y)。
  更新所有的时间标签。
2.3 清除陈旧码元
  背景建模一段时间后,需要定期清除陈旧码元,针对每一个CodeBook,根据经验将其时间t的一半当做阈值,遍历所有码元,将与之对应的时间标签stale与阈值比较,大于阈值的则删除,阈值之内的保留,同时更新时间标签。
2.4 前景分割
  前景分割也就是利用训练好的CodeBook进行运动检测,遍历该像素对应的CodeBook的所有码元,如果其中一个码元满足当前像素I(x,y)min-minMod且I(x,y)max+maxMod,则判断该像素属于背景,如果一个条件不满足,则属于前景。

3. CodeBook算法流程介绍

CodeBook算法的基本思想是得到每个像素的时间序列模型。这种模型能很好地处理时间起伏,缺点是需要消耗大量的内存。CodeBook算法为当前图像的每一个像素建立一个CodeBook(CB)结构,每个CodeBook结构又由多个CodeWord(CW)组成。
  CB和CW的形式如下:
  CB={CW1,CW2,…CWn,t}
  CW={lHigh,lLow,max,min,t_last,stale}
  其中n为一个CB中所包含的CW的数目,当n太小时,退化为简单背景,当n较大时可以对复杂背景进行建模;t为CB更新的次数。CW是一个6元组,其中IHigh和ILow作为更新时的学习上下界,max和min记录当前像素的最大值和最小值。上次更新的时间t_last和陈旧时间stale(记录该CW多久未被访问)用来删除很少使用的CodeWord。
假设当前训练图像I中某一像素为I(x,y),该像素的CB的更新算法如下,另外记背景阈值的增长判定阈值为Bounds:
  (1) CB的访问次数加1;
  (2) 遍历CB中的每个CW,如果存在一个CW中的IHigh,ILow满足ILow≤I(x,y)≤ IHigh,则转(4);
  (3) 创建一个新的码字CWnew加入到CB中, CWnew的max与min都赋值为I(x,y), IHigh <- I(x,y) + Bounds,ILow <- I(x,y) – Bounds,并且转(6);
  (4) 更新该码字的t_last,若当前像素值I(x,y)大于该码字的max,则max <- I(x,y),若 I(x,y)小于该码字的min,则min <- I(x,y);
  (5) 更新该码字的学习上下界,以增加背景模型对于复杂背景的适应能力,具体做法是: 若IHigh < I(x,y) + Bounds,则IHigh 增长1,若ILow > I(x,y) – Bounds,则ILow 减少1;
  (6) 更新CB中每个CW的stale。
  使用已建立好的CB进行运动目标检测的方法很简单,记判断前景的范围上下界为minMod和maxMod,对于当前待检测图像上的某一像素I(x,y),遍历它对应像素背景模型CB中的每一个码字CW,若存在一个CW,使得I(x,y) < max + maxMod并且I(x,y) > min – minMod,则I(x,y)被判断为背景,否则被判断为前景。
  在实际使用CodeBook进行运动检测时,除了要隔一定的时间对CB进行更新的同时,需要对CB进行一个时间滤波,目的是去除很少被访问到的CW,其方法是访问每个CW的stale,若stale大于一个阈值(通常设置为总更新次数的一半),移除该CW。
  综上所述,CodeBook算法检测运动目标的流程如下:
  (1) 选择一帧到多帧使用更新算法建立CodeBook背景模型;
  (2) 按上面所述方法检测前景(运动目标);
  (3) 间隔一定时间使用更新算法更新CodeBook模型,并对CodeBook进行时间滤波;
  (4) 若检测继续,转(2),否则结束。

Love is everywhere.
爱无处不在。

【OpenCV】 码书(CodeBook)基本原理介绍相关推荐

  1. 【码书】一本经典且内容全面算法书籍,学算法必备

    之前推荐了好几本算法书,有<啊哈!算法>,有<算法图解>,有<漫画算法>,也有<我的第一本算法书>,很多粉丝不乐意了,觉得我推荐了这么多算法书籍,竟然没 ...

  2. Android系统源码目录及功能介绍

    Android的移植按如下流程:     1.android linux 内核的普通驱动移植,让内核可以在目标平台上运行起来.     2.正确挂载文件系统,确保内核启动参数和 android 源代码 ...

  3. 码书:编码与解码的战争 PDF 下载

    码书:编码与解码的战争 PDF 下载 下载地址:https://pan.baidu.com/s/14Y_krHh-unOv4g2KYFFDgQ 如需分享码:[打开微信]->[扫描右侧二维码]-& ...

  4. 豆瓣 9.0,评论人数过万的 9 本经典科技图书 | 码书排行榜

    三更灯火五更鸡,正是男儿读书时.而最适合学习的季节,莫过于春天这样不冷亦不热的时令! 或许,发小的优秀.同事的出色,都能成为你上进的动力. 但是,以一个会变的人事物,来作为奋斗目标,未必能让你活出最精 ...

  5. 最萌算法学习来啦,看不懂才怪!| 码书

    普通程序员,不学算法,也可以成为大神吗? 对不起,这个,绝对不可以. 可是算法好难啊~~看两页书就想睡觉-- 所以就不学了吗?就一直当普通程序员吗? 如果有一本算法书,看着很轻松--又有代码示例--又 ...

  6. Java 网络通信必备之socket通信基本原理介绍

    Java socket通信基本原理介绍 Java socket通信在不断的进行相关代码的开发,下面我们就看看如何才能更好的使用有关技术为我们的编程工作带来一定的帮助. 作者:佚名来源:互联网|2010 ...

  7. Linux内核 eBPF基础:kprobe原理源码分析:基本介绍与使用示例

    Linux内核 eBPF基础 kprobe原理源码分析:基本介绍与使用示例 荣涛 2021年5月11日 kprobe调试技术是为了便于跟踪内核函数执行状态所设计的一种轻量级内核调试技术. 利用kpro ...

  8. 这本 Kindle 排名第一的 Python 3 入门书,火遍了整个编程圈!| 码书

    "大多数优秀的程序员从事编程工作,不是因为期望获得报酬或得到公众的称赞,而是因为编程是件有趣的事儿." --林纳斯·托瓦兹(Linus Torvalds) 在美国亚马逊,有一本书的 ...

  9. OpenCV距离变换函数:distanceTransform()介绍

    OpenCV距离变换函数:distanceTransform()介绍

  10. 支付宝扫码支付模式平台介绍

    互联网在逐渐普及过程中,智能手机逐渐成为人们日常生活内主要电子设备.互联网支付在逐渐普及过程中,移动支付也逐渐出现在人们日常生活工作内,互联网支付企业也逐渐参与到线下支付行列内.第三方支付企业在为社会 ...

最新文章

  1. android中获取某段程序的执行时间
  2. linux服务端搭配win7客户端的frp
  3. linux find 权限不够,超级用户find: `/home/pipi/.gvfs': 权限不够
  4. POJ 1804 Brainman (归并排序 -- 求逆序对数)
  5. POJ 3264 Balanced Lineup 【线段树】
  6. c语言求数组中绝对值最小值,(C语言)简单的绝对值排序
  7. Java 8 Lambda表达式10个示例【存】
  8. ORA-01157报错cannot identify/lock data file
  9. android 点击屏幕 回调,Android 点击回调传递
  10. 1901005每日一句
  11. ubuntu 安装qq
  12. 程序员人生之路(强烈推荐,分析的透彻!)
  13. android毫秒数转换为时分秒,如何将毫秒转换成单独的时分秒的形式?
  14. 提升用户体验?指示性设计元素不可或缺
  15. 企业邮箱是什么?企业邮箱和个人邮箱的区别在哪里
  16. html提取excel指定单元格数据,怎样从很多的表格中提取指定单元格数据
  17. 9091端口及8998端口
  18. SpringMVC大体流程框架类图版
  19. webbench1-5源码分析
  20. 冯 诺依曼体系结构是现代计算机的基础,作为现代计算机基本结构的冯·诺依曼体系包括______。...

热门文章

  1. 在武汉火车站转车需要出现吗_武汉打造40分钟“高铁中转站” 无需出站可换乘...
  2. IP雷达4.0+网络检测
  3. Java弹球游戏,刚学Java时做的
  4. IBM P750 AIX机器根目录空间满问题解决办法
  5. matlab图片模板匹配算法,基于Matlab-图像匹配——模板匹配.docx
  6. 统计学权威盘点过去50年最重要的统计学思想,因果推理、bootstrap等上榜,Judea Pearl点赞
  7. IOC容器构造之资源文件定位源码分析
  8. 餐饮企业免费申请点餐小程序
  9. 仿蜜雪冰城点餐小程序
  10. 最常用20000英语单词表_家长最值得一看的文章如何培养孩子好的学习习惯!