10

I have downloaded a .bin FastText model, and I use it with gensim as follows:

model = FastText.load_fasttext_format("cc.fr.300.bin")

I would like to continue the training of the model to adapt it to my domain. After checking FastText's Github and the Gensim documentation it seems like it is not currently feasible appart from using this person's proposed modification (not yet merged).

Am I missing something?

3 Answers 3

5

You can continue training in some versions of Gensim's fastText (for example, v.3.7.*). Here is an example of "Loading, inferring, continuing training"

from gensim.test.utils import datapath
model = load_facebook_model(datapath("crime-and-punishment.bin"))
sent = [['lord', 'of', 'the', 'rings'], ['lord', 'of', 'the', 'semi-groups']]
model.build_vocab(sent, update=True)
model.train(sentences=sent, total_examples = len(sent), epochs=5)

For some reason, the gensim.models.fasttext.load_facebook_model() is missing on Windows, but exists on Mac's installation. Alternatively, one can use gensim.models.FastText.load_fasttext_format() to load a pre-trained model and continue training.

Here are various pre-trained Wiki word models and vectors (or here).

Another example. "Note: As in the case of Word2Vec, you can continue to train your model while using Gensim's native implementation of fastText."

Sign up to request clarification or add additional context in comments.

1 Comment

In 2021 with gensim==3.6.0 model.build_vocab() throws AttributeError: 'FastTextTrainables' object has no attribute 'syn1neg'
1

The pull request #1327 (https://github.com/facebookresearch/fastText/pull/1327)

Allows for:

  1. test after each epoch
  2. checkpointing
  3. training on large data which does not fit into memory (largest I tested was 1.6TB)
  4. finetuning already trained models

The trained model is indistinguishable from a model that was created by an original tool and can be used for inference by the old code.

Comments

0

The official FastText implementation currently doesn't support that, although there is an open ticket related to this issue which you can find here.

1 Comment

Thanks, that's the one I referrenced in my question

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.