CoreNLP: Может ли он сказать, относится ли существительное к человеку? - PullRequest
0 голосов
/ 11 апреля 2019

Может ли CoreNLP определить, относится ли обычное существительное (в отличие от имени существительного или имени) к человеку «из коробки»? Или, если мне нужно обучить модель для этой задачи, как мне это сделать?

Во-первых, я не ищу разрешение по ядру, а скорее строительный блок для него. Корреляция по определению зависит от контекста, тогда как я пытаюсь оценить, является ли слово в отдельности подмножеством «человек» или «человек». Например:

is_human('effort') # False
is_human('dog') # False
is_human('engineer') # True

Моя наивная попытка использовать предварительно обученные векторы слов Генсима и spaCy не сумела поставить «инженер» выше двух других слов.

import gensim.downloader as api
word_vectors = api.load("glove-wiki-gigaword-100") 
for word in ('effort', 'dog', 'engineer'):
    print(word, word_vectors.similarity(word, 'person'))

# effort 0.42303842
# dog 0.46886832
# engineer 0.32456854

Я нашел следующие списки из CoreNLP многообещающими.

dcoref.demonym                   // The path for a file that includes a list of demonyms 
dcoref.animate                   // The list of animate/inanimate mentions (Ji and Lin, 2009)
dcoref.inanimate 
dcoref.male                      // The list of male/neutral/female mentions (Bergsma and Lin, 2006) 
dcoref.neutral                   // Neutral means a mention that is usually referred by 'it'
dcoref.female 
dcoref.plural                    // The list of plural/singular mentions (Bergsma and Lin, 2006)
dcoref.singular

Будет ли это работать для моей задачи? И если так, как я могу получить к ним доступ из Оболочки Python ? Спасибо.

1 Ответ

1 голос
/ 11 апреля 2019

Я бы предложил вместо этого попробовать WordNet и посмотреть:

  1. , если WordNet достаточно покрывает достаточно ваших терминов, и
  2. , если нужные вам термины являются гипонимами.из person.n.01.

Вы должны были бы расширить это, чтобы охватить несколько чувств, но суть была бы:

from nltk.corpus import wordnet as wn

# True
wn.synset('person.n.01') in wn.synset('engineer.n.01').lowest_common_hypernyms(wn.synset('person.n.01'))

# False
wn.synset('person.n.01') in wn.synset('dog.n.01').lowest_common_hypernyms(wn.synset('person.n.01'))

См. документы NLTK для lowest_common_hypernym: http://www.nltk.org/howto/wordnet_lch.html

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...