6

我正在定义一个函数,它接受一个单词列表并返回关于列表中彼此之间具有非零余弦相似度(以及相似度值)的单词的信息。

谁能帮我解决这个问题。我在想如果我能得到一个预先计算好的 word2vec 矢量文件,那会很有帮助,但互联网上没有。

4

2 回答 2

6

你可以定义这两个函数

def word2vec(word):
    from collections import Counter
    from math import sqrt

    # count the characters in word
    cw = Counter(word)
    # precomputes a set of the different characters
    sw = set(cw)
    # precomputes the "length" of the word vector
    lw = sqrt(sum(c*c for c in cw.values()))

    # return a tuple
    return cw, sw, lw

def cosdis(v1, v2):
    # which characters are common to the two words?
    common = v1[1].intersection(v2[1])
    # by definition of cosine distance we have
    return sum(v1[0][ch]*v2[0][ch] for ch in common)/v1[2]/v2[2]

并在本例中使用它们

>>> a = 'safasfeqefscwaeeafweeaeawaw'
>>> b = 'tsafdstrdfadsdfdswdfafdwaed'
>>> c = 'optykop;lvhopijresokpghwji7'
>>> 
>>> va = word2vec(a)
>>> vb = word2vec(b)
>>> vc = word2vec(c)
>>> 
>>> print cosdis(va,vb)
0.551843662321
>>> print cosdis(vb,vc)
0.113746579656
>>> print cosdis(vc,va)
0.153494378078

顺便说一句,word2vec您在标签中提到的是完全不同的业务,这需要我们中的一个人花费大量时间和精力来研究它,然后猜猜看,我不是那个...

于 2015-04-07T06:41:01.273 回答
1

那这个呢?

scipy.spatial.distance.cosine(word2vec(a),word2vec(b))

您可以为此使用 word2vec 库。

于 2019-02-19T22:50:54.020 回答