This project provides only a wrapper for ENIAM (see online source code) Author of original code is Wojciech Jaworski.
- First, you have to install eniam by calling
pip install eniam - Then you can try parsing some example phrases (see
examples/example.ipynb):
# !pip install opencv-python
# !pip install camelot-py
# !pip install wand
from eniam import *
dom_result = Eniam(['KOT', 'MYSZ'], {
rule(lemma='kot',pos=subst,case=nom): gram('KOT'),
rule(lemma='gonić',pos=fin,person=ter): (ip<gram('KOT'))>gram('MYSZ'),
rule(lemma='mysz',pos=subst,case=acc): gram('MYSZ'),
root_rule(): s % ip,
}, ['KOT', 'MYSZ', 'ZDARZENIE'], {
valence_rule('kot', 'noun'): 'KOT',
valence_rule('mysz', 'noun'): 'MYSZ',
valence_rule('gonić', 'verb'): 'ZDARZENIE',
}).dom("Kot goni mysz.")
dom_result.show()The eniam library uses custom primitive AST the most of the operations looks exactly the same as in normal ENIAM convensions except for those modifications:
/is replaced with>\is replaced with<ip{ |x1, |x2, |x3... |xn}is replaced withip[ x1 | x2 | ... | xn]?xis replaced with functionoptional(x)a\?(x)is replaced witha % x- the grammar can contain inline literals created using
gram()function for examplerule(lemma='kot',pos=subst): gram('np/np\\np'),would be a valid rule.
- Showing the result in Jupyter notebook
Eniam(...).dom("Kot goni mysz.").show() - Getting the html code
Eniam(...).dom("Kot goni mysz.").html() - Saving the html code
Eniam(...).dom("Kot goni mysz.").save_html('output_file') - Multiple input sentences
- Showing the result in Jupyter notebook
Eniam(...).dom(["Kot goni mysz.", "Mysz goni kota."]).show()
To run ENIAM docker please use the following commands:
# Run subsyntax tool
$ docker run -it styczynski/eniam:1.0 /root/subsyntax --help
# Run lexicon printer
$ docker run -it styczynski/eniam:1.0 /root/print_lexicon --help
# Run DOM parser
$ docker run -it styczynski/eniam:1.0 /root/domparser --helpYou can install Python wrapper to get a nice wrapper around the docker container (this requires Python +3 and Docker installed):
$ pip install eniam
$ eniam-cli sub --help
$ eniam-cli lex --help
$ eniam-cli dom --helpNote: Before installing you may wish to add python /bin/ directory to the PATH variable. On MacOS for Python 3.7 that would be:
$ export PATH="$PATH:/usr/local/Cellar/python/3.7.5/Frameworks/Python.framework/Versions/3.7/bin"