一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

视频编解码方法、装置、设备及存储介质与流程

2022-03-09 02:57:07 来源:中国专利 TAG:


1.本技术涉及视频处理技术领域,具体涉及一种视频编解码方法、装置、设备及存储介质。


背景技术:

2.视频包含巨大的信息量,难以进行存储和传输,因此,需要对视频进行编码,以便于对视频进行存储和传输。
3.在相关技术中,通常以h.264为标准对视频进行编码,在实际应用过程中,h.264采用帧内编码和帧间编码的方式对视频进行压缩,上述编码方式中,视频每一帧图像之间以及每一帧图像之内的像素块之间均具有较强的相关性,编码时只能按照顺序依次处理像素块,再依次处理每一帧图像,整个编码过程的计算量非常大,导致视频编码的速率较慢。


技术实现要素:

4.本技术涉及一种视频编解码方法、装置、设备及存储介质,提高了视频编码的速率。
5.第一方面,本技术实施例提供一种视频编码方法,包括:
6.获取待编码视频的帧图像;
7.确定所述帧图像对应的n个像素块,所述n为大于1的整数;
8.并行对所述n个像素块进行压缩处理,得到n个压缩图像信息;
9.对所述n个压缩图像信息进行编码处理,得到所述帧图像对应的比特流。
10.在一种可能的实施方式中,对所述n个压缩图像信息进行编码处理,得到所述帧图像对应的比特流,包括:
11.分别对每个压缩图像信息进行编码处理,得到每个像素块对应的像素块比特流;
12.确定所述帧图像对应的比特流包括每个像素块对应的像素块比特流。
13.在一种可能的实施方式中,针对所述n个压缩图像信息中的任意一个压缩图像信息;对所述压缩图像信息进行编码处理,得到所述像素块对应的像素块比特流,包括:
14.在所述压缩图像信息中确定直流分量和交流分量;
15.对所述直流分量进行编码处理,得到直流比特流,以及对所述交流分量进行编码处理,得到交流比特流,其中,所述像素块对应的像素块比特流包括所述直流比特流和所述交流比特流。
16.在一种可能的实施方式中,所述压缩图像信息为量化矩阵;在所述压缩图像信息中确定直流分量和交流分量,包括:
17.将所述量化矩阵转换为一维数组;
18.将所述一维数组中的第一个元素确定为所述直流分量;
19.将所述一维数组中除所述第一个元素之外的其它元素确定为所述交流分量。
20.在一种可能的实施方式中,针对所述n个像素块中的任意一个像素块;对所述像素
块进行压缩处理,得到所述压缩图像信息,包括:
21.对所述像素块进行dct变换处理,得到浮点数矩阵;
22.对所述浮点数矩阵进行量化处理,得到所述量化矩阵,所述量化矩阵为所述压缩图像信息。
23.第二方面,本技术实施例提供了一种视频编码装置,包括获取模块、确定模块、压缩模块和编码模块,其中,
24.所述获取模块用于,获取待编码视频的帧图像;
25.所述确定模块用于,确定所述帧图像对应的n个像素块,所述n为大于1的整数;
26.所述压缩模块用于,并行对所述n个像素块进行压缩处理,得到n个压缩图像信息;
27.所述编码模块用于,对所述n个压缩图像信息进行编码处理,得到所述帧图像对应的比特流。
28.在一种可能的实施方式中,所述编码模块具体用于:
29.分别对每个压缩图像信息进行编码处理,得到每个像素块对应的像素块比特流;
30.确定所述帧图像对应的比特流包括每个像素块对应的像素块比特流。
31.在一种可能的实施方式中,针对所述n个压缩图像信息中的任意一个压缩图像信息;所述编码模块具体用于:
32.在所述压缩图像信息中确定直流分量和交流分量;
33.对所述直流分量进行编码处理,得到直流比特流,以及对所述交流分量进行编码处理,得到交流比特流,其中,所述像素块对应的像素块比特流包括所述直流比特流和所述交流比特流。
34.在一种可能的实施方式中,所述压缩图像信息为量化矩阵;所述编码模块具体用于:
35.将所述量化矩阵转换为一维数组;
36.将所述一维数组中的第一个元素确定为所述直流分量;
37.将所述一维数组中除所述第一个元素之外的其它元素确定为所述交流分量。
38.在一种可能的实施方式中,针对所述n个像素块中的任意一个像素块;所述压缩模块具体用于:
39.对所述像素块进行离散余弦变换处理,得到浮点数矩阵;
40.对所述浮点数矩阵进行量化处理,得到所述量化矩阵,所述量化矩阵为所述压缩图像信息。
41.第三方面,本技术实施例提供了一种视频编码设备,包括:处理器、存储器;
42.所述存储器存储计算机执行指令;
43.所述处理器执行所述存储器存储的计算机执行指令,使得所述处理器执行如第一方面所述的视频压缩方法。
44.第四方面,本技术实施例提供了一种计算机可读存储介质,所述计算机可读存储介质中存储有计算机执行指令,当所述计算机执行指令被处理器执行时用于实现第一方面所述的视频编码方法。
45.第五方面,本技术实施例提供了一种计算机程序产品,包括计算机程序,该计算机程序被处理器执行时实现第一方面所述的视频编码方法。
46.本技术实施例提供了一种视频编码方法、装置、设备及存储介质,先获取待编码视频的帧图像,将帧图像划分为n个像素块,并行对n个像素块进行压缩处理,得到n个压缩图像信息;对n个压缩图像信息进行编码处理,得到帧图像对应的比特流。上述视频编码方法,对一帧图像内的各个像素块进行独立编码,以及对各个帧图像进行独立编码,降低了帧图像内各个像素块之间的耦合性、以及降低了各个帧图像之间的耦合性,进而可以实现对帧图像内的各个像素块进行并行编码,也可以对多个帧图像进行并行编码,提高了视频编码效率。
47.第六方面,本技术实施例提供了一种视频解码方法,包括:
48.获取待解码比特流,所述待解码比特流为待解码视频中一个帧图像对应的比特流;
49.对所述待解码比特流进行解码处理,得到n个压缩图像信息,所述n为大于1的整数;
50.对所述n个压缩图像信息进行解压缩处理,得到n个像素块;
51.根据所述n个像素块确定解码后的帧图像。
52.在一种可能的实施方式中,对所述待解码比特流进行解码处理,得到n个压缩图像信息,包括:
53.在所述待解码比特流中获取n个像素块比特流;
54.分别对每个像素块对应的像素块比特流进行解码处理,得到所述n个压缩图像信息。
55.在一种可能的实施方式中,针对任意一个像素块比特流;对所述像素块比特流进行解码处理,得到所述像素块比特流对应的压缩图像信息,包括:
56.在所述像素块比特流中确定直流比特流和交流比特流;
57.对所述直流比特流进行解码处理,得到直流分量;
58.对所述交流比特流进行解码处理,得到交流分量;
59.确定所述压缩图像信息包括所述直流分量和所述交流分量。
60.在一种可能的实施方式中,针对所述n个压缩图像信息中的任意一个压缩图像信息;对所述压缩图像信息进行解压缩处理,得到所述压缩图像信息对应的像素块,包括:
61.对所述压缩图像信息进行反量化处理,得到反量化矩阵;
62.对所述反量化矩阵进行逆离散余弦变化处理,得到所述压缩图像信息对应的像素块。
63.第七方面,本技术实施例提供了一种视频解码装置,包括获取模块、解码模块、解压缩模块和确定模块,其中,
64.所以获取模块用于,获取待解码比特流,所述待解码比特流为待解码视频中一个帧图像对应的比特流;
65.所述解码模块用于,对所述待解码比特流进行解码处理,得到n个压缩图像信息,所述n为大于1的整数;
66.所述解压缩模块用于,对所述n个压缩图像信息进行解压缩处理,得到n个像素块;
67.所述确定模块用于,根据所述n个像素块确定解码后的帧图像。
68.在一种可能的实施方式中,所述解码模块具体用于:
69.在所述待解码比特流中获取n个像素块比特流;
70.分别对每个像素块对应的像素块比特流进行解码处理,得到所述n个压缩图像信息。
71.在一种可能的实施方式中,针对任意一个像素块比特流;所述解码模块具体用于:
72.在所述像素块比特流中确定直流比特流和交流比特流;
73.对所述直流比特流进行解码处理,得到直流分量;
74.对所述交流比特流进行解码处理,得到交流分量;
75.确定所述压缩图像信息包括所述直流分量和所述交流分量。
76.在一种可能的实施方式中,针对所述n个压缩图像信息中的任意一个压缩图像信息;所述解压缩模块具体用于:
77.对所述压缩图像信息进行反量化处理,得到反量化矩阵;
78.对所述反量化矩阵进行逆离散余弦变化处理,得到所述压缩图像信息对应的像素块。
79.第八方面,本技术实施例提供了一种视频解码设备,包括:处理器、存储器;
80.所述存储器存储计算机执行指令;
81.所述处理器执行所述存储器存储的计算机执行指令,使得所述处理器执行如第六方面所述的视频解码方法。
82.第九方面,本技术实施例提供了一种计算机可读存储介质,所述计算机可读存储介质中存储有计算机执行指令,当所述计算机执行指令被处理器执行时用于实现第六方面所述的视频解码方法。
83.第十方面,本技术实施例提供了一种计算机程序产品,包括计算机程序,该计算机程序被处理器执行时实现第六方面所述的视频解码方法。
84.本技术实施例提供一种视频解码方法、装置、设备及存储介质,先获取待解码视频中一个帧图像的比特流,将比特流进行解码处理,得到n个压缩图像信息,再对n个压缩图像信息进行解压缩处理,得到n个像素块,根据n个像素块确定解压缩后的帧图像。由于视频编码时是对一帧图像内的各个像素块进行独立编码,以及对各个帧图像进行独立编码,帧图像中的各个像素块之间、以及不同的帧图像之间解耦和,因此,在解码的时候,可以对图像帧中的各个像素块进行并行解码、以及对多个帧图像进行并行解码,提高了解码效率。
附图说明
85.图1为本技术实施例提供的一种应用场景示意图;
86.图2为本技术实施例提供的一种视频编码方法的流程示意图一;
87.图3为本技术实施例提供的视频编码方法的流程示意图二;
88.图4为本技术实施例提供的视频解码方法的流程示意图一;
89.图5为本技术实施例提供的视频解码方法的流程示意图二;
90.图6为本技术实施例提供的一种视频编码装置的结构示意图;
91.图7为本技术实施例提供的一种视频编码设备的结构示意图;
92.图8为本技术实施例提供的一种视频解码装置的结构示意图;
93.图9为本技术实施例提供的一种视频解码设备的结构示意图。
具体实施方式
94.为使本技术实施例的目的、技术方案和优点更加清楚,下面将结合本技术实施例中的附图,对本技术实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本技术一部分实施例,而不是全部的实施例。基于本技术中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本技术保护的范围。
95.在演出、大型赛事,商业活动等场景中,通常需要使用摄像机将现场的过程录制为视频进行保存,以便后续进行重播等,而这些录制视频的分辨率通常较高。为了能够更好的保存和传输录制视频,需要对视频进行压缩。
96.为了便于理解,下面结合图1,对本技术实施例所适用的应用场景进行说明。
97.图1为本技术实施例提供的一种应用场景示意图。请参见图1,终端设备中可以设置有压缩模块、编码模块、解码模块和解压缩模块。当终端设备需要对视频进行编码时,终端设备可以将获取的视频拆分为多个帧图像,然后通过压缩模块和编码模块对多个帧图像进行编码处理,得到比特流。当终端设备需要对视频进行解码时,终端设备可以先获取待解码视频中多个帧图像的比特流,然后通过解码模块和编码模块对多个帧图像的比特流进行解码处理,得到视频。
98.在相关技术中,终端设备在对视频编码时,由于每一帧图像之间有相关性,因此,只能对每一帧图像依次按照顺序进行处理;又由于每一帧图像内像素块之间也有相关性,因此,每一帧图像内的像素块也只能依次按照顺序处理。整个编码过程的计算量非常大,导致视频编码的速率较慢。
99.终端设备在对视频解码时,由于编码时每一帧图像之间以及每一帧图像内像素块之间均有相关性,因此解码时只能先按照顺序依次处理像素块,再依次处理每一帧图像,整个解码过程的计算量非常大,导致视频解码的速率较慢。
100.为了解决上述技术问题,在本技术中,在对视频进行编码时,先获取待编码视频的帧图像,将帧图像划分为n个像素块,并行对n个像素块进行压缩处理,得到n个压缩图像信息;对n个压缩图像信息进行编码处理,得到帧图像对应的比特流。上述视频编码方法中,对一帧图像内的各个像素块进行独立编码,以及对各个帧图像进行独立编码,降低了帧图像内各个像素块之间的耦合性、以及降低了各个帧图像之间的耦合性,进而可以实现对帧图像内的各个像素块进行并行编码,也可以对多个图像帧进行并行编码,提高了视频编码效率。并且,在解码过程中,由于帧图像中的各个像素块之间、以及不同的帧图像之间解耦和,可以对图像帧中的各个像素块进行并行解码、以及对多个帧图像进行并行解码,提高了解码效率。
101.下面,通过具体实施例对本技术所示的技术方案进行详细说明。需要说明的是,下面几个实施例可以独立存在,也可以相互结合,对于相同或显示的内容,在不同的实施例中不再重复说明。
102.图2为本技术实施例提供的一种视频编码方法的流程示意图一。请参见图2,该方法包括:
103.s201、获取待编码视频的帧图像。
104.本技术实施例的执行主体可以为手机、相机等终端设备,也可以为设置在终端设备中的视频编码装置,该视频编码装置可以通过软件实现,也可以通过软件和硬件的结合
实现。
105.帧图像可以是ycbcr图像经过4:2:2或者4:2:0采样处理得到的图像。
106.若待编码视频中的图像为rgb图像,可以将rgb图像转换为ycbcr图像。
107.可以对待编码视频中的多帧图像并行执行s202-s204步骤,也可以对待编码视频中的多帧图像顺序执行s202-s204步骤。
108.s202、确定帧图像对应的n个像素块。
109.n为大于1的整数。
110.像素块的大小可以为8*8;像素块可以为宏块。
111.可以通过以下方式确定帧图像对应的n个像素块:
112.可以将ycbcr格式的帧图像按照颜色通道分别拆分为y通道图像、cb通道图像和cr通道图像,再将三个颜色通道的图像分别拆分为大小相同的像素块。
113.例如,若帧图像的分辨率为7680*4320,采样方式为4:2:2,像素块的大小为8*8,则可以将y颜色通道的图像拆分为个像素块,cb颜色通道的图像拆分为个像素块,cr颜色通道的图像拆分为个像素块,一个帧图像可以对应得到1036800个像素块。
114.s203、并行对n个像素块进行压缩处理,得到n个压缩图像信息。
115.可以基于显卡中的并行计算单元对n个像素块进行并行处理。
116.压缩处理可以包括离散余弦变化处理和量化处理。
117.在进行压缩处理之前,可以对每个像素块的像素值做预处理,以使像素块在进行离散余弦变化之前,数据值范围在-122~127之间。
118.压缩图像信息可以为量化矩阵;压缩图像信息中可以包括直流分量和交流分量。
119.针对n个像素块中的任意一个像素块,可以通过以下方式对像素块进行压缩处理,得到压缩图像信息:对所述像素块进行离散余弦变换处理,得到浮点数矩阵;对所述浮点数矩阵进行量化处理,得到所述量化矩阵,所述量化矩阵为所述压缩图像信息。
120.s204、对n个压缩图像信息进行编码处理,得到帧图像对应的比特流。
121.编码处理可以是哈夫曼编码处理。
122.可以将二维矩阵中的数据按照预定顺序转换为一维数组,再进行编码处理,编码处理后得到的比特流序列比一维数组的序列短。
123.例如,矩阵经过z字形的顺序,可以转换为{3,2,0,9,4,1,5,8,7}。
124.帧图像对应的比特流可以按照帧图像的预定顺序进行放置,得到待编码视频的比特流。
125.可以通过以下方式对n个压缩图像信息进行编码处理,得到帧图像对应的比特流:分别对每个压缩图像信息进行编码处理,得到每个像素块对应的像素块比特流;确定所述帧图像对应的比特流包括每个像素块对应的像素块比特流。
126.在图2所示的实施例中,先获取待编码视频的帧图像,将帧图像划分为n个像素块,并行对n个像素块进行压缩处理,得到n个压缩图像信息;对n个压缩图像信息进行编码处
理,得到帧图像对应的比特流。上述视频编码方法,对一帧图像内的各个像素块进行独立编码,以及对各个帧图像进行独立编码,降低了帧图像内各个像素块之间的耦合性、以及降低了各个帧图像之间的耦合性,进而可以实现对帧图像内的各个像素块进行并行编码,也可以对多个图像帧进行并行编码,提高了视频编码效率。
127.在上述任意实施例的基础上,下面,结合图3所示的实施例,对上述视频编码方法进行详细说明。
128.图3为本技术实施例提供的视频编码方法的流程示意图二。请参见图3,该方法可以包括:
129.s301、获取待编码视频的帧图像。
130.需要说明的是,s301的执行过程可以参见s201的执行过程,此处不再进行赘述。
131.s302、确定帧图像对应的n个像素块。
132.需要说明的是,s302的执行过程可以参见s202的执行过程,此处不再赘述。
133.s303、并行对n个像素块进行离散余弦变化处理,得到n个浮点数矩阵。
134.离散余弦变换可以将信号从空域(时域)转换为频域。
135.若f(x,y)为m*n的数字图像矩阵,经过以下离散余弦变换公式变换可以得到浮点数矩阵f(u,v)。
[0136][0137]
其中,x,u=0,1,2,

,m-1;y,v=0,1,2,

,n-1;
[0138][0138][0139]
例如,一个8*8的像素块经过离散余弦变换后得到一个8*8的浮点数矩阵
[0140]
s304、并行对n个浮点数矩阵进行量化处理,得到n个压缩图像信息。
[0141]
压缩图像信息可以为量化矩阵,量化矩阵可以为整数矩阵。
[0142]
量化处理是一种有损处理,可以去除人眼不敏感的频率信息。
[0143]
量化处理具体可以采用以下量化公式对浮点数矩阵中的数据进行处理:
[0144][0145]
其中,g是需要处理的浮点数矩阵;q为量化系数矩阵;b为处理后的量化矩阵;若处理的矩阵为8*8,则i,j=0,1,2,

,7。
[0146]
对于ycbcr图像,有两张标准的量化系数矩阵:标准亮度量化系数矩阵qy和标准色差量化系数矩阵qc,分别用于处理亮度数据y和色差数据cr、cb。
[0147][0148][0149]
round函数是考虑到四舍五入的取整函数。
[0150]
例如,针对浮点数矩阵:
[0151][0152]
采用qy进行量化处理,以左上角的257.1为例,对应的量子化系数是16,那么round(257.1/16)=round(16.06875)=16,最终得到的量化矩阵为:
[0153][0154]
s305、针对n个压缩图像信息中的任意一个压缩图像信息,在压缩图像信息中确定直流分量和交流分量。
[0155]
可以通过以下方式在压缩图像信息中确定直流分量和交流分量:将所述量化矩阵转换为一维数组;将所述一维数组中的第一个元素确定为所述直流分量;将所述一维数组中除所述第一个元素之外的其它元素确定为所述交流分量。
[0156]
可以将量化矩阵中的数据按照预定顺序转换为一维数据;预定顺序可以将量化矩阵中的数据“0”尽可能放在一起,预定顺序可以为z字形顺序。例如,针对s304中得到的量化矩阵,通过z字形的顺序转换为一维数组{16,1,1,0,0,

,0,0};在一维数组中,16为直流分量,除16以外的数据为交流分量。
[0157]
s306、对直流分量进行编码处理,得到直流比特流,以及对交流分量进行编码处理,得到交流比特流。
[0158]
每一个像素块之间的直流分量单独进行编码;每一个像素块之间的交流分量单独进行编码。
[0159]
编码处理可以为哈夫曼编码处理。
[0160]
哈夫曼编码时直流分量和交流分量可以分别采用不同的哈夫曼编码表,对于亮度y和色度(cr、cd)也可以采用不同的哈夫曼编码表。
[0161]
哈夫曼编码表可以采用现在已知的,也可以由编码人员自己定义。
[0162]
比特流可以为二进制或者十六进制的字符串。
[0163]
例如,64字节的原始数据:
[0164]
35,7,0,0,0,-6,-2,0,0,-9,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,8,0,0,0,

