From f01b3d043ea2b8a37f79afcf513936722c445a24 Mon Sep 17 00:00:00 2001 From: Matthew Honnibal Date: Tue, 23 Jun 2015 03:03:22 +0200 Subject: [PATCH] * Add padding to arrays in stateclass. May be papering over a deeper bug. --- spacy/syntax/stateclass.pyx | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/spacy/syntax/stateclass.pyx b/spacy/syntax/stateclass.pyx index 68e8a2198..725850850 100644 --- a/spacy/syntax/stateclass.pyx +++ b/spacy/syntax/stateclass.pyx @@ -7,14 +7,17 @@ from ..structs cimport Entity cdef class StateClass: def __init__(self, int length): cdef Pool mem = Pool() - self._buffer = mem.alloc(length, sizeof(int)) - self._stack = mem.alloc(length, sizeof(int)) - self.shifted = mem.alloc(length, sizeof(bint)) - self._sent = mem.alloc(length, sizeof(TokenC)) - self._ents = mem.alloc(length, sizeof(Entity)) + PADDING = 5 + self._buffer = mem.alloc(length + PADDING, sizeof(int)) + self._stack = mem.alloc(length + PADDING, sizeof(int)) + self.shifted = mem.alloc(length + PADDING, sizeof(bint)) + self._sent = mem.alloc(length + PADDING, sizeof(TokenC)) + self._ents = mem.alloc(length + PADDING, sizeof(Entity)) cdef int i for i in range(length): self._ents[i].end = -1 + for i in range(length, length + PADDING): + self._sent[i].lex = &EMPTY_LEXEME self.mem = mem self.length = length self._break = -1 @@ -181,8 +184,6 @@ cdef class StateClass: cdef int dist = head - child self._sent[child].head = dist self._sent[child].dep = label - # Keep a bit-vector tracking child dependencies. If a word has a child at - # offset i from it, set that bit (tracking left and right separately) if child > head: self._sent[head].r_kids += 1 else: