Skip to content

Latest commit

 

History

History
140 lines (88 loc) · 7.85 KB

README.md

File metadata and controls

140 lines (88 loc) · 7.85 KB

Dockerfiles for OpenAI's Whisper model

This repository contains Dockerfiles to containerize OpenAI's Whisper ASR model and it's dependencies PyTorch, HuggingFace Transformers and tokenizers. For media file conversion ffmpeg and ffmpeg-python are also included.

About the Whisper model

Architecture and training of the model

Whisper is a general-purpose speech recognition model. It is trained on a large dataset of diverse audio and is also a multi-task model that can perform multilingual speech recognition as well as speech translation and language identification.

Conceptually, it is a transformer sequence-to-sequence model trained on multilingual speech recognition, speech translation, spoken language identification, and voice activity detection. All of these tasks are jointly represented as a sequence of tokens to be predicted by the decoder, allowing for a single model to replace many different stages of a traditional speech processing pipeline. The multitask training format uses a set of special tokens that serve as task specifiers or classification targets.

Further information on the model is available in the authors' blog and the corresponding scientific publication.

Available pre-trained models and languages

There are five model sizes, four with English-only versions, offering speed and accuracy tradeoffs. The table below comprises the available models and their approximate memory requirements and relative speed.

Size Parameters English-only model Multilingual model Required VRAM Relative speed
tiny 39 M tiny.en tiny ~1 GB ~32x
base 74 M base.en base ~1 GB ~16x
small 244 M small.en small ~2 GB ~6x
medium 769 M medium.en medium ~5 GB ~2x
large 1550 M N/A large ~10 GB 1x

For English-only applications, the .en models tend to perform better, especially for the tiny.en and base.en models. It was observed that the difference becomes less significant for the small.en and medium.en models.

Building the containerized versions

To build the containerized version of the Whisper model, local builds are recommended. However, the tiny, base and small models can also still be packaged when run on Github Actions.

By default, the container images contain a cached copy of the base model. Set the value of WHISPER_MODEL as build argument accordingly to choose a different model. Supported values are listed in the table above. In addition, also the values all and all.en are legit, which will download multiple models to the cache in $HOME/.cache/whisper. Mind that caching too many models will significantly bloat the size of your Docker container image. Provided that there is network access, downloading other models when requested is still possible.

Building locally

To build the image locally, Docker (e.g. Docker Desktop) needs to be installed on your system. You can build the CPU version of the image directly off this Git repository. Specify a tag name with the -t parameter.

docker build https://github.com/MatthiasZepper/whisper-dockerized.git -t whisper_dockerized_cpu

Alternatively, you can also clone this repository beforehand

git clone https://github.com/MatthiasZepper/whisper-dockerized.git && cd whisper-dockerized
docker build . --file Dockerfile -t whisper_dockerized_cpu

To specify the model(s) to be included in the container, set the value of WHISPER_MODEL as --build_arg:

docker build https://github.com/MatthiasZepper/whisper-dockerized.git -t whisper_dockerized_cpu --build-arg WHISPER_MODEL=small.en

To build the GPU version of the container, use Dockerfile.gpu instead of Dockerfile:

docker build https://github.com/MatthiasZepper/whisper-dockerized.git -f Dockerfile.gpu -t whisper_dockerized_cpu
git clone https://github.com/MatthiasZepper/whisper-dockerized.git && cd whisper-dockerized
docker build . -f Dockerfile.gpu -t whisper_dockerized_gpu

Building on Github Actions

This repository also contains a Github Action workflow to build the container image.

To run the workflow successfully, you need to fork the repository and create your own repository secrets. Navigate to Settings and then to Secrets, where you need to create the two secrets DOCKERHUB_USERNAME and DOCKERHUB_TOKEN. Both will be needed by the workflow to upload the finished container image to Docker Hub.

The workflow can be dispatched manually in the Actions tab. Choose the desired settings in the dialogue and launch the workflow run.

Running containerized Whisper

To run the containerized version of the Whisper model, invoke the container like so

docker run --rm -itv $(pwd):$(pwd) -w $(pwd) whisper_dockerized_cpu

Replace whisper_dockerized_cpu with whatever tag you specified to the -t parameter when building the container image.

To simplify the invocation, you can also declare an alias, which can be perpetuated in your ~/.bashrc respectively ~/.zshrc.

alias whisper="docker run --rm -itv $(pwd):$(pwd) -w $(pwd) whisper_dockerized_cpu whisper"

The standard model of whisper is small, therefore the container images also contain the small by default. Nonetheless, it is recommended to always specify the --model parameter during invocation. If the --model parameter is not specified the small will be used by default. Models not cached inside the container will be downloaded as required. In this case consider skipping the --rm flag and save your modified image to prevent repeated downloads of models.

For convenience, the WHISPER_MODEL build argument is persisted as environmental variable in the container, so that the cached model of a container can be obtained like so:

WHISPER_MODEL=$(docker run -it whisper_dockerized:cpu printenv WHISPER_MODEL)

Subsequently, $WHISPER_MODEL can be used as argument to the --model parameter.

The following command will transcribe speech in audio files, using the cached model:

whisper --model "$WHISPER_MODEL" <audio.flac audio.mp3 audio.wav>

To transcribe an audio file containing non-English speech, you can specify the language using the --language option:

whisper --language Japanese japanese.wav 

Adding --task translate will translate the speech into English:

whisper --language Japanese --task translate japanese.wav 

Run the following to view all available options:

whisper --help

Troubleshooting: Common issues

💥 Torch.storage.UntypedStorage

File "/usr/local/lib/python3.10/dist-packages/torch/serialization.py", line 218, in default_restore_location
    raise RuntimeError("don't know how to restore data location of "
RuntimeError: don't know how to restore data location of torch.storage.UntypedStorage (tagged with CPU)

✅ This error is raised when an invalid value is specified for the argument --device. In above example, the value was erroneously provided capitalized as --device "CPU" instead of --device "cpu". Currently, the only accepted values are cpu or gpu.

License

The code and the model weights of Whisper are released under the MIT License and so are the contents of this repository. See LICENSE for further details.