,0
[0165]
通过哈夫曼编码处理后可以得到以下比特流:
[0166]
10010001110011111111111010100101011111111101000110111111110011111111
1010010001010
[0167]
或者以下比特流:91cf fe a5 7f d1 bf cf fa 45
[0168]
s307、根据直流比特流和交流比特流,确定每个像素块对应的像素块比特流。
[0169]
s308、根据每个像素块对应的像素块比特流,确定帧图像对应的比特流。
[0170]
可以按照帧图像内像素块的位置关系存放对应的像素块比特流,以得到帧图像对应的比特流。
[0171]
在图3所示的实施例中,先获取待编码视频的帧图像,将帧图像划分为n个像素块,并行对n个像素块进行离散余弦变化处理,得到n个浮点数矩阵;并行对n个浮点数矩阵进行量化处理,得到n个压缩图像信息;针对n个压缩图像信息中的任意一个压缩图像信息,在压缩图像信息中确定直流分量和交流分量;对直流分量进行编码处理,得到直流比特流,对交流分量进行编码处理,得到交流比特流;根据直流比特流和交流比特流,确定每个像素块对应的像素块比特流;根据每个像素块对应的像素块比特流,确定帧图像对应的比特流。上述视频编码方法,对一帧图像内的各个像素块进行独立编码,以及对各个帧图像进行独立编码,降低了帧图像内各个像素块之间的耦合性、以及降低了各个帧图像之间的耦合性,进而可以实现对帧图像内的各个像素块进行并行编码,也可以对多个图像帧进行并行编码,提高了视频编码效率。
[0172]
图2和图3所示的实施例对视频编码方法进行了说明,下面,以图4和图5所示的实施例对视频解码方法进行说明。
[0173]
图4为本技术实施例提供的视频解码方法的流程示意图一。请参见图4,该方法包括:
[0174]
s401、获取待解码比特流。
[0175]
待解码比特流可以为待解码视频中一个帧图像对应的比特流。
[0176]
可以对待解码视频中多个帧图像对应的比特流并行执行s402-s404步骤,也可以对待解码视频中多个帧图像对应比特流顺序执行s402-s404步骤。
[0177]
s402、对待解码比特流进行解码处理,得到n个压缩图像信息。
[0178]
n为大于1的整数。
[0179]
解码处理可以为哈夫曼解码处理。
[0180]
s403、对n个压缩图像信息进行解压缩处理,得到n个像素块。
[0181]
解压缩处理可以为反量化处理和逆离散余弦变化处理。
[0182]
n个压缩图像信息可以并行进行解压缩处理,也可以单独进行解压缩处理。例如,针对一个待解码视频,若是将视频全部解码,可以对帧图像对应的n个压缩图像信息并行进行解压缩处理;若是将视频部分解码(例如,只解码视频中涉及的一个人的脸),可以对帧图像对应的n个压缩图像信息中,涉及该人脸的压缩图像信息,进行解压缩处理。
[0183]
s404、根据n个像素块确定解码后的帧图像。
[0184]
n个像素块可以根据其位置进行拼接后得到帧图像;帧图像可以按照时间顺序排列,得到解码的视频。
[0185]
在图4所示的实施例中,先获取待解码视频中一个帧图像的比特流,将比特流进行解码处理,得到n个压缩图像信息,再对n个压缩图像信息进行解压缩处理,得到n个像素块,根据n个像素块确定解压缩后的帧图像。由于视频编码时是对一帧图像内的各个像素块进
行独立编码,以及对各个帧图像进行独立编码,帧图像中的各个像素块之间、以及不同的帧图像之间解耦和,因此,在解码的时候,可以对图像帧中的各个像素块进行并行解码、以及对多个帧图像进行并行解码,提高了解码效率。还可以对帧图像中部分像素块对应的比特流进行解码,以及对部分帧图像对应的比特流进行解码,提高了解码的灵活性。
[0186]
在上述任意实施例的基础上,下面,结合图5所示的实施例,对上述视频解码方法进行详细说明。
[0187]
图5为本技术实施例提供的视频解码方法的流程示意图二。请参见图5,该方法可以包括:
[0188]
s501、获取待解码比特流。
[0189]
需要说明的是,s501的执行过程可以参见s401的执行过程,此处不再赘述。
[0190]
s502、在待解码比特流中获取n个像素块比特流。
[0191]
可以根据视频编码时,像素块比特流的放置位置获取像素块比特流。
[0192]
s503、针对任意一个像素块比特流,在像素块比特流中确定直流比特流和交流比特流。
[0193]
例如,一个像素块比特流可以包括两个比特流数据,其中一个为直流比特流数据,另一个为交流比特流数据。
[0194]
s504、对直流比特流进行解码处理,得到直流分量。
[0195]
直流比特流可以根据哈夫曼解码的规则解码得到直流分量。
[0196]
直流分量可以为一维数组。
[0197]
s505、对交流比特流进行解码处理,得到交流分量。
[0198]
交流比特流可以根据哈夫曼解码的规则解码得到直流分量。
[0199]
交流分量可以为一维数组。
[0200]
s506、根据直流分量和交流分量确定压缩图像信息。
[0201]
直流分量和交流分量可以按照预定顺序排列后组成二维压缩图像信息。
[0202]
例如,直流分量为16,交流分量为1,1,0,0,

