CN113660443A - 一种视频插帧方法、终端以及存储介质 - Google Patents

一种视频插帧方法、终端以及存储介质 Download PDF

Info

Publication number
CN113660443A
CN113660443A CN202010396385.3A CN202010396385A CN113660443A CN 113660443 A CN113660443 A CN 113660443A CN 202010396385 A CN202010396385 A CN 202010396385A CN 113660443 A CN113660443 A CN 113660443A
Authority
CN
China
Prior art keywords
optical flow
image
pixel
pixel point
value
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.)
Pending
Application number
CN202010396385.3A
Other languages
English (en)
Inventor
徐鹏
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Wuhan TCL Group Industrial Research Institute Co Ltd
Original Assignee
Wuhan TCL Group Industrial Research Institute Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Wuhan TCL Group Industrial Research Institute Co Ltd filed Critical Wuhan TCL Group Industrial Research Institute Co Ltd
Priority to CN202010396385.3A priority Critical patent/CN113660443A/zh
Publication of CN113660443A publication Critical patent/CN113660443A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/01Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level
    • H04N7/0135Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level involving interpolation processes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/01Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level
    • H04N7/0135Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level involving interpolation processes
    • H04N7/0137Conversion of standards, e.g. involving analogue television standards or digital television standards processed at pixel level involving interpolation processes dependent on presence/absence of motion, e.g. of motion zones

Abstract

本发明公开了一种视频插帧方法、终端及存储介质,所述视频插帧方法通过分别计算目标图像对的前向光流和后向光流,根据前向光流和后向光流获取图像中的遮挡区域,并根据图像中的遮挡区域对前向光流和后向光流进行修正,使用修正后的前向光流和后向光流来生成用于插入至目标图像对中的目标帧,由于在生成目标帧的过程中对于遮挡区域进行了单独的光流修正,能够提高存在遮挡情形下的插帧效果。

Description

