Skip to content

Latest commit

 

History

History
236 lines (187 loc) · 8.91 KB

DOCUMENTATION.md

File metadata and controls

236 lines (187 loc) · 8.91 KB

Introduction

Executing open-dubbing --help produces the following output:

usage: open-dubbing [-h] --input_file INPUT_FILE
                    [--output_directory OUTPUT_DIRECTORY]
                    [--source_language SOURCE_LANGUAGE] --target_language
                    TARGET_LANGUAGE [--hugging_face_token HUGGING_FACE_TOKEN]
                    [--tts {mms,coqui,openai,edge,cli,api}]
                    [--openai_api_key OPENAI_API_KEY]
                    [--stt {auto,faster-whisper,transformers}] [--vad]
                    [--translator {nllb,apertium}]
                    [--apertium_server APERTIUM_SERVER] [--device {cpu,cuda}]
                    [--cpu_threads CPU_THREADS] [--clean-intermediate-files]
                    [--nllb_model {nllb-200-1.3B,nllb-200-3.3B}]
                    [--whisper_model {medium,large-v2,large-v3}]
                    [--target_language_region TARGET_LANGUAGE_REGION]
                    [--tts_cli_cfg_file TTS_CLI_CFG_FILE]
                    [--log_level {DEBUG,INFO,WARNING,ERROR,CRITICAL}]
                    [--tts_api_server TTS_API_SERVER] [--update]
                    [--original_subtitles] [--dubbed_subtitles]

AI dubbing system which uses machine learning models to automatically
translate and synchronize audio dialogue into different languages

options:
  -h, --help            show this help message and exit
  --input_file INPUT_FILE
                        Path to the input video file.
  --output_directory OUTPUT_DIRECTORY
                        Directory to save output files.
  --source_language SOURCE_LANGUAGE
                        Source language (ISO 639-3)
  --target_language TARGET_LANGUAGE
                        Target language for dubbing (ISO 639-3).
  --hugging_face_token HUGGING_FACE_TOKEN
                        Hugging Face API token.
  --tts {mms,coqui,openai,edge,cli,api}
                        Text to Speech engine to use. Choices are:
                        'mms': Meta Multilingual Speech engine, supports +1100
                        languages.
                        'coqui': Coqui TTS, an open-source alternative for
                        high-quality TTS.
                        'openai': OpenAI TTS.
                        'edge': Microsoft Edge TSS.
                        'cli': User defined TTS invoked from command line.
                        'api': Implements a user defined TTS API contract to
                        enable non supported TTS.
  --openai_api_key OPENAI_API_KEY
                        OpenAI API key used for OpenAI TTS defined by passing
                        this argument or having environment variable the
                        OPENAI_API_KEY defined
  --stt {auto,faster-whisper,transformers}
                        Speech to text. Choices are:
                        'auto': Autoselect best implementation.
                        'faster-whisper': Faster-whisper's OpenAI whisper
                        implementation.
                        'transformers': Transformers OpenAI whisper
                        implementation.
  --vad                 Enable VAD filter when using faster-whisper (reduces
                        hallucinations).
  --translator {nllb,apertium}
                        Text to Speech engine to use. Choices are:
                        'nllb': Meta's no Language Left Behind (NLLB).
                        'apertium': Apertium compatible API server.
  --apertium_server APERTIUM_SERVER
                        Apertium's URL server to use
  --device {cpu,cuda}   Device to use
  --cpu_threads CPU_THREADS
                        number of threads used for CPU inference (if is not
                        specified uses defaults for each framework)
  --clean-intermediate-files
                        clean intermediate files used during the dubbing
                        process
  --nllb_model {nllb-200-1.3B,nllb-200-3.3B}
                        Meta NLLB translation model size. Choices are:
                        'nllb-200-3.3B': gives best translation quality.
                        'nllb-200-1.3B': is the fastest.
  --whisper_model {medium,large-v2,large-v3}
                        name of the OpenAI Whisper speech to text model size
                        to use
  --target_language_region TARGET_LANGUAGE_REGION
                        For some TTS you can specify the region of the
                        language. For example, 'ES' will indicate accent from
                        Spain.
  --tts_cli_cfg_file TTS_CLI_CFG_FILE
                        JSon configuration file when using a TTS which is
                        invoked from the command line.
  --log_level {DEBUG,INFO,WARNING,ERROR,CRITICAL}
                        Set the logging level
  --tts_api_server TTS_API_SERVER
                        TTS api server URL when using the 'API' tts
  --update              Update the dubbed video produced by a previous
                        execution with the latest changes in
                        utterance_metadata file
  --original_subtitles  Add original subtitles as stream in the output video
  --dubbed_subtitles    Add dubbed subtitles as stream in the output video

How it works

The system follows these steps:

  1. Isolate the speech from background noise, music, and other non-speech elements in the audio.
  2. Segment the audio in fragments where there is voice and identify the speakers (speaker diarization).
  3. Identify the gender of the speakers.
  4. Transcribe the speech (STT) into text using OpenAI Whisper.
  5. Translate the text from source language (e.g. English) to target language (e.g. Catalan).
  6. Synthesize speech using a Text to Speech System (TTS) using voices that match the gender and adjusting speed.
  7. The final dubbed video is then assembled, combining the synthetic audio with the original video footage, including any background sounds or music that were isolated earlier.

There are 6 different AI models applied during the dubbing process.

Speech to text (SST)

For speech to text we use OpenAI Whisper. We provide two implementations:

  • HuggingFace transformer's
  • faster-whisper

faster-whisper works on Linux and it is a better implementation. HuggingFace transformer works in mac OS and Linux.

It is possible to add support for new Speech to text engines by extending the class SpeechToText

TTS (text to speech)

Currently the system supports the following TTS systems:

  • MMS: Meta Multilingual Speech engine, supports many languages
    • Pros
      • Supports over 1000 languages
    • Cons
      • Does not allow to select the voice (not possible to have male and female voices)
  • Coqui TTS
    • Pros
      • Possibility to add new languages
    • Cons
      • Many languages only support a single voice (not possible to have male and female voices)
  • Microsoft Edge TSS server based
    • Pros
      • Good quality for the languages supported
    • Cons
      • This is a closed source option only for benchmarking
  • CLI TTS
    • Allows you to use any TTS that can be called from the command line
  • api TTS
    • Allows you to use any TTS that implements an API contract

The main driver to decide which TTS to use is the quality for your target language and the number of voices supported.

Extending support for new TTS engines

Adding new code

It is possible to add support for new TTS engines by extending the class TextToSpeech. You have several examples to get you started.

CLI

The CLI TTS, allows you to use any TTS that can be called from the command line.

You need to provide a configuration file (see tss_cli_sample.json and call it like this.

 open-dubbing --input_file video.mp4 --tts="cmd" --tts_cmd_cfg_file="your_tts_configuration.json"

The CLI approach works if your videos are very short but consider that it will be called to each segment and this
is slow for long videos since you need to load the ML models for each fragment.

API

The API allows


Endpoints

1. List voices

  • URL: /voices

  • Method: GET

  • Response:

    • Code: 200

    • Content:

          [
            {
              "gender": "male",
              "id": "2",
              "language": "cat",
              "name": "grau-central",
              "region": "central"
            },
            {
              "gender": "male",
              "id": "4",
              "language": "cat",
              "name": "pere-nord",
              "region": "nord"
            }
          ]

2. Syntetize a text using a voice

  • URL: /speak?{voice}&{text}

  • Method: GET

  • URL Parameters:

    • id - ID of the voice
    • text - Text to synthesize
  • Response:

    • Code: 200 OK
    • Content: - WAW audio file

Translation

We currently support two translation engines:

It is possible to add support for new TTS engines by extending the class Translation