Library That Preprocessing Audio For TTS.
Project description
PAFTS
Library That Preprocessing Audio For TTS.
This library enables easy processing of audio files into a format suitable for TTS training data with a simple execution.
Description
PAFTS have three features.
- Separator
- Diarization
- STT
- Separator : Removes background music (MR) and noise from each audio file to isolate clean voice tracks.
- Diarization : Separates speakers within each audio file, identifying distinct voices.
- STT : Extract text from audio.
# before run()
path
├── 1_001.wav # have mr or noise
├── 1_002.wav
├── 1_003.wav
├── 1_004.wav
└── abc.wav
# after run()
path
├── SPEAKER_00
│ ├── SPEAKER_00_1.wav # removed mr and noise
│ ├── SPEAKER_00_2.wav
│ └── SPEAKER_00_3.wav
├── SPEAKER_01
│ ├── SPEAKER_01_1.wav
│ └── SPEAKER_01_2.wav
├── SPEAKER_02
│ ├── SPEAKER_02_1.wav
│ └── SPEAKER_02_2.wav
└── audio.json
# audio.json
{
'SPEAKER_00_1.wav' : "I have a note.",
'SPEAKER_00_2.wav' : "I want to eat chicken.",
'SPEAKER_00_3.wav' : "...",
'SPEAKER_01_1.wav' : "...",
'SPEAKER_01_2.wav' : "...",
}
Features
- Separator : Using the UVR project’s model and code for music source separation.
- Diarization : Using speaker diarization from pyannote-audio
- STT : Using STT model whisper from OpenAI
Setup
This library was developed using Python 3.10, and we recommend using Python versions 3.8 to 3.10 for compatibility.
While the library is compatible with both Linux and Windows, all testing was conducted on Windows. For any issues or errors encountered while running on Linux, please feel free to open an issue.
Before running the library, please ensure the following are installed:
PyTorch
We highly recommend using a GPU to optimize performance. For PyTorch installation, please follow the commands below to ensure compatibility with your GPU
# Example for installing PyTorch with CUDA 11.8
pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118
ffmpeg
ffmpeg is required for audio processing tasks within this library. Please ensure it is installed and accessible from your system’s PATH. To install ffmpeg:
Windows
Download the latest FFmpeg release from FFmpeg’s official website, and add the bin folder to your system’s PATH.
Linux
Use the following command to install FFmpeg:
sudo apt update
sudo apt install ffmpeg
After installation, you can verify by running
ffmpeg -version
HuggingFace Access Token (required for diarization)
To enable diarization functionality, please complete the following steps
- Accept
pyannote/segmentation-3.0
user conditions - Accept
pyannote/speaker-diarization-3.1
user conditions - Create access token at
hf.co/settings/tokens
.
from pafts.pafts import PAFTS
p = PAFTS(
path = 'your_audio_directory_path',
output_path = 'output_path',
hf_token="HUGGINGFACE_ACCESS_TOKEN_GOES_HERE"
)
After completing the setup steps above, you can install this library by running
pip install pafts
Usage
from pafts import PAFTS
p = PAFTS(
path = 'your_audio_directory_path',
output_path = 'output_path',
hf_token="HUGGINGFACE_ACCESS_TOKEN_GOES_HERE" # if you use diarization
)
# Separator
p.separator()
# Diarization
p.diarization()
# STT
p.STT(model_size='small')
# One-Click Process
p.run()
TODO
- Command line
- Clean logging
- Separator with Model Selection
- Update README.md
- Add VAD
License
The code of PAFTS is MIT-licensed
Project details
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 pafts-1.0.1.tar.gz
.
File metadata
- Download URL: pafts-1.0.1.tar.gz
- Upload date:
- Size: 119.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 22a9277ae170a120a0378a4787db346fed71b1a89631474f1501ef23d0c26579 |
|
MD5 | 6f13c9f1d2a3321d2ae3d6c7cde713ef |
|
BLAKE2b-256 | 03b2b1127d1869a908255f1628ccd6be463e58cf9eed6e9e59dd020a1b714736 |
File details
Details for the file pafts-1.0.1-py3-none-any.whl
.
File metadata
- Download URL: pafts-1.0.1-py3-none-any.whl
- Upload date:
- Size: 151.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f6d1398c89fb586d9ee5238272e97e15f8e18921f22f7f6a2c7b5cd16119f093 |
|
MD5 | a0026d8402b886ad7c89ebc00b54fcb9 |
|
BLAKE2b-256 | 9961a103ef243cb54de6baf9900c7279e6a2909ce52d301e696d7e4686197677 |