一种视频插帧方法、终端以及存储介质
技术领域
本发明涉及计算机视觉技术领域,特别涉及一种视频插帧方法、终端以及存储介质。
背景技术
视频插帧时在视频的帧与帧之间插入额外帧的技术,视频插帧可以提高视频的流畅度,提高观看体验。基于光流的视频插帧方法是一种主流的视频插帧方法,在现有技术中,虽然基于光流的视频插帧方法虽然取得了不错的效果,但是在对于帧图像中存在物体遮挡的情况下,基于光流的视频插帧效果不佳,特别是帧与帧之间存在物体的大幅度运动时插帧效果较差。
因此,现有技术还有待改进和提高。
发明内容
针对现有技术的上述缺陷,本发明提供一种视频插帧方法、终端及存储介质,旨在解决现有技术中的基于光流的视频插帧方法插帧效果差的问题。
为了解决上述技术问题,本发明所采用的技术方案如下:
一种视频插帧方法,其中,所述视频插帧方法包括:
获取目标图像对对应的前向光流,根据所述前向光流获取所述目标图像对对应的后向光流,其中,所述前向光流为所述目标图像对中第一图像到第二图像的光流,所述后向光流为所述第二图像到所述第一图像的光流;
根据所述前向光流获取所述第一图像中的第一遮挡区域,根据所述后向光流获取所述第二图像中的第二遮挡区域;
对所述第一遮挡区域对应的前向光流值进行修正,生成修正前向光流,对所述第二遮挡区域对应的后向光流值进行修正,生成修正后向光流;
根据所述修正前向光流和所述修正后向光流生成用于插入至所述第一图像和所述第二图像之间的目标帧。
所述的视频插帧方法,其中,所述根据所述前向光流获取所述目标图像对对应的后向光流包括:
获取所述第一图像中各个像素点分别对应的各个第一前向光流值;
对所述各个第一前向光流值向上取整,获取所述第一图像中各个像素点分别对应的各个整数中间光流值;
根据所述第一图像中各个像素点的坐标、所述各个第一前向光流值以及所述各个整数中间光流值获取所述第二图像中多个像素点的后向光流值。
所述的视频插帧方法,其中,所述根据所述第一图像中各个像素点的坐标、所述各个第一前向光流值以及所述各个整数中间光流值获取所述第二图像中多个像素点的后向光流值包括:
根据公式
Figure BDA0002487737320000021
获取所述第二图像中多个像素点的后向光流值;
其中,
Figure BDA0002487737320000022
为所述第二图像中坐标为
Figure BDA0002487737320000023
的像素点的后向光流值,x为所述第一图像中的像素点的坐标,F0→1(x)为所述第一图像中坐标为x的像素点的第一前向光流值,
Figure BDA0002487737320000024
为所述第一图像中坐标为x的像素点对应的整数中间光流值。
所述的视频插帧方法,其中,所述根据所述前向光流获取所述第一图像的第一遮挡区域包括:
从所述第一图像中的各个像素点中提取至少一个像素点集合,所述像素点集合中包括至少两个像素点,所述像素点集合中包括前向光流值指向所述第二图像中的同一点的各个像素点;
获取所述像素点集合中各个像素点分别对应的各个像素值以及所述像素点集合中各个像素点的前向光流值在所述第二图像中指向的点的第二像素值,将所述像素点集合中像素值与所述第二像素值最接近的像素点之外的像素点标记为第一遮挡区域。
所述的视频插帧方法,其中,所述根据所述后向光流获取所述第二图像的第二遮挡区域包括:
获取各个后向光流值对应的第三像素点;
将所述第二图像中所述第三像素点之外的像素点标记为第二遮挡区域。
所述的视频插帧方法,其中,所述对所述第一遮挡区域对应的前向光流值进行修正包括:
获取与所述第一遮挡区域中第一目标像素点的距离小于第一预设值的至少一个预设尺寸的第一非遮挡区域;
获取各个第一非遮挡区域分别对应的像素值,将所述第一目标像素点的前向光流值修正为目标前向光流值,其中,所述目标前向光流值为与所述第一目标像素点的像素值最接近的第一非遮挡区域对应的前向光流值;
所述对所述第二遮挡区域内的各个像素点对应的后向光流值进行修正包括:
获取与所述第二遮挡区域中第二目标像素点的距离小于第二预设值的至少一个预设尺寸的第二非遮挡区域;
获取各个第二非遮挡区域分别对应的像素值,将所述第二目标像素点的后向光流值修正为目标后向光流值,其中,所述目标后向光流值为与所述第二目标像素点的像素值最接近的第二非遮挡区域对应的后向光流值。
所述的视频插帧方法,其中,所述根据所述修正前向光流和所述修正后向光流生成用于插入至所述第一图像和所述第二图像之间的目标帧包括:
根据所述修正前向光流和所述第一图像生成第一中间帧,根据所述修正后向光流和所述第二图像生成第二中间帧;
根据所述第一中间帧和所述第二中间帧生成所述目标帧。
所述的视频插帧方法,其中,所述根据所述修正前向光流和所述第一图像生成第一中间帧包括:
根据所述修正前向光流获取所述第一图像到所述目标帧的第一中间光流;
根据第一预设公式以及所述第一中间光流获取第一中间帧上多个像素点对应的像素值,生成所述第一中间帧;
所述根据所述修正后向光流和所述第二图像生成第二中间帧包括:
根据所述修正后向光流获取所述第二图像到所述目标帧的第二中间光流;
根据第二预设公式以及所述第二中间光流获取第二中间帧上多个像素点对应的像素值,生成所述第二中间帧。
所述的视频插帧方法,其中,所述第一预设公式为:I0(m+Δm)=It1(m+Δm+F0→t(m))
其中,I0(m+Δm)为所述第一图像上坐标为m+Δm的点的像素值,It1(m+Δm+F0→t(m))为所述第一中间帧上坐标为m+Δm+F0→t(m)的像素点的像素值,F0→t(m)为所述第一图像上坐标为m的像素点对应的第一中间光流值,m为整数,Δm为使得Δm+F0→t(m)为整数的值,0≤Δm<1;
所述第二预设公式为:I1(n+Δn)=It2(n+Δn+F1→t(n))
其中,I1(n+Δn)为所述第二图像上坐标为n+Δn的点的像素值,It2(n+Δn+F1→t(n))为所述第二中间帧上坐标为n+Δn+F1→t(n)的像素点的像素值,F1→t(n)为所述第二图像上坐标为n的像素点对应的第二中间光流值,n为整数,Δn为使得Δn+F1→t(n)为整数的值,0≤Δn<1。
所述的视频插帧方法,其中,所述根据所述第一预设公式以及所述第一中间光流获取第一中间帧上各个像素点对应的像素值包括:
当所述第一图像中存在多个第一像素点对应的第一中间光流值指向所述第一中间帧上的同一个像素点时,获取所述多个第一像素点中不处于所述第一遮挡区域内的第三像素点,将所述第三像素点在所述第一中间帧上对应的像素点的像素值作为所述多个第一像素点在所述第一中间帧上对应的像素点的像素值;
所述根据所述第二预设公式以及所述第二中间光流获取第二中间帧上各个像素点对应的像素值包括:
当所述第二图像中存在多个第二像素点对应的第二中间光流值指向所述第二中间帧上的同一个像素点时,获取所述多个第二像素点中不处于所述第二遮挡区域内的第四像素点,将所述第四像素点在所述第二中间帧上对应的像素点的像素值作为所述多个像素点在所述第二中间帧上对应的像素点的像素值。
一种终端,其中,所述终端包括:处理器、与处理器通信连接的存储介质,所述存储介质适于存储多条指令,所述处理器适于调用所述存储介质中的指令,以执行实现上述任一项所述的视频插帧方法的步骤。
一种存储介质,其中,所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现上述任一项所述的视频插帧方法的步骤。
有益效果:与现有技术相比,本发明提供了一种视频插帧方法、终端及存储介质,所述视频插帧方法对待插入目标帧的目标图像对,分别计算前向光流和后向光流,根据前向光流和后向光流获取图像中的遮挡区域,并根据图像中的遮挡区域对前向光流和后向光流进行修正,使用修正后的前向光流和后向光流来生成目标帧,由于在生成目标帧的过程中对于遮挡区域进行了单独的光流修正,能够提高存在遮挡情形下的插帧效果。
附图说明
图1为本发明提供的视频插帧方法的实施例的流程图;
图2为根据前向光流生成后向光流的一种实现方式的示意图;
图3为根据前向光流生成后向光流的另一种实现方式的示意图;
图4为遮挡情形的示意图;
图5为本发明提供的视频插帧方法与现有方法的插帧效果对比图;
图6为本发明提供的终端的实施例的结构原理图。
具体实施方式
为使本发明的目的、技术方案及效果更加清楚、明确,以下参照附图并举实施例对本发明进一步详细说明。应当理解,此处所描述的具体实施例仅用以解释本发明,并不用于限定本发明。
本发明提供的一种视频插帧方法,是可以应用在终端中,终端可以但不限于是各种个人计算机、笔记本电脑、手机、平板电脑、车载电脑和便携式可穿戴设备。所述终端在获取到待插入目标帧的目标图像对时,可以通过本发明提供的视频插帧方法生成目标帧。
实施例一
请参照图1,图1为本发明提供的视频插帧方法的实施例一的流程图。
所述视频插帧方法包括步骤:
S100、获取目标图像对对应的前向光流,根据所述前向光流获取所述目标图像对对应的后向光流。
视频插帧是在视频的帧与帧之前插入额外帧,也就是说,是根据两张帧图像生成时间序列在所述两张帧图像之间的一帧新图像,即,需要根据一个图像对来生成一张新的帧图像,在本实施例中,在获取需要插入目标帧的目标图像对后,是先获取所述目标图像对的前向光流,具体地,所述目标图像对中包括两张图像:第一图像和第二图像,所述前向光流为所述第一图像到所述第二图像的光流,所述后向光流为所述第二图像到所述第一图像的光流,也就是说,所述前向光流反映了所述第一图像中的各个点在第一图像到第二图像的时间段里产生的位移,所述后向光流反映了所述第二图像中过的各个点在所述第二图像到所述第一图像的时间段里产生的位移。例如,所述第一图像中坐标为x的像素点对应的前向光流值为F0→1(x),那么,这个点在经过一段从所述第一图像到所述第二图像的时间的运动后,在第二图像上的坐标为x+F0→1(x),不难看出,在所述第二图像上的坐标为x+F0→1(x)的点在经过从所述第二图像到所述第一图像的时间的运动后,在第一图像上的坐标为x,即,所述第二图像中坐标为x+F0→1(x)的点的后向光流值F1→0(x+F0→1(x))=-F0→1(x)。
在实际应用中,在获取所述后向光流时,需要知道的是整数坐标位置的光流值,而所述前向光流中包括的是所述第一图像中各个整数坐标位置处的前向光流值,且所述前向光流中包括的各个前向光流值基本上为浮点数,也就是说,x为整数,x+F0→1(x)往往不是整数,因此,不能直接根据公式F1→0(x+F0→1(x))=-F0→1(x)获取到所述后向光流。
在一种可能的实现方式中,如图2所示,直接将所述第二图像(图中I0为所述第一图像,I1为所述第二图像)中坐标为x的像素点的后向光流值设置为-F0→1(x),即F1→0(x)=-F0→1(x),那么,根据公式F1→0(x+F0→1(x))=-F0→1(x),可以得出F1→0(x+F0→1(x))=-F0→1(x)=F1→0(x),即,采用这种方式获取所述后向光流值时,包含了默认条件:x+F0→1(x)=x,当物体在所述第一图像和所述第二图像之间的相对运动比较小时,F0→1(x)也较小,这种方式导致的误差也不大,但是,在运动比较大时,这种方式导致的误差就会随之增大,造成插帧效果明显异常。
在另一种可能的实现方式中,所述根据所述前向光流获取所述目标图像对对应的后向光流包括:
S110、获取所述第一图像中各个像素点分别对应的各个第一前向光流值。
前面已经说明,所述前向光流中包括所述第一图像中坐标为整数的点的前向光流值,而在本领域中,图像是由像素点组成的,图像中的像素点的坐标均为整数,因此,在获取到所述前向光流后,可以获取到所述第一图像中各个像素点分别对应的各个第一前向光流值。
S120、对所述各个第一前向光流值向上取整,获取所述第一图像中各个像素点分别对应的各个整数中间光流值。
正如前面所说明的,所述前向光流中的各个前向光流值为浮点数,在获取到所述各个第一前向光流值之后,对所述各个第一前向光流值进行向上取整,也就是说,对于每一个前向光流值,是获取大于所述前向光流值且与所述前向光流值最接近的整数作为所述整数中间光流值。
S130、根据所述第一图像中各个像素点的坐标、所述各个第一前向光流值以及所述各个整数中间光流值获取所述第二图像中多个像素点的后向光流值。
具体地,如图3所示,在S130中,是根据公式
Figure BDA0002487737320000081
来获取所述第二图像中多个像素点的后向光流值,其中,
Figure BDA0002487737320000082
为所述第二图像中坐标为
Figure BDA0002487737320000083
的像素点的后向光流值,x为所述第一图像中的像素点的坐标,F0→1(x)为所述第一图像中坐标为x的像素点的第一前向光流值,
Figure BDA0002487737320000084
为所述第一图像中坐标为x的像素点对应的整数中间光流值。不难看出,由于所述第一图像中各个像素点的坐标为整数,即,x为整数,那么,
Figure BDA0002487737320000085
为整数,就能够获得所述第二图像中多个整数坐标点(即多个像素点)的后向光流值。不难看出,在采用这种方式获取所述后向光流时,包含了默认条件:
Figure BDA0002487737320000086
相当于用所述第二图像中坐标为
Figure BDA0002487737320000087
的点在1个像素点范围内的浮点坐标x+F0→1(x)处的后向光流值作为
Figure BDA0002487737320000088
处的后向光流值。这样,将所述后向光流值的误差控制在一个像素点内,提高插帧效果。
请参照图1,在获取到所述前向光流和所述后向光流之后,所述视频插帧方法还包括:
S200、根据所述前向光流获取所述第一图像中的第一遮挡区域,根据所述后向光流获取所述第二图像中的第二遮挡区域。
所述第一图像和所述第二图像中的物体可能存在遮挡的情形,在本实施例中,将在所述第一图像中可见,而在所述第二图像中被遮挡的区域称为所述第一图像中的第一遮挡区域,将在所述第一图像中被遮挡,而在所述第二图像中可见的区域称为所述第二图像中的第二遮挡区域。遮挡区域的像素点的前向光流值和后向光流值往往是不准确的,因此,在本实施例中,还获取所述第一遮挡区域和所述第二遮挡区域,分别根据所述第一遮挡区域和所述第二遮挡区域对所述前向光流和所述后向光流进行修正。
具体地,所述根据所述前向光流获取所述第一图像中的第一遮挡区域包括:
S211、从所述第一图像中的各个像素点中提取至少一个像素点集合,所述像素点集合中包括至少两个像素点,所述像素点集合中前向光流值指向所述第二图像中的同一点的各个像素点。
如果所述第一图像中存在两个或以上的像素点的前向光流值指向所述第二图像中的同一点,那么这些前向光流值指向同一点的像素点中的部分像素点在一段时间的运动后,在所述第二图像中被遮挡了,如图4所示,图像I0上坐标分别为x和y的像素点的前向光流值都指向图像I1上的z点,即x+F0→1(x)=y+F0→1(y),那么x和y中有像素点在图像I1上被遮挡了。
在本实施例中,获取所述第一图像中各个像素点中前向光流值指向所述第二图像中的同一点的像素点的像素点集合,也就是说,每个像素点集合中包括的各个像素点的前向光流值指向所述第二图像中的同一点。
S212、获取所述像素点集合中各个像素点分别对应的各个像素值以及所述像素点集合中各个像素点的前向光流值在所述第二图像中指向的点的第二像素值,将所述像素点集合中像素值与所述第二像素值最接近的像素点之外的像素点标记为第一遮挡区域。
在获取到在所述第一图像中可见,在所述第二图像中可能被遮挡的像素点后,根据这些像素点的像素值和这些像素点的前向光流值指向的所述第二图像中的点的像素值来确定这些像素点中哪些被遮挡,具体地,是将所述像素点集合中各个像素点分别对应的各个像素值以及所述像素点集合中各个像素点的前向光流值在所述第二图像中指向的点的第二像素值,确定所述像素点集合中像素值与所述第二像素值最接近的像素点没有被遮挡,也就是说,所述像素点集合中像素值与所述第二像素值最接近的像素点的前向光流值是真实的,将所述像素点集合中其余的像素点标记为第一遮挡区域。具体地,所述像素点集合中各个像素点的前向光流值在所述第二图像中指向的点的坐标可能不是整数,也就是说,这个点不是像素点,那么可以通过双线性插值的方法求得该点的像素值作为所述第二像素值,或者是获取与这个点最接近的像素点的像素值作为所述第二像素值。所述像素点集合可能有多个,在获取所有的所述像素点集合中标记为第一遮挡区域的像素点,则获取到了在所述第一图像上的所述第一遮挡区域。例如,图4中的图像I0上坐标分别为x和y的像素点的前向光流值都指向图像I1上的z点,那么,获取坐标分别为x和y的像素点的像素值I0(x),I0(y)以及图像I1上的z点的像素值I1(z),如果I1(z)和I0(x)更接近,那么确定I0上坐标为y的像素点在图像I1上被遮挡了,标记I0上坐标为y的像素点为第一遮挡区域。
所述根据所述后向光流获取所述第二图像中的第二遮挡区域包括:
S221、获取各个后向光流值对应的第三像素点;
S222、将所述第二图像中所述第三像素点之外的像素点标记为第二遮挡区域。
所述第二图像中的所述第二遮挡区域是在所述第二图像中可见,在所述第一图像中被遮挡的区域,而在所述第一图像中被遮挡的区域在所述第一图像中是不存在对应的前向光流值的,也就是说,所述第二图像上的第二遮挡区域中的点不会被所述前向光流所指向,因此,在根据所述前向光流获取所述后向光流时,当所述第二图像中存在所述第二遮挡区域时,根据所述前向光流获取到后向光流值的像素点是所述第二图像中的部分像素点,而不能获取到所述第二图像中所述第二遮挡区域中的点的后向光流值。在获取所述第二遮挡区域时,获取各个后向光流值对应的第三像素点,所述第三像素点在所述第一图像中也是可见的,而所述第三像素点之外的像素点在所述第一图像中被遮挡,将所述第二图像中所述第三像素点之外的像素点标记为所述第二遮挡区域。
所述视频插帧方法还包括:
S300、对所述第一遮挡区域内对应的前向光流值进行修正,生成修正前向光流,对所述第二遮挡区域对应的后向光流值进行修正,生成修正后向光流。
根据前面的说明,由于所述第一图像中的所述第一遮挡区域内的像素点在所述第二图像中被遮挡,那么,无法获取所述第一遮挡区域内的像素点的真实的前向光流值,同样地,由于所述第二图像中的所述第二遮挡区域内的像素点在所述第一图像中被遮挡,所述后向光流中不存在所述第二遮挡区域的像素点的后向光流值,因此,在本发明提供的视频插帧方法中,还对所述前向光流和所述后向光流进行修正。
具体地,所述对所述第一遮挡区域对应的前向光流值进行修正包括:
S311、获取与所述第一遮挡区域中第一目标像素点的距离小于第一预设值的至少一个预设尺寸的第一非遮挡区域。
由于物体在所述第一图像和所述第二图像之间的运动为刚性运动,那么同一个语义物体具有相同的运动,即同一个语义物体前向光流基本一样,而同一个语义物体一般具有相似的像素值,因此,在本实施例中,对于所述第一遮挡区域中的每个第一目标像素点,是获取所述所述第一目标像素点周围的至少一个第一非遮挡区域,根据各个第一非遮挡区域的像素值来确定各个第一非遮挡区域中哪个区域与所述第一目标像素点属于同一个语义物体。具体地,是获取与所述第一目标像素点距离小于所述第一预设值的预设尺寸的第一非遮挡区域,所述第一非遮挡区域可以是不在所述第一遮挡区域内的单个像素点,即所述第一非遮挡区域的预设尺寸为1*1,获取与所述第一目标像素点距离小于所述第一预设值的预设尺寸的第一非遮挡区域即为获取与所述第一目标像素点最接近的不在所述第一遮挡区域内的像素点;所述第一非遮挡区域还可以是不在所述第一遮挡区域内的多个像素点组成的区域,所述预设尺寸可以为3*3,或者5*3等等,此时第一非遮挡区域与所述第一目标像素点的距离是第一非遮挡区域的中心像素点与所述第一目标像素点的距离,也就是说,获取以与所述第一目标像素点距离小于所述第一预设值的像素点为中心的预设尺寸的非遮挡区域。所述第一预设值可以是两个像素点、五个像素点等,不难看出,在这种情况下,所述第一非遮挡区域可以有多个。在一种可能的实现方式中,所述第一预设值可以是根据所述第一图像中各个预设尺寸的非遮挡区域与所述第一目标像素点的距离中的最小值来确定,具体地,是可以直接获取与所述第一目标像素点的距离最小的预设尺寸的非遮挡区域作为所述第一非遮挡区域,值得说明的是,在这种情况下,也可能存在多个第一非遮挡区域,也就是说,存在多个预设尺寸的非遮挡区域的距离与所述第一目标像素点的距离最小且相等,这和计算距离时选取的精度有关。
S312、获取各个第一非遮挡区域分别对应的像素值,将所述第一目标像素点的前向光流值修正为目标前向光流值,其中,所述目标前向光流值为与所述第一目标像素点的像素值最接近的第一非遮挡区域对应的前向光流值。
在获取到各个第一非遮挡区域后,获取所述各个第一非遮挡区域分别对应的像素值,具体地,所述第一非遮挡区域对应的像素值可以是所述第一非遮挡区域内包含的所有像素点的平均像素值、所述第一非遮挡区域内的中心像素点的像素值、或者是所述第一非遮挡区域内与所述第一目标像素点最接近的像素点的像素值等。将各个第一非遮挡区域对应的像素值与所述第一目标像素点的像素值进行比较,获取像素值与所述第一目标像素点的像素值最接近的第一非遮挡区域,将所述第一目标像素点的前向光流值修正为该第一非遮挡区域对应的前向光流值(即所述目标前向光流值)。具体地,所述第一非遮挡区域对应的前向光流值可以是所述第一非遮挡区域内包含的所有像素点的平均前向光流值,所述第一非遮挡区域内的中心像素点的前向光流值、或者是所述第一非遮挡区域内与所述第一目标像素点最接近的像素点的前向光流值等。
所述第一目标像素点为所述第一遮挡区域内的各个像素点,在对所述第一遮挡区域内各个像素点的前向光流值进行修正后,生成所述修正前向光流。
所述对所述第二遮挡区域对应的后向光流值进行修正包括:
S321、获取与所述第二遮挡区域中第二目标像素点的距离小于第二预设值的至少一个预设尺寸的第二非遮挡区域。
与所述第一遮挡区域类似,在本实施例中,对于所述第二遮挡区域中的每个第二目标像素点,是获取所述所述第二目标像素点周围的至少一个第二非遮挡区域,根据各个第二非遮挡区域的像素值来确定各个第二非遮挡区域中哪个区域与所述第二目标像素点属于同一个语义物体。具体地,是获取与所述第二目标像素点距离小于第二预设值的预设尺寸的第二非遮挡区域,所述第二非遮挡区域可以是不在所述第二遮挡区域内的单个像素点,即所述第二非遮挡区域的预设尺寸为1*1,获取与所述第二目标像素点距离小于所述第二预设值的预设尺寸的第二非遮挡区域即为获取与所述第二目标像素点最接近的不在所述第二遮挡区域内的像素点;所述第二非遮挡区域还可以是不在所述第二遮挡区域内的多个像素点组成的区域,所述预设尺寸可以为3*3,或者5*3等等,此时第二非遮挡区域与所述第二目标像素点的距离是第二非遮挡区域的中心像素点与所述第二目标像素点的距离,也就是说,获取以与所述第二目标像素点距离小于所述第二预设值的像素点为中心的预设尺寸的非遮挡区域。所述第二预设值可以与所述第一预设值相等,也可以不同,所述第二预设值可以是两个像素点、五个像素点等,不难看出,在这种情况下,所述第二非遮挡区域可以有多个。在一种可能的实现方式中,所述第二预设值可以是根据所述第二图像中各个预设尺寸的非遮挡区域与所述第二目标像素点的距离中的最小值来确定,具体地,是可以直接获取与所述第二目标像素点的距离最小的预设尺寸的非遮挡区域作为所述第二非遮挡区域,值得说明的是,在这种情况下,也可能存在多个第二非遮挡区域,也就是说,存在多个预设尺寸的非遮挡区域的距离与所述第二目标像素点的距离最小且相等,这和计算距离时选取的精度有关。
S322、获取所述各个第二非遮挡区域分别对应的像素值,将所述第二目标像素点的后向光流值修正为目标后向光流值,其中,所述目标后向光流值为与所述第二目标像素点的像素值最接近的第二非遮挡区域对应的后向光流值。
在获取到各个第二非遮挡区域后,获取所述各个第二非遮挡区域分别对应的像素值,具体地,所述第二非遮挡区域对应的像素值可以是所述第二非遮挡区域内包含的所有像素点的平均像素值、所述第二非遮挡区域内的中心像素点的像素值、或者是所述第二非遮挡区域内与所述第二目标像素点最接近的像素点的像素值等。将各个第二非遮挡区域对应的像素值与所述第二目标像素点的像素值进行比较,获取像素值与所述第二目标像素点的像素值最接近的第二非遮挡区域,将所述第二目标像素点的后向光流值修正为该第二非遮挡区域对应的后向光流值(即所述目标后向光流值)。具体地,所述第二非遮挡区域对应的后向光流值可以是所述第二非遮挡区域内包含的所有像素点的平均后向光流值,所述第二非遮挡区域内的中心像素点的后向光流值、或者是所述第二非遮挡区域内与所述第二目标像素点最接近的像素点的后向光流值等。
所述第二目标像素点为所述第二遮挡区域内的各个像素点,在对所述第二遮挡区域内各个像素点的后向光流值进行修正后,生成所述修正后向光流。
获取所述修正前向光流和所述修正后向光流后,所述视频插帧方法还包括:
S400、根据所述修正前向光流和所述修正后向光流生成用于插入至所述第一图像和所述第二图像之间的目标帧。
所述根据所述修正前向光流和所述修正后向光流生成用于插入至所述第一图像和所述第二图像之间的目标帧包括:
根据所述修正前向光流和所述第一图像生成第一中间帧,根据所述修正后向光流和所述第二图像生成第二中间帧;
根据所述第一中间帧和所述第二中间帧生成所述目标帧。
所述目标帧是时间顺序上在所述第一图像和所述第二图像之间的一帧图像,那么根据所述目标帧与所述第一图像的时间间隔,可以获取到所述第一图像到所述目标帧的光流以及所述第二图像到所述目标帧的光流,而由于所述第一图像和所述第二图像中的物体是运动的,那么,所述目标帧上可能存在部分像素点在所述中间帧上可见,而在所述第一图像上被遮挡,那么,此时根据所述第一图像到所述目标帧的光流是无法求出这部分像素点的像素值,但是,这部分像素点很大概率在所述第二图像上是可见的,因此,可以根据所述第二图像到所述目标帧的光流来求得这部分像素点的像素值;也可能存在部分像素点在所述中间帧上可见,而在所述第二图像上被遮挡,那么,根据所述第二图像到所述中间帧的光流是无法求出这部分像素点的像素值,但是,同样地,这部分像素点很大概率在所述第一图像上可见,因此,可以根据所述第一图像到所述目标帧的光流来求得这部分像素点的像素值。因此,可以根据所述所述第一图像到所述目标帧的光流来获取所述第一中间帧,根据所述第二图像到所述目标帧的光流来获取所述第二中间帧,并将二者进行融合,即使用所述第二中间帧去补所述第一中间帧中缺失的像素点的像素值,或使用所述第一中间帧去补所述第二中间帧中缺失的像素点的像素值,进而生成完整的所述目标帧。
具体地,所述根据所述修正前向光流和所述第一图像生成第一中间帧包括:
S411、根据所述修正前向光流获取所述第一图像到所述目标帧的第一中间光流。
具体地,在确定了所述目标帧距所述第一图像和所述第二图像的时间后,就可以根据所述修正前向光流获取所述第一图像到所述目标帧的第一中间光流,此为现有技术,在此不再赘述。
S412、根据第一预设公式以及所述第一中间光流获取第一中间帧上多个像素点对应的像素值,生成所述第一中间帧。
所述第一图像上坐标为m的像素点对应的第一中间光流值反映了所述第一图像上坐标为m的像素点在所述第一图像和所述第一中间帧之间的位移,记所述第一图像上坐标为m的像素点的第一中间光流值为F0→t(m),也就是说,所述第一图像上坐标为m的像素点在所述第一中间帧上的坐标为m+F0→t(m),也就是说,所述第一中间帧上坐标为m+F0→t(m)的像素点的像素值等于所述所述第一图像上坐标为m的像素点的像素值,用公式可以记为:I0(m)=It1(m+F0→t(m)),其中,I0(m)为所述第一图像上坐标为m的像素点的像素值,It1(m+F0→t(m))为所述第一中间帧上坐标为m+F0→t(m)的像素点的像素值,F0→t(m)为所述第一图像上坐标为m的像素点的第一中间光流值。
正如前面所说明的,光流值为浮点数,往往不是整数,也就是说,m+F0→t(m)往往不是整数,而在生成所述第一中间帧时,需要获取所述第一中间帧上各个坐标为整数的像素点的像素值。在本实施例中,通过第一预设公式来获取所述第一中间帧上多个像素点的像素值,所述第一预设公式为:I0(m+Δm)=It1(m+Δm+F0→t(m))
其中,I0(m+Δm)为所述第一图像上坐标为m+Δm的点的像素值,It1(m+Δm+F0→t(m))为所述第一中间帧上坐标为m+Δm+F0→t(m)的像素点的像素值,F0→t(m)为所述第一图像上坐标为m的像素点对应的第一中间光流值,m为整数,Δm为使得Δm+F0→t(m)为整数的值,0≤Δm<1。这样,可以求得所述第一中间帧上多个整数坐标点的像素值,其中所述第一图像上坐标为m+Δm的点的像素值可以通过双线性插值的方式获取。
正如前面所说明的,在所述第一中间帧上可能存在部分像素点在所述第一中间帧上可见,而在所述第一图像上被遮挡,那么,这些像素点不会被第一中间光流所指向,也就是说,无法根据所述第一图像和所述第一中间光流求出这些像素点的像素值,也就是说,所述第一中间帧中缺失了部分像素点的像素值。在本实施例中,是根据所述修正后向光流和所述第二图像生成第二中间帧,使用所述第二中间帧获取这些像素点的像素值。
所述根据所述修正后向光流和所述第二图像生成第二中间帧包括:
S421、根据所述修正后向光流获取所述第二图像到所述目标帧的第二中间光流。
在确定了所述目标帧距所述第一图像和所述第二图像的时间后,就可以根据所述修正后向光流获取所述第二图像到所述目标帧的第二中间光流,此为现有技术,在此不再赘述。
S422、根据第二预设公式以及所述第二中间光流获取第二中间帧上多个像素点对应的像素值,生成所述第二中间帧。
与所述第一中间帧类似,所述第二图像上坐标为n的像素点对应的第二中间光流值反映了所述第二图像上坐标为n的像素点在所述第二图像和所述第二中间帧之间的位移,记所述第二图像上坐标为n的像素点的第二中间光流值为F1→t(n),也就是说,所述第二图像上坐标为n的像素点在所述第二中间帧上的坐标为n+F1→t(n),也就是说,所述第二中间帧上坐标为n+F1→t(n)的像素点的像素值等于所述所述第二图像上坐标为n的像素点的像素值,用公式可以记为:I1(n)=It2(n+F1→t(n)),其中,I1(n)为所述第二图像上坐标为n的像素点的像素值,It2(n+F1→t(n))为所述第二中间帧上坐标为n+F1→t(n)的像素点的像素值,F1→t(n)为所述第二图像上坐标为n的像素点的第二中间光流值。
正如前面所说明的,光流值为浮点数,往往不是整数,也就是说,n+F1→t(n)往往不是整数,而在生成所述第二中间帧时,需要获取所述第二中间帧上各个坐标为整数的像素点的像素值。在本实施例中,通过第二预设公式来获取所述第二中间帧上多个像素点的像素值,所述第二预设公式为:I1(n+Δn)=It2(n+Δn+F1→t(n))
其中,I1(n+Δn)为所述第二图像上坐标为n+Δn的点的像素值,It2(n+Δn+F1→t(n))为所述第二中间帧上坐标为n+Δn+F1→t(n)的像素点的像素值,F1→t(n)为所述第二图像上坐标为n的像素点对应的第二中间光流值,n为整数,Δn为使得Δn+F1→t(n)为整数的值,0≤Δn<1。这样,可以求得所述第二中间帧上多个整数坐标点的像素值,其中所述第二图像上坐标为n+Δn的点的像素值可以通过双线性插值的方式获取。
在实际应用中还可能出现所述第一图像上的像素点在所述第一中间帧上被遮挡,所述第二图像上的像素点在所述第二中间帧上被遮挡的情况,因此,在本实施例中,所述根据所述第一预设公式以及所述第一中间光流获取第一中间帧上各个像素点对应的像素值包括:
S4121、当所述第一图像中存在多个第一像素点对应的第一中间光流值指向所述第一中间帧上的同一个像素点时,获取所述多个第一像素点中不处于所述第一遮挡区域内的第三像素点,将所述第三像素点在所述第一中间帧上对应的像素点的像素值作为所述多个第一像素点在所述第一中间帧上对应的像素点的像素值。
当所述第一图像中存在多个第一像素点对应的第一中间光流值指向所述第一中间帧上的同一个像素点时,说明所述多个第一像素点中包括在所述第一图像上可见,在所述第一中间帧上被遮挡的像素点,而所述第一遮挡区域是在所述第一图像上可见,在所述第二图像上被遮挡的区域,在本实施例中在所述多个第一像素点中,确定属于所述第一遮挡区域内的第一像素点是在所述第一中间帧上被遮挡的点。获取所述多个第一像素点中不处于所述第一遮挡区域内的第三像素点,将所述第三像素点在所述第一中间帧上对应的像素点的像素值作为所述多个第一像素点在所述第一中间帧上对应的像素点的像素值。
所述根据所述第二预设公式以及所述第二中间光流获取第二中间帧上各个像素点对应的像素值包括:
S4221、当所述第二图像中存在多个第二像素点对应的第二中间光流值指向所述第二中间帧上的同一个像素点时,获取所述多个第二像素点中不处于所述第二遮挡区域内的第四像素点,将所述第四像素点在所述第二中间帧上对应的像素点的像素值作为所述多个像素点在所述第二中间帧上对应的像素点的像素值。
当所述第二图像中存在多个第二像素点对应的第二中间光流值指向所述第二中间帧上的同一个像素点时,说明所述多个第二像素点中包括在所述第二图像上可见,在所述第二中间帧上被遮挡的像素点,而所述第二遮挡区域是在所述第二图像上可见,在所述第一图像上被遮挡的区域,在本实施例中,在所述多个第二像素点中,确定属于所述第二遮挡区域内的第二像素点是在所述第二中间帧上被遮挡的点。获取所述多个第二像素点中不处于所述第二遮挡区域内的第四像素点,将所述第四像素点在所述第二中间帧上对应的像素点的像素值作为所述多个第二像素点在所述第二中间帧上对应的像素点的像素值。
从上面的说明不难看出,所述第一中间帧中包含了根据所述第一图像和所述前向修正光流获得的所述目标帧上的部分像素点的像素值,所述第二中间帧中包含了根据所述第二图像和所述后向修正光流获得的所述目标帧上的部分像素点的像素值,将所述第一中间帧和所述第二中间帧进行融合,可以获取到所述目标帧上所有像素点的像素值,进而生成所述目标帧,而正如前面所提到的,可以是保留所述第一中间帧中的所有像素点的像素值,对于所述第一中间帧中缺失的像素点的像素值,获取所述第二中间帧中相应的像素点的像素值进行补充,也可以是保留所述第二中间帧上的所有像素点的像素值,对于所述第二中间帧中缺失的像素点的像素值,获取所述第一中间帧中相应的像素点的像素值进行补充,而由于所述后向光流是根据所述前向光流求得的,因此,所述修正前向光流比所述后向修正后向光流的准确性更高,即,所述第一中间帧比所述第二中间帧的准确性更高,因此,在本实施例中,是优先保留所述第一中间帧中的像素点的像素值,对于所述第一中间帧上无法获取到像素值的像素点,使用所述第二中间帧中相应坐标的像素点的像素值进行补充。
如图5所示,图5为本实施例提供的视频插帧方法与现有方法的插帧效果对比图,图5中第一行为待插入目标帧的图像对中的第一图像,第四行为待插入目标帧的图像对中的第二图像,第二行为现有方法中生成的目标帧,第三行为本实施例提供的视频插帧方法生成的目标帧,从图5中不难看出,相对于现有方法,本实施例提供的视频插帧方法生成的目标帧没有前景重影和边缘黑影,效果更好。
综上所述,本实施例提供一种视频插帧方法,对待插入目标帧的目标图像对,分别计算前向光流和后向光流,根据前向光流和后向光流获取图像中的遮挡区域,并根据图像中的遮挡区域对前向光流和后向光流进行修正,使用修正后的前向光流和后向光流来生成目标帧,由于在生成目标帧的过程中对于遮挡区域进行了单独的光流修正,能够提高存在遮挡情形下的插帧效果。
应该理解的是,虽然本发明说明书附图中给出的的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,这些步骤可以以其它的顺序执行。而且,流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,这些子步骤或者阶段的执行顺序也不必然是依次进行,而是可以与其它步骤或者其它步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一非易失性计算机可读取存储介质中,该计算机程序在执行时,可包括如上述各方法的实施例的流程。其中,本发明所提供的各实施例中所使用的对存储器、存储、数据库或其它介质的任何引用,均可包括非易失性和/或易失性存储器。非易失性存储器可包括只读存储器(ROM)、可编程ROM(PROM)、电可编程ROM(EPROM)、电可擦除可编程ROM(EEPROM)或闪存。易失性存储器可包括随机存取存储器(RAM)或者外部高速缓冲存储器。作为说明而非局限,RAM以多种形式可得,诸如静态RAM(SRAM)、动态RAM(DRAM)、同步DRAM(SDRAM)、双数据率SDRAM(DDRSDRAM)、增强型SDRAM(ESDRAM)、同步链路(Synchlink)DRAM(SLDRAM)、存储器总线(Rambus)直接RAM(RDRAM)、直接存储器总线动态RAM(DRDRAM)、以及存储器总线动态RAM(RDRAM)等。
实施例二
基于上述实施例,本发明还提供了一种终端,其原理框图可以如图6所示。该终端包括通过系统总线连接的处理器、存储器、网络接口、显示屏、温度传感器。其中,该终端的处理器用于提供计算和控制能力。该终端的存储器包括非易失性存储介质、内存储器。该非易失性存储介质存储有操作系统和计算机程序。该内存储器为非易失性存储介质中的操作系统和计算机程序的运行提供环境。该终端的网络接口用于与外部的终端通过网络连接通信。该计算机程序被处理器执行时以实现一种视频插帧方法。该终端的显示屏可以是液晶显示屏或者电子墨水显示屏,该终端的温度传感器是预先在终端内部设置,用于检测内部设备的当前运行温度。
本领域技术人员可以理解,图6中示出的原理框图,仅仅是与本发明方案相关的部分结构的框图,并不构成对本发明方案所应用于其上的终端的限定,具体的终端可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
在一个实施例中,提供了一种终端,包括存储器和处理器,存储器中存储有计算机程序,该处理器执行计算机程序时至少可以实现以下步骤:
获取目标图像对对应的前向光流,根据所述前向光流获取所述目标图像对对应的后向光流,其中,所述前向光流为所述目标图像对中第一图像到第二图像的光流,所述后向光流为所述第二图像到所述第一图像的光流;
根据所述前向光流获取所述第一图像中的第一遮挡区域,根据所述后向光流获取所述第二图像中的第二遮挡区域;
对所述第一遮挡区域对应的前向光流值进行修正,生成修正前向光流,对所述第二遮挡区域对应的后向光流值进行修正,生成修正后向光流;
根据所述修正前向光流和所述修正后向光流生成用于插入至所述第一图像和所述第二图像之间的目标帧。
其中,所述根据所述前向光流获取所述目标图像对对应的后向光流包括:
获取所述第一图像中各个像素点分别对应的各个第一前向光流值;
对所述各个第一前向光流值向上取整,获取所述第一图像中各个像素点分别对应的各个整数中间光流值;
根据所述第一图像中各个像素点的坐标、所述各个第一前向光流值以及所述各个整数中间光流值获取所述第二图像中多个像素点的后向光流值。
其中,所述根据所述第一图像中各个像素点的坐标、所述各个第一前向光流值以及所述各个整数中间光流值获取所述第二图像中多个像素点的后向光流值包括:
根据公式
Figure BDA0002487737320000231
获取所述第二图像中多个像素点的后向光流值;
其中,
Figure BDA0002487737320000232
为所述第二图像中坐标为
Figure BDA0002487737320000233
的像素点的后向光流值,x为所述第一图像中的像素点的坐标,F0→1(x)为所述第一图像中坐标为x的像素点的第一前向光流值,
Figure BDA0002487737320000234
为所述第一图像中坐标为x的像素点对应的整数中间光流值。
其中,所述根据所述前向光流获取所述第一图像的第一遮挡区域包括:
从所述第一图像中的各个像素点中提取至少一个像素点集合,所述像素点集合中包括至少两个像素点,所述像素点集合中包括前向光流值指向所述第二图像中的同一点的各个像素点;
获取所述像素点集合中各个像素点分别对应的各个像素值以及所述像素点集合中各个像素点的前向光流值在所述第二图像中指向的点的第二像素值,将所述像素点集合中像素值与所述第二像素值最接近的像素点之外的像素点标记为第一遮挡区域。
其中,所述根据所述后向光流获取所述第二图像的第二遮挡区域包括:
获取各个后向光流值对应的第三像素点;
将所述第二图像中所述第三像素点之外的像素点标记为第二遮挡区域。
其中,所述对所述第一遮挡区域对应的前向光流值进行修正包括:
获取与所述第一遮挡区域中第一目标像素点的距离小于第一预设值的至少一个预设尺寸的第一非遮挡区域;
获取各个第一非遮挡区域分别对应的像素值,将所述第一目标像素点的前向光流值修正为目标前向光流值,其中,所述目标前向光流值为与所述第一目标像素点的像素值最接近的第一非遮挡区域对应的前向光流值;
所述对所述第二遮挡区域对应的后向光流值进行修正包括:
获取与所述第二遮挡区域中第二目标像素点的距离小于第二预设值的至少一个预设尺寸的第二非遮挡区域;
获取各个第二非遮挡区域分别对应的像素值,将所述第二目标像素点的后向光流值修正为目标后向光流值,其中,所述目标后向光流值为与所述第二目标像素点的像素值最接近的第二非遮挡区域对应的后向光流值。
其中,所述根据所述修正前向光流和所述修正后向光流生成用于插入至所述第一图像和所述第二图像之间的目标帧包括:
根据所述修正前向光流和所述第一图像生成第一中间帧,根据所述修正后向光流和所述第二图像生成第二中间帧;
根据所述第一中间帧和所述第二中间帧生成所述目标帧。
其中,所述根据所述修正前向光流和所述第一图像生成第一中间帧包括:
根据所述修正前向光流获取所述第一图像到所述目标帧的第一中间光流;
根据第一预设公式以及所述第一中间光流获取第一中间帧上多个像素点对应的像素值,生成所述第一中间帧;
所述根据所述修正后向光流和所述第二图像生成第二中间帧包括:
根据所述修正后向光流获取所述第二图像到所述目标帧的第二中间光流;
根据第二预设公式以及所述第二中间光流获取第二中间帧上多个像素点对应的像素值,生成所述第二中间帧。
其中,所述第一预设公式为:I0(m+Δm)=It1(m+Δm+F0→t(m))
其中,I0(m+Δm)为所述第一图像上坐标为m+Δm的点的像素值,It1(m+Δm+F0→t(m))为所述第一中间帧上坐标为m+Δm+F0→t(m)的像素点的像素值,F0→t(m)为所述第一图像上坐标为m的像素点对应的第一中间光流值,m为整数,Δm为使得Δm+F0→t(m)为整数的值,0≤Δm<1;
所述第二预设公式为:I1(n+Δn)=It2(n+Δn+F1→t(n))
其中,I1(n+Δn)为所述第二图像上坐标为n+Δn的点的像素值,It2(n+Δn+F1→t(n))为所述第二中间帧上坐标为n+Δn+F1→t(n)的像素点的像素值,F1→t(n)为所述第二图像上坐标为n的像素点对应的第二中间光流值,n为整数,Δn为使得Δn+F1→t(n)为整数的值,0≤Δn<1。
其中,所述根据所述第一预设公式以及所述第一中间光流获取第一中间帧上各个像素点对应的像素值包括:
当所述第一图像中存在多个第一像素点对应的第一中间光流值指向所述第一中间帧上的同一个像素点时,获取所述多个第一像素点中不处于所述第一遮挡区域内的第三像素点,将所述第三像素点在所述第一中间帧上对应的像素点的像素值作为所述多个第一像素点在所述第一中间帧上对应的像素点的像素值;
所述根据所述第二预设公式以及所述第二中间光流获取第二中间帧上各个像素点对应的像素值包括:
当所述第二图像中存在多个第二像素点对应的第二中间光流值指向所述第二中间帧上的同一个像素点时,获取所述多个第二像素点中不处于所述第二遮挡区域内的第四像素点,将所述第四像素点在所述第二中间帧上对应的像素点的像素值作为所述多个像素点在所述第二中间帧上对应的像素点的像素值。
实施例三
本发明还提供了一种存储介质,所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现上述实施例所述的视频插帧方法的步骤。
最后应说明的是:以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。

