From cfd7254d2f27b927dd548c6d046fbd433f41c80b Mon Sep 17 00:00:00 2001 From: Joel Niklaus Date: Sun, 22 Dec 2024 13:09:56 +0100 Subject: [PATCH] Made inference code more robust against empty responses. --- examples/custom_models/google_translate_model.py | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/examples/custom_models/google_translate_model.py b/examples/custom_models/google_translate_model.py index b6ef145f..b60276cc 100644 --- a/examples/custom_models/google_translate_model.py +++ b/examples/custom_models/google_translate_model.py @@ -76,6 +76,7 @@ def __init__(self, config, env_config) -> None: def _get_cache_key(self, context: str, src_lang: str, tgt_lang: str) -> str: """Generate a unique cache key for the translation request.""" + # IMPORTANT: In case we want to support other translators, we can add the translator name to the key key_string = f"{context}|{src_lang}|{tgt_lang}" return hashlib.md5(key_string.encode()).hexdigest() @@ -91,13 +92,20 @@ def _translate_with_cache(self, context: str, src_lang: str, tgt_lang: str) -> s # Try to get from cache if cache_key in self.cache: - return self.cache[cache_key] + result = self.cache[cache_key] + if result is not None and result != "": + return result + logger.warning("Translation in cache is empty. Removing from cache and retrying...") + del self.cache[cache_key] try: # Updated translation call for deep-translator self.translator.source = src_lang self.translator.target = tgt_lang result = self.translator.translate(context) + if result is None or result == "": + result = "" + self.cache[cache_key] = result return result except Exception as e: @@ -140,6 +148,8 @@ def greedy_until( context = r.context.replace(f"{src_lang.upper()}: ", "").replace(f"\n{tgt_lang.upper()}: ", "") result = self._translate_with_cache(context, src_lang, tgt_lang) + if result is None: + result = "" # Set to empty string to prevent errors in metric computation cur_response = GenerativeResponse( result=result,