• Stars
    star
    443
  • Rank 98,504 (Top 2 %)
  • Language
    Python
  • License
    MIT License
  • Created over 4 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Console Interface and Library to remove silent parts of a media file ๐Ÿ”ˆ

Unsilence

Console Interface and Library to remove silent parts of a media file

MIT License Badge Github Action Badge Docker Cloud Build Status Documentation Build Status Codacy Badge Lines of code


Demo

Unedited (Before) Processed by Unsilence (After)
Unedited Demo Video Edited Demo Video
Time before edit: 0:09:45 (100%) Time after edit: 0:07:56 (81.2%), Difference: -0:01:50 (-18.8%)

The MIT Intro at the beginning is not included into the time, since I left it in to show the license of the videos.

These videos are from this online lecture:

Ana Bell, Eric Grimson, and John Guttag. 6.0001 Introduction to Computer Science and Programming in Python. Fall 2016. Massachusetts Institute of Technology: MIT OpenCourseWare, https://ocw.mit.edu. License: Creative Commons BY-NC-SA.

More Information about Licensing can be found in the Licensing Segment of this README.

Introduction

Unsilence is an open-source tool that removes silence from a media clip of your choice (audio, video).

You can use it to speed up videos without changing the audible speed, so you can understand everything, but get through a video faster.

Exemplary use cases

  • You are a college student and watch your lectures online (but have access to the video files). Instead of just increasing the playback speed to ~1.5x, you can remove the parts that do not contain any value, like your lecturer thinking or waiting for something. But instead of cutting out these silent parts, speeding them up by a different, much faster factor (think 6-8x) makes you still able to follow what is happening, so drawing or writing with no speech is sped up, which makes it far more pleasant to watch

  • You want a video editor that automatically cuts any time you talk (or make any sound). That could be useful for manual time lapses (you make a sound every time a short segment should be recorded), or for very fast jump cut videos with no manual editing required

  • You want to have some fun and remove all the audible parts from a video, leaving only the parts where nearly silent noises are in the video (breathing, writing, ...)

Communication

If you have any (technical) questions about unsilence or want to get community feedback, you can use the new GitHub Discussions Feature. To report a bug or suggest a new feature, create a new issue instead.

Usage Information

Unsilence can be used as a console line interface or as a python library, with which you can develop your own projects

Prerequisites

  • Python >= 3.7.0
  • pip (should be installed automatically with python, could be different on some linux distros)
  • ffmpeg >= 4.2.4

In order to see the fancy progress bar and other terminal styling on windows, you should use Windows Terminal.

Installation as command line interface (using pip and pipx)

# Installing pipx
pip install pipx

# Installing Unsilence as Command Line Software
pipx install unsilence

# If pipx asks you to, you also need to execute the following line
# as well as close and reopen your terminal window
pipx ensurepath

Installation as library (using pip)

# Installing Unsilence as Command Line Software
pip install unsilence

Installation as command line interface (from source)

# Clone the repository (stable branch)
git clone -b master https://github.com/lagmoellertim/unsilence.git unsilence

#Change Directory
cd unsilence

# Install pip packages
pip install -r requirements.txt
pip install pipx

# Install unsilence package
pipx install .

Installation as library (from source)

# Clone the repository (stable branch)
git clone -b master https://github.com/lagmoellertim/unsilence.git unsilence

#Change Directory
cd unsilence

# Install pip packages
pip install -r requirements.txt

# Install unsilence package
python3 setup.py install

Basic Command Line Usage

This generates a new file, where the silent parts are 6x as fast as before, the audible parts are the same speed as before

unsilence [input_file] [output_file]

You can change the speed of audible parts with -as [speed], the speed of silent parts with -ss [speed]

unsilence [input_file] [output_file] -as [speed] -ss [speed]

You can change the volume of audible parts with -av [volume], the volume of silent parts with -sv [volume]

unsilence [input_file] [output_file] -av [volume] -sv [volume]

To generate an audio only output file, you can add the -ao flag

unsilence [input_file] [output_file] -ao

To speed up the rendering process, you can increase the thread count using -t [threads]

unsilence [input_file] [output_file] -t [threads]

For many more settings, type -h or --help

unsilence --help

Basic Library Usage

Take a look at this example

Idea/Inspiration

For this project, I took inspiration from the CaryKH's video Jumpcutter. This project does not share any source code with his implementation, and is more optimized for my use case (fast and efficient lecture silence removal).

Contributing

If you are missing a feature or have new idea, go for it! That is what open-source is for! ๐Ÿ˜ƒ

Author

Tim-Luca Lagmรถller (@lagmoellertim)

Donations / Sponsors

I'm part of the official GitHub Sponsors program where you can support me on a monthly basis.

GitHub Sponsors

You can also contribute by buying me a coffee (this is a one-time donation).

Ko-Fi Sponsors

Thank you for your support!

License

The Code is licensed under the

MIT License

Copyright ยฉ 2019-present, Tim-Luca Lagmรถller

All used videos are licensed under the

Creative Commons BY-NC-SA License

Have fun ๐ŸŽ‰

More Repositories

1

cryption

In-Browser AES File Encryption ๐Ÿ” with Data Integrity Check ๐Ÿ”
JavaScript
119
star
2

pyon

The Pythonic way to use JSON - with native objects ๐Ÿ›  and path support ๐Ÿ“
Python
92
star
3

freenet-funk-api

Reverse engineered API ๐Ÿ’ป of Freenet FUNK ๐Ÿ“ก
Python
62
star
4

spotify-playlist-from-text

Generate spotify playlists based on a text message which the song names represent
Python
9
star
5

ImageShare-DesktopApp

Desktop App to receive Images send via ImageShare Mobile App
Python
6
star
6

ImageShare-App

Transfer Pictures to ImageShare Desktop Application
Dart
6
star
7

pyCYK

Cocke-Younger-Kasami-Algorithm implemented in Python
Python
5
star
8

hanoi-towers

Fast implementation of the Hanoi Towers logic riddle
Python
4
star
9

react-native-webrtc-getdisplaymedia-demo

A small demo for using getDisplayMedia (screen sharing) on React Native
Java
3
star
10

rescreen

Display Manager with fractional scaling support for X11
Python
3
star
11

food-classifier

Classify food out of 100 categories
Python
3
star
12

VideoSorter

VideoSorter sorts your videos based on their filenames
Python
3
star
13

Web-QR-Redirect

Scans QR Codes in the browser and redirects you to the website the QR code pointed at
HTML
3
star
14

Knapsack-Algorithm

Python
2
star
15

PassGen

PassGen is a Password Generator that generates a unique password based on the information given
Python
2
star
16

go-expose-functions

Simple Go script to expose Golang functions via a REST API to the web or other docker containers
Go
2
star
17

jsCYK

Cocke-Younger-Kasami-Algorithm implemented in JavaScript
JavaScript
2
star
18

ColorTiles

Firmware for ColorTiles ๐Ÿ”บWiFi controllable, self-build Light Panels ๐Ÿ’ก
Python
2
star
19

appfall-backend

Backend for the AppFall-PWA
Python
2
star
20

pythagoras-tree-fractal

Generate Pythagoras Tree Fractals ๐ŸŒณ
Python
2
star
21

uni-osnabrueck-nav-plan

JavaScript
1
star
22

lagmoellertim

1
star
23

shared-repo-files

Shared repository files
1
star
24

silence-remover

Automatically remove silence from any audio or video format
Python
1
star
25

minigame-minecraft-plugin

Java
1
star
26

descaling

Interface for getting/setting the UI scale of several linux desktop environments
Python
1
star