o
    i                     @   s   d dl mZ dddZdS )    )wordnetNengc                    sT   t |  |du rtj||d}rfdd|D }|sdS t| fddd}|S )a  Return a synset for an ambiguous word in a context.

    :param iter context_sentence: The context sentence where the ambiguous word
         occurs, passed as an iterable of words.
    :param str ambiguous_word: The ambiguous word that requires WSD.
    :param str pos: A specified Part-of-Speech (POS).
    :param iter synsets: Possible synsets of the ambiguous word.
    :param str lang: WordNet language.
    :return: ``lesk_sense`` The Synset() object with the highest signature overlaps.

    This function is an implementation of the original Lesk algorithm (1986) [1].

    Usage example::

        >>> lesk(['I', 'went', 'to', 'the', 'bank', 'to', 'deposit', 'money', '.'], 'bank', 'n')
        Synset('depository_financial_institution.n.01')

    [1] Lesk, Michael. "Automatic sense disambiguation using machine
    readable dictionaries: how to tell a pine cone from an ice cream
    cone." Proceedings of the 5th Annual International Conference on
    Systems Documentation. ACM, 1986.
    https://dl.acm.org/citation.cfm?id=318728
    N)langc                    s    g | ]}t |  kr|qS  )strpos).0ss)r   r   C/var/www/edux/Edux_v2/venv/lib/python3.10/site-packages/nltk/wsd.py
<listcomp>+   s     zlesk.<locals>.<listcomp>c                    s   t  |   S )N)lenintersection
definitionsplit)r	   )contextr   r
   <lambda>1   s    zlesk.<locals>.<lambda>)key)setr   synsetsmax)context_sentenceambiguous_wordr   r   r   senser   )r   r   r
   lesk   s   r   )NNr   )nltk.corpusr   r   r   r   r   r
   <module>   s   	