【计算机视觉文章阅读之二】Video2Gif: Automatic Generation of Animated GIFs from Video_CVPR2016

本文介绍了CVPR2016会议上的一项研究,旨在从视频中自动生成GIF。研究构建了一个包含120K个GIF和80K个源视频的数据库,利用RankNet网络和自适应Huber损失函数进行训练,提高了匹配准确性和效率。实验结果显示,该方法在平均精度和有意义摘要时长方面优于其他方法。
摘要由CSDN通过智能技术生成

Video2Gif: Automatic Generation of Animated GIFs from Video 将视频转成GIF

  • 一、文章大体概括
  • 二、文章主要内容
  • 三、评估结果
  • 四、总结

今天要讲的这篇是CVPR2016的文章,文章要做的事情在题目当中也写的很清楚,就是要从源视频当中提取GIF小片段,GIF就是短小的,循环播放的无声由50帧左右组成的小视频,一般表达的是强烈的情感,或者什么好玩的事情。现在有GIFSoup, Imgflip, Ezgif这三个商业软件,用户可以手动选择视频当中的一些小片段形成动图。由于现在GIF动图特别流行,所以作者就想做这么一款自动生成动图的想法的文章,有现实的需求和意义。

一、文章大体概括

这里写图片描述
文章的大致流程就是上图所示,先在youtube上匹配GIF与其对应的源视频,形成一个数据集。在网络训练阶段,采用的是RankNet这个网络,一次输入一对正例和负例视频,计算两个之间的判断误差,为了更好的评估两者之间的误差,本文引入了自适应的Huber loss计算误差的方式,得到训练好的排名模型。在测试阶段,输入一段视频,就可以得到这个视频中的小片段成为GIF的匹配度大小。

二、文章主要内容

1、Video2Gif数据库

文章在手动选取GIF动图的软件中,搜索匹配原有GIF对应的源视频的时候,方便之后文章的建立和学习,建立了一个关于GIF的数据库,数据库中包含120K个动图,以及超过80K个的视频,总体包括了7379小时。

在找到GIF与其对应的源视频之后,为了数据库能够从各个方面进行进一步的评估应用等,这里要找到GIF与其对应的源视频,打算做一个将二者匹配起来的工作,也方便之后监督学习的时候作为训练数据。

GIF与源视频进行匹配的工作,采用的是将两者的每一帧都采用离散余弦变化得到的一个矢量表示,之后这个矢量用二值化表现形式进行体现,最后通过比较这个矩阵的汉明距离来判断是否出现了重复片段,以此判

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用`v-for`指令结合`:class`绑定来动态渲染多个元素,并且通过Vue的数据驱动特性来控制它们的显示与隐藏。具体实现可以参考以下代码: ```html <template> <div> <div v-for="(item, index) in elements" :key="index" :class="[item.visible ? 'animate__animated animate__fadeIn' : 'animate__animated animate__fadeOut', 'threebox_image_box']" > 这是第 {{ index + 1 }} 个元素 </div> <button @click="hideElements">隐藏元素</button> </div> </template> <script> export default { data() { return { elements: [ { visible: true }, { visible: true }, { visible: true }, { visible: true }, { visible: true }, { visible: true }, { visible: true }, { visible: true } ] }; }, methods: { hideElements() { for (let i = 0; i < this.elements.length; i++) { this.elements[i].visible = false; } } } }; </script> <style> .threebox_image_box { display: block; } .animate__animated { animation-duration: 1s; } .animate__fadeIn { animation-name: fadeIn; } .animate__fadeOut { animation-name: fadeOut; } @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } } @keyframes fadeOut { from { opacity: 1; } to { opacity: 0; } } </style> ``` 在上面的代码中,我们首先定义了一个`elements`数组,它包含了需要动态渲染的多个元素,并且每个元素都有一个`visible`属性,用于控制它们的显示与隐藏。然后在模板中使用`v-for`指令循环渲染多个元素,并且通过`:class`绑定来动态设置元素的`class`属性,以便实现渐变动画效果。最后在方法中,我们通过修改`elements`数组中每个元素的`visible`属性,来控制它们的显示与隐藏。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值