2022-10-08 10:16:37 +02:00
|
|
|
## Whisper model files in custom ggml format
|
|
|
|
|
|
|
|
The [original Whisper PyTorch models provided by OpenAI](https://github.com/openai/whisper/blob/main/whisper/__init__.py#L17-L27)
|
2023-05-08 19:58:36 +02:00
|
|
|
are converted to custom `ggml` format in order to be able to load them in C/C++.
|
|
|
|
Conversion is performed using the [convert-pt-to-ggml.py](convert-pt-to-ggml.py) script.
|
|
|
|
|
|
|
|
You can either obtain the original models and generate the `ggml` files yourself using the conversion script,
|
|
|
|
or you can use the [download-ggml-model.sh](download-ggml-model.sh) script to download the already converted models.
|
|
|
|
Currently, they are hosted on the following locations:
|
2022-11-15 18:47:06 +01:00
|
|
|
|
2023-03-22 19:44:56 +01:00
|
|
|
- https://huggingface.co/ggerganov/whisper.cpp
|
2022-11-15 18:47:06 +01:00
|
|
|
- https://ggml.ggerganov.com
|
2022-10-08 10:16:37 +02:00
|
|
|
|
2023-05-08 19:58:36 +02:00
|
|
|
Sample download:
|
2022-10-08 10:16:37 +02:00
|
|
|
|
|
|
|
```java
|
|
|
|
$ ./download-ggml-model.sh base.en
|
|
|
|
Downloading ggml model base.en ...
|
2022-10-10 21:06:03 +02:00
|
|
|
models/ggml-base.en.bin 100%[=============================================>] 141.11M 5.41MB/s in 22s
|
2022-10-08 10:16:37 +02:00
|
|
|
Done! Model 'base.en' saved in 'models/ggml-base.en.bin'
|
|
|
|
You can now use it like this:
|
|
|
|
|
|
|
|
$ ./main -m models/ggml-base.en.bin -f samples/jfk.wav
|
|
|
|
```
|
|
|
|
|
2023-05-08 19:58:36 +02:00
|
|
|
To convert the files yourself, use the convert-pt-to-ggml.py script. Here is an example usage.
|
|
|
|
The original PyTorch files are assumed to have been downloaded into ~/.cache/whisper
|
|
|
|
Change `~/path/to/repo/whisper/` to the location for your copy of the Whisper source:
|
|
|
|
```
|
|
|
|
mkdir models/whisper-medium
|
|
|
|
python models/convert-pt-to-ggml.py ~/.cache/whisper/medium.pt ~/path/to/repo/whisper/ ./models/whisper-medium
|
|
|
|
mv ./models/whisper-medium/ggml-model.bin models/ggml-medium.bin
|
|
|
|
rmdir models/whisper-medium
|
|
|
|
```
|
|
|
|
|
2022-10-08 10:16:37 +02:00
|
|
|
A third option to obtain the model files is to download them from Hugging Face:
|
|
|
|
|
2023-03-22 19:44:56 +01:00
|
|
|
https://huggingface.co/ggerganov/whisper.cpp/tree/main
|
2022-10-08 10:16:37 +02:00
|
|
|
|
2022-11-02 17:31:55 +01:00
|
|
|
## Available models
|
|
|
|
|
|
|
|
| Model | Disk | Mem | SHA |
|
|
|
|
| --- | --- | --- | --- |
|
|
|
|
| tiny | 75 MB | ~390 MB | `bd577a113a864445d4c299885e0cb97d4ba92b5f` |
|
|
|
|
| tiny.en | 75 MB | ~390 MB | `c78c86eb1a8faa21b369bcd33207cc90d64ae9df` |
|
|
|
|
| base | 142 MB | ~500 MB | `465707469ff3a37a2b9b8d8f89f2f99de7299dac` |
|
|
|
|
| base.en | 142 MB | ~500 MB | `137c40403d78fd54d454da0f9bd998f78703390c` |
|
|
|
|
| small | 466 MB | ~1.0 GB | `55356645c2b361a969dfd0ef2c5a50d530afd8d5` |
|
|
|
|
| small.en | 466 MB | ~1.0 GB | `db8a495a91d927739e50b3fc1cc4c6b8f6c2d022` |
|
|
|
|
| medium | 1.5 GB | ~2.6 GB | `fd9727b6e1217c2f614f9b698455c4ffd82463b4` |
|
|
|
|
| medium.en | 1.5 GB | ~2.6 GB | `8c30f0e44ce9560643ebd10bbe50cd20eafd3723` |
|
2022-12-06 17:48:57 +01:00
|
|
|
| large-v1 | 2.9 GB | ~4.7 GB | `b1caaf735c4cc1429223d5a74f0f4d0b9b59a299` |
|
2023-11-07 14:30:18 +01:00
|
|
|
| large-v2 | 2.9 GB | ~4.7 GB | `0f4c8e34f21cf1a914c59d8b3ce882345ad349d6` |
|
|
|
|
| large | 2.9 GB | ~4.7 GB | `ad82bf6a9043ceed055076d0fd39f5f186ff8062` |
|
2022-11-02 17:31:55 +01:00
|
|
|
|
2022-10-08 10:16:37 +02:00
|
|
|
## Model files for testing purposes
|
|
|
|
|
2022-11-24 16:54:41 +01:00
|
|
|
The model files prefixed with `for-tests-` are empty (i.e. do not contain any weights) and are used by the CI for
|
|
|
|
testing purposes. They are directly included in this repository for convenience and the Github Actions CI uses them to
|
|
|
|
run various sanitizer tests.
|
|
|
|
|
|
|
|
## Fine-tuned models
|
|
|
|
|
|
|
|
There are community efforts for creating fine-tuned Whisper models using extra training data. For example, this
|
|
|
|
[blog post](https://huggingface.co/blog/fine-tune-whisper) describes a method for fine-tuning using Hugging Face (HF)
|
|
|
|
Transformer implementation of Whisper. The produced models are in slightly different format compared to the original
|
|
|
|
OpenAI format. To read the HF models you can use the [convert-h5-to-ggml.py](convert-h5-to-ggml.py) script like this:
|
|
|
|
|
2022-11-24 17:24:06 +01:00
|
|
|
```bash
|
2022-11-24 16:54:41 +01:00
|
|
|
git clone https://github.com/openai/whisper
|
|
|
|
git clone https://github.com/ggerganov/whisper.cpp
|
|
|
|
|
|
|
|
# clone HF fine-tuned model (this is just an example)
|
2023-05-27 09:40:28 +02:00
|
|
|
git clone https://huggingface.co/openai/whisper-medium
|
2022-11-24 16:54:41 +01:00
|
|
|
|
|
|
|
# convert the model to ggml
|
|
|
|
python3 ./whisper.cpp/models/convert-h5-to-ggml.py ./whisper-medium/ ./whisper .
|
|
|
|
```
|