mirror of
https://github.com/explosion/spaCy.git
synced 2024-12-24 17:06:29 +03:00
* Implement validation and oracle on pystate, for testing
This commit is contained in:
parent
3709ed9d6d
commit
82247169f2
|
@ -11,6 +11,7 @@ cdef class PyState:
|
||||||
cdef readonly dict moves_by_name
|
cdef readonly dict moves_by_name
|
||||||
|
|
||||||
cdef Move* _moves
|
cdef Move* _moves
|
||||||
|
cdef Move* _golds
|
||||||
cdef State* _s
|
cdef State* _s
|
||||||
|
|
||||||
cdef Move* _get_move(self, unicode move_name) except NULL
|
cdef Move* _get_move(self, unicode move_name) except NULL
|
||||||
|
|
|
@ -4,7 +4,7 @@ from ._state cimport init_state
|
||||||
from ._state cimport entity_is_open
|
from ._state cimport entity_is_open
|
||||||
from .moves cimport fill_moves
|
from .moves cimport fill_moves
|
||||||
from .moves cimport transition
|
from .moves cimport transition
|
||||||
from .moves cimport set_accept_if_valid
|
from .moves cimport set_accept_if_valid, set_accept_if_oracle
|
||||||
from .moves import get_n_moves
|
from .moves import get_n_moves
|
||||||
from .moves import ACTION_NAMES
|
from .moves import ACTION_NAMES
|
||||||
|
|
||||||
|
@ -27,10 +27,18 @@ cdef class PyState:
|
||||||
else:
|
else:
|
||||||
tag_name = tag_names[m.label]
|
tag_name = tag_names[m.label]
|
||||||
self.moves_by_name['%s-%s' % (action_name, tag_name)] = i
|
self.moves_by_name['%s-%s' % (action_name, tag_name)] = i
|
||||||
|
# TODO
|
||||||
|
self._golds = <Move*>self.mem.alloc(n_tokens, sizeof(Move))
|
||||||
|
|
||||||
cdef Move* _get_move(self, unicode move_name) except NULL:
|
cdef Move* _get_move(self, unicode move_name) except NULL:
|
||||||
return &self._moves[self.moves_by_name[move_name]]
|
return &self._moves[self.moves_by_name[move_name]]
|
||||||
|
|
||||||
|
def set_golds(self, list gold_names):
|
||||||
|
cdef Move* m
|
||||||
|
for i, name in enumerate(gold_names):
|
||||||
|
m = self._get_move(name)
|
||||||
|
self._golds[i] = m[0]
|
||||||
|
|
||||||
def transition(self, unicode move_name):
|
def transition(self, unicode move_name):
|
||||||
cdef Move* m = self._get_move(move_name)
|
cdef Move* m = self._get_move(move_name)
|
||||||
transition(self._s, m)
|
transition(self._s, m)
|
||||||
|
@ -41,15 +49,17 @@ cdef class PyState:
|
||||||
return m.accept
|
return m.accept
|
||||||
|
|
||||||
def is_gold(self, unicode move_name):
|
def is_gold(self, unicode move_name):
|
||||||
pass
|
set_accept_if_oracle(self._moves, self._golds, self.n_classes, self._s)
|
||||||
|
cdef Move* m = self._get_move(move_name)
|
||||||
|
return m.accept
|
||||||
|
|
||||||
property ent:
|
property ent:
|
||||||
def __get__(self):
|
def __get__(self):
|
||||||
return self._s.ents[self._s.j]
|
return self._s.curr
|
||||||
|
|
||||||
property n_ents:
|
property n_ents:
|
||||||
def __get__(self):
|
def __get__(self):
|
||||||
return self._s.j + 1
|
return self._s.j
|
||||||
|
|
||||||
property i:
|
property i:
|
||||||
def __get__(self):
|
def __get__(self):
|
||||||
|
@ -58,5 +68,3 @@ cdef class PyState:
|
||||||
property open_entity:
|
property open_entity:
|
||||||
def __get__(self):
|
def __get__(self):
|
||||||
return entity_is_open(self._s)
|
return entity_is_open(self._s)
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user