一种基于特征拐点的人体高度估计方法转让专利

申请号 : CN201710178219.4

文献号 : CN107093182B

文献日 :

基本信息:

PDF:

法律信息:

相似专利:

发明人 : 戚隆宁黄海飞李罩羚王健许贺郑凯

申请人 : 东南大学

摘要 :

本发明公开了一种基于特征拐点的人体高度估计方法,主要解决传统双目视觉复杂度较高难以满足实时性的问题,首先对视频帧进行运动检测得到运动行人前景,然后对前景区域进行特征拐点检测得到头肩特征拐点,接着再根据拐点分割出行人头部计算当前头身比,比较当前帧头身比与头身比模型值,判断遮挡是否发生,若未发生遮挡,更新头身比模型值,若发生遮挡,用头身比模型值与头部高度完成人体高度估计。本发明方法通过人体头身比特征完成人体高度估计得到行人脚部位置,成本低,算法时间复杂度低,可用于智能监控、视觉定位系统等。

权利要求 :

1.一种基于特征拐点的人体高度估计方法,其特征在于,该方法包括以下步骤:(1)对视频帧进行运动检测获取运动行人的前景目标区域T;

(2)对运动行人的前景目标区域T进行特征拐点检测得到头肩特征拐点P1与P2;

(3)根据头肩特征拐点P1与P2分割出行人头部,计算当前帧头身比Rc;

(4)根据当前帧头身比Rc以及头身比模型值Rs完成人体遮挡判断,若未遮挡则更新头身比模型值Rs,若遮挡,则进行高度估计获取人体脚部位置;

其中,步骤(2)包括如下步骤:

(21)对前景区域T进行轮廓线提取得到若干轮廓线;

(22)对若干轮廓线进行检测,滤除轮廓线点个数小于预设门限TH的噪声轮廓,得到有效行人轮廓线C;

(23)以顺时针方向为轮廓线方向,对有效行人轮廓线C上的任一点Pi分别取其前后各N个点,计算Pi的轮廓走向矢量ADi,所述轮廓走向矢量ADi定义为:ADi={prePi,r,prePi,l,prePi,u,prePi,d,sufPi,r,sufPi,l,sufPi,u,sufPi,d}其中,pre表示点Pi前面的点,suf表示点Pi后面的点,Pi,rPi,lPi,uPi,d分别表示轮廓向右、左、上、下的程度;

(24)将ADi中各元素初始化为0,分别对点Pi之前的N个点以及点Pi之后的N个点进行扫描,得到Pi点的走向矢量ADi;

(25)将满足prePi,r>M1并且sufPi,u>M2的点记录为特征拐点P1;将满足prePi,d>M1并且sufPi,r>M2的点记录为特征拐点P2,M1与M2为预设阈值。

2.根据权利要求1所述的基于特征拐点的人体高度估计方法,其特征在于,步骤(24)中对点Pi之前的N个点以及点Pi之后的N个点进行扫描,指的是:(241)对于点Pi之前的某个点Pj,若该点的下一个点Pj+1在该点的右侧,则prePi,r加1;若该点的下一个点Pj+1在该点的上侧,则prePi,u加1;若该点的下一个点Pj+1在该点的下侧,则prePi,d加1;若该点的下一个点Pj+1在该点的左侧,则prePi,l加1;

(242)对于点Pi之后的某个点Pj,若该点的下一个点Pj+1在该点的右侧,则sufPi,r加1;若该点的下一个点Pj+1在该点的上侧,则sufPi,u加1;若该点的下一个点Pj+1在该点的下侧,则sufPi,d加1;若该点的下一个点Pj+1在该点的左侧,则sufPi,l加1。

3.根据权利要求1所述的基于特征拐点的人体高度估计方法,其特征在于,步骤(4)中根据当前头身比Rc以及头身比模型值Rs完成人体遮挡判断,具体如下:(41)根据头身比模型值Rs以及预设置信区间[rl,rh]计算无遮挡时头身比有效范围[Rs·rl,Rs·rh],判断当前帧头身比Rc是否在此范围中;

(42)若当前帧头身比Rc在有效范围中,则没有发生遮挡;

(43)若当前帧头身比Rc不在有效范围中,则发生遮挡。

4.根据权利要求3所述的基于特征拐点的人体高度估计方法,其特征在于,头身比模型值Rs的更新过程如下:

1)初始化头身比模型值Rs为R0,并初始化头身比模型滑动数组MoveAve_FIFO[N]={R0,R0...R0};