Claims (12)

1.一种视频插帧方法,其特征在于,所述视频插帧方法包括:
获取目标图像对对应的前向光流,根据所述前向光流获取所述目标图像对对应的后向光流,其中,所述前向光流为所述目标图像对中第一图像到第二图像的光流,所述后向光流为所述第二图像到所述第一图像的光流;
根据所述前向光流获取所述第一图像中的第一遮挡区域,根据所述后向光流获取所述第二图像中的第二遮挡区域;
对所述第一遮挡区域对应的前向光流值进行修正,生成修正前向光流,对所述第二遮挡区域内对应的后向光流值进行修正,生成修正后向光流;
根据所述修正前向光流和所述修正后向光流生成用于插入至所述第一图像和所述第二图像之间的目标帧。
2.根据权利要求1所述的视频插帧方法,其特征在于,所述根据所述前向光流获取所述目标图像对对应的后向光流包括:
获取所述第一图像中各个像素点分别对应的各个第一前向光流值;
对所述各个第一前向光流值向上取整,获取所述第一图像中各个像素点分别对应的各个整数中间光流值;
根据所述第一图像中各个像素点的坐标、所述各个第一前向光流值以及所述各个整数中间光流值获取所述第二图像中多个像素点的后向光流值。
3.根据权利要求2所述的视频插帧方法,其特征在于,所述根据所述第一图像中各个像素点的坐标、所述各个第一前向光流值以及所述各个整数中间光流值获取所述第二图像中多个像素点的后向光流值包括:
根据公式
Figure FDA0002487737310000011
获取所述第二图像中多个像素点的后向光流值;
其中,
Figure FDA0002487737310000012
为所述第二图像中坐标为
Figure FDA0002487737310000013
的像素点的后向光流值,x为所述第一图像中的像素点的坐标,F0→1(x)为所述第一图像中坐标为x的像素点的第一前向光流值,
Figure FDA0002487737310000021
为所述第一图像中坐标为x的像素点对应的整数中间光流值。
4.根据权利要求1所述的视频插帧方法,其特征在于,所述根据所述前向光流获取所述第一图像的第一遮挡区域包括:
从所述第一图像中的各个像素点中提取至少一个像素点集合,所述像素点集合中包括至少两个像素点,所述像素点集合中包括前向光流值指向所述第二图像中的同一点的各个像素点;
获取所述像素点集合中各个像素点分别对应的各个像素值以及所述像素点集合中各个像素点的前向光流值在所述第二图像中指向的点的第二像素值,将所述像素点集合中像素值与所述第二像素值最接近的像素点之外的像素点标记为第一遮挡区域。
5.根据权利要求1所述的视频插帧方法,其特征在于,所述根据所述后向光流获取所述第二图像的第二遮挡区域包括:
获取各个后向光流值对应的第三像素点;
将所述第二图像中所述第三像素点之外的像素点标记为第二遮挡区域。
6.根据权利要求1所述的视频插帧方法,其特征在于,所述对所述第一遮挡区域对应的前向光流值进行修正包括:
获取与所述第一遮挡区域中第一目标像素点的距离小于第一预设值的至少一个预设尺寸的第一非遮挡区域;
获取各个第一非遮挡区域分别对应的像素值,将所述第一目标像素点的前向光流值修正为目标前向光流值,其中,所述目标前向光流值为与所述第一目标像素点的像素值最接近的第一非遮挡区域对应的前向光流值;
所述对所述第二遮挡区域对应的后向光流值进行修正包括:
获取与所述第二遮挡区域中第二目标像素点的距离小于第二预设值的至少一个预设尺寸的第二非遮挡区域;
获取各个第二非遮挡区域分别对应的像素值,将所述第二目标像素点的后向光流值修正为目标后向光流值,其中,所述目标后向光流值为与所述第二目标像素点的像素值最接近的第二非遮挡区域对应的后向光流值。
7.根据权利要求1所述的视频插帧方法,其特征在于,所述根据所述修正前向光流和所述修正后向光流生成用于插入至所述第一图像和所述第二图像之间的目标帧包括:
根据所述修正前向光流和所述第一图像生成第一中间帧,根据所述修正后向光流和所述第二图像生成第二中间帧;
根据所述第一中间帧和所述第二中间帧生成所述目标帧。
8.根据权利要求7所述的视频插帧方法,其特征在于,所述根据所述修正前向光流和所述第一图像生成第一中间帧包括:
根据所述修正前向光流获取所述第一图像到所述目标帧的第一中间光流;
根据第一预设公式以及所述第一中间光流获取第一中间帧上多个像素点对应的像素值,生成所述第一中间帧;
所述根据所述修正后向光流和所述第二图像生成第二中间帧包括:
根据所述修正后向光流获取所述第二图像到所述目标帧的第二中间光流;
根据第二预设公式以及所述第二中间光流获取第二中间帧上多个像素点对应的像素值,生成所述第二中间帧。
9.根据权利要求8所述的视频插帧方法,其特征在于,所述第一预设公式为:I0(m+Δm)=It1(m+Δm+F0→t(m))
其中,I0(m+Δm)为所述第一图像上坐标为m+Δm的点的像素值,It1(m+Δm+F0→t(m))为所述第一中间帧上坐标为m+Δm+F0→t(m)的像素点的像素值,F0→t(m)为所述第一图像上坐标为m的像素点对应的第一中间光流值,m为整数,Δm为使得Δm+F0→t(m)为整数的值,0≤Δm<1;
所述第二预设公式为:I1(n+Δn)=It2(n+Δn+F1→t(n))
其中,I1(n+Δn)为所述第二图像上坐标为n+Δn的点的像素值,It2(n+Δn+F1→t(n))为所述第二中间帧上坐标为n+Δn+F1→t(n)的像素点的像素值,F1→t(n)为所述第二图像上坐标为n的像素点对应的第二中间光流值,n为整数,Δn为使得Δn+F1→t(n)为整数的值,0≤Δn<1。
10.根据权利要求8所述的视频插帧方法,其特征在于,所述根据所述第一预设公式以及所述第一中间光流获取第一中间帧上各个像素点对应的像素值包括:
当所述第一图像中存在多个第一像素点对应的第一中间光流值指向所述第一中间帧上的同一个像素点时,获取所述多个第一像素点中不处于所述第一遮挡区域内的第三像素点,将所述第三像素点在所述第一中间帧上对应的像素点的像素值作为所述多个第一像素点在所述第一中间帧上对应的像素点的像素值;
所述根据所述第二预设公式以及所述第二中间光流获取第二中间帧上各个像素点对应的像素值包括:
当所述第二图像中存在多个第二像素点对应的第二中间光流值指向所述第二中间帧上的同一个像素点时,获取所述多个第二像素点中不处于所述第二遮挡区域内的第四像素点,将所述第四像素点在所述第二中间帧上对应的像素点的像素值作为所述多个像素点在所述第二中间帧上对应的像素点的像素值。
11.一种终端,其特征在于,所述终端包括:处理器、与处理器通信连接的存储介质,所述存储介质适于存储多条指令,所述处理器适于调用所述存储介质中的指令,以执行实现上述权利要求1-10任一项所述的视频插帧方法的步骤。
12.一种存储介质,其特征在于,所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现如权利要求1-10任一项所述的视频插帧方法的步骤。
CN202010396385.3A 2020-05-12 2020-05-12 一种视频插帧方法、终端以及存储介质 Pending CN113660443A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010396385.3A CN113660443A (zh) 2020-05-12 2020-05-12 一种视频插帧方法、终端以及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010396385.3A CN113660443A (zh) 2020-05-12 2020-05-12 一种视频插帧方法、终端以及存储介质

