2014-12-19 22:54:03 +03:00
|
|
|
from libcpp.vector cimport vector
|
|
|
|
|
|
|
|
from preshed.maps cimport PreshMap
|
|
|
|
from cymem.cymem cimport Pool
|
|
|
|
from murmurhash.mrmr cimport hash64
|
|
|
|
|
2015-07-22 05:49:39 +03:00
|
|
|
from .structs cimport LexemeC, TokenC
|
2015-07-23 02:18:19 +03:00
|
|
|
from .typedefs cimport utf8_t, attr_t, hash_t
|
2014-12-19 22:54:03 +03:00
|
|
|
from .strings cimport StringStore
|
2015-08-26 20:21:03 +03:00
|
|
|
from .morphology cimport Morphology
|
2014-12-19 22:54:03 +03:00
|
|
|
|
|
|
|
|
2015-01-12 02:26:22 +03:00
|
|
|
cdef LexemeC EMPTY_LEXEME
|
2014-12-24 09:42:00 +03:00
|
|
|
|
|
|
|
|
2014-12-19 22:54:03 +03:00
|
|
|
cdef union LexemesOrTokens:
|
2015-01-12 02:26:22 +03:00
|
|
|
const LexemeC* const* lexemes
|
2015-08-28 03:02:33 +03:00
|
|
|
const TokenC* tokens
|
2014-12-19 22:54:03 +03:00
|
|
|
|
|
|
|
|
|
|
|
cdef struct _Cached:
|
|
|
|
LexemesOrTokens data
|
|
|
|
bint is_lex
|
|
|
|
int length
|
|
|
|
|
|
|
|
|
|
|
|
cdef class Vocab:
|
|
|
|
cdef Pool mem
|
|
|
|
cpdef readonly StringStore strings
|
2017-05-31 00:34:50 +03:00
|
|
|
cpdef public Morphology morphology
|
|
|
|
cpdef public object vectors
|
2015-07-18 23:42:15 +03:00
|
|
|
cdef readonly int length
|
2015-07-23 02:18:19 +03:00
|
|
|
cdef public object data_dir
|
2016-09-25 15:49:53 +03:00
|
|
|
cdef public object lex_attr_getters
|
2014-12-19 22:54:03 +03:00
|
|
|
|
2015-07-22 05:49:39 +03:00
|
|
|
cdef const LexemeC* get(self, Pool mem, unicode string) except NULL
|
2015-07-23 02:18:19 +03:00
|
|
|
cdef const LexemeC* get_by_orth(self, Pool mem, attr_t orth) except NULL
|
2015-08-28 03:02:33 +03:00
|
|
|
cdef const TokenC* make_fused_token(self, substrings) except NULL
|
2017-05-31 00:34:50 +03:00
|
|
|
|
2015-08-23 21:49:18 +03:00
|
|
|
cdef const LexemeC* _new_lexeme(self, Pool mem, unicode string) except NULL
|
2015-01-13 16:03:48 +03:00
|
|
|
cdef int _add_lex_to_vocab(self, hash_t key, const LexemeC* lex) except -1
|
2015-09-06 20:45:15 +03:00
|
|
|
cdef const LexemeC* _new_lexeme(self, Pool mem, unicode string) except NULL
|
2015-04-19 11:31:31 +03:00
|
|
|
|
2015-07-18 23:42:15 +03:00
|
|
|
cdef PreshMap _by_hash
|
|
|
|
cdef PreshMap _by_orth
|