Reputation: 2611
I have some custom data I want to use to further pre-train the BERT model. I’ve tried the two following approaches so far:
MLM
) + Next Sentence Prediction (NSP
) heads (e.g. using BertForPreTraining model)MLM
objective (e.g. using the BertForMaskedLM model assuming we don’t need NSP for the pretraining part.)But I’m still confused that if using either BertForPreTraining or BertForMaskedLM actually does the continual pre-training on BERT or these are just two models for fine-tuning that use MLM+NSP and MLM for fine-tuning BERT, respectively. Is there even any difference between fine-tuning BERT with MLM+NSP or continually pre-train it using these two heads or this is something we need to test?
I've reviewed similar questions such as this one but still, I want to make sure that whether technically there's a difference between continual pre-training a model from an initial checkpoint and fine-tuning it using the same objective/head.
Upvotes: 14
Views: 18364
Reputation: 5201
For true continual pre-training of a real LLM (like GPT4 or Mistral7b) see:
note wrt original Q talking about Bert (sounds outdated):
note, people mostly use today 2024 Decoder only models. I only know encoder only models being used for retrieval and I conjecture this is suboptimal. I bet one could take a larger model like Claude or Llama3-70B, quantize it + use it as an embedding model like arxiv.org/pdf/2406.04165
Upvotes: 0
Reputation: 7369
The answer is a mere difference in the terminology used. When the model is trained on a large generic corpus, it is called 'pre-training'. When it is adapted to a particular task or dataset it is called as 'fine-tuning'.
Technically speaking, in either cases ('pre-training' or 'fine-tuning'), there are updates to the model weights.
For example, usually, you can just take the pre-trained model and then fine-tune it for a specific task (such as classification, question-answering, etc.). However, if you find that the target dataset is from a specific domain, and you have a few unlabled data that might help the model to adapt to the particular domain, then you can do a MLM or MLM+NSP 'fine-tuning' (unsupervised learning) (some researchers do call this as 'pre-training' especially when a huge corpus is used to train the model), followed by using the target corpus with target task fine-tuning.
Upvotes: 25
Reputation: 351
Yes, there is a difference between pre-training and "further pre-training".
Pre-training usually would mean take the original model, initialize the weights randomly, and train the model from absolute scratch on some large corpora.
Further pre-training means take some already pre-trained model, and basically apply transfer learning - use the already saved weights from the trained model and train it on some new domain. This is usually beneficial if you don't have a very large corpora.
Regarding BertForPreTraining
and BertForMaskedLM
, you can use either one of them for both of the above purposes. It has been shown that further pre-training on MLM is very beneficial, and often NSP is not needed at all. So you will be good to go with BertForMaskedLM
.
NB! You can initialize a model checkpoint by: BertForMaskedLM.from_pretrained({model_name})
and then apply the training procedure, otherwise just pass it a config (from the huggingface API)
Upvotes: 12