Publications (1)

Publication Number Publication Date
CN113660443A true CN113660443A (zh) 2021-11-16

Family

ID=78488659

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010396385.3A Pending CN113660443A (zh) 2020-05-12 2020-05-12 一种视频插帧方法、终端以及存储介质

Country Status (1)

Country Link
CN (1) CN113660443A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114205648A (zh) * 2021-12-07 2022-03-18 网易(杭州)网络有限公司 插帧方法及装置
WO2023160525A1 (zh) * 2022-02-22 2023-08-31 北京字跳网络技术有限公司 视频处理方法、装置、设备及介质

Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2007107685A1 (en) * 2006-03-23 2007-09-27 Nds Limited System for analysis of motion
KR20100087963A (ko) * 2009-01-29 2010-08-06 서강대학교산학협력단 광류 정보를 이용한 중간 영상 생성 방법
CN101854465A (zh) * 2010-02-01 2010-10-06 杭州海康威视软件有限公司 基于光流算法的图像处理方法及装置
CN103384331A (zh) * 2013-07-19 2013-11-06 上海交通大学 基于光流一致性的视频帧间篡改检测方法
CN105517671A (zh) * 2015-05-25 2016-04-20 北京大学深圳研究生院 一种基于光流法的视频插帧方法及系统
US20160269684A1 (en) * 2014-01-06 2016-09-15 Sk Telecom Co., Ltd. Method and apparatus for generating combined video stream for multiple images
JP2016173795A (ja) * 2015-03-18 2016-09-29 株式会社リコー 画像処理装置、画像処理方法およびプログラム
CN108074247A (zh) * 2016-11-11 2018-05-25 财团法人工业技术研究院 视频帧产生方法及其系统
US20180315174A1 (en) * 2017-05-01 2018-11-01 Gopro, Inc. Apparatus and methods for artifact detection and removal using frame interpolation techniques
CN109151474A (zh) * 2018-08-23 2019-01-04 复旦大学 一种生成新视频帧的方法
CN109816611A (zh) * 2019-01-31 2019-05-28 北京市商汤科技开发有限公司 视频修复方法及装置、电子设备和存储介质
CN109922231A (zh) * 2019-02-01 2019-06-21 重庆爱奇艺智能科技有限公司 一种用于生成视频的插帧图像的方法和装置
WO2019120012A1 (zh) * 2017-12-20 2019-06-27 深圳岚锋创视网络科技有限公司 一种视频解码的方法及相机
CN110392282A (zh) * 2018-04-18 2019-10-29 优酷网络技术(北京)有限公司 一种视频插帧的方法、计算机存储介质及服务器
CN111047626A (zh) * 2019-12-26 2020-04-21 深圳云天励飞技术有限公司 目标跟踪方法、装置、电子设备及存储介质

