RIFE-实时视频插帧算法 | RIFE:Real-Time Intermediate Flow Estimation for Video Frame Interpolation

本文主要是介绍RIFE-实时视频插帧算法 | RIFE:Real-Time Intermediate Flow Estimation for Video Frame Interpolation,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关注一下实时视频插帧算法
论文地址:https://arxiv.org/pdf/2011.06294.pdf
Github地址:https://github.com/hzwer/arXiv2020-RIFE

在这里插入图片描述

Abstract:

我们为视频帧插值(VFI)提出了一种实时中间流估计算法RIFE (Real-Time Intermediate Flow Estimation)。 现有的大多数方法首先估计双向光流,然后将它们线性组合以近似中间流,从而导致运动边界周围出现伪影。 我们设计了一个中间流模型IFNet,它可以直接估计从粗到细的中间流。 然后,我们根据估计的中间流对输入帧进行warp,并采用融合过程来计算最终结果。 基于我们提出的leakage蒸馏技术,RIFE可以进行端到端的训练并获得出色的性能。 实验表明,RIFE比现有的基于流的VFI方法要快得多,并且可以在多个基准上达到最新的指标。

Introduction:

视频帧插值(VFI)

旨在合成视频的两个连续帧之间的中间帧,并广泛用于提高帧速率和增强视觉质量。VFI还支持各种应用,例如慢动作生成,视频压缩和用于视频运动去模糊的训练数据生成。 此外,以实时速度运行在高分辨率视频(例如720p和1080p)上的VFI算法具有更多潜在的应用,例如在客户端播放器上播放更高帧频的视频,为有限的用户提供视频编辑服务 计算资源。

目前VFI的常用方法包括两个步骤

1)根据近似的光流对输入帧进行warping;

2)使用卷积神经网络(CNN)融合和完善warped的帧。
在这里插入图片描述
依据输入帧如何warping,基于流的VFI算法可以分为基于forward warping的方法和基于backward warping的方法。目前主要采用后者的warping方式。给定输入帧 I 0 I_{0} I0 I 1 I_{1} I1,基于backward warping的方法需要从我们希望进行合成的帧It的角度近似中间流Ft-> 0,Ft-> 1。双向流的方法过于繁杂,无法达到实时。此外,也不能很好地消除运动边界伪影问题。

为了解决这些问题,本文首先提出了一个名为IFNet的专门高效的中间流网络,以直接估算中间流。 IFNet采取从粗到精的策略,并逐步提高分辨率。 它通过以递增分辨率运行的连续IFBlock迭代地更新流场。

如上图所示,RIFE是第一个基于流的实时VFI算法,以每秒30帧的速度处理720p视频。 实验表明,RIFE可以在多个公共基准上取得令人印象深刻的性能。

RIFE:

A.Pipeline Overview
在这里插入图片描述
如图2所示,给定两帧输入 I 0 I_{0} I0 I 1 I_{1} I1,VFI的目的是生成 t − > ( 0 , 1 ) t->(0,1) t>(0,1)的中间帧 I t ^ \hat{I_{t}} It^。首先,本文算法通过将输入帧输入到IFNet来直接估计中间流 F t − > 0 F_{t->0} Ft>0,然后使用线性运动假设近似 F t − > 1 F_{t->1} Ft>1
在这里插入图片描述
其次,通过backward warping输入帧得到两个粗略结果 I ^ 0 − > t \hat{I}_{0->t} I^0>t I ^ 1 − > t \hat{I}_{1->t} I^1>t。 为了消除warp后的伪像,本文使用FusionNet等编解码器将输入帧,近似流和warp后帧馈入融合过程,以生成最终的插帧图像。

B.Efficient Architecture Design

RIFE有两个主要组成部分:

(1)使用IFNet进行有效的中间流估算。

(2)使用FusionNet对warp后的帧进行融合处理。

(1)IFNet:
在这里插入图片描述
网络结构上图所示,IFNet采用了“Coarse-to-Fine”方式逐渐提升分辨率,也就是先在低分辨率上计算粗糙的光流,然后在高分辨率上计算精细的光流。主要组成部分就是IFBlock,降采样和上采样模块。

在这里插入图片描述
在上图中,本文提供了IFNet的视觉结果,并将它们与由预训练的LiteFlowNet 成的线性组合双向光流进行比较。可以看出,IFNet产生清晰而清晰的运动边界,而线性组合流会遇到像素重叠以及运动边界周围模糊的问题。

(2)Fusion process:

通过IFNet和对输入帧backward warping得到两个粗略结果 I ^ 0 − > t \hat{I}_{0->t} I^0>t I ^ 1 − > t \hat{I}_{1->t} I^1>t后,为降低仿射结果的伪影问题,作者提出了如下的调整与融合方式:
在这里插入图片描述
其中 M M M是用于融合两个warp帧的软融合图, Δ \Delta Δ是用于细化图像细节的重建残差项。

融合网络包括上下文提取器ContextNet和具有类似于U-Net的编解-码器架构的FusionNet。 FusionNet的上下文提取器和编码器部分具有相似的架构,由4个步幅为2的ResNet块组成。FusionNet的解码器部分具有四个转置卷积层。 使用sigmoid形函数来限制FusionNet的输出。

结合代码,具体来说:

class ContextNet(nn.Module):def __init__(self):super(ContextNet, self).__init__()self.conv1 = ResBlock(3, c)self.conv2 = ResBlock(c, 2*c)self.conv3 = ResBlock(2*c, 4*c)self.conv4 = ResBlock(4*c, 8*c)def forward(self, x, flow):x = self.conv1(x)f1 = warp(x, flow)x = self.conv2(x)flow = F.interpolate(flow, scale_factor=0.5, mode="bilinear",align_corners=False) * 0.5f2 = warp(x, flow)x = self.conv3(x)flow = F.interpolate(flow, scale_factor=0.5, mode="bilinear",align_corners=False) * 0.5f3 = warp(x, flow)x = self.conv4(x)flow = F.interpolate(flow, scale_factor=0.5, mode="bilinear",align_corners=False) * 0.5f4 = warp(x, flow)return [f1, f2, f3, f4]

ContextNet主要做的:

1.对原始输入图像 I 0 I_{0} I0 I 1 I_{1} I1通过上下文提取器分别提取金字塔上下文特征,文中表示为 C 0 C_{0} C0 C 1 C_{1} C1

2.对以上特征和对应的IFNet估计流一起使用backward warping,得到估计的中间流以生成对齐的金字塔特征 C 0 − > t C_{0->t} C0>t C 1 − > t C_{1->t} C1>t;每个金字塔上下文特征包含4个尺度的特征 f 1 f_{1} f1-> f 4 f_{4} f4

class FusionNet(nn.Module):def __init__(self):super(FusionNet, self).__init__()self.down0 = ResBlock(8, 2*c)self.down1 = ResBlock(4*c, 4*c)self.down2 = ResBlock(8*c, 8*c)self.down3 = ResBlock(16*c, 16*c)self.up0 = deconv(32*c, 8*c)self.up1 = deconv(16*c, 4*c)self.up2 = deconv(8*c, 2*c)self.up3 = deconv(4*c, c)self.conv = nn.Conv2d(c, 4, 3, 1, 1)def forward(self, img0, img1, flow, c0, c1, flow_gt):warped_img0 = warp(img0, flow)warped_img1 = warp(img1, -flow)if flow_gt == None:warped_img0_gt, warped_img1_gt = None, Noneelse:warped_img0_gt = warp(img0, flow_gt[:, :2])warped_img1_gt = warp(img1, flow_gt[:, 2:4])s0 = self.down0(torch.cat((warped_img0, warped_img1, flow), 1))s1 = self.down1(torch.cat((s0, c0[0], c1[0]), 1))s2 = self.down2(torch.cat((s1, c0[1], c1[1]), 1))s3 = self.down3(torch.cat((s2, c0[2], c1[2]), 1))x = self.up0(torch.cat((s3, c0[3], c1[3]), 1))x = self.up1(torch.cat((x, s2), 1))x = self.up2(torch.cat((x, s1), 1))x = self.up3(torch.cat((x, s0), 1))x = self.conv(x)return x, warped_img0, warped_img1, warped_img0_gt, warped_img1_gt

然后,将另外两个输入:warp后的的帧和IFNet估计的中间流输入到FusionNet,将FusionNet编码器部分中每个块的输出与相应的对齐金字塔特征连接起来,然后馈入下一个块。最后输出的x包含4个通,其中前3个通道是生成的重建残差 Δ \Delta Δ,第4个是融合图M。其他返回的4个warped_img0, warped_img1, warped_img0_gt, warped_img1_gt主要是被下面所介绍的Leakage Distillation使用。

C.Leakage Distillation for IFNet

为了使得IFNet预测的中间流结果比较准,采用一个预训练的光流模型提供额外的中间流信息作为监督信息训练。
在这里插入图片描述

Experiments:

1.UCF101, Vimeo90K, Middlebury OTHER set and HD benchmarks:
在这里插入图片描述
2.Increase model complexity:
在这里插入图片描述
3.Ablation Study:
在这里插入图片描述

这篇关于RIFE-实时视频插帧算法 | RIFE:Real-Time Intermediate Flow Estimation for Video Frame Interpolation的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/379632

相关文章

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

dp算法练习题【8】

不同二叉搜索树 96. 不同的二叉搜索树 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。 示例 1: 输入:n = 3输出:5 示例 2: 输入:n = 1输出:1 class Solution {public int numTrees(int n) {int[] dp = new int