Skip to content

Convert video with subtitles into a dubbed video by using text to speech and ffmpeg

License

Notifications You must be signed in to change notification settings

kompot/opi-targalt

Repository files navigation

Õpi targalt

Learning a rare language that does not have enough audio content of your basic level?

Make use of modern text to speech technologies that are able to generate hiqh quality speech from subtitles.

Use this project to generate a dubbed video file in any language with a half muted original audio track and your language of choice dubbed over it.

All you need is original video file (mkv, mp4) and an subtitles (srt) file.

Only Estonian as of now

As of now only Estonian language is supported by means of /~https://github.com/TartuNLP/text-to-speech-api

Other languages?

Any other language could be added easily. Just add:

  • docker-compose-tts-XXX.yaml that should expose text-to-speech API
  • implement text-to-speech function in src/tts-functions/XXX.ts that will use that API

Usage

You need docker and docker-compose

  1. [Estonian only] Download and unpack TTS models to ./models from /~https://github.com/TartuNLP/text-to-speech-worker/releases
  2. env LANGUAGE=est DIR_INPUT=./input DIR_OUTPUT=./output make start

If everything goes ok then you'll find similarly named video files in the ./output folder but with an audio track and subtitles embedded. Or just stop and restart, every run should continue from where it has stopped/failed (except for generating shifted subtitles, that's to fixed).

What's going on under the hood when you run the converter

  • it tries to find video and matching subtitle files in input folder (so for each X.mkv there should be X.srt)
  • if original video file contains subtitles then it automatically will try to find better subtitles shift (TODO will fail if original file has no subtitles)
  • it creates tmp_ folder in the output folder that will contain intermediate files: chunks of speech generated from srt source
  • in case something goes wrong (as speech generation is a lengthy process) you may just restart and already generated chunks will not be generated twice
  • when all chunks are ready then the final audio track is composed by joining original audio track volumed down to 40% and all the generated chunks
  • every chunk is checked whether it fits within required range and if it does not then special ffmpeg parameter is used to speed up the chunk
  • generated audio track is merged along with (probably shifted) subtitles into the source video file
  • the result is a single file in output folder with the same path as in input folder

Original video files are not touched in any way. Original subtitles files are shifted inplace (should change that?).

TODOs

  • make it possible to set base language to any custom language, not only English (which is used to shift subtitles and in the final dubbed audio at low volume)
  • TECH DEBT: add better logging
  • TECH DEBT: init as a class so that input/output folder are not passed in every function

What a weird name?!

Õpi targalt means learn the smart way in Estonian.

About

Convert video with subtitles into a dubbed video by using text to speech and ffmpeg

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published