Patent Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2007107685A1 (en) * 2006-03-23 2007-09-27 Nds Limited System for analysis of motion
KR20100087963A (ko) * 2009-01-29 2010-08-06 서강대학교산학협력단 광류 정보를 이용한 중간 영상 생성 방법
CN101854465A (zh) * 2010-02-01 2010-10-06 杭州海康威视软件有限公司 基于光流算法的图像处理方法及装置
CN103384331A (zh) * 2013-07-19 2013-11-06 上海交通大学 基于光流一致性的视频帧间篡改检测方法
US20160269684A1 (en) * 2014-01-06 2016-09-15 Sk Telecom Co., Ltd. Method and apparatus for generating combined video stream for multiple images
JP2016173795A (ja) * 2015-03-18 2016-09-29 株式会社リコー 画像処理装置、画像処理方法およびプログラム
CN105517671A (zh) * 2015-05-25 2016-04-20 北京大学深圳研究生院 一种基于光流法的视频插帧方法及系统
CN108074247A (zh) * 2016-11-11 2018-05-25 财团法人工业技术研究院 视频帧产生方法及其系统
US20180315174A1 (en) * 2017-05-01 2018-11-01 Gopro, Inc. Apparatus and methods for artifact detection and removal using frame interpolation techniques
WO2019120012A1 (zh) * 2017-12-20 2019-06-27 深圳岚锋创视网络科技有限公司 一种视频解码的方法及相机
CN110392282A (zh) * 2018-04-18 2019-10-29 优酷网络技术(北京)有限公司 一种视频插帧的方法、计算机存储介质及服务器
CN109151474A (zh) * 2018-08-23 2019-01-04 复旦大学 一种生成新视频帧的方法
CN109816611A (zh) * 2019-01-31 2019-05-28 北京市商汤科技开发有限公司 视频修复方法及装置、电子设备和存储介质
CN109922231A (zh) * 2019-02-01 2019-06-21 重庆爱奇艺智能科技有限公司 一种用于生成视频的插帧图像的方法和装置
CN111047626A (zh) * 2019-12-26 2020-04-21 深圳云天励飞技术有限公司 目标跟踪方法、装置、电子设备及存储介质

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
刘建;李峰;周书仁;黄龙;: "一种基于PSO的改进光流算法", 计算技术与自动化, no. 04, pages 1 - 3 *
朱珏钰;刘建;李峰;周书仁;: "基于遮挡修补的TV-L1光流算法", 计算机工程与应用, no. 19 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114205648A (zh) * 2021-12-07 2022-03-18 网易(杭州)网络有限公司 插帧方法及装置
WO2023160525A1 (zh) * 2022-02-22 2023-08-31 北京字跳网络技术有限公司 视频处理方法、装置、设备及介质

