Расчет коэффициента Левенштейна в PythonPython

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Расчет коэффициента Левенштейна в Python

Сообщение Anonymous »

У меня есть следующие две строки:

Код: Выделить всё

a = 'bjork gudmundsdottir'
b = 'b. gudmundsson gunnar'
Расстояние Левенштейна между ними равно 12. Когда я использую следующую формулу для расстояния Левенштейна, я получаю расхождение 0,01 с библиотекой python-Левенштейна:

Код: Выделить всё

>>> Ldist / max(len( a ), len( b ))
>>> float(12)/21
0.5714285714285714
# python-Levenshtein
Levenshtein.ratio(a,b)
0.5853658536585366
# difflib
>>> seq=difflib.SequenceMatcher(a=a,b=b)
>>> seq.ratio()
0.5853658536585366
Чем объясняется эта разница? Что я делаю неправильно в своих расчетах? Обратите внимание, что я рассмотрел аналогичный вопрос, и он не совсем отвечает на мой вопрос.
Как работает формула, которая используется для расчета приведенного выше соотношения?

Подробнее здесь: https://stackoverflow.com/questions/294 ... -in-python
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»