Skip to content

mozilla/firefox-translations-models

Repository files navigation

Firefox Translations models

CPU-optimized NMT models for Firefox Translations.

The model files are hosted using Git LFS.

The models are located in the /models directory and grouped by available configuration:

  • tiny - the fastest and the smallest models but with lower translation quality
  • base - best quality but slower and larger
  • base-memory - slightly lower quality than base but also lower memory footprint

Automatic quality evaluation

BLEU scores, COMET scores

The evaluation is run as part of a pull request in CI. The evaluation will automatically run, and then commits will be added to the pull request. The evaluation uses Microsoft and Google translation APIs, Argos Translate, NLLB and Opus-MT models and pushes results back to the branch (not available for forks). It is performed using the evals tool.

Model training

Use Firefox Translations training pipeline or browsermt/students recipe to train CPU-optimized models. They should have similar size and inference speed to already submitted models.

Training data

Do not use SacreBLEU or Flores datasets as a part of training data, otherwise evaluation will not be correct.

To see SacreBLEU datasets run sacrebleu --list.

Maintainers adding models

Create a pull request to the main branch from another branch in this repo (not a fork). This pull request should include the models, and the evaluation will be added as extra commits in the CI task.

Contributors adding models

Create a pull request to the contrib branch. When it is reviewed and merged, a maintainer should create a pull request from contrib to main. This second PR will run the automatic evaluation and add the evaluation commits.

Local testing

You can run model evaluation locally by running bash scripts/update-results.sh. Make sure to set environment variables GCP_CREDS_PATH and AZURE_TRANSLATOR_KEY to use Google and Microsoft APIs. If you want to run it with bergamot only, remove mentions of those variables from bash scripts/update-results.sh and remove microsoft,google from scripts/eval.sh.

Model types

Vocabulary

Prefix of the vocabulary file:

  • vocab. - vocabulary is reused for the source and target languages
  • srcvocab. and trgvocab. - different vocabularies for the source and target languages

GEMM precision

Suffix of the model file:

  • intgemm8.bin - supports gemm-precision: int8shiftAll inference setting
  • intgemm.alphas.bin - supports gemm-precision: int8shiftAlphaAll inference setting

Add a model from Taskcluster

  1. Run python scripts/pull_models.py [TASK_ID] where [TASK_ID] is a Taskcluster ID of the exporttask such asSjPZGW9CRYeb9PQr68jCUw`.
  2. Commit the changes, which adds the files and removes any previous evaluations.
  3. Push the changes to origin and open a PR.
  4. Wait for the CI to run the evaluations and add the commits.
  5. Merge the PR.

Model deployment

Models are deployed to Remote Settings to be delivered to Firefox.

Records and attachments are uploaded via a CLI tool which lives in the remote_settings directory in this repository.

View the remote_settings README for more details on publishing models.

Currently supported Languages

Firefox Release

  • Arabic <-> English
  • Bulgarian <-> English
  • Catalan <-> English
  • Chinese (Simplified) <-> English
  • Croatian -> English
  • Czech <-> English
  • Danish <-> English
  • Dutch <-> English
  • Estonian <-> English
  • Finnish <-> English
  • French <-> English
  • German <-> English
  • Greek <-> English
  • Hungarian <-> English
  • Indonesian <-> English
  • Italian <-> English
  • Japanese <-> English
  • Korean <-> English
  • Latvian (Lettish) <-> English
  • Lithuanian <-> English
  • Polish <-> English
  • Portuguese <-> English
  • Romanian <-> English
  • Russian <-> English
  • Serbian -> English
  • Slovak <-> English
  • Slovenian <-> English
  • Spanish <-> English
  • Swedish <-> English
  • Turkish <-> English
  • Ukrainian <-> English
  • Vietnamese -> English

Firefox Nightly

  • Albanian -> English
  • Azerbaijani -> English
  • Belarusian -> English
  • Bengali -> English
  • Bosnian -> English
  • Croatian <- English
  • Gujarati -> English
  • Hebrew -> English
  • Hindi -> English
  • Icelandic -> English
  • Kannada -> English
  • Malay -> English
  • Malayalam -> English
  • Maltese -> English
  • Norwegian Bokmål -> English
  • Norwegian Nynorsk -> English
  • Persian (Farsi) <-> English
  • Tamil -> English
  • Telugu -> English

About

CPU-optimized Neural Machine Translation models for Firefox Translations

Resources

License

Stars

Watchers

Forks

Packages

No packages published