AutoTokenizer.from_pretrained не может загрузить локально сохраненный предварительно обученный токенизатор (PyTorch) - PullRequest
0 голосов
/ 19 июня 2020

Я новичок в PyTorch, и в последнее время я пытался работать с Transformers. Я использую предварительно обученные токенизаторы, предоставленные HuggingFace.
Мне удалось их загрузить и запустить. Но если я попытаюсь сохранить их и снова загрузить, то возникнет ошибка.
Если я использую AutoTokenizer.from_pretrained для загрузки токенизатора, он работает.

[1]:    tokenizer = AutoTokenizer.from_pretrained('distilroberta-base')
        text = "Hello there"
        enc = tokenizer.encode_plus(text)
        enc.keys()

Out[1]: dict_keys(['input_ids', 'attention_mask'])

Но если я сохраню его, используя tokenizer.save_pretrained("distilroberta-tokenizer"), и попытаюсь загрузить его локально, это не удастся.

[2]:    tmp = AutoTokenizer.from_pretrained('distilroberta-tokenizer')


---------------------------------------------------------------------------
OSError                                   Traceback (most recent call last)
/opt/conda/lib/python3.7/site-packages/transformers/configuration_utils.py in get_config_dict(cls, pretrained_model_name_or_path, **kwargs)
    238                 resume_download=resume_download,
--> 239                 local_files_only=local_files_only,
    240             )

/opt/conda/lib/python3.7/site-packages/transformers/file_utils.py in cached_path(url_or_filename, cache_dir, force_download, proxies, resume_download, user_agent, extract_compressed_file, force_extract, local_files_only)
    266         # File, but it doesn't exist.
--> 267         raise EnvironmentError("file {} not found".format(url_or_filename))
    268     else:

OSError: file distilroberta-tokenizer/config.json not found

During handling of the above exception, another exception occurred:

OSError                                   Traceback (most recent call last)
<ipython-input-25-3bd2f7a79271> in <module>
----> 1 tmp = AutoTokenizer.from_pretrained("distilroberta-tokenizer")

/opt/conda/lib/python3.7/site-packages/transformers/tokenization_auto.py in from_pretrained(cls, pretrained_model_name_or_path, *inputs, **kwargs)
    193         config = kwargs.pop("config", None)
    194         if not isinstance(config, PretrainedConfig):
--> 195             config = AutoConfig.from_pretrained(pretrained_model_name_or_path, **kwargs)
    196 
    197         if "bert-base-japanese" in pretrained_model_name_or_path:

/opt/conda/lib/python3.7/site-packages/transformers/configuration_auto.py in from_pretrained(cls, pretrained_model_name_or_path, **kwargs)
    194 
    195         """
--> 196         config_dict, _ = PretrainedConfig.get_config_dict(pretrained_model_name_or_path, **kwargs)
    197 
    198         if "model_type" in config_dict:

/opt/conda/lib/python3.7/site-packages/transformers/configuration_utils.py in get_config_dict(cls, pretrained_model_name_or_path, **kwargs)
    250                 f"- or '{pretrained_model_name_or_path}' is the correct path to a directory containing a {CONFIG_NAME} file\n\n"
    251             )
--> 252             raise EnvironmentError(msg)
    253 
    254         except json.JSONDecodeError:

OSError: Can't load config for 'distilroberta-tokenizer'. Make sure that:

- 'distilroberta-tokenizer' is a correct model identifier listed on 'https://huggingface.co/models'

- or 'distilroberta-tokenizer' is the correct path to a directory containing a config.json file

Его сообщение 'config.josn' отсутствует в каталоге . При проверке каталога я получаю список этих файлов:

[3]:    !ls distilroberta-tokenizer

Out[3]: merges.txt  special_tokens_map.json  tokenizer_config.json  vocab.json

Я знаю, что эта проблема была опубликована ранее, но ни один из них, похоже, не работает. Я также пытался следовать docs , но все еще не могу заставить его работать.
Любая помощь приветствуется.

Ответы [ 2 ]

1 голос
/ 22 июня 2020

Я вижу несколько проблем в вашем коде, которые я перечислил ниже:

  1. distilroberta-tokenizer - это каталог, содержащий файлы конфигурации словаря и т.д. c. Обязательно сначала создайте этот каталог.

  2. Использование AutoTokenizer работает, если этот каталог содержит config. json, а НЕ tokenizer_config. json. Итак, переименуйте этот файл.

Я изменил ваш код, и он работает.

dir_name = "distilroberta-tokenizer"

if os.path.isdir(dir_name) == False:
    os.mkdir(dir_name)  

tokenizer.save_pretrained(dir_name)

#Rename config file now

#tmp = AutoTokenizer.from_pretrained(dir_name)   

Надеюсь, это поможет!

Спасибо!

0 голосов
/ 30 июня 2020

В настоящее время расследуется проблема , которая влияет только на автоматические токенизаторы, но не на базовые токенизаторы, такие как (RobertaTokenizer). Например, должно работать следующее:

from transformers import RobertaTokenizer

tokenizer = RobertaTokenizer.from_pretrained('YOURPATH')

Для работы с AutoTokenizer вам также необходимо сохранить конфигурацию, чтобы загружать ее в автономном режиме:

from transformers import AutoTokenizer, AutoConfig

tokenizer = AutoTokenizer.from_pretrained('distilroberta-base')
config = AutoConfig.from_pretrained('distilroberta-base')

tokenizer.save_pretrained('YOURPATH')
config.save_pretrained('YOURPATH')

tokenizer = AutoTokenizer.from_pretrained('YOURPATH')

Я рекомендую либо используйте другой путь для токенизаторов и модели или , чтобы сохранить конфигурацию. json вашей модели, потому что некоторые изменения, которые вы применяете к вашей модели, будут сохранены в config. json, который является создается во время model.save_pretrained() и будет перезаписан, когда вы сохраните токенизатор, как описано выше, после вашей модели (то есть вы не сможете загрузить свою измененную модель с конфигурацией токенизатора. json).

...