• Stars
    star
    2,080
  • Rank 22,049 (Top 0.5 %)
  • Language
    Python
  • License
    MIT License
  • Created over 4 years ago
  • Updated about 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Open-source offline translation library written in Python

Argos Translate

Demo | Website | Docs | Forum | Video intro | GitHub | Wiki

Open-source offline translation library written in Python

Argos Translate uses OpenNMT for translations and can be used as either a Python library, command-line, or GUI application. Argos Translate supports installing language model packages which are zip archives with a ".argosmodel" extension containing the data needed for translation. LibreTranslate is an API and web-app built on top of Argos Translate.

Argos Translate also manages automatically pivoting through intermediate languages to translate between languages that don't have a direct translation between them installed. For example, if you have a es → en and en → fr translation installed you are able to translate from es → fr as if you had that translation installed. This allows for translating between a wide variety of languages at the cost of some loss of translation quality.

Supported languages

Arabic, Azerbaijani, Catalan, Chinese, Czech, Danish, Dutch, English, Esperanto, Finnish, French, German, Greek, Hebrew, Hindi, Hungarian, Indonesian, Irish, Italian, Japanese, Korean, Persian, Polish, Portuguese, Russian, Slovak, Spanish, Swedish, Turkish, Ukrainian

Request a language

Installation

Install with Python

Argos Translate is available from PyPI and can be easily installed or updated with pip.

pip install argostranslate

Install GUI:

pip install argostranslategui

Installation for macOS

  1. Download the latest macOS release.
  2. Extract the archive.
  3. Copy the .app file to the Applications directory.

Python source installation into virtualenv

Download a copy of this repo and install with pip.

git clone https://github.com/argosopentech/argos-translate.git
cd argos-translate
virtualenv env
source env/bin/activate
pip install -e .

Examples

Python

import argostranslate.package
import argostranslate.translate

from_code = "en"
to_code = "es"

# Download and install Argos Translate package
argostranslate.package.update_package_index()
available_packages = argostranslate.package.get_available_packages()
package_to_install = next(
    filter(
        lambda x: x.from_code == from_code and x.to_code == to_code, available_packages
    )
)
argostranslate.package.install_from_path(package_to_install.download())

# Translate
translatedText = argostranslate.translate.translate("Hello World", from_code, to_code)
print(translatedText)
# '¡Hola Mundo!'

Command Line Interface

argospm update
argospm install translate-en_de
argos-translate --from en --to de "Hello World!"
# Hallo Welt!

Install all translation packages:

argospm install translate

LibreTranslate Web App (Demo)

Web App Screenshot

LibreTranslate API

const res = await fetch("https://translate.argosopentech.com/translate", {
	method: "POST",
	body: JSON.stringify({
		q: "Hello!",
		source: "en",
		target: "es"
	}),
	headers: {
		"Content-Type": "application/json"}
	});

console.log(await res.json());

{
    "translatedText": "¡Hola!"
}

Graphical user interface

The GUI code is in a separate repository.

Screenshot Screenshot2 Argos Translate macOS Screenshot

Packages

GPU Acceleration

To enable GPU support, you need to set the ARGOS_DEVICE_TYPE env variable to cuda or auto.

$ ARGOS_DEVICE_TYPE=cuda argos-translate --from-lang en --to-lang es "Hello World"
Hola Mundo

The above env variable passes the device type to CTranslate2.

HTML Translation

The translate-html library is built on top of Argos Translate and Beautiful Soup and parses and translates HTML. The LibreTranslate API also has support for translating HTML.

Files Translation

The argos-translate-files library is built on top of Argos Translate and parses and translates files. The LibreTranslate API also has support for translating files.

Uninstall

pip uninstall argostranslate

You may choose to also delete temporary and cached files:

rm -r ~/.local/cache/argos-translate
rm -r ~/.local/share/argos-translate

Related Projects

Contributing

Contributions are welcome! Available issues are on the GitHub issues page. Contributions of code, data, and pre-trained models can all be accepted.

Support

For support please use the LibreTranslate Forum or GitHub Issues.

For questions about CTranslate2 or general machine translation research the OpenNMT Forum is a good resource.

Services

Custom models trained on your own data are available for $1000/language (negotiable).

I am also available for hire to do support, consulting, or custom software development.

Donate

If you find this software useful donations are appreciated.

Paid supporters receive priority support.

Hosting affiliate links

You can help support Argos Translate financially by purchasing hosting through these referral links:

Argos Translate 2 beta

A beta version of Argos Translate 2 is available to install from source from the v2 branch on GitHub. Argos Translate 2 has a multilingual model architecture, more extensive unit testing, and a more experimental orientation.

Contributing

Contributions are welcome! Bug reports, pull requests, documentation writing, and feature ideas are all appreciated.

License

Argos Translate is dual licensed under either the MIT License or Creative Commons CC0.

More Repositories

1

Conquest

Open source clone of the Risk board game
GDScript
90
star
2

argos-train

Training scripts for Argos Translate
Python
81
star
3

LibreTranslate-py

Python bindings to connect to a LibreTranslate API
Python
70
star
4

translate-html

Translate HTML using Argos Translate
Python
38
star
5

argos-translate-gui

Graphical user interface for Argos Translate
Python
33
star
6

LibreTranslate-init

Shell scripts to install LibreTranslate
Shell
32
star
7

MetalTranslate

Customizable machine translation in C++
C++
27
star
8

LibreTranslate-cpp

LibreTranslate C++ bindings
C++
14
star
9

argospm-index

Argos Translate package index
JavaScript
9
star
10

argos-parallel-corpus

Community data for Argos Translate
8
star
11

LibreTranslate-sh

Unix bindings to connect to a LibreTranslate API
Shell
7
star
12

Conquest-server

Server for Conquest
GDScript
7
star
13

argos-fantasy-tcg

Open source playing cards compatible with MTG
7
star
14

argos-search

Small search engine
Python
6
star
15

argos-art

Public domain image site
Python
6
star
16

argos-ai-adventure

A text based adventure game written with GitHub Copilot
Python
4
star
17

argos-files

File distribution by Argos Open Tech
Python
4
star
18

argos-predict

Open source prediction markets
Solidity
4
star
19

2008pedia

2008 Wikipedia Archive
3
star
20

argos-os

Argos Open Tech rice for Ubuntu Linux
Shell
3
star
21

argos-data

Build datasets for Argos Translate
Go
3
star
22

snapcraft-tkinter

Python
3
star
23

operating-systems

Self study operating systems
3
star
24

Network-Economics

Networks, Crowds, and Markets Textbook
3
star
25

videos

Argos Open Tech Videos
3
star
26

argosopentech

Profile README
3
star
27

morel-mushrooms

Researching Morel mushroom cultivation
Shell
3
star
28

custom-translation

Script for doing custom translations with Argos Translate
Python
2
star
29

public-domain-art

Public domain art data
2
star
30

argos-lingo-flashcards

Python
2
star
31

operating-systems-engineering

Guide for self studying MIT 6.828 Operating Systems Engineering
2
star
32

XPRIZE

Open source XPRIZE carbon removal entry
Python
2
star
33

coding-kit

Kit designed for teaching programming, computer science, and electronics.
2
star
34

openai-api-py-lite

OpenAI API Python bindings with no dependencies
Python
2
star
35

data-wiki

Open Source NLP data
2
star
36

argos-rl-craft

Reinforcement learning Minecraft
2
star
37

ipfs-data

Machine learning data IPFS links
2
star
38

jsonix

JSONix DB
Python
1
star
39

argos-feed

Python
1
star
40

LTSuggest

Submit suggestions to a LibreTranslate server from Python
1
star
41

argos-console

Shell
1
star
42

practical-programming-in-python

Python
1
star
43

provision-instance

Provision a server for Argos Open Tech
Shell
1
star
44

argospm-index-dev

JavaScript
1
star
45

argos-translate-dependencies

Shell
1
star
46

argos-desktop-rl

Reinforcement learning for the Linux Desktop
Python
1
star
47

argos-infer

Language model by Argos Open Tech
Python
1
star
48

argos-backup

Backup scripts for Argos Open Tech
Shell
1
star
49

argos-deploy

Deploy Argos Open Tech services
Shell
1
star
50

sbd

Sentence boundary detection for machine translation
Python
1
star
51

cooking

HTML
1
star
52

lindy-news

Bag of Words model to classify news headlines as Lindy or Not Lindy
Python
1
star
53

NeuralEasel

Python
1
star
54

argos-summary

Open source language models for summarization using OpenNMT
Python
1
star
55

snapcraft-desktop-icon

Python
1
star