Similar Documents

Publication Publication Date Title
US9860446B2 (en) Flare detection and mitigation in panoramic images
TWI390468B (zh) 影像處理設備及影像處理方法
CN110473159B (zh) 图像处理方法和装置、电子设备、计算机可读存储介质
US7773819B2 (en) Image processing apparatus
JP4960992B2 (ja) 魚眼補正と透視歪み削減の画像処理方法及び画像処理装置
US20220222830A1 (en) Subject detecting method and device, electronic device, and non-transitory computer-readable storage medium
CN110475067B (zh) 图像处理方法和装置、电子设备、计算机可读存储介质
WO2021115136A1 (zh) 视频图像的防抖方法、装置、电子设备和存储介质
CN113660443A (zh) 一种视频插帧方法、终端以及存储介质
WO2021093534A1 (zh) 主体检测方法和装置、电子设备、计算机可读存储介质
CN111062881A (zh) 图像处理方法及装置、存储介质、电子设备
JP2008135980A (ja) 補間フレーム作成方法および補間フレーム作成装置
CN111105367A (zh) 人脸畸变校正方法、装置、电子设备及存储介质
US20220182595A1 (en) Optical flow based omnidirectional stereo video processing method
CN109271123B (zh) 一种画面显示方法及画面显示装置
TW201220251A (en) Image correction method and image correction apparatus
CN108027646B (zh) 一种终端显示防抖方法及装置
CN113395434B (zh) 一种预览图像虚化方法、存储介质及终端设备
CN113902644A (zh) 一种图像处理方法、装置、设备以及存储介质
CN115049572A (zh) 图像处理方法、装置、电子设备和计算机可读存储介质
CN113438421A (zh) 图像处理方法、装置、终端和可读存储介质
CN113766090B (zh) 一种图像处理方法、终端以及存储介质
CN112419147A (zh) 图像渲染方法及装置
CN113949926A (zh) 一种视频插帧方法、存储介质及终端设备
CN113938578A (zh) 一种图像虚化方法、存储介质及终端设备

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination