Skip to content
This repository has been archived by the owner on Feb 22, 2020. It is now read-only.

Commit

Permalink
fix(preprocessor): add random sampling to ffmpeg
Browse files Browse the repository at this point in the history
  • Loading branch information
Larryjianfeng committed Aug 7, 2019
1 parent 82ee826 commit 7031fe2
Showing 1 changed file with 7 additions and 1 deletion.
8 changes: 7 additions & 1 deletion gnes/preprocessor/video/ffmpeg.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
from typing import List

import numpy as np

import random
from .base import BaseVideoPreprocessor
from ..helper import get_video_frames, phash_descriptor
from ...proto import gnes_pb2, array2blob
Expand Down Expand Up @@ -107,18 +107,24 @@ def __init__(self,
segment_method: str = 'cut_by_frame',
segment_interval: int = -1,
segment_num: int = 3,
max_frames_per_doc: int = -1,
*args,
**kwargs):
super().__init__(*args, **kwargs)
self.segment_method = segment_method
self.segment_interval = segment_interval
self.segment_num = segment_num
self.max_frames_per_doc = max_frames_per_doc
self._ffmpeg_kwargs = kwargs

def apply(self, doc: 'gnes_pb2.Document') -> None:
super().apply(doc)
if doc.raw_bytes:
frames = get_video_frames(doc.raw_bytes, **self._ffmpeg_kwargs)
if self.max_frames_per_doc > 0:
random_id = random.sample(range(len(frames)),
k=min(self.max_frames_per_doc, len(frames)))
frames = [frames[i] for i in sorted(random_id)]

sub_videos = []
if len(frames) >= 1:
Expand Down

0 comments on commit 7031fe2

Please sign in to comment.