mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-12 02:06:31 +03:00
* Work on beam parser
This commit is contained in:
parent
5c3016bac8
commit
80baa2e3db
2
setup.py
2
setup.py
|
@ -57,7 +57,7 @@ exts = [
|
||||||
Extension("spacy.ner._state", ["spacy/ner/_state.pyx"], language="c++", include_dirs=includes),
|
Extension("spacy.ner._state", ["spacy/ner/_state.pyx"], language="c++", include_dirs=includes),
|
||||||
Extension("spacy.ner.bilou_moves", ["spacy/ner/bilou_moves.pyx"], language="c++", include_dirs=includes),
|
Extension("spacy.ner.bilou_moves", ["spacy/ner/bilou_moves.pyx"], language="c++", include_dirs=includes),
|
||||||
Extension("spacy.ner.io_moves", ["spacy/ner/io_moves.pyx"], language="c++", include_dirs=includes),
|
Extension("spacy.ner.io_moves", ["spacy/ner/io_moves.pyx"], language="c++", include_dirs=includes),
|
||||||
Extension("spacy.ner.greedy_parser", ["spacy/ner/greedy_parser.pyx"], language="c++", include_dirs=includes),
|
#Extension("spacy.ner.greedy_parser", ["spacy/ner/greedy_parser.pyx"], language="c++", include_dirs=includes),
|
||||||
Extension("spacy.ner.pystate", ["spacy/ner/pystate.pyx"], language="c++", include_dirs=includes),
|
Extension("spacy.ner.pystate", ["spacy/ner/pystate.pyx"], language="c++", include_dirs=includes),
|
||||||
Extension("spacy.ner.context", ["spacy/ner/context.pyx"], language="c++", include_dirs=includes),
|
Extension("spacy.ner.context", ["spacy/ner/context.pyx"], language="c++", include_dirs=includes),
|
||||||
Extension("spacy.ner.feats", ["spacy/ner/feats.pyx"], language="c++", include_dirs=includes),
|
Extension("spacy.ner.feats", ["spacy/ner/feats.pyx"], language="c++", include_dirs=includes),
|
||||||
|
|
|
@ -10,4 +10,6 @@ cdef int copy_state(Pool mem, State* dest, State* source) except -1
|
||||||
|
|
||||||
cdef bint entity_is_open(State *s) except -1
|
cdef bint entity_is_open(State *s) except -1
|
||||||
|
|
||||||
cdef bint entity_is_sunk(State *s, Move* golds) except -1
|
cdef int entity_is_sunk(State *s, Move* golds) except -1
|
||||||
|
|
||||||
|
cdef int is_done(State* s) except -1
|
||||||
|
|
|
@ -1,11 +1,14 @@
|
||||||
cdef void begin_entity(State* s, label):
|
from libc.string cimport memcpy
|
||||||
|
|
||||||
|
|
||||||
|
cdef int begin_entity(State* s, label) except -1:
|
||||||
s.j += 1
|
s.j += 1
|
||||||
s.ents[s.j].start = s.i
|
s.ents[s.j].start = s.i
|
||||||
s.ents[s.j].tag = label
|
s.ents[s.j].tag = label
|
||||||
s.ents[s.j].end = s.i + 1
|
s.ents[s.j].end = s.i + 1
|
||||||
|
|
||||||
|
|
||||||
cdef void end_entity(State* s):
|
cdef int end_entity(State* s) except -1:
|
||||||
s.ents[s.j].end = s.i + 1
|
s.ents[s.j].end = s.i + 1
|
||||||
|
|
||||||
|
|
||||||
|
@ -16,22 +19,22 @@ cdef State* init_state(Pool mem, int sent_length) except NULL:
|
||||||
s.length = sent_length
|
s.length = sent_length
|
||||||
|
|
||||||
|
|
||||||
cdef bint entity_is_open(State *s):
|
cdef bint entity_is_open(State *s) except -1:
|
||||||
return s.ents[s.j].start != 0
|
return s.ents[s.j].start != 0
|
||||||
|
|
||||||
|
|
||||||
cdef bint entity_is_sunk(State *s, Move* golds):
|
cdef int entity_is_sunk(State *s, Move* golds) except -1:
|
||||||
if not entity_is_open(s):
|
if not entity_is_open(s):
|
||||||
return False
|
return False
|
||||||
|
raise StandardError
|
||||||
cdef Entity* ent = &s.ents[s.j]
|
#cdef Entity* ent = &s.ents[s.j]
|
||||||
cdef Move* gold = &golds[ent.start]
|
#cdef Move* gold = &golds[ent.start]
|
||||||
if gold.action != BEGIN and gold.action != UNIT:
|
#if gold.action != BEGIN and gold.action != UNIT:
|
||||||
return True
|
# return True
|
||||||
elif gold.label != ent.label:
|
#elif gold.label != ent.label:
|
||||||
return True
|
# return True
|
||||||
else:
|
#else:
|
||||||
return False
|
# return False
|
||||||
|
|
||||||
|
|
||||||
cdef int copy_state(Pool mem, State* dest, State* source) except -1:
|
cdef int copy_state(Pool mem, State* dest, State* source) except -1:
|
||||||
|
@ -47,4 +50,5 @@ cdef int copy_state(Pool mem, State* dest, State* source) except -1:
|
||||||
dest.curr = source.curr
|
dest.curr = source.curr
|
||||||
|
|
||||||
|
|
||||||
|
cdef int is_done(State* s) except -1:
|
||||||
|
return s.i >= s.length and not entity_is_open(s)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user