2)若当前帧头身比Rc未发生遮挡,更新MoveAve_FIFO及头身比模型值Rs,更新策略为:将头身比模型滑动数组MoveAve_FIFO的后N-1个数据前移一位;将当前帧Rc放入数组最后一个位置;则更新后的头身比模型值

说明书 :

一种基于特征拐点的人体高度估计方法

[0001] 所属领域
[0002] 本发明属于计算机视觉技术领域,具体涉及一种基于特征拐点的人体高度估计方法,可用于智能交通系统、智能监控系统以及视觉定位系统。

背景技术

[0003] 随着计算机视觉的发展和应用,室内行人视觉定位技术迅速兴起并得到广泛关注。在单目视觉下,通过运动检测得到运动行人前景,通过摄像机标定可以得到摄像机内参数以及标定板所处的地平面外参数,根据前两部分结果可以完成行人定位。由于单目视觉无法获取深度信息,主流的单目定位方法是对行人的脚部进行检测定位。在行人下半身被遮挡的情况下,行人脚部所处的位置无法得到,对定位带来困难。传统的解决办法是通过双目视觉获取运动行人深度信息完成定位。但双目视觉存在一些问题:1)相比于单目视觉,成本较高;2)双目的计算量较大,对于计算单元的性能要求较高,对于实时性的要求是个挑战;3)双目的立体匹配一直是立体视觉中最困难的一步,它易受光学噪声、平滑表面镜面反射、透视失真、投影缩减、重复纹理、低纹理等因素的影响,使得匹配结果变差。

发明内容

[0004] 发明目的:在于针对上述已有技术中的问题,提出一种基于特征拐点的人体高度估计方法,能够在低成本、低运算性能要求的前提下,解决因遮挡带来的定位困难问题,提高定位精度。
[0005] 技术方案:为实现上述目的,本发明中一种基于特征拐点的人体高度估计方法,包括以下步骤:
[0006] (1)对视频帧进行运动检测获取运动行人的前景目标区域T;
[0007] (2)对运动行人的前景目标区域T进行特征拐点检测得到头肩特征拐点P1与P2[0008] (3)根据头肩特征拐点P1与P2分割出行人头部,计算当前头身比Rc;
[0009] (4)根据当前帧头身比Rc以及头身比模型值Rs完成人体遮挡判断,若未遮挡则更新头身比模型值Rs,若遮挡,则进行高度估计获取人体脚步位置。
[0010] 其中,步骤(2)中所述特征拐点检测包括如下步骤:
[0011] (21)对前景区域T进行轮廓线提取得到若干轮廓线;
[0012] (22)对若干轮廓线进行检测,滤除轮廓线点个数小于预设门限TH的噪声轮廓,得到有效行人轮廓C;
[0013] (23)以顺时针方向为轮廓线方向,对有效行人轮廓线C上的任一点Pi分别取其前后各N个点,计算Pi的轮廓走向矢量ADi,所述轮廓走向矢量ADi定义为:
[0014] ADi={prePi,r,prePi,l,prePi,u,prePi,d,sufPi,r,sufPi,l,sufPi,u,sufPi,d}[0015] 其中,pre表示点Pi前面的点,suf表示点Pi后面的点,Pi,r Pi,l Pi,u Pi,d分别表示轮廓向右、左、上、下的程度;
[0016] (24)将ADi中各元素初始化为0,分别对点Pi之前的N个点以及点Pi之后的N个点进行扫描,得到Pi点的走向矢量ADi;
[0017] (25)将满足prePi,r>M1并且sufPi,u>M2的点记录为特征拐点P1;将满足prePi,d>M1并且sufPi,r>M2的点记录为特征拐点P2,M1与M2为预设阈值。
[0018] 具体地,步骤(24)中对点Pi之前的N个点以及点Pi之后的N个点进行扫描,指的是:
[0019] (241)对于点Pi之前的某个点Pj,若该点的下一个点Pj+1在该点的右侧,则prePi,r加1;若该点的下一个点Pj+1在该点的上侧,则prePi,u加1;若该点的下一个点Pj+1在该点的下侧,则prePi,d加1;若该点的下一个点Pj+1在该点的左侧则prePi,l加1;
[0020] (242)对于点Pi之后的某个点Pj,若该点的下一个点Pj+1在该点的右侧,则sufPi,r加1;若该点的下一个点Pj+1在该点的上侧,则sufPi,u加1;若该点的下一个点Pj+1在该点的下侧,则sufPi,d加1;若该点的下一个点Pj+1在该点的左侧,则sufPi,l加1。
[0021] 具体地,步骤(4)中根据当前头身比Rc以及头身比模型值Rs完成人体遮挡判断,具体如下:
[0022] (41)根据头身比模型值Rs以及预设置信区间[rl,rh]计算无遮挡时头身比有效范围[Rs·rl,Rs·rh],判断当前帧头身比Rc是否在此范围中;
[0023] (42)若当前帧头身比Rc在有效范围中,则没有发生遮挡;
[0024] (43)若当前帧头身比Rc不在有效范围中,则发生遮挡。
[0025] 有益效果:本发明中基于特征拐点的人体高度估计方法,通过运动检测得到行人的前景区域,根据检测到的两个特征拐点分割行人头部,通过行人未被遮挡时构建的头身比模型以及分割出的头部高度对人体高度进行估计,完成人体脚部位置的估计,从而实现遮挡情况下的定位。本发明方法在实现时只需要采用单目摄像头,成本低,算法时间复杂度低,避免了传统双目视觉的问题,并能使结果维持在较高的精度。

