Basic template of a python repository
Project description
Skelly Synchronize
This package synchronizes a set of videos of the same event by cross-correlating their audio files. The videos will be synchronized so that they all start at the earliest shared time, and end at the latest shared time.
Install and Run
Skelly_synchronize can be installed through pip by running pip install skelly_synchronize
in your terminal. Once it has installed, it can be run with the command python -m skelly_synchronize
. While running, the GUI window may appear frozen, but the terminal should show the progress. Large videos may take a significant amount of time.
Skelly_synchronize currently depends on FFmpeg, a command line tool that handles the video files. If you do not have FFmpeg downloaded, you will need to install it separately. You can download FFmpeg here: https://ffmpeg.org/download.html
Video Requirements
The following requirements must be met for the script to function:
- Videos must have audio
- Videos must be in the same file format (default is ".mp4")
- Videos must have the exact same framerate (frames per second). There are often slight differences between brands/models of camera that lead to one camera's "60 fps" being different from another's. If your frame rates do not match, an error will be thrown.
- Videos must have the same audio sample rate. Most cameras record either 44100 or 48000 Hz, so there are not as much variation in audio sample rates as there are in video framerates.
- All videos in folder must have overlapping audio from the same real world event
Downsampling
If you video frame rates or audio sample rates do not match, it is possible to downsample them in a separate tool like VLC to have matching frame rates and sample rates. This must be done before trying to synchronize the videos using skelly_synchronize.
How to run from source
First clone this repository and pip install the requirements.txt
file.
Synchronize your videos by setting the path to your folder of raw videos and the file types of your videos into skelly_synchronize.py
, lines 343-344, then run the file.
The terminal output while running should look like this:
A SyncedVideos
folder will be created in the session folder and filled with the synchronized video files. The session folder will also have an AudioFiles
folder containing audio files of the raw videos, which are used in processing.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file skelly_synchronize-2023.6.1018.tar.gz
.
File metadata
- Download URL: skelly_synchronize-2023.6.1018.tar.gz
- Upload date:
- Size: 30.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.16
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c2940efa8c2fa171921c1bd799f5a9b22463ee050b619fe37b1a4141fd46f130 |
|
MD5 | cfe87c31df6f3ff6d14435dbca654784 |
|
BLAKE2b-256 | 74f3f21eb486e23606ef1c375e9bb52cfe95b91594da2196aadf2b6131432a95 |
File details
Details for the file skelly_synchronize-2023.6.1018-py3-none-any.whl
.
File metadata
- Download URL: skelly_synchronize-2023.6.1018-py3-none-any.whl
- Upload date:
- Size: 35.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.16
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 52d9196708b1894fc404e27928c3baf55b94dc9c5d7a4ca57e06080ca314a677 |
|
MD5 | b61c9818122147bff40fe0d1f3eee523 |
|
BLAKE2b-256 | 4bc7306782450d9f9971731244a26a941d936515e7bef0eaef1058a4a036465b |