From d15a88c66ac1eae1a34d434df0871ff4d51d2304 Mon Sep 17 00:00:00 2001 From: Matthew Honnibal Date: Mon, 17 Oct 2016 02:43:35 +0200 Subject: [PATCH] Defer some attributes to Doc via getters_for_spans --- spacy/tokens/span.pyx | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/spacy/tokens/span.pyx b/spacy/tokens/span.pyx index 49403ccc3..6fff4d93a 100644 --- a/spacy/tokens/span.pyx +++ b/spacy/tokens/span.pyx @@ -81,6 +81,8 @@ cdef class Span: self.doc.merge(self.start_char, self.end_char, tag, lemma, ent_type) def similarity(self, other): + if 'similarity' in self.doc.getters_for_spans: + self.doc.getters_for_spans['similarity'](self, other) if self.vector_norm == 0.0 or other.vector_norm == 0.0: return 0.0 return numpy.dot(self.vector, other.vector) / (self.vector_norm * other.vector_norm) @@ -102,6 +104,8 @@ cdef class Span: property sent: '''Get the sentence span that this span is a part of.''' def __get__(self): + if 'sent' in self.doc.getters_for_spans: + return self.doc.getters_for_spans['sent'](self) # This should raise if we're not parsed. self.doc.sents cdef int n = 0 @@ -115,16 +119,22 @@ cdef class Span: property has_vector: def __get__(self): + if 'has_vector' in self.doc.getters_for_spans: + return self.doc.getters_for_spans['has_vector'](self) return any(token.has_vector for token in self) property vector: def __get__(self): + if 'vector' in self.doc.getters_for_spans: + return self.doc.getters_for_spans['vector'](self) if self._vector is None: self._vector = sum(t.vector for t in self) / len(self) return self._vector property vector_norm: def __get__(self): + if 'vector_norm' in self.doc.getters_for_spans: + return self.doc.getters_for_spans['vector'](self) cdef float value if self._vector_norm is None: self._vector_norm = 1e-20 @@ -187,6 +197,8 @@ cdef class Span: """ def __get__(self): self._recalculate_indices() + if 'root' in self.doc.getters_for_spans: + return self.doc.getters_for_spans['root'](self) # This should probably be called 'head', and the other one called # 'gov'. But we went with 'head' elsehwhere, and now we're stuck =/ cdef int i