Note
Go to the end to download the full example code.
BERTScore¶
BERTScore is a text generation metric to compute the similarity between a generated text and a reference text using a pre-trained BERT model. Instead of relying on exact token matches, BERTScore leverages contextual embeddings to capture the semantic similarity between the texts. This makes BERTScore robust to paraphrasing and word order variations. BERTScore has been shown to correlate well with human judgments and is widely used in evaluating text generation models.
Let’s consider a use case in natural language processing where BERTScore is used to evaluate the quality of a text generation model. In this case we are imaging that we are developing a automated news summarization system. The goal is to create concise summaries of news articles that accurately capture the key points of the original articles. To evaluate the performance of your summarization system, you need a metric that can compare the generated summaries to human-written summaries. This is where the BERTScore can be used.
9 from transformers import AutoTokenizer, pipeline
10
11 from torchmetrics.text import BERTScore, ROUGEScore
12
13 pipe = pipeline("text-generation", model="openai-community/gpt2")
14 tokenizer = AutoTokenizer.from_pretrained("openai-community/gpt2")
Define the prompt and target texts
19 prompt = "Economic recovery is underway with a 3.5% GDP growth and a decrease in unemployment. Experts forecast continued improvement with boosts from consumer spending and government projects. In summary: "
20 target_summary = "the recession is ending."
Generate a sample text using the GPT-2 model
25 generated_summary = pipe(prompt, max_new_tokens=20, do_sample=False, pad_token_id=tokenizer.eos_token_id)[0][
26 "generated_text"
27 ][len(prompt) :].strip()
Calculate the BERTScore of the generated text
32 bertscore = BERTScore(model_name_or_path="roberta-base")
33 score = bertscore(preds=[generated_summary], target=[target_summary])
34
35 print(f"Prompt: {prompt}")
36 print(f"Target summary: {target_summary}")
37 print(f"Generated summary: {generated_summary}")
38 print(f"BERTScore: {score['f1']:.4f}")
Prompt: Economic recovery is underway with a 3.5% GDP growth and a decrease in unemployment. Experts forecast continued improvement with boosts from consumer spending and government projects. In summary:
Target summary: the recession is ending.
Generated summary: The economy is growing at a 3.5% GDP growth and a decrease in unemployment.
BERTScore: 0.9075
In addition, to illustrate BERTScore’s robustness to paraphrasing, let’s consider two candidate texts that are variations of the reference text.
42 reference = "the weather is freezing"
43 candidate_good = "it is cold today"
44 candidate_bad = "it is warm outside"
Here we see that using the BERTScore we are able to differentiate between the candidate texts based on their similarity to the reference text, whereas the ROUGE scores for the same text pairs are identical.
48 rouge = ROUGEScore()
49
50 print(f"ROUGE for candidate_good: {rouge(preds=[candidate_good], target=[reference])['rouge1_fmeasure'].item()}")
51 print(f"ROUGE for candidate_bad: {rouge(preds=[candidate_bad], target=[reference])['rouge1_fmeasure'].item()}")
52 print(f"BERTScore for candidate_good: {bertscore(preds=[candidate_good], target=[reference])['f1'].item():.4f}")
53 print(f"BERTScore for candidate_bad: {bertscore(preds=[candidate_bad], target=[reference])['f1'].item():.4f}")
ROUGE for candidate_good: 0.25
ROUGE for candidate_bad: 0.25
BERTScore for candidate_good: 0.9254
BERTScore for candidate_bad: 0.9145
Total running time of the script: (0 minutes 10.441 seconds)