2020-10-12 09:41:27 +00:00
|
|
|
from pathlib import Path
|
2020-08-18 14:10:36 +00:00
|
|
|
from typing import Optional, Callable, Iterable
|
2020-02-27 17:42:27 +00:00
|
|
|
from thinc.api import chain, clone, list2ragged, reduce_mean, residual
|
|
|
|
from thinc.api import Model, Maxout, Linear
|
|
|
|
|
2020-02-28 10:57:41 +00:00
|
|
|
from ...util import registry
|
2020-08-18 14:10:36 +00:00
|
|
|
from ...kb import KnowledgeBase, Candidate, get_candidates
|
2020-05-20 09:41:12 +00:00
|
|
|
from ...vocab import Vocab
|
2021-06-28 09:29:29 +00:00
|
|
|
from ...tokens import Span
|
2020-02-27 17:42:27 +00:00
|
|
|
|
|
|
|
|
2021-03-02 16:56:28 +00:00
|
|
|
@registry.architectures("spacy.EntityLinker.v1")
|
2020-07-31 15:02:54 +00:00
|
|
|
def build_nel_encoder(tok2vec: Model, nO: Optional[int] = None) -> Model:
|
2020-02-27 17:42:27 +00:00
|
|
|
with Model.define_operators({">>": chain, "**": clone}):
|
2021-05-06 08:14:47 +00:00
|
|
|
token_width = tok2vec.maybe_get_dim("nO")
|
2020-02-27 17:42:27 +00:00
|
|
|
output_layer = Linear(nO=nO, nI=token_width)
|
|
|
|
model = (
|
|
|
|
tok2vec
|
|
|
|
>> list2ragged()
|
|
|
|
>> reduce_mean()
|
|
|
|
>> residual(Maxout(nO=token_width, nI=token_width, nP=2, dropout=0.0))
|
|
|
|
>> output_layer
|
|
|
|
)
|
|
|
|
model.set_ref("output_layer", output_layer)
|
|
|
|
model.set_ref("tok2vec", tok2vec)
|
|
|
|
return model
|
2020-05-20 09:41:12 +00:00
|
|
|
|
|
|
|
|
2021-03-02 16:56:28 +00:00
|
|
|
@registry.misc("spacy.KBFromFile.v1")
|
2020-10-12 09:41:27 +00:00
|
|
|
def load_kb(kb_path: Path) -> Callable[[Vocab], KnowledgeBase]:
|
2020-08-18 14:10:36 +00:00
|
|
|
def kb_from_file(vocab):
|
|
|
|
kb = KnowledgeBase(vocab, entity_vector_length=1)
|
|
|
|
kb.from_disk(kb_path)
|
|
|
|
return kb
|
2020-08-23 19:15:12 +00:00
|
|
|
|
2020-08-18 14:10:36 +00:00
|
|
|
return kb_from_file
|
2020-08-04 12:34:09 +00:00
|
|
|
|
|
|
|
|
2021-03-02 16:56:28 +00:00
|
|
|
@registry.misc("spacy.EmptyKB.v1")
|
2020-08-18 14:10:36 +00:00
|
|
|
def empty_kb(entity_vector_length: int) -> Callable[[Vocab], KnowledgeBase]:
|
|
|
|
def empty_kb_factory(vocab):
|
|
|
|
return KnowledgeBase(vocab=vocab, entity_vector_length=entity_vector_length)
|
2020-08-23 19:15:12 +00:00
|
|
|
|
2020-08-18 14:10:36 +00:00
|
|
|
return empty_kb_factory
|
|
|
|
|
|
|
|
|
2021-03-02 16:56:28 +00:00
|
|
|
@registry.misc("spacy.CandidateGenerator.v1")
|
2021-06-28 09:29:29 +00:00
|
|
|
def create_candidates() -> Callable[[KnowledgeBase, Span], Iterable[Candidate]]:
|
2020-08-18 14:10:36 +00:00
|
|
|
return get_candidates
|