视频亲嘴片段识别,精彩片段识别。 https://git.yoqi.me/lyq/PredictWonderfulTV

Amir Ziai 0ab982e895 poster + vid 4 years ago
dev 2839e906d1 last min cleanup 4 years ago
examples 2839e906d1 last min cleanup 4 years ago
.gitignore aa643772e8 Initial commit 5 years ago
LICENSE aa643772e8 Initial commit 5 years ago
README.md 0ab982e895 poster + vid 4 years ago
conv.py 98455f0e8f cleanup 4 years ago
conv3d.py 2839e906d1 last min cleanup 4 years ago
data.py ac2fe34279 more cleanup 4 years ago
experiments.py 2839e906d1 last min cleanup 4 years ago
kissing_detector.py ac2fe34279 more cleanup 4 years ago
mel_features.py 0059ff6654 vggish and resnet combined, figuring out input 4 years ago
params.py 2839e906d1 last min cleanup 4 years ago
pipeline.py ac2fe34279 more cleanup 4 years ago
poster.pdf 0ab982e895 poster + vid 4 years ago
qualitative.py 98455f0e8f cleanup 4 years ago
requirements.txt 98455f0e8f cleanup 4 years ago
segmentor.py 2839e906d1 last min cleanup 4 years ago
test_segmentor.py b2fcb55f40 added segmentor, qual stuff next 4 years ago
train.py 089b8572d7 refs 4 years ago
utils.py efcbf4099a add experiment runner 4 years ago
vggish.py 089b8572d7 refs 4 years ago
vggish_input.py 0059ff6654 vggish and resnet combined, figuring out input 4 years ago
vggish_params.py 0059ff6654 vggish and resnet combined, figuring out input 4 years ago

README.md

Kissing Detector

Detect kissing scenes in a movie using both audio and video features.

Project for Stanford CS231N

Resources

Running the code

Use Python 3.6+

python3 experiments.py

this will run the experiments in params.py specified by the experiments dictionary.

Requirements

This is a PyTorch project. Look at requirements.txt for more details.

Build dataset

The following will build the dataset for training. You need to provide path to video segments.

from pipeline import BuildDataset

videos_and_labels = [
    # (file name in base_path, label) where label is 1 for kissing and 0 for not kissing
    ('movies_casino_royale_2006_kissing_1.mp4', 1),
    ('movies_casino_royale_2006_kissing_2.mp4', 1),
    ('movies_casino_royale_2006_kissing_3.mp4', 1),
    ('movies_casino_royale_2006_not_1.mp4', 0),
    ('movies_casino_royale_2006_not_2.mp4', 0),
    ('movies_casino_royale_2006_not_3.mp4', 0),
    
    ('movies_goldeneye_1995_kissing_1.mp4', 1),
    ('movies_goldeneye_1995_kissing_2.mp4', 1),
    ('movies_goldeneye_1995_kissing_3.mp4', 1),
    ('movies_goldeneye_1995_not_1.mp4', 0),
    ('movies_goldeneye_1995_not_2.mp4', 0),
    ('movies_goldeneye_1995_not_3.mp4', 0),
]

builder = BuildDataset(base_path='path/to/movies',
                 videos_and_labels=videos_and_labels,
                 output_path='/path/to/output',
                 test_size=1 / 3)  # set aside 1 / 3 of data for validation
builder.build_dataset()

Detect kissing segments in a given video

from segmentor import Segmentor
import utils

# download model.pkl from https://drive.google.com/file/d/1RlvvdInTXtJikGv_ZbHcKoblCypN1Z0A/view?usp=sharing
# or train your own
model = utils.unpickle('model.pkl')  # pickled PyTorch model 
s = Segmentor(model, min_frames=10, threshold=0.7)

# For YouTube clip Hot Summer Nights - Kiss Scene (Maika Monroe and Timothee Chalamet)
# at https://www.youtube.com/watch?v=GG5HmLQ_Fx0
# v=XXX is the YouTube ID, pass that here 
s.visualize_segments_youtube('GG5HmLQ_Fx0')

# alternatively you can provide a path to a local mp4 file
s.visualize_segments('path/to/file.mp4')

See examples in examples/detector.ipynb.

References