mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-12 10:16:27 +03:00
* Move moves to bilou_moves. Refactor context, returning to the simpler giant-enum style
This commit is contained in:
parent
c788633429
commit
e6bb8aa3a9
|
@ -1,21 +1,5 @@
|
||||||
from cymem.cymem cimport Pool
|
from cymem.cymem cimport Pool
|
||||||
from .moves cimport Move
|
from .structs cimport State, Entity, Move
|
||||||
|
|
||||||
|
|
||||||
cdef struct Entity:
|
|
||||||
int start
|
|
||||||
int end
|
|
||||||
int label
|
|
||||||
|
|
||||||
|
|
||||||
cdef struct State:
|
|
||||||
Entity curr
|
|
||||||
Entity* ents
|
|
||||||
int* tags
|
|
||||||
int i
|
|
||||||
int j
|
|
||||||
int length
|
|
||||||
|
|
||||||
|
|
||||||
cdef int begin_entity(State* s, label) except -1
|
cdef int begin_entity(State* s, label) except -1
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from .moves cimport BEGIN, UNIT
|
from .bilou_moves cimport BEGIN, UNIT
|
||||||
|
|
||||||
|
|
||||||
cdef int begin_entity(State* s, label) except -1:
|
cdef int begin_entity(State* s, label) except -1:
|
||||||
|
|
|
@ -3,7 +3,8 @@ from cymem.cymem cimport Pool
|
||||||
from thinc.typedefs cimport class_t
|
from thinc.typedefs cimport class_t
|
||||||
from thinc.typedefs cimport weight_t
|
from thinc.typedefs cimport weight_t
|
||||||
|
|
||||||
from ._state cimport State
|
from .structs cimport State, Move
|
||||||
|
|
||||||
|
|
||||||
cpdef enum ActionType:
|
cpdef enum ActionType:
|
||||||
MISSING
|
MISSING
|
||||||
|
@ -15,13 +16,6 @@ cpdef enum ActionType:
|
||||||
N_ACTIONS
|
N_ACTIONS
|
||||||
|
|
||||||
|
|
||||||
cdef struct Move:
|
|
||||||
class_t clas
|
|
||||||
int action
|
|
||||||
int label
|
|
||||||
bint accept
|
|
||||||
|
|
||||||
|
|
||||||
cdef int set_accept_if_oracle(Move* moves, Move* golds, int n, State* s) except 0
|
cdef int set_accept_if_oracle(Move* moves, Move* golds, int n, State* s) except 0
|
||||||
|
|
||||||
cdef int set_accept_if_valid(Move* moves, int n, State* s) except 0
|
cdef int set_accept_if_valid(Move* moves, int n, State* s) except 0
|
|
@ -6,7 +6,7 @@ from thinc.typedefs cimport *
|
||||||
from ..tokens cimport Tokens
|
from ..tokens cimport Tokens
|
||||||
from ..typedefs cimport *
|
from ..typedefs cimport *
|
||||||
|
|
||||||
from .moves cimport Move
|
from .bilou_moves cimport Move
|
||||||
|
|
||||||
|
|
||||||
cdef class NERParser:
|
cdef class NERParser:
|
||||||
|
|
|
@ -12,11 +12,11 @@ from thinc.features cimport ConjFeat
|
||||||
|
|
||||||
from .context cimport fill_context
|
from .context cimport fill_context
|
||||||
from .context cimport N_FIELDS
|
from .context cimport N_FIELDS
|
||||||
from .moves cimport Move
|
from .bilou_moves cimport Move
|
||||||
from .moves cimport fill_moves, transition, best_accepted
|
from .bilou_moves cimport fill_moves, transition, best_accepted
|
||||||
from .moves cimport set_accept_if_valid, set_accept_if_oracle
|
from .bilou_moves cimport set_accept_if_valid, set_accept_if_oracle
|
||||||
from ._state cimport entity_is_open
|
from ._state cimport entity_is_open
|
||||||
from .moves import get_n_moves
|
from .bilou_moves import get_n_moves
|
||||||
from ._state cimport State
|
from ._state cimport State
|
||||||
from ._state cimport init_state
|
from ._state cimport init_state
|
||||||
|
|
||||||
|
@ -81,7 +81,7 @@ cdef class NERParser:
|
||||||
n_correct = 0
|
n_correct = 0
|
||||||
cdef int f = 0
|
cdef int f = 0
|
||||||
while s.i < tokens.length:
|
while s.i < tokens.length:
|
||||||
fill_context(self._context, s.i, tokens)
|
fill_context(self._context, s, tokens)
|
||||||
self.extractor.extract(self._feats, self._values, self._context, NULL)
|
self.extractor.extract(self._feats, self._values, self._context, NULL)
|
||||||
self.model.score(self._scores, self._feats, self._values)
|
self.model.score(self._scores, self._feats, self._values)
|
||||||
|
|
||||||
|
@ -109,7 +109,7 @@ cdef class NERParser:
|
||||||
cdef State* s = init_state(mem, tokens.length)
|
cdef State* s = init_state(mem, tokens.length)
|
||||||
cdef Move* move
|
cdef Move* move
|
||||||
while s.i < tokens.length:
|
while s.i < tokens.length:
|
||||||
fill_context(self._context, s.i, tokens)
|
fill_context(self._context, s, tokens)
|
||||||
self.extractor.extract(self._feats, self._values, self._context, NULL)
|
self.extractor.extract(self._feats, self._values, self._context, NULL)
|
||||||
self.model.score(self._scores, self._feats, self._values)
|
self.model.score(self._scores, self._feats, self._values)
|
||||||
set_accept_if_valid(self._moves, self.n_classes, s)
|
set_accept_if_valid(self._moves, self.n_classes, s)
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
from cymem.cymem cimport Pool
|
from cymem.cymem cimport Pool
|
||||||
|
|
||||||
from .moves cimport Move
|
from .structs cimport Move, State
|
||||||
from ._state cimport State
|
|
||||||
|
|
||||||
|
|
||||||
cdef class PyState:
|
cdef class PyState:
|
||||||
|
|
|
@ -2,11 +2,11 @@ from __future__ import unicode_literals
|
||||||
|
|
||||||
from ._state cimport init_state
|
from ._state cimport init_state
|
||||||
from ._state cimport entity_is_open
|
from ._state cimport entity_is_open
|
||||||
from .moves cimport fill_moves
|
from .bilou_moves cimport fill_moves
|
||||||
from .moves cimport transition
|
from .bilou_moves cimport transition
|
||||||
from .moves cimport set_accept_if_valid, set_accept_if_oracle
|
from .bilou_moves cimport set_accept_if_valid, set_accept_if_oracle
|
||||||
from .moves import get_n_moves
|
from .bilou_moves import get_n_moves
|
||||||
from .moves import ACTION_NAMES
|
from .bilou_moves import ACTION_NAMES
|
||||||
|
|
||||||
|
|
||||||
cdef class PyState:
|
cdef class PyState:
|
||||||
|
|
Loading…
Reference in New Issue
Block a user