Skip to main content

Voice changer for desktop

Project description

AVoc: Local Realtime Voice Changer for Desktop

A speech-to-speech converter that uses AI models locally to convert microphone audio to a different voice in near-realtime.

Suitable for gaming and streaming.

Quick Start

Features

  • Import of the voice models provided by the user
  • Switching between voices
  • Pitch and volume adjustments
  • Hotkeys and popup notifications for the ease of use in the background

Platforms

All desktops.

Linux is the priority.

Goal

Make voice changing more developer-friendly by creating

  • a voice conversion library
  • a simple voice changer desktop application
  • a command-line voice changer program

Open Source and Free for modification.

Installation

With Python Environment

Install:

mkdir avoc-installdir
cd avoc-installdir
pyenv local 3.12.3
python -m venv .venv
source .venv/bin/activate
pip install avoc
avoc_files=$(pip show --files avoc)
site_packages=$(echo "$avoc_files" | sed -nre 's/^Location:\s*(.*$)/\1/p')
desktop_file="$site_packages/$(echo "$avoc_files" | sed -nre 's/^\s*(.*AVoc.desktop$)/\1/p')"
icon_file="$site_packages/$(echo "$avoc_files" | sed -nre 's/^\s*(.*AVoc.svg$)/\1/p')"
cp -t ~/.local/share/applications/ "$desktop_file"
echo "Path=$PWD" >> ~/.local/share/applications/AVoc.desktop
cp -t ~/.local/share/icons/hicolor/scalable/apps/ "$icon_file"

Launch:

gio launch ~/.local/share/applications/AVoc.desktop

(Optional) Virtual Microphone

To make a game take audio from the voice changer, the operating system needs to be configured to create a virtual microphone.

Linux with PulseAudio

Add this to ~/.config/pulse/default.pa:

load-module module-null-sink sink_name=voice-sink sink_properties=device.description=Voice_Sink
load-module module-remap-source master=voice-sink.monitor source_name=voice-mic source_properties=device.description=Voice_Microphone

And re-login or restart PulseAudio with pulseaudio -k

The Voice_Sink and Voice_Microphone devices will appear. Use the Voice_Sink as voice changer output, and use the Voice_Microphone as input for the game.

Development

Python Environment

Assign a compatible Python version to this directory using pyenv:

pyenv local 3.12.3

Create an environment using venv:

python -m venv .venv

or through VSCode with ~/.pyenv/shims/python as the Python interpreter.

Install the dependencies:

source .venv/bin/activate
pip install .

(Optional) If it doesn't install, try installing reproducible requirements:

pip install -r requirements-3.12.3.txt

Run:

python -m main

(Optional) Get sources of the voice conversion library and install it in developer mode:

(cd .. && git clone https://github.com/develOseven/voiceconversion)
source .venv/bin/activate
pip uninstall voiceconversion
pip install -e ../voiceconversion --config-settings editable_mode=strict

It allows to work on the voice conversion library.

(Optional) Add to the "configurations" in the VSCode's launch.json:

{
    "name": "Python Debugger: Module",
    "type": "debugpy",
    "request": "launch",
    "module": "main",
}

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

avoc-0.0.3.tar.gz (90.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

avoc-0.0.3-py3-none-any.whl (17.8 kB view details)

Uploaded Python 3

File details

Details for the file avoc-0.0.3.tar.gz.

File metadata

  • Download URL: avoc-0.0.3.tar.gz
  • Upload date:
  • Size: 90.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for avoc-0.0.3.tar.gz
Algorithm Hash digest
SHA256 4d93b23b9686a20a419b32a07103b4ce9676e5eedf8e3024f5625dcd5671dd0a
MD5 dbba3c32735287619141de134006c2ff
BLAKE2b-256 947bb6388d787a2202a922d332bcca2f42193f15556ae6bdb6ad16e978fca678

See more details on using hashes here.

File details

Details for the file avoc-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: avoc-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 17.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for avoc-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 fbe9d01d9ac6644ecc46316d292954ad4ace056477555a20c6eeab0d16236032
MD5 48ecfb66812add9a7a4428126e99b522
BLAKE2b-256 914a27d7756c9245a197bc6e70015acc92326b7546d4ae6ea6a666131ebaef8d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page