CN1240025C - 基于视频内容的视频编码方法 - Google Patents
基于视频内容的视频编码方法 Download PDFInfo
- Publication number
- CN1240025C CN1240025C CN 03122943 CN03122943A CN1240025C CN 1240025 C CN1240025 C CN 1240025C CN 03122943 CN03122943 CN 03122943 CN 03122943 A CN03122943 A CN 03122943A CN 1240025 C CN1240025 C CN 1240025C
- Authority
- CN
- China
- Prior art keywords
- video
- coding
- macro block
- motion vector
- circle filtering
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
Abstract
一种基于视频内容的视频编码方法,涉及数字视频编码技术领域。该方法是将经摄像机、视频采集卡后得到的视频数据流输入计算机,视频数据流在计算机中依次进行变换和量化,再经过视频处理子程序后回馈到输入部分,继续参与变换和量化,之后做熵编码,最后输出编码好的视频数据流。所述的视频处理子程序主要是对视频进行运动补偿与预测;其中的环滤波子程序是在JVT视频编码技术的基础上,将图像编码的QP值,相邻宏块之间的相关系数,相邻像素之间的像素差值,宏块的运动向量均值这四个影响因子输入到环滤波中,并将这四个影响因子通过加权平均,添加到插值滤波函数中。该方法很好地消除了由于分块变化编码带来的块效应,达到了很高的编码效率和效果。
Description
技术领域:
本发明涉及计算机数字视频编码技术领域,针对的是视频编码系统。
背景技术:
现有的视频图像,在经过传输之前,需要先对视频举行压缩编码,然后才可以进行传输。视频编码技术的好坏将直接影响解码后的视频效果。目前,国内外有关视频编码的大多数技术方案,都是基于MPEG4或者H.26L标准的。其中JVT(该组织是由ITU-T和ISO/IEC JTC1这两个国际标准化组织联合形成的一个音视频标准化组织)出具的视频编码标准则是目前国内外十分流行的一种编码标准技术。
在JVT所提供的视频编码技术中,有关环滤波技术是如下描述的:采用经过统计得到的环滤波插值函数,所有的插值系数都是固定不变的,没有和不同的视频内容建立相互影响关系。这种技术中所有使用的插值滤波函数都是经过对视频内容的统计而得到的。该技术的最大缺点就是不考虑视频内容的特征,无法充分利用视频内容对象之间的相互关系。这将导致不同内容的视频有不同的压缩效果。
发明内容:
本发明的主要目的在于提供一种基于视频内容的可适应性环滤波方案。
本发明是在现有JVT提供的编码标准6.0版本的基础上,主要改动了环滤波的一些方法和编码流程。其具体创新点在于针对不同视频内容,考虑了视频内容之间的相互联系和相互影响,添加了四个影响因子,并将这四个影响因子通过加权平均,添加到插值滤波函数中。具体来说,方案中包括了下列技术内容:
1、相邻宏块之间的相关性:相关性的衡量采用数理统计中的传统方法,即为相关系数的计算。本发明采用的宏块计算,一般来说按照变换的模块大小,分为4×4的模块和8×8的模块。计算得到的相邻宏块之间的相关系数以后,将该系数取对数添加到插值滤波函数中。
2、宏块的运动向量信息:运动向量的大小直接影响了环滤波的效果。本发明对宏块的运动向量采用均值和差值两种处理办法。如果相邻宏块的运动向量差值为零,则说明没有块效应,应该取消环滤波。否则就应该做环滤波。而且,如果运动向量的均值比较大,则说明图像运动比较剧烈,应该加大环滤波的强度。否则应该相应减小。
3、相邻像素之间的像素差值:相邻像素之间,如果像素差值很小,则说明相关性比较大,所以在插值滤波函数中应该担当比较重要的决策因素。反之,则该像素的影响力度要有所减轻。
4、宏块的量化值(QP)信息:QP值最终决定了环滤波的作用与效果。一般来说,QP值越大,则分块编码所产生的块效应就越大。对宏块所使用的QP值取对数,所得到的数值添加到插值滤波函数中。
对于插值滤波函数,应该综合考虑这四个影响因子。将这四个影响因子进行加权累加,得到一个综合的滤波系数因子。
本发明的技术方案如图2-图5所示。这种基于视频内容的视频编码方法,是通过视频摄像机得到原始视频流作为输入,通过视频采集卡后变成视频数据流进入计算机,并采用JVT提供的6.0版本的视频编码技术,由计算机进行处理与运算,其方法步骤为:计算机系统接受采集卡处理好的原始视频流,经过变换和量化后,并通过视频处理子程序后所得到的数据流再回馈到输入部分,主要做编码校正,继续参与变换和量化,然后做熵编码,最后输出编码好的视频数据流,本发明的特征在于,所述的视频处理子程序主要是对视频进行运动补偿与预测,其方法步骤为:
对视频依次做新的反量化、反变换处理后,进入环滤波子程序,然后存储处理后的视频帧,对视频帧做运动补偿和运动估计,运动补偿所得到的结果用来辅助编码,反馈回环滤波子程序中,最后作运动估计,得到的数据作为子系统的输出;
前述的环滤波子程序中是在JVT视频编码技术的环滤波中,将图像编码的QP值,相邻宏块之间的相关系数,相邻像素之间的像素差值,宏块的运动向量均值这四个影响因子输入到环滤波中,作为插值系数,这四个影响因子经过优化组合进行滤波。其环滤波子程序的依次方法步骤如下:
1)测定当前编码宏块和相邻宏块之间的运动向量的差值,如果插值为零,则不做环滤波,退出环滤波子程序;如果差值不为零,则进行下一步;
2)测定相邻宏块之间的相关性,如果计算得到的相关性大,说明宏块之间有很大的关系,应该加强其影响力度,采用较强的滤波系数;反之,如果计算得到的相关性小,就采用较弱的滤波系数;
3)测定相邻宏块之间的像素差值,如果像素差值小,说明宏块之间有很大的关系,应该加强其影响力度,采用较强的滤波系数;反之,如果像素差值大,采用较弱的滤波系数;
4)测定当前编码宏块的量化值(QP),如果量化值大,则采用较强的滤波系数,反之,采用较弱的滤波系数;
5)测定宏块的运动向量均值,如果运动向量均值大,则采用较强的滤波系数,反之,采用较弱的滤波系数;
6)最后,对宏块的边界强度进行判定,边界强度越大,则滤波系数越强,如果边界强度为0,则不做环滤波
基于视频内容的视频编码方法中所述的环滤波子程序中、作为插值系数输入到环滤波中的四个影响因子的取得分别为:
宏块图像编码的QP值主要对当前编码的宏块的QP值作指数处理,得到的幂指数作为影响因子,这里的QP值是指宏块的量化参数值,主要作用是决定了对当前视频数据流作量化的单位长度。
相邻宏块之间的相关系数通过下述公式进行计算:
其中,
这里P,Q分别代表两个相邻的宏块Pi和Qi则分别代表宏块内的像素点;相邻宏块之间的像素差值,利用像素平均差值计算:
宏块的运动向量均值,则在当前编码的宏块内,计算所有像素的运动向量均值:
这里的H和W分别代表了当前宏块的高度和宽度;MotionVector[x][i][j]代表了(i,j)点的运动向量,当x=0的时候,表示X轴方向的运动向量分量;当x=1的时候,表示Y轴方向的运动向量分量。
本发明可以很好地消除由于分块变化编码所带来的块效应,以达到很高的编码效率以及更好的编码效果。
附图说明:
图1:系统框图;
图2:计算机编码流程图;
图3:视频处理子程序流程图;
图4:环滤波原理框图;
图5:环滤波子程序流程图;
具体实施方式:
根据图1-图5配置本发明的实施例。本发明中计算机为奔腾2以上CPU,10G以上硬盘,具有一般图像处理能力的普通台式微机。采用现有的JVT提供的编码标准6.0版本,对环滤波这一环节的程序进行完全替换。这里添加了四个影响因子的计算函数,以及修改过后的插值滤波函数。
具体实施方案为:
1、相邻像素的像素值差值区别方案:
视频图像的每一个宏块在做环滤波的时候,对相邻4个像素点作插值。具体位置关系如图所示:
图中P0,P1,P2,P3,Q0,Q1,Q2,Q3表示8个像素位置。他们的插值方案所使用的系数和通道位移都采用了固定系数。
实际上,像素之间的像素值对滤波效果有一定的影响作用。所以,本文提出的环滤波编码方案考虑了相邻像素之间的关系,对所要计算的八个像素点的相邻像素作差,取绝对值,然后取这四个的平均值,用作通道位移变量。具体如下:
这里P,Q分别代表两个相邻的宏块Pi和Qi则分别代表宏块内的像素点。由于相邻像素之间的差距在一般情况下比较小,所以相邻宏块之间的像素差值将直接用于通道位移的可变量。
2、相邻宏块之间的相关性考虑方案:
基于内容的环滤波编码方案,必然应该考虑相邻宏块之间的相关性。因为如果相邻宏块之间的相关性很大,则对滤波效果应该有很大的不同。所以,在插值方案中添加相邻宏块的相关性参数。具体如下:
其中,
这里P,Q分别代表两个相邻的宏块Pi和Qi则分别代表宏块内的像素点。由于一般情况下相关系数值比较大,为了不影响插值滤波的实际效果,对计算得到的相关系数值作归一化处理,归一化的参数值经过统计得到。关于相关系数值的具体应用,将在后面做统一的阐述。
3、运动向量的分级滤波方案:
经过对视频序列的统计分析,发现运动比较剧烈的视频对以上处理结果有不同的滤波效果。因此对视频内容的运动剧烈程度作划分,将有效提高上面的滤波系数改良效果。对当前帧的运动向量,对当前帧的所有运动向量求平均值。所得到的运动向量均值。
这里的H和W分别代表了当前宏块的高度和宽度;MotionVector[x][i][j]代表了(i,j)点的运动向量,当x=0的时候,表示X轴方向的运动向量分量;当x=1的时候,表示Y轴方向的运动向量分量。
但是运动向量均值相对于前面所提到的相关值来说,数值很大,所以也需要以相关系数值为基准作归一化。在做归一化之前,先对运动向量均值取2的幂指数,所得到的数值再做归一化。
4、对量化值QP的综合考虑方案:
众所周知,环滤波效果与量化值QP有很大关系,所以环滤波方案中很有必要将QP值的影响因素考虑在内。同理,由于QP值相对于前面所提到的相关值来说,数值也很大,所以也需要以相关系数correlation为基准作归一化。这里,改进办法与运动平均向量相同。
5、综述:
综合以上四种因素的考虑,实际改进细节如下:
首先,针对不同的视频序列,按条件组合以上四种因素,具体如下:(其中,下面的运动向量frm_mv和量化值frm_qp都是经过2的幂次处理)
当frm_mv>12时:
当frm_mv≥10时:
当frm_mv<10时
以上是对相关系数作综合考虑后的结果,试验表明,利用该相关系数可以有效提高数字视频的编码效率。具体试验数据与比较结果参见本文附后的试验数据表格。
至于在具体滤波方案中,有如下改进:
(1)当边界强度为4的时候:
首先,改变判断条件:
如果宏块之间的像差值>1,那么判断标准为:
|p0-q0<((a>>((correlation×2+frm_qp+dis tan ce)>>dis tan ce))+frm_qp);这里α代表了像素阀值,correlation代表了宏块之间的相关系数,distance代表宏块之间的像素差值;(以下公式的符号表示含义与此相同)
否则 判断标准为|p0-q0|<((α>>(distan ce+frm_qp));
如果满足以上判断标准,则象素值相应修改为:
p0=(p2+2×p1+2×p0+2×q0+q1+frm+qp)>>3;
p1=(p2+p1+p0+q0+correlation)>>2;
p2=(2×p3+3×p2+p1+p0+q0+frm+qp)>>3;
如果不满足以上判断条件,则像素值相应修改为:
p0=(2×p1+p0+q1+correlation)>>2;
以上的>>表示右移位操作,<<表示左移位操作
至于q0,q1,q2,q3,则同样按照以上规则进行处理。
(2)边界强度小于4的时候:
改变差异度衡量标准:
=Clip3(-C,C,(((q0-p0)×4+(p1-q1)+((frm_qp×2+dis tan ce+correlation)÷2))÷8));
这里的代表衡量计算得到的值,C表示最大阀值,-C表示最小阀值。
Clip3(-C,C,value)表示:对V值限定上下限(-C,C)。V表示上面计算得到的值。若满足该衡量标准,则象素值做下列相应修改:
由于以上的计算公式计算复杂度较高,所以在方案实现中,所有的除法和乘法全部采用对数据作移位操作,这样计算效果相同,同时保证了整个方案的计算复杂度基本没有增加。
本实施例的实验效果显著,可以有效提高数字视频的编码效率,具体实验效果数据如下:
第一个测试视频序列的测试结果:(帧率:30Hz,20帧,176*144)
QP=20 | QP=28 | QP=34 | QP=40 | |||||
信噪比 | 比特率 | 信噪比 | 比特率 | 信噪比 | 比特率 | 信噪比 | 比特率 | |
现有方案 | 42.01 | 577.46 | 36.34 | 225.52 | 32.46 | 114.23 | 28.44 | 57.23 |
改进方案 | 41.99 | 578.04 | 36.38 | 225.12 | 32.52 | 114.82 | 28.53 | 57.82 |
第二个视频序列的测试结果:(帧率:30Hz,20帧,176*144)
QP=20 | QP=28 | QP=34 | QP=40 | |||||
信噪比 | 比特率 | 信噪比 | 比特率 | 信噪比 | 比特率 | 信噪比 | 比特率 | |
现有方案 | 42.82 | 333.98 | 36.95 | 139.96 | 32.59 | 70.44 | 28.42 | 35.28 |
改进方案 | 42.77 | 334.40 | 36.93 | 138.05 | 32.49 | 71.60 | 28.33 | 35.36 |
Claims (2)
1、一种基于视频内容的视频编码方法,是通过视频摄像机得到原始视频流作为输入,通过视频采集卡后变成视频数据流进入计算机,并采用JVT提供的6.0版本的视频编码技术,由计算机进行处理与运算,其方法步骤为:计算机系统接受采集卡处理好的原始视频流,经过变换和量化后,并通过视频处理子程序后所得到的数据流再回馈到输入部分,主要做编码校正,继续参与变换和量化,然后做熵编码,最后输出编码好的视频数据流,本发明的特征在于,所述的视频处理子程序主要是对视频进行运动补偿与预测,其方法步骤为:
对视频依次做新的反量化、反变换处理后,进入环滤波子程序,然后存储处理后的视频帧,对视频帧做运动补偿和运动估计,运动补偿所得到的结果用来辅助编码,反馈回环滤波子程序中,最后作运动估计,得到的数据作为子系统的输出;
前述的环滤波子程序中是在JVT视频编码技术的环滤波中,将图像编码的量化值QP,相邻宏块之间的相关系数,相邻像素之间的像素差值,宏块的运动向量均值这四个影响因子输入到环滤波中,作为插值系数,其环滤波子程序的依次方法步骤如下:
1)测定当前编码宏块和相邻宏块之间的运动向量的差值,如果差值为零,则不做环滤波,退出环滤波子程序;如果差值不为零,则进行下一步;
2)测定相邻宏块之间的相关性,如果计算得到的相关性大,说明宏块之间有很大的关系,应该加强其影响力度,采用较强的滤波系数;反之,如果计算得到的相关性小,就采用较弱的滤波系数;
3)测定相邻宏块之间的像素差值,如果像素差值小,说明宏块之间有很大的关系,应该加强其影响力度,采用较强的滤波系数;反之,如果像素差值大,采用较弱的滤波系数;
4)测定当前编码宏块的量化值QP,如果量化值大,则采用较强的滤波系数,反之,采用较弱的滤波系数;
5)测定宏块的运动向量均值,如果运动向量均值大,则采用较强的滤波系数,反之,采用较弱的滤波系数;
6)最后,对宏块的边界强度进行判定,边界强度越大,则滤波系数越强,如果边界强度为0,则不做环滤波。
2、根据权利要求1所述的基于视频内容的视频编码方法,其特征在于,所述的环滤波子程序中、作为插值系数输入到环滤波中的四个影响因子的取得分别为:
宏块图像编码的量化值QP主要对当前编码的宏块的量化值QP作指数处理,得到的幂指数作为影响因子;这里的量化值QP是指宏块的量化参数值,主要作用是决定了对当前视频数据流作量化的单位长度;
相邻宏块之间的相关系数通过下述公式进行计算:
其中,
这里P,Q分别代表两个相邻的宏块,Pi和Qi则分别代表宏块内的像素点;相邻宏块之间的像素差值,利用像素平均差值计算:
宏块的运动向量均值,则在当前编码的宏块内,计算所有像素的运动向量均值:
这里的H和W分别代表了当前宏块的高度和宽度;MotionVector[x][i][j]代表了(i,j)点的运动向量,这里的(i,j)点是指当前编码图像帧的像素点,其中i为横坐标值,j为纵坐标值;当x=0的时候,表示X轴方向的运动向量分量;当x=1的时候,表示Y轴方向的运动向量分量。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 03122943 CN1240025C (zh) | 2003-04-25 | 2003-04-25 | 基于视频内容的视频编码方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 03122943 CN1240025C (zh) | 2003-04-25 | 2003-04-25 | 基于视频内容的视频编码方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN1450497A CN1450497A (zh) | 2003-10-22 |
CN1240025C true CN1240025C (zh) | 2006-02-01 |
Family
ID=28684416
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN 03122943 Expired - Fee Related CN1240025C (zh) | 2003-04-25 | 2003-04-25 | 基于视频内容的视频编码方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN1240025C (zh) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
BRPI0706362B1 (pt) * | 2006-01-09 | 2019-10-01 | Interdigital Madison Patent Holdings | Método e aparelho para proporcionar modo de atualização de resolução reduzida para codificação de vídeo multivisão |
WO2007104266A1 (en) * | 2006-03-16 | 2007-09-20 | Huawei Technologies Co., Ltd. | Method and apparatus for realizing adaptive quantization in encoding process |
KR100922275B1 (ko) * | 2006-12-15 | 2009-10-15 | 경희대학교 산학협력단 | 경계 필터링 강도의 결정 방법 및 이를 이용한 디블록킹필터링 방법과 장치 |
CN102123277B (zh) * | 2007-05-08 | 2012-11-14 | 孟智平 | 一种基于流格式的指定区域图像传输及显示方法 |
JP5705833B2 (ja) | 2010-04-13 | 2015-04-22 | パナソニック インテレクチュアル プロパティ コーポレーション オブアメリカPanasonic Intellectual Property Corporation of America | 画像符号化方法および画像復号化方法 |
-
2003
- 2003-04-25 CN CN 03122943 patent/CN1240025C/zh not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
CN1450497A (zh) | 2003-10-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN1232124C (zh) | 基于离散余弦变换的高级视频编码方法和设备 | |
CN103327325B (zh) | 基于hevc标准的帧内预测模式快速自适应选择方法 | |
CN105791872A (zh) | Hevc视频编解码中执行帧内预测的图像处理装置及方法 | |
CN1794817A (zh) | 运动图像压缩编码方法和运动图像压缩编码装置以及程序 | |
CN1794815A (zh) | 产生对图像或图像序列进行编码的量化矩阵的方法和设备 | |
CN1933601A (zh) | 用于无损视频编码和解码的方法及设备 | |
CN1809168A (zh) | 编码器中的帧内预测模式选择 | |
CN1758762A (zh) | 用于编码和/或解码运动图像的方法和装置 | |
CN1794816A (zh) | 运动图像压缩编码方法、运动图像压缩编码装置以及程序 | |
CN1275469C (zh) | 一种复杂度可分级的帧内预测方法 | |
CN1233171C (zh) | 一种用于视频编码的简单化环路滤波方法 | |
TW200307463A (en) | Animation encoding method, animation encoding device, and animation encoding processing program | |
CN1723711A (zh) | 用于数字视频处理的一元化量度(umdvp) | |
CN106170093A (zh) | 一种帧内预测性能提升编码方法 | |
CN1547853A (zh) | 用于消除区块效应和/或铃振噪声的滤波方法和装置 | |
Fan et al. | A novel coefficient scanning scheme for directional spatial prediction-based image compression | |
CN1665299A (zh) | 可伸缩视频编解码器体系结构设计方法 | |
CN1675929A (zh) | 降低视频编码器中计算复杂性的方法和设备 | |
CN1240025C (zh) | 基于视频内容的视频编码方法 | |
CN1310190C (zh) | 根据每块的能量编码静止图像的离散小波变换器件与方法 | |
CN109672891B (zh) | Jpeg图像的无损二次压缩方法 | |
CN1757238A (zh) | 考虑与运动矢量的分量相关的部分来编码视频图像的方法 | |
CN1809167A (zh) | 一种快速帧间预测模式选择方法 | |
CN1741612A (zh) | 一种用于视频图像编码过程中的量化方法 | |
CN100337481C (zh) | 一种mpeg-2到avs视频码流格式转换方法及其装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant | ||
C17 | Cessation of patent right | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20060201 Termination date: 20130425 |