* Fixing #13381 * Enabling automatic LED models.
This commit is contained in:
@@ -88,7 +88,7 @@ class ZeroShotClassificationPipeline(Pipeline):
|
|||||||
hypothesis_template,
|
hypothesis_template,
|
||||||
padding=True,
|
padding=True,
|
||||||
add_special_tokens=True,
|
add_special_tokens=True,
|
||||||
truncation=TruncationStrategy.DO_NOT_TRUNCATE,
|
truncation=TruncationStrategy.ONLY_FIRST,
|
||||||
**kwargs
|
**kwargs
|
||||||
):
|
):
|
||||||
"""
|
"""
|
||||||
@@ -113,13 +113,31 @@ class ZeroShotClassificationPipeline(Pipeline):
|
|||||||
)
|
)
|
||||||
inputs.append(model_input)
|
inputs.append(model_input)
|
||||||
else:
|
else:
|
||||||
inputs = self.tokenizer(
|
try:
|
||||||
sequence_pairs,
|
inputs = self.tokenizer(
|
||||||
add_special_tokens=add_special_tokens,
|
sequence_pairs,
|
||||||
return_tensors=return_tensors,
|
add_special_tokens=add_special_tokens,
|
||||||
padding=padding,
|
return_tensors=return_tensors,
|
||||||
truncation=truncation,
|
padding=padding,
|
||||||
)
|
truncation=truncation,
|
||||||
|
)
|
||||||
|
except Exception as e:
|
||||||
|
if "too short" in str(e):
|
||||||
|
# tokenizers might yell that we want to truncate
|
||||||
|
# to a value that is not even reached by the input.
|
||||||
|
# In that case we don't want to truncate.
|
||||||
|
# It seems there's not a really better way to catch that
|
||||||
|
# exception.
|
||||||
|
|
||||||
|
inputs = self.tokenizer(
|
||||||
|
sequence_pairs,
|
||||||
|
add_special_tokens=add_special_tokens,
|
||||||
|
return_tensors=return_tensors,
|
||||||
|
padding=padding,
|
||||||
|
truncation=TruncationStrategy.DO_NOT_TRUNCATE,
|
||||||
|
)
|
||||||
|
else:
|
||||||
|
raise e
|
||||||
|
|
||||||
return inputs
|
return inputs
|
||||||
|
|
||||||
|
|||||||
@@ -105,6 +105,20 @@ class ZeroShotClassificationPipelineTests(unittest.TestCase, metaclass=PipelineT
|
|||||||
zero_shot_classifier.model.config.label2id = original_label2id
|
zero_shot_classifier.model.config.label2id = original_label2id
|
||||||
self.assertEqual(original_entailment, zero_shot_classifier.entailment_id)
|
self.assertEqual(original_entailment, zero_shot_classifier.entailment_id)
|
||||||
|
|
||||||
|
@require_torch
|
||||||
|
def test_truncation(self):
|
||||||
|
zero_shot_classifier = pipeline(
|
||||||
|
"zero-shot-classification",
|
||||||
|
model="sshleifer/tiny-distilbert-base-cased-distilled-squad",
|
||||||
|
framework="pt",
|
||||||
|
)
|
||||||
|
# There was a regression in 4.10 for this
|
||||||
|
# Adding a test so we don't make the mistake again.
|
||||||
|
# https://github.com/huggingface/transformers/issues/13381#issuecomment-912343499
|
||||||
|
zero_shot_classifier(
|
||||||
|
"Who are you voting for in 2020?" * 100, candidate_labels=["politics", "public health", "science"]
|
||||||
|
)
|
||||||
|
|
||||||
@require_torch
|
@require_torch
|
||||||
def test_small_model_pt(self):
|
def test_small_model_pt(self):
|
||||||
zero_shot_classifier = pipeline(
|
zero_shot_classifier = pipeline(
|
||||||
|
|||||||
Reference in New Issue
Block a user