Tilde MT is a translation platform for instant, fluent, and secure text, document translation.
This .NET library provides a robust and user-friendly interface for integrating machine translation capabilities into your .NET applications. Powered by advanced neural machine translation models, it enables seamless translation of text between multiple languages.
Using the .NET Core command-line interface (CLI) tools:
dotnet add package Tilde.Translation
Using the NuGet Command Line Interface (CLI):
nuget install Tilde.Translation
- .NET Standard 2.0
- .NET 6.0
Initialize Translator using Access key (API key).
using Tilde.Translation;
using Tilde.Translation.Exceptions;
var apiKey = "00000000-0000-0000-0000-000000000000";
var translator = new Translator(apiKey);
When implementing this library in your application, please provide information about application where this library will be used. This is optional step, but recomended
var options = new TranslatorOptions()
{
AppInfo = new AppInfo()
{
AppName = "my-app",
AppVersion = "1.0.0",
}
};
var translator = new Translator(apiKey, options);
var translation = await translator.TranslateTextAsync("First sentence", "en", "lv");
Console.WriteLine(translation.DetectedLanguage); // null | "en" | ...
Console.WriteLine(translation.Domain); // "finance"
Console.WriteLine(translation.Translations[0].Translation); // "Pirmais teikums"
// Specify file to translate
var sourceDocument = new FileInfo(@"./Document/ExampleDocument.txt");
// Start document translation
var documentHandle = await translator.TranslateDocumentAsync(sourceDocument, "en", "lv");
// Wait for document translation to finish
var documentStatus = await translator.TranslateDocumentWaitUntilDoneAsync(documentHandle);
Console.WriteLine(documentStatus.Status); // Completed
Console.WriteLine(documentStatus.Substatus); // Unspecified
// Save file
var fileStream = File.Create(@"./Document/ExampleDocumentResult.txt");
await translator.TranslateDocumentResultAsync(documentHandle, fileStream);
fileStream.Close();
var engines = await translator.GetEnginesAsync();
Console.WriteLine(engines.First().SourceLanguages.First()); // "en"
Console.WriteLine(engines.First().TargetLanguages.First()); // "lv"
This is similar to available engines, but engines are grouped by source language, target language and domain
await foreach (var languageDirection in translator.GetLanguageDirections())
{
var srcLang = languageDirection.SourceLanguage;
var trgLang = languageDirection.TargetLanguage;
var domain = languageDirection.Domain;
var engineId = languageDirection.EngineId;
var engineName = languageDirection.EngineName;
Console.WriteLine($"{srcLang} -> {trgLang} [{domain}] | {engineId} ({engineName})");
}
All errors are derived from TildeException
base exception. To catch errors use TildeException
or derived specific exceptions.
try
{
var translation = await translator.TranslateTextAsync("First sentence", "en", "lv");
Console.WriteLine(translation.DetectedLanguage);
Console.WriteLine(translation.Domain);
Console.WriteLine(translation.Translations[0].Translation);
}
catch (TildeException ex)
{
Console.WriteLine(ex.Message);
}
We welcome contributions from the community! If you encounter issues, have suggestions, or want to add new features, please submit a pull request or open an issue on the GitHub repository.
This library is licensed under the MIT License, allowing flexibility for both personal and commercial use.