,0,0,省略号表示省去的0,交流分量一共有63位数据;根据编码时变换的z字形顺序,可以得到压缩图像信息
[0203]
s507、对压缩图像信息进行反量化处理,得到反量化矩阵。
[0204]
反量化处理可以是将压缩图像信息中的数值,乘以s304中对应的量化矩阵中的数值,例如,压缩图像信息左上角的数值为16,反量化处理后,反量化矩阵左上角的数值为16*16=256。
[0205]
s508、对反量化矩阵进行逆离散余弦变化处理,得到压缩图像信息对应的像素块。
[0206]
若反量化矩阵f(u,v)为m*n的矩阵,经过以下逆离散余弦变换公式变换可以得到
相应像素块的像素矩阵f(x,y)。
[0207][0208]
其中,x,u=0,1,2,

,m-1;y,v=0,1,2,

,n-1;
[0209][0209][0210]
可以对像素矩阵中的所有数值加上128以得到像素块的像素值。
[0211]
s509、根据n个像素块确定解码后的帧图像。
[0212]
可以将n个像素块拼接后得到解码后的帧图像。
[0213]
在图5所示的实施例中,先获取待解码视频中一个帧图像的比特流,在帧图像比特流中确定n个像素块比特流,针对任意一个像素块比特流,在像素块比特流中确定直流比特流和交流比特流;对直流比特流进行解码处理,得到直流分量,对交流比特流进行解码处理,得到交流分量;根据直流分量和交流分量确定压缩图像信息;对压缩图像信息进行反量化处理,得到反量化矩阵;对反量化矩阵进行逆离散余弦变化处理,得到压缩图像信息对应的像素块;根据n个像素块确定解压缩后的帧图像。由于视频编码时是对一帧图像内的各个像素块进行独立编码,以及对各个帧图像进行独立编码,帧图像中的各个像素块之间、以及不同的帧图像之间解耦和,因此,在解码的时候,可以对图像帧中的各个像素块进行并行解码、以及对多个帧图像进行并行解码,提高了解码效率。还可以对帧图像中部分像素块对应的比特流进行解码,以及对部分帧图像对应的比特流进行解码,提高了解码的灵活性。
[0214]
图6为本技术实施例提供的一种视频编码装置的结构示意图。请参见图6,该视频编码装置10包括获取模块11、确定模块12、压缩模块13和编码模块14,其中,
[0215]
所述获取模块11用于,获取待编码视频的帧图像;
[0216]
所述确定模块12用于,确定所述帧图像对应的n个像素块,所述n为大于1的整数;
[0217]
所述压缩模块13用于,并行对所述n个像素块进行压缩处理,得到n个压缩图像信息;
[0218]
所述编码模块14用于,对所述n个压缩图像信息进行编码处理,得到所述帧图像对应的比特流。
[0219]
在一种可能的实施方式中,所述编码模块14具体用于:
[0220]
分别对每个压缩图像信息进行编码处理,得到每个像素块对应的像素块比特流;
[0221]
确定所述帧图像对应的比特流包括每个像素块对应的像素块比特流。
[0222]
在一种可能的实施方式中,针对所述n个压缩图像信息中的任意一个压缩图像信息;所述编码模块14具体用于:
[0223]
在所述压缩图像信息中确定直流分量和交流分量;
[0224]
对所述直流分量进行编码处理,得到直流比特流,以及对所述交流分量进行编码处理,得到交流比特流,其中,所述像素块对应的像素块比特流包括所述直流比特流和所述交流比特流。
[0225]
在一种可能的实施方式中,所述压缩图像信息为量化矩阵;所述编码模块14具体用于:
[0226]
将所述量化矩阵转换为一维数组;
[0227]
将所述一维数组中的第一个元素确定为所述直流分量;
[0228]
将所述一维数组中除所述第一个元素之外的其它元素确定为所述交流分量。
[0229]
在一种可能的实施方式中,针对所述n个像素块中的任意一个像素块;所述压缩模块13具体用于:
[0230]
对所述像素块进行离散余弦变换处理,得到浮点数矩阵;
[0231]
对所述浮点数矩阵进行量化处理,得到所述量化矩阵,所述量化矩阵为所述压缩图像信息。
[0232]
本技术实施例提供的视频编码装置10可以执行上述视频编码方法实施例所示的技术方案,其实现原理以及有益效果类似,此处不再赘述。
[0233]
图7为本技术实施例提供的一种视频编码设备的结构示意图。请参见图7,视频编码设备20包括:存储器21、处理器22。示例性地,存储器21、处理器22,各部分之间通过总线23相互连接。
[0234]
存储器21用于存储程序指令;
[0235]
处理器22用于执行该存储器所存储的程序指令,用以使得视频编码设备20执行上述的视频编码方法。
[0236]
图7实施例所示的视频编码设备可以执行上述视频编码方法实施例所示的技术方案,其实现原理以及有益效果类似,此处不再进行赘述。
[0237]
本技术实施例提供一种计算机可读存储介质,计算机可读存储介质中存储有计算机执行指令,当计算机执行指令被处理器执行时用于实现上述的视频编码方法。
[0238]
本技术实施例还可提供一种计算机程序产品,包括计算机程序,该计算机程序被处理器执行时,可实现上述视频编码方法。
[0239]
图8为本技术实施例提供的一种视频解码装置的结构示意图。请参见图8,该视频解码装置30包括:获取模块31、解码模块32、解压缩模块33和确定模块34,其中,
[0240]
所以获取模块31用于,获取待解码比特流,所述待解码比特流为待解码视频中一个帧图像对应的比特流;
[0241]
所述解码模块32用于,对所述待解码比特流进行解码处理,得到n个压缩图像信息,所述n为大于1的整数;
[0242]
所述解压缩模块33用于,对所述n个压缩图像信息进行解压缩处理,得到n个像素块;
[0243]
所述确定模块34用于,根据所述n个像素块确定解码后的帧图像。
[0244]
在一种可能的实施方式中,所述解码模块32具体用于:
[0245]
在所述待解码比特流中获取n个像素块比特流;
[0246]
分别对每个像素块对应的像素块比特流进行解码处理,得到所述n个压缩图像信息。
[0247]
在一种可能的实施方式中,针对任意一个像素块比特流;所述解码模块32具体用于:
[0248]
在所述像素块比特流中确定直流比特流和交流比特流;
[0249]
对所述直流比特流进行解码处理,得到直流分量;
[0250]
对所述交流比特流进行解码处理,得到交流分量;
[0251]
确定所述压缩图像信息包括所述直流分量和所述交流分量。
[0252]
在一种可能的实施方式中,针对所述n个压缩图像信息中的任意一个压缩图像信息;所述解压缩模块33具体用于:
[0253]
对所述压缩图像信息进行反量化处理,得到反量化矩阵;
[0254]
对所述反量化矩阵进行逆离散余弦变化处理,得到所述压缩图像信息对应的像素块。
[0255]
本技术实施例提供的视频解码装置30可以执行上述视频解码方法实施例所示的技术方案,其实现原理以及有益效果类似,此次不再进行赘述。
[0256]
图9为本技术实施例提供的一种视频解码设备的结构示意图。请参见图9,视频解码设备40可以包括:存储器41、处理器42。示例性地,存储器41、处理器42,各部分之间通过总线43相互连接。
[0257]
存储器41用于存储程序指令;
[0258]
处理器42用于执行该存储器所存储的程序指令,用以使得视频解码设备40执行上述的视频解码方法。
[0259]
图9实施例所示的视频解码设备可以执行上述视频解码方法实施例所示的技术方案,其实现原理以及有益效果类似,此处不再进行赘述。
[0260]
本技术实施例提供一种计算机可读存储介质,计算机可读存储介质中存储有计算机执行指令,当计算机执行指令被处理器执行时用于实现上述的视频解码方法。
[0261]
本技术实施例还可提供一种计算机程序产品,包括计算机程序,该计算机程序被处理器执行时,可实现上述视频解码方法。
[0262]
以上描述仅为本技术的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本技术中所涉及的公开范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述公开构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本技术中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
[0263]
此外,虽然采用特定次序描绘了各操作,但是这不应当理解为要求这些操作以所示出的特定次序或以顺序次序执行来执行。在一定环境下,多任务和并行处理可能是有利的。同样地,虽然在上面论述中包含了若干具体实现细节,但是这些不应当被解释为对本技术的范围的限制。在单独的实施例的上下文中描述的某些特征还可以组合地实现在单个实施例中。相反地,在单个实施例的上下文中描述的各种特征也可以单独地或以任何合适的子组合的方式实现在多个实施例中。
[0264]
尽管已经采用特定于结构特征和/或方法逻辑动作的语言描述了本主题,但是应当理解所附权利要求书中所限定的主题未必局限于上面描述的特定特征或动作。相反,上面所描述的特定特征和动作仅仅是实现权利要求书的示例形式。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献