Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/amsehili/auditok
An audio/acoustic activity detection and audio segmentation tool
https://github.com/amsehili/auditok
audio-activities audio-data audio-segmentation vad voice-activity-detection voice-detection
Last synced: 3 months ago
JSON representation
An audio/acoustic activity detection and audio segmentation tool
- Host: GitHub
- URL: https://github.com/amsehili/auditok
- Owner: amsehili
- License: mit
- Created: 2015-09-17T14:46:20.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2023-03-30T08:31:43.000Z (almost 2 years ago)
- Last Synced: 2024-04-28T18:03:50.238Z (9 months ago)
- Topics: audio-activities, audio-data, audio-segmentation, vad, voice-activity-detection, voice-detection
- Language: Python
- Homepage:
- Size: 3.58 MB
- Stars: 710
- Watchers: 28
- Forks: 93
- Open Issues: 7
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG
- License: LICENSE
- Audit: auditok/__init__.py
Awesome Lists containing this project
- awesome-sources - Auditok - line program or by calling its API (Audio ##)
- awesome-github-repos - amsehili/auditok - An audio/acoustic activity detection and audio segmentation tool (Python)
README
.. image:: doc/figures/auditok-logo.png
:align: center
:alt: Build status.. image:: https://travis-ci.org/amsehili/auditok.svg?branch=master
:target: https://travis-ci.org/amsehili/auditok.. image:: https://readthedocs.org/projects/auditok/badge/?version=latest
:target: http://auditok.readthedocs.org/en/latest/?badge=latest
:alt: Documentation status``auditok`` is an **Audio Activity Detection** tool that can process online data
(read from an audio device or from standard input) as well as audio files.
It can be used as a command-line program or by calling its API.The latest version of the documentation can be found on
`readthedocs. `_Installation
------------A basic version of ``auditok`` will run with standard Python (>=3.4). However,
without installing additional dependencies, ``auditok`` can only deal with audio
files in *wav* or *raw* formats. if you want more features, the following
packages are needed:- `pydub `_ : read audio files in popular audio formats (ogg, mp3, etc.) or extract audio from a video file.
- `pyaudio `_ : read audio data from the microphone and play audio back.
- `tqdm `_ : show progress bar while playing audio clips.
- `matplotlib `_ : plot audio signal and detections.
- `numpy `_ : required by matplotlib. Also used for some math operations instead of standard python if available.Install the latest stable version with pip:
.. code:: bash
sudo pip install auditok
Install the latest development version from github:
.. code:: bash
pip install git+https://github.com/amsehili/auditok
or
.. code:: bash
git clone https://github.com/amsehili/auditok.git
cd auditok
python setup.py installBasic example
-------------.. code:: python
import auditok
# split returns a generator of AudioRegion objects
audio_regions = auditok.split(
"audio.wav",
min_dur=0.2, # minimum duration of a valid audio event in seconds
max_dur=4, # maximum duration of an event
max_silence=0.3, # maximum duration of tolerated continuous silence within an event
energy_threshold=55 # threshold of detection
)for i, r in enumerate(audio_regions):
# Regions returned by `split` have 'start' and 'end' metadata fields
print("Region {i}: {r.meta.start:.3f}s -- {r.meta.end:.3f}s".format(i=i, r=r))# play detection
# r.play(progress_bar=True)# region's metadata can also be used with the `save` method
# (no need to explicitly specify region's object and `format` arguments)
filename = r.save("region_{meta.start:.3f}-{meta.end:.3f}.wav")
print("region saved as: {}".format(filename))output example:
.. code:: bash
Region 0: 0.700s -- 1.400s
region saved as: region_0.700-1.400.wav
Region 1: 3.800s -- 4.500s
region saved as: region_3.800-4.500.wav
Region 2: 8.750s -- 9.950s
region saved as: region_8.750-9.950.wav
Region 3: 11.700s -- 12.400s
region saved as: region_11.700-12.400.wav
Region 4: 15.050s -- 15.850s
region saved as: region_15.050-15.850.wavSplit and plot
--------------Visualize audio signal and detections:
.. code:: python
import auditok
region = auditok.load("audio.wav") # returns an AudioRegion object
regions = region.split_and_plot(...) # or just region.splitp()output figure:
.. image:: doc/figures/example_1.png
Limitations
-----------Currently, the core detection algorithm is based on the energy of audio signal.
While this is fast and works very well for audio streams with low background
noise (e.g., podcasts with few people talking, language lessons, audio recorded
in a rather quiet environment, etc.) the performance can drop as the level of
noise increases. Furthermore, the algorithm makes no distinction between speech
and other kinds of sounds, so you shouldn't use it for Voice Activity Detection
if your audio data also contain non-speech events.License
-------
MIT.