предварительно обученные векторы не загружаются в пространстве - PullRequest
0 голосов
/ 24 марта 2020

Я тренирую пользовательскую модель NER с нуля, используя модель spacy.blank ("en"). Я добавляю собственные векторы слов к нему. Векторы загружаются следующим образом:

from gensim.models.word2vec import Word2Vec
from gensim.models import KeyedVectors
med_vec = KeyedVectors.load_word2vec_format('./wikipedia-pubmed-and-PMC-w2v.bin', binary=True, limit = 300000)

и я добавляю его в пустую модель в этом фрагменте кода здесь:

def main(model=None, n_iter=3, output_dir=None):
    """Set up the pipeline and entity recognizer, and train the new entity."""
    random.seed(0)
    if model is not None:
        nlp = spacy.load(model) # load existing spaCy model
        print("Loaded model '%s'" % model)
    else:
        nlp = spacy.blank("en")  # create blank Language class
        nlp.vocab.reset_vectors(width=200)
        for idx in range(len(med_vec.index2word)):
            word = med_vec.index2word[idx]
            vector = med_vec.vectors[idx]
            nlp.vocab.set_vector(word, vector)
        for key, vector in nlp.vocab.vectors.items():
            nlp.vocab.strings.add(nlp.vocab.strings[key])
        nlp.vocab.vectors.name = 'spacy_pretrained_vectors'
        print("Created blank 'en' model")
......Code for training the ner

Затем я сохраняю эту модель.

Когда я пытаюсь загрузить модель, nlp = spacy.load("./NDLA/vectorModel0")

я получаю следующую ошибку:


`~\AppData\Local\Continuum\anaconda3\lib\site-packages\thinc\neural\_classes\static_vectors.py in __init__(self, lang, nO, drop_factor, column)
     47         if self.nM == 0:
     48             raise ValueError(
---> 49                 "Cannot create vectors table with dimension 0.\n"
     50                 "If you're using pre-trained vectors, are the vectors loaded?"
     51             )

ValueError: Cannot create vectors table with dimension 0.
If you're using pre-trained vectors, are the vectors loaded?

Я также получаю это предупреждение:

 UserWarning: [W019] Changing vectors name from spacy_pretrained_vectors to spacy_pretrained_vectors_336876, to avoid clash with previously loaded vectors. See Issue #3853.
  "__main__", mod_spec)

Голос Каталог в модели имеет файл векторов размером 270 МБ. Итак, я знаю, что это не пусто ... Что является причиной этой ошибки?

1 Ответ

0 голосов
/ 24 марта 2020

Вы можете попытаться передать все векторы одновременно вместо использования для l oop.

nlp.vocab.vectors = spacy.vocab.Vectors(data=med_vec.syn0, keys=med_vec.vocab.keys())

Значит, ваше утверждение выглядело бы так:

else:
    nlp = spacy.blank("en")  # create blank Language class
    nlp.vocab.reset_vectors(width=200)
    nlp.vocab.vectors = spacy.vocab.Vectors(data=med_vec.syn0, keys=med_vec.vocab.keys()) 
    nlp.vocab.vectors.name = 'spacy_pretrained_vectors'
    print("Created blank 'en' model")
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...