附图说明

[0026] 图1是头肩特征拐点以及头身比定义示意图;
[0027] 图2是本发明中基于特征拐点的人体高度估计方法的流程图;
[0028] 图3是轮廓走向矢量计算模板;
[0029] 图4是本发明方法拐点检测效果对比图,(a)是运动行人的前景目标区域,图4(b)为图4(a)的拐点检测效果图;
[0030] 图5是轮廓走向矢量计算示意图,图5(a)是人体轮廓片段图,图5(b)是对轮廓片中的点1进行扫描示意图,图5(c)是对轮廓片中的点2进行扫描示意图,图5(d)是对轮廓片中的点3进行扫描示意图。

具体实施方式

[0031] 下面结合实施例对本发明作更进一步的说明。
[0032] 如图1所示,本发明中的两类特征拐点P1、P2,分别位于人头与一侧肩膀之间,P1反映轮廓先向右,后向上的走向,P2反映轮廓先向下,后向右的走向。定义头身比为h1/h2,h1为头顶至肩膀的距离,h2为头顶至脚的距离。
[0033] 如图2所示,本发明中基于特征拐点的人体高度估计方法,对于每一时刻的视频数据进行处理,包括以下步骤:
[0034] (1)对视频帧进行运动检测获取运动行人的前景目标区域T;
[0035] (2)对运动行人的前景目标区域T进行特征拐点检测得到头肩特征拐点P1与P2;
[0036] (3)根据头肩特征拐点P1与P2分割出行人头部,计算当前帧头身比Rc;
[0037] (4)根据当前帧头身比Rc以及头身比模型值Rs完成人体遮挡判断,若未遮挡则可以直接获取到人体脚步位置,不需要进行高度估计,此时更新头身比模型值Rs,若遮挡,则进行高度估计获取人体脚步位置。
[0038] 利用上述步骤对运动行人的高度进行估计后,便可根据人头坐标和所估计的高度估计出人体脚部位置,实现定位;对每个视频帧进行上述处理后,便可获取到运动行人的行进轨迹。
[0039] 上述步骤(2)中,特征拐点检测具体包括如下步骤:
[0040] (21)对前景区域T进行轮廓线提取得到若干轮廓线;
[0041] (22)对若干轮廓线进行检测,滤除轮廓线点个数小于预设门限TH(TH>>10)的噪声轮廓,得到有效行人轮廓C;
[0042] (23)规定顺时针方向为轮廓线方向,对轮廓线C上的任一点Pi分别取其前后各N(N=10)点,按图3所示的模板计算Pi的轮廓走向矢量ADi,该模板中以Pj(i-N≤j<i+N)为中心,按轮廓线方向检测点Pj下一个点Pj+1的位置,数字0至7代表的是点Pj+1可能出现的位置,如1代表的是Pj+1在Pi的右侧,3代表的是Pj+1在Pi的下侧,5代表的是Pj+1在Pi的左侧,7代表的是Pj+1在Pi的上侧。
[0043] 轮廓走向矢量ADi定义为:
[0044] ADi={prePi,r,prePi,l,prePi,u,prePi,d,sufPi,r,sufPi,l,sufPi,u,sufPi,d}[0045] pre表示前面的点,suf表示后面的点,Pi,r Pi,l Pi,u Pi,d分别表示轮廓向右、左、上、下的程度;
[0046] (24)将ADi中各元素初始化为0,分别对点Pi之前的N个点以及点Pi之后N个的点进行扫描,得到Pi点的走向矢量ADi;具体如下:
[0047] (241)对点Pj(i-10≤j≤i-1),重复以下步骤:
[0048] 将点Pj(i-10≤j≤i-1)作为图3表格的中心,点Pj的下一个点Pj+1如果在位置1,则prePi,r加1,如果在位置7,则prePi,u加1,在位置3,则prePi,d加1,在位置5,则prePi,l加1,其他位置则不变。
[0049] (242)对点Pj(i≤j≤i+9),重复以下步骤:
[0050] 将点Pj(i≤j≤i+9)作为图3表格的中心,点Pj的下一个点Pj+1如果在位置1,则sufPi,r加1,如果在位置7,则sufPi,u加1,在位置3,则sufPi,d加1,在位置5,则sufPi,l加1,其他位置则不变。
[0051] (25)对轮廓线C上所有点的ADi进行遍历,将满足prePi,r>M1并且sufPi,u>M2的点记录为第一类拐点;将满足prePi,d>M1并且sufPi,r>M2的点记录为第二类拐点,M1与M2为预设阈值,实际检测效果如图4(b)所示,左侧白点为第一类拐点P1,右侧白点为第二类拐点P2。
[0052] 为了进一步清楚地解释步骤4),以图5(a)所示的行人轮廓片段为例,设N=5,计算轮廓片段中的轮廓点6的走向矢量AD6,过程如下:
[0053] 1)将AD6中各元素初始化为0,则:
[0054] AD6={0,0,0,0,0,0,0,0}
[0055] 2)第一步,先对轮廓点6之前的5个点中的轮廓点1进行扫描,按照图3走向矢量计算模板计算AD6,如图5(b)所示,此时轮廓点1的下一个轮廓点2在矢量模板位置2,所以AD6不变;
[0056] 3)扫描轮廓点2,按照图3走向矢量计算模板计算AD6,如图5(c)所示,此时轮廓点2的下一个轮廓点3在矢量模板位置3,则AD6的preP6,d加1变为:
[0057] AD6={0,0,0,1,0,0,0,0}
[0058] 4)扫描轮廓点3,按照图3走向矢量计算模板计算AD6,如图5(d)所示,此时轮廓点3的下一个轮廓点4在矢量模板位置3,则AD6的preP6,d加1变为:
[0059] AD6={0,0,0,2,0,0,0,0}
[0060] 5)依次扫描轮廓点6之前的5个点中剩下的轮廓点4-5,得到AD6为:
[0061] AD6={0,0,0,3,0,0,0,0}
[0062] 6)第二步,对轮廓点6及轮廓点6之后的5个轮廓点6-10按照类似于2)3)4)5)中的扫描方式进行扫描,得到最终的AD6为:
[0063] AD6={0,0,0,3,5,0,0,0}。
[0064] 上述步骤(3)中,根据特征拐点分割头部以及头身比Rc计算具体包括如下步骤:
[0065] (31)依据图1坐标系定义读取特征拐点坐标P1(u1,v1)与P2(u2,v2),头顶坐标Ph(uh,vh),及检测到的人体前景区域底部坐标Pf(uf,vf);
[0066] (32)计算头部分割线
[0067] (33)计算当前帧头身比
[0068] 上述步骤(4)中根据当前帧头身比Rc以及头身比模型值Rs完成人体遮挡判断及高度估计,具体如下:
[0069] (41)根据头身比模型值Rs以及预设置信区间[rl,rh]计算无遮挡时头身比有效范围[Rs·rl,Rs·rh],判断Rc是否在此范围中;
[0070] (42)若Rc在有效范围中,则此时没有发生遮挡,用Rc更新数据库中的头身比模型Rs;
[0071] (43)若Rc不在有效范围中,则此时发生遮挡,根据此时的Rs以及P1与P2分割出的头部高度估计人体高度,即得到人体脚部位置。
[0072] 其中,头身比模型值Rs的更新过程如下:
[0073] 1)初始化头身比模型值Rs为R0(头身比R0大约为1/7),并初始化头身比模型滑动数组MoveAve_FIFO[N]={R0,R0...R0}(N为滑动数组大小,N一般取10);
[0074] 2)根据当前帧头身比Rc进行行人遮挡判断,若发生遮挡,根据Rs完成人体高度估计,若未发生遮挡,更新MoveAve_FIFO及Rs值,更新策略具体为:
[0075] 21)将MoveAve_FIFO的后N-1个数据前移一位;
[0076] 22)将当前帧Rc放入数组最后一个位置;
[0077] 23)则更新的头身比模型值