DEV Community

Cover image for Back Translation for Text Augmentation with Google Sheets
Amit Chaudhary
Amit Chaudhary

Posted on • Edited on • Originally published at amitness.com

Back Translation for Text Augmentation with Google Sheets

When working on Natural Language Processing applications such as Text Classification, collecting enough labeled examples for each category manually can be difficult. In this article, I will go over an interesting technique to augment your existing text data automatically called back translation.

Introduction to Back Translation

The key idea of back translation is very simple. We create augmented version of a sentence using the following steps:

  1. You take the original text written in English
  2. You convert it into another language (say French) using Google Translate
  3. You convert the translated text back into English using Google Translate
  4. Keep the augmented text if the original text and the back-translated text are different.

Backtranslation with English and French
Figure: Back Translation
{: .text-center}

Using Back Translation in Google Sheets

We need a machine translation service to perform the translation to a different language and back to English. Google Translate is the most popular service for this purpose, but you need to get an API key to use it and it is a paid service.

Luckily, Google provides a handy feature in their Google Sheets web app, which we can leverage for our purpose.

Step 1: Load your data

Let's assume we are building a sentiment analysis model and our dataset has sentences and their associated labels. We can load it into Google Sheets by importing the Excel/CSV file directly.

Loading Files in Google Sheets

Step 2: Add a column to hold augmented data

Add a new column and use the GOOGLETRANSLATE() function to translate from English to French and back to English.

Add column for translation

The command to place in the column is

=GOOGLETRANSLATE(GOOGLETRANSLATE(A2, "en", "fr"), "fr", "en")
Enter fullscreen mode Exit fullscreen mode

Once the command is placed, press Enter and you will see the translation.

Run translation on cells

Now, select the first cell of "Backtranslated" column and drag the small square at the bottom right side below to apply this formula over the whole column

Drag translation to all cells

This should apply to all your training texts and you will get back the augmented version.

Example of translated rows

Step 3: Filter out duplicated data

For texts where the original text and what get back from back translation are the same, we can filter them out programmatically by comparing the original text column and the augmented column. Then, only keep responses that have True value in the Changed column.

Filter out same translation

Step 4: Export your data

You can download your data as a CSV file and augment your existing training data.

Example Sheet

Here is a Google Sheet demonstrating all the four steps above. You can refer to that and make a copy of it to test things out.

Conclusion

Back translation offers an interesting approach when you've small training data but want to improve the performance of your model.

Connect

If you enjoyed this blog post, feel free to connect with me on Twitter where I share new blog posts every week.

Top comments (0)