mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-12 02:06:31 +03:00
37 lines
1.2 KiB
Python
37 lines
1.2 KiB
Python
|
from typing import Optional
|
||
|
|
||
|
|
||
|
def is_base_form(univ_pos: str, morphology: Optional[dict] = None) -> bool:
|
||
|
"""
|
||
|
Check whether we're dealing with an uninflected paradigm, so we can
|
||
|
avoid lemmatization entirely.
|
||
|
|
||
|
univ_pos (unicode / int): The token's universal part-of-speech tag.
|
||
|
morphology (dict): The token's morphological features following the
|
||
|
Universal Dependencies scheme.
|
||
|
"""
|
||
|
if morphology is None:
|
||
|
morphology = {}
|
||
|
if univ_pos == "noun" and morphology.get("Number") == "sing":
|
||
|
return True
|
||
|
elif univ_pos == "verb" and morphology.get("VerbForm") == "inf":
|
||
|
return True
|
||
|
# This maps 'VBP' to base form -- probably just need 'IS_BASE'
|
||
|
# morphology
|
||
|
elif univ_pos == "verb" and (
|
||
|
morphology.get("VerbForm") == "fin"
|
||
|
and morphology.get("Tense") == "pres"
|
||
|
and morphology.get("Number") is None
|
||
|
):
|
||
|
return True
|
||
|
elif univ_pos == "adj" and morphology.get("Degree") == "pos":
|
||
|
return True
|
||
|
elif morphology.get("VerbForm") == "inf":
|
||
|
return True
|
||
|
elif morphology.get("VerbForm") == "none":
|
||
|
return True
|
||
|
elif morphology.get("Degree") == "pos":
|
||
|
return True
|
||
|
else:
|
||
|
return False
|