如何检索 A 视频中的片段在 B 视频中出现的时间点?

2020-05-11 01:41:07 +08:00
 woolong800

A 视频为短视频,B 视频为长视频,A 视频中的所有片段均由 B 视频中剪辑出来(可能经过处理,比如加字幕,加上下边距等)。现在需要检索 A 视频中的所有片段出现在 B 视频中的哪个时间点。

思路:每秒抽取一个关键帧,然后通过图片相似度算法从 B 中找出最匹配的帧,粗略实现了一版,发现效率太低了。假设 A 视频 10 分钟,B 视频 120 分钟,那么平均需要对比 600*12 = 7200 次,图片相似算法使用的 ssim,匹配准确度也不理想。

是否有其他思路,或者开源解决方案,或者付费产品?

1599 次点击
所在节点    视频技术
6 条回复
widewing
2020-05-11 02:20:34 +08:00
比如每一帧压缩成一个特征,比如中位数什么的,然后匹配两个序列?
mumbler
2020-05-11 02:23:00 +08:00
如果有台词,可以语音识别把 AB 分别生成字幕,用字幕时间轴去查找匹配位置,精度远高于图像识别
mumbler
2020-05-11 02:26:34 +08:00
没台词也行,声音波形图对比,音乐 APP 常用的哼唱搜索,听音找歌用的就是这种技术
threebr
2020-05-11 02:59:20 +08:00
思路肯定是 1l 说的特征提取,然后做近似的匹配,声音和图像都可以,我想到的就是直接做个短时的傅里叶变换
woolong800
2020-05-11 10:17:19 +08:00
@mumbler 声音不行 ,有可能去掉原声了,加的自己的解说配音
mxT52CRuqR6o5
2020-05-11 10:44:20 +08:00
把 B 视频的每一帧降分辨率然后进行 Spatial Indexing,然后再查

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/670380

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX