mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-26 09:14:32 +03:00
124 lines
2.3 KiB
Cython
124 lines
2.3 KiB
Cython
from libc.stdint cimport uint8_t, uint32_t, int32_t, uint64_t
|
|
|
|
from .typedefs cimport flags_t, attr_t, hash_t
|
|
from .parts_of_speech cimport univ_pos_t
|
|
|
|
|
|
cdef struct LexemeC:
|
|
flags_t flags
|
|
|
|
attr_t lang
|
|
|
|
attr_t id
|
|
attr_t length
|
|
|
|
attr_t orth
|
|
attr_t lower
|
|
attr_t norm
|
|
attr_t shape
|
|
attr_t prefix
|
|
attr_t suffix
|
|
|
|
attr_t cluster
|
|
|
|
float prob
|
|
float sentiment
|
|
|
|
|
|
cdef struct SerializedLexemeC:
|
|
unsigned char[8 + 8*10 + 4 + 4] data
|
|
# sizeof(flags_t) # flags
|
|
# + sizeof(attr_t) # lang
|
|
# + sizeof(attr_t) # id
|
|
# + sizeof(attr_t) # length
|
|
# + sizeof(attr_t) # orth
|
|
# + sizeof(attr_t) # lower
|
|
# + sizeof(attr_t) # norm
|
|
# + sizeof(attr_t) # shape
|
|
# + sizeof(attr_t) # prefix
|
|
# + sizeof(attr_t) # suffix
|
|
# + sizeof(attr_t) # cluster
|
|
# + sizeof(float) # prob
|
|
# + sizeof(float) # cluster
|
|
# + sizeof(float) # l2_norm
|
|
|
|
|
|
cdef struct Entity:
|
|
hash_t id
|
|
int start
|
|
int end
|
|
attr_t label
|
|
|
|
|
|
cdef struct TokenC:
|
|
const LexemeC* lex
|
|
uint64_t morph
|
|
univ_pos_t pos
|
|
bint spacy
|
|
attr_t tag
|
|
int idx
|
|
attr_t lemma
|
|
attr_t norm
|
|
int head
|
|
attr_t dep
|
|
|
|
uint32_t l_kids
|
|
uint32_t r_kids
|
|
uint32_t l_edge
|
|
uint32_t r_edge
|
|
|
|
int sent_start
|
|
int ent_iob
|
|
attr_t ent_type # TODO: Is there a better way to do this? Multiple sources of truth..
|
|
hash_t ent_id
|
|
|
|
|
|
cdef struct MorphAnalysisC:
|
|
univ_pos_t pos
|
|
int length
|
|
|
|
attr_t abbr
|
|
attr_t adp_type
|
|
attr_t adv_type
|
|
attr_t animacy
|
|
attr_t aspect
|
|
attr_t case
|
|
attr_t conj_type
|
|
attr_t connegative
|
|
attr_t definite
|
|
attr_t degree
|
|
attr_t derivation
|
|
attr_t echo
|
|
attr_t foreign
|
|
attr_t gender
|
|
attr_t hyph
|
|
attr_t inf_form
|
|
attr_t mood
|
|
attr_t negative
|
|
attr_t number
|
|
attr_t name_type
|
|
attr_t noun_type
|
|
attr_t num_form
|
|
attr_t num_type
|
|
attr_t num_value
|
|
attr_t part_form
|
|
attr_t part_type
|
|
attr_t person
|
|
attr_t polite
|
|
attr_t polarity
|
|
attr_t poss
|
|
attr_t prefix
|
|
attr_t prep_case
|
|
attr_t pron_type
|
|
attr_t punct_side
|
|
attr_t punct_type
|
|
attr_t reflex
|
|
attr_t style
|
|
attr_t style_variant
|
|
attr_t tense
|
|
attr_t typo
|
|
attr_t verb_form
|
|
attr_t voice
|
|
attr_t verb_type
|
|
|