Audioperm
A python library for generating different permutations of audible segments from audio files.
Install / Use
/learn @zabir-nabil/AudiopermREADME
<p align="center">
<a href="#"><img src="docs/images/logo.png" alt="audioperm"></a>
</p>
<p align="center">
<em>Audioperm, a python library for generating different permutations of audible segments from audio files.</em>
</p>
<p align="center">
<a href="https://pypi.org/project/audioperm/" style="text-decoration: none;" target="_blank">
<img src="https://img.shields.io/pypi/pyversions/audioperm" alt="License">
</a>
<a href="https://pypi.org/project/audioperm/" style="text-decoration: none;" target="_blank">
<img src="https://img.shields.io/pypi/v/audioperm?color=%2334D058&label=pypi%20package" alt="Package version">
</a>
<a href="https://pypi.org/project/audioperm/" style="text-decoration: none;" target="_blank">
<img src="https://img.shields.io/pypi/l/audioperm?style=flat" alt="License">
</a>
<a href="https://colab.research.google.com/github/zabir-nabil/audioperm/blob/main/notebooks/audioperm_demo.ipynb" style="text-decoration: none;">
<img src="https://colab.research.google.com/assets/colab-badge.svg" alt="Open In Colab"/>
</a>
</p>
Audioperm
A python library for generating different permutations of audible segments from audio files.
pip install audioperm
Use:
- Silence Removal from Audio
- Audio / Speech augmentation
- Word segmentation
- Word level permutation generation
- Add new synthetic data for deep learning
- Speaker recognition, Speaker verification, Audio classification, Audio fingerprinting
Documentation: <a href="https://zabir-nabil.github.io/audioperm/" target="_blank">https://zabir-nabil.github.io/audioperm/</a>
Source Code: <a href="https://github.com/zabir-nabil/audioperm" target="_blank">https://github.com/zabir-nabil/audioperm</a>
Word segmentation
from audioperm import AudioPerm
from audioperm.utils import save_audio
ap = AudioPerm("i_love_cats.m4a")
label = "i love cats"
words = ap.word_segments()
label_words = label.split()
for i, w in enumerate(words):
save_audio(w, label_words[i] + ".wav")
cats.wav i_love_cats.m4a i.wav love.wav
Word-level permutation
import numpy as np
from audioperm import AudioPerm
from audioperm.utils import save_audio
ap = AudioPerm("i_love_cats.m4a")
ap.word_segments(return_words=False)
perm_sentences = ap.permute(n_permutations = 5)
for i, s in enumerate(perm_sentences):
save_audio(s, f"perm_{i}.wav")
cats.wav i.wav perm_1.wav perm_4.wav
i_love_cats.m4a love.wav perm_2.wav perm_0.wav
perm_3.wav
permutations on multiple files
from audioperm import read_audio, word_segments, permutations
ap = read_audio(["bangla_demo.wav", "i_love_cats.m4a"])
out = word_segments(ap)
perms = permutations(out, n_permutations = 5)
Fixed-length segments
- Generate fixed length audible segments (with permutation/augmentation)
from audioperm import fixed_len_segments
fixed_len_segments("bangla_demo.wav", return_segments = False, save_path = "fls_out", save = True, segment_size = 0.5)
out = fixed_len_segments("bangla_demo.wav", return_segments = True, max_segments = 5, permute = True, save = False, segment_size = 0.5)
Support
Tested with:
python3.6python3.7python3.8
Internal audio representation:
PCM 16float32
TO-DO:
- [ ] multi-channel audio
- [ ] augmentation
- [ ] multi-processing
- [ ] gpu-support
Others
To run the code: Google Colab
Any contribution is welcome.
