* Add implementation of batching + backwards compatibility fixes. Tests indicate issue with batch disambiguation for custom singular entity lookups. * Fix tests. Add distinction w.r.t. batch size. * Remove redundant and add new comments. * Adjust comments. Fix variable naming in EL prediction. * Fix mypy errors. * Remove KB entity type config option. Change return types of candidate retrieval functions to Iterable from Iterator. Fix various other issues. * Update spacy/pipeline/entity_linker.py Co-authored-by: Paul O'Leary McCann <polm@dampfkraft.com> * Update spacy/pipeline/entity_linker.py Co-authored-by: Paul O'Leary McCann <polm@dampfkraft.com> * Update spacy/kb_base.pyx Co-authored-by: Paul O'Leary McCann <polm@dampfkraft.com> * Update spacy/kb_base.pyx Co-authored-by: Paul O'Leary McCann <polm@dampfkraft.com> * Update spacy/pipeline/entity_linker.py Co-authored-by: Paul O'Leary McCann <polm@dampfkraft.com> * Add error messages to NotImplementedErrors. Remove redundant comment. * Fix imports. * Remove redundant comments. * Rename KnowledgeBase to InMemoryLookupKB and BaseKnowledgeBase to KnowledgeBase. * Fix tests. * Update spacy/errors.py Co-authored-by: Sofie Van Landeghem <svlandeg@users.noreply.github.com> * Move KB into subdirectory. * Adjust imports after KB move to dedicated subdirectory. * Fix config imports. * Move Candidate + retrieval functions to separate module. Fix other, small issues. * Fix docstrings and error message w.r.t. class names. Fix typing for candidate retrieval functions. * Update spacy/kb/kb_in_memory.pyx Co-authored-by: Sofie Van Landeghem <svlandeg@users.noreply.github.com> * Update spacy/ml/models/entity_linker.py Co-authored-by: Sofie Van Landeghem <svlandeg@users.noreply.github.com> * Fix typing. * Change typing of mentions to be Span instead of Union[Span, str]. * Update docs. * Update EntityLinker and _architecture docs. * Update website/docs/api/entitylinker.md Co-authored-by: Paul O'Leary McCann <polm@dampfkraft.com> * Adjust message for E1046. * Re-add section for Candidate in kb.md, add reference to dedicated page. * Update docs and docstrings. * Re-add section + reference for KnowledgeBase.get_alias_candidates() in docs. * Update spacy/kb/candidate.pyx * Update spacy/kb/kb_in_memory.pyx * Update spacy/pipeline/legacy/entity_linker.py * Remove canididate.md. Remove mistakenly added config snippet in entity_linker.py. Co-authored-by: Paul O'Leary McCann <polm@dampfkraft.com> Co-authored-by: Sofie Van Landeghem <svlandeg@users.noreply.github.com>
63 KiB
title | teaser | source | menu | ||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Model Architectures | Pre-defined model architectures included with the core library | spacy/ml/models |
|
A model architecture is a function that wires up a
Model
instance, which you can then use in a
pipeline component or as a layer of a larger network. This page documents
spaCy's built-in architectures that are used for different NLP tasks. All
trainable built-in components expect a model
argument defined in the config and document their the default architecture.
Custom architectures can be registered using the
@spacy.registry.architectures
decorator and used as
part of the training config. Also see the
usage documentation on
layers and model architectures.
Tok2Vec architectures
spacy.Tok2Vec.v2
Example config
[model] @architectures = "spacy.Tok2Vec.v2" [model.embed] @architectures = "spacy.CharacterEmbed.v2" # ... [model.encode] @architectures = "spacy.MaxoutWindowEncoder.v2" # ...
Construct a tok2vec model out of two subnetworks: one for embedding and one for encoding. See the "Embed, Encode, Attend, Predict" blog post for background.
Name | Description |
---|---|
embed |
Embed tokens into context-independent word vector representations. For example, CharacterEmbed or MultiHashEmbed. |
encode |
Encode context into the embeddings, using an architecture such as a CNN, BiLSTM or transformer. For example, MaxoutWindowEncoder. |
CREATES | The model using the architecture. |
spacy.HashEmbedCNN.v2
Example Config
[model] @architectures = "spacy.HashEmbedCNN.v2" pretrained_vectors = null width = 96 depth = 4 embed_size = 2000 window_size = 1 maxout_pieces = 3 subword_features = true
Build spaCy's "standard" tok2vec layer. This layer is defined by a MultiHashEmbed embedding layer that uses subword features, and a MaxoutWindowEncoder encoding layer consisting of a CNN and a layer-normalized maxout activation function.
Name | Description |
---|---|
width |
The width of the input and output. These are required to be the same, so that residual connections can be used. Recommended values are 96 , 128 or 300 . |
depth |
The number of convolutional layers to use. Recommended values are between 2 and 8 . |
embed_size |
The number of rows in the hash embedding tables. This can be surprisingly small, due to the use of the hash embeddings. Recommended values are between 2000 and 10000 . |
window_size |
The number of tokens on either side to concatenate during the convolutions. The receptive field of the CNN will be depth * (window_size * 2 + 1) , so a 4-layer network with a window size of 2 will be sensitive to 20 words at a time. Recommended value is 1 . |
maxout_pieces |
The number of pieces to use in the maxout non-linearity. If 1 , the Mish non-linearity is used instead. Recommended values are 1 -3 . |
subword_features |
Whether to also embed subword features, specifically the prefix, suffix and word shape. This is recommended for alphabetic languages like English, but not if single-character tokens are used for a language such as Chinese. |
pretrained_vectors |
Whether to also use static vectors. |
CREATES | The model using the architecture. |
spacy.Tok2VecListener.v1
Example config
[components.tok2vec] factory = "tok2vec" [components.tok2vec.model] @architectures = "spacy.HashEmbedCNN.v2" width = 342 [components.tagger] factory = "tagger" [components.tagger.model] @architectures = "spacy.Tagger.v2" [components.tagger.model.tok2vec] @architectures = "spacy.Tok2VecListener.v1" width = ${components.tok2vec.model.width}
A listener is used as a sublayer within a component such as a
DependencyParser
,
EntityRecognizer
or
TextCategorizer
. Usually you'll have multiple
listeners connecting to a single upstream Tok2Vec
component
that's earlier in the pipeline. The listener layers act as proxies, passing
the predictions from the Tok2Vec
component into downstream components, and
communicating gradients back upstream.
Instead of defining its own Tok2Vec
instance, a model architecture like
Tagger can define a listener as its tok2vec
argument that connects to the shared tok2vec
component in the pipeline.
Listeners work by caching the Tok2Vec
output for a given batch of Doc
s. This
means that in order for a component to work with the listener, the batch of
Doc
s passed to the listener must be the same as the batch of Doc
s passed to
the Tok2Vec
. As a result, any manipulation of the Doc
s which would affect
Tok2Vec
output, such as to create special contexts or remove Doc
s for which
no prediction can be made, must happen inside the model, after the call to
the Tok2Vec
component.
Name | Description |
---|---|
width |
The width of the vectors produced by the "upstream" Tok2Vec component. |
upstream |
A string to identify the "upstream" Tok2Vec component to communicate with. By default, the upstream name is the wildcard string "*" , but you could also specify the name of the Tok2Vec component. You'll almost never have multiple upstream Tok2Vec components, so the wildcard string will almost always be fine. |
CREATES | The model using the architecture. |
spacy.MultiHashEmbed.v2
Example config
[model] @architectures = "spacy.MultiHashEmbed.v2" width = 64 attrs = ["NORM", "PREFIX", "SUFFIX", "SHAPE"] rows = [2000, 1000, 1000, 1000] include_static_vectors = true
Construct an embedding layer that separately embeds a number of lexical
attributes using hash embedding, concatenates the results, and passes it through
a feed-forward subnetwork to build a mixed representation. The features used can
be configured with the attrs
argument. The suggested attributes are NORM
,
PREFIX
, SUFFIX
and SHAPE
. This lets the model take into account some
subword information, without construction a fully character-based
representation. If pretrained vectors are available, they can be included in the
representation as well, with the vectors table kept static (i.e. it's not
updated).
Name | Description |
---|---|
width |
The output width. Also used as the width of the embedding tables. Recommended values are between 64 and 300 . If static vectors are included, a learned linear layer is used to map the vectors to the specified width before concatenating it with the other embedding outputs. A single maxout layer is then used to reduce the concatenated vectors to the final width. |
attrs |
The token attributes to embed. A separate embedding table will be constructed for each attribute. |
rows |
The number of rows for each embedding tables. Can be low, due to the hashing trick. Recommended values are between 1000 and 10000 . The layer needs surprisingly few rows, due to its use of the hashing trick. Generally between 2000 and 10000 rows is sufficient, even for very large vocabularies. A number of rows must be specified for each table, so the rows list must be of the same length as the attrs parameter. |
include_static_vectors |
Whether to also use static word vectors. Requires a vectors table to be loaded in the Doc objects' vocab. |
CREATES | The model using the architecture. |
spacy.CharacterEmbed.v2
Example config
[model] @architectures = "spacy.CharacterEmbed.v2" width = 128 rows = 7000 nM = 64 nC = 8
Construct an embedded representation based on character embeddings, using a feed-forward network. A fixed number of UTF-8 byte characters are used for each word, taken from the beginning and end of the word equally. Padding is used in the center for words that are too short.
For instance, let's say nC=4
, and the word is "jumping". The characters used
will be "jung"
(two from the start, two from the end). If we had nC=8
, the
characters would be "jumpping"
: 4 from the start, 4 from the end. This ensures
that the final character is always in the last position, instead of being in an
arbitrary position depending on the word length.
The characters are embedded in a embedding table with a given number of rows,
and the vectors concatenated. A hash-embedded vector of the NORM
of the word
is also concatenated on, and the result is then passed through a feed-forward
network to construct a single vector to represent the information.
Name | Description |
---|---|
width |
The width of the output vector and the NORM hash embedding. |
rows |
The number of rows in the NORM hash embedding table. |
nM |
The dimensionality of the character embeddings. Recommended values are between 16 and 64 . |
nC |
The number of UTF-8 bytes to embed per word. Recommended values are between 3 and 8 , although it may depend on the length of words in the language. |
CREATES | The model using the architecture. |
spacy.MaxoutWindowEncoder.v2
Example config
[model] @architectures = "spacy.MaxoutWindowEncoder.v2" width = 128 window_size = 1 maxout_pieces = 3 depth = 4
Encode context using convolutions with maxout activation, layer normalization and residual connections.
Name | Description |
---|---|
width |
The input and output width. These are required to be the same, to allow residual connections. This value will be determined by the width of the inputs. Recommended values are between 64 and 300 . |
window_size |
The number of words to concatenate around each token to construct the convolution. Recommended value is 1 . |
maxout_pieces |
The number of maxout pieces to use. Recommended values are 2 or 3 . |
depth |
The number of convolutional layers. Recommended value is 4 . |
CREATES | The model using the architecture. |
spacy.MishWindowEncoder.v2
Example config
[model] @architectures = "spacy.MishWindowEncoder.v2" width = 64 window_size = 1 depth = 4
Encode context using convolutions with
Mish
activation, layer normalization
and residual connections.
Name | Description |
---|---|
width |
The input and output width. These are required to be the same, to allow residual connections. This value will be determined by the width of the inputs. Recommended values are between 64 and 300 . |
window_size |
The number of words to concatenate around each token to construct the convolution. Recommended value is 1 . |
depth |
The number of convolutional layers. Recommended value is 4 . |
CREATES | The model using the architecture. |
spacy.TorchBiLSTMEncoder.v1
Example config
[model] @architectures = "spacy.TorchBiLSTMEncoder.v1" width = 64 depth = 2 dropout = 0.0
Encode context using bidirectional LSTM layers. Requires PyTorch.
Name | Description |
---|---|
width |
The input and output width. These are required to be the same, to allow residual connections. This value will be determined by the width of the inputs. Recommended values are between 64 and 300 . |
depth |
The number of recurrent layers, for instance depth=2 results in stacking two LSTMs together. |
dropout |
Creates a Dropout layer on the outputs of each LSTM layer except the last layer. Set to 0.0 to disable this functionality. |
CREATES | The model using the architecture. |
spacy.StaticVectors.v2
Example config
[model] @architectures = "spacy.StaticVectors.v2" nO = null nM = null dropout = 0.2 key_attr = "ORTH" [model.init_W] @initializers = "glorot_uniform_init.v1"
Embed Doc
objects with their vocab's vectors table, applying a
learned linear projection to control the dimensionality. Unknown tokens are
mapped to a zero vector. See the documentation on
static vectors for details.
Name | Description |
---|---|
nO |
The output width of the layer, after the linear projection. |
nM |
The width of the static vectors. |
dropout |
Optional dropout rate. If set, it's applied per dimension over the whole batch. Defaults to None . |
init_W |
The initialization function. Defaults to glorot_uniform_init . |
key_attr |
Defaults to "ORTH" . |
CREATES | The model using the architecture. |
spacy.FeatureExtractor.v1
Example config
[model] @architectures = "spacy.FeatureExtractor.v1" columns = ["NORM", "PREFIX", "SUFFIX", "SHAPE", "ORTH"]
Extract arrays of input features from Doc
objects. Expects a list
of feature names to extract, which should refer to token attributes.
Name | Description |
---|---|
columns |
The token attributes to extract. |
CREATES | The created feature extraction layer. |
Transformer architectures
The following architectures are provided by the package
spacy-transformers
. See the
usage documentation for how to
integrate the architectures into your training config.
Note that in order to use these architectures in your config, you need to
install the
spacy-transformers
. See the
installation docs
for details and system requirements.
spacy-transformers.TransformerModel.v3
Example Config
[model] @architectures = "spacy-transformers.TransformerModel.v3" name = "roberta-base" tokenizer_config = {"use_fast": true} transformer_config = {} mixed_precision = true grad_scaler_config = {"init_scale": 32768} [model.get_spans] @span_getters = "spacy-transformers.strided_spans.v1" window = 128 stride = 96
Load and wrap a transformer model from the
HuggingFace transformers
library. You
can use any transformer that has pretrained weights and a PyTorch
implementation. The name
variable is passed through to the underlying library,
so it can be either a string or a path. If it's a string, the pretrained weights
will be downloaded via the transformers library if they are not already
available locally.
In order to support longer documents, the
TransformerModel layer allows you to pass
in a get_spans
function that will divide up the Doc
objects
before passing them through the transformer. Your spans are allowed to overlap
or exclude tokens. This layer is usually used directly by the
Transformer
component, which allows you to share the
transformer weights across your pipeline. For a layer that's configured for use
in other components, see
Tok2VecTransformer.
Name | Description |
---|---|
name |
Any model name that can be loaded by transformers.AutoModel . |
get_spans |
Function that takes a batch of Doc object and returns lists of Span objects to process by the transformer. See here for built-in options and examples. |
tokenizer_config |
Tokenizer settings passed to transformers.AutoTokenizer . |
transformer_config |
Transformer settings passed to transformers.AutoConfig |
mixed_precision |
Replace whitelisted ops by half-precision counterparts. Speeds up training and prediction on GPUs with Tensor Cores and reduces GPU memory use. |
grad_scaler_config |
Configuration to pass to thinc.api.PyTorchGradScaler during training when mixed_precision is enabled. |
CREATES | The model using the architecture. |
- The
transformer_config
argument was added inspacy-transformers.TransformerModel.v2
. - The
mixed_precision
andgrad_scaler_config
arguments were added inspacy-transformers.TransformerModel.v3
.
The other arguments are shared between all versions.
spacy-transformers.TransformerListener.v1
Example Config
[model] @architectures = "spacy-transformers.TransformerListener.v1" grad_factor = 1.0 [model.pooling] @layers = "reduce_mean.v1"
Create a TransformerListener
layer, which will connect to a
Transformer
component earlier in the pipeline. The layer
takes a list of Doc
objects as input, and produces a list of
2-dimensional arrays as output, with each array having one row per token. Most
spaCy models expect a sublayer with this signature, making it easy to connect
them to a transformer model via this sublayer. Transformer models usually
operate over wordpieces, which usually don't align one-to-one against spaCy
tokens. The layer therefore requires a reduction operation in order to calculate
a single token vector given zero or more wordpiece vectors.
Name | Description |
---|---|
pooling |
A reduction layer used to calculate the token vectors based on zero or more wordpiece vectors. If in doubt, mean pooling (see reduce_mean ) is usually a good choice. |
grad_factor |
Reweight gradients from the component before passing them upstream. You can set this to 0 to "freeze" the transformer weights with respect to the component, or use it to make some components more significant than others. Leaving it at 1.0 is usually fine. |
upstream |
A string to identify the "upstream" Transformer component to communicate with. By default, the upstream name is the wildcard string "*" , but you could also specify the name of the Transformer component. You'll almost never have multiple upstream Transformer components, so the wildcard string will almost always be fine. |
CREATES | The model using the architecture. |
spacy-transformers.Tok2VecTransformer.v3
Example Config
[model] @architectures = "spacy-transformers.Tok2VecTransformer.v3" name = "albert-base-v2" tokenizer_config = {"use_fast": false} transformer_config = {} grad_factor = 1.0 mixed_precision = true grad_scaler_config = {"init_scale": 32768}
Use a transformer as a Tok2Vec
layer directly. This does
not allow multiple components to share the transformer weights and does
not allow the transformer to set annotations into the Doc
object, but it's a simpler solution if you only need the transformer within
one component.
Name | Description |
---|---|
get_spans |
Function that takes a batch of Doc object and returns lists of Span objects to process by the transformer. See here for built-in options and examples. |
tokenizer_config |
Tokenizer settings passed to transformers.AutoTokenizer . |
transformer_config |
Settings to pass to the transformers forward pass. |
pooling |
A reduction layer used to calculate the token vectors based on zero or more wordpiece vectors. If in doubt, mean pooling (see reduce_mean ) is usually a good choice. |
grad_factor |
Reweight gradients from the component before passing them upstream. You can set this to 0 to "freeze" the transformer weights with respect to the component, or use it to make some components more significant than others. Leaving it at 1.0 is usually fine. |
mixed_precision |
Replace whitelisted ops by half-precision counterparts. Speeds up training and prediction on GPUs with Tensor Cores and reduces GPU memory use. |
grad_scaler_config |
Configuration to pass to thinc.api.PyTorchGradScaler during training when mixed_precision is enabled. |
CREATES | The model using the architecture. |
- The
transformer_config
argument was added inspacy-transformers.Tok2VecTransformer.v2
. - The
mixed_precision
andgrad_scaler_config
arguments were added inspacy-transformers.Tok2VecTransformer.v3
.
The other arguments are shared between all versions.
Pretraining architectures
The spacy pretrain
command lets you initialize a Tok2Vec
layer in your
pipeline with information from raw text. To this end, additional layers are
added to build a network for a temporary task that forces the Tok2Vec
layer to
learn something about sentence structure and word cooccurrence statistics. Two
pretraining objectives are available, both of which are variants of the cloze
task Devlin et al. (2018) introduced for
BERT.
For more information, see the section on pretraining.
spacy.PretrainVectors.v1
Example config
[pretraining] component = "tok2vec" [initialize] vectors = "en_core_web_lg" ... [pretraining.objective] @architectures = "spacy.PretrainVectors.v1" maxout_pieces = 3 hidden_size = 300 loss = "cosine"
Predict the word's vector from a static embeddings table as pretraining
objective for a Tok2Vec layer. To use this objective, make sure that the
initialize.vectors
section in the config refers to a model with static
vectors.
Name | Description |
---|---|
maxout_pieces |
The number of maxout pieces to use. Recommended values are 2 or 3 . |
hidden_size |
Size of the hidden layer of the model. |
loss |
The loss function can be either "cosine" or "L2". We typically recommend to use "cosine". ~ |
CREATES | A callable function that can create the Model, given the vocab of the pipeline and the tok2vec layer to pretrain. |
spacy.PretrainCharacters.v1
Example config
[pretraining] component = "tok2vec" ... [pretraining.objective] @architectures = "spacy.PretrainCharacters.v1" maxout_pieces = 3 hidden_size = 300 n_characters = 4
Predict some number of leading and trailing UTF-8 bytes as pretraining objective for a Tok2Vec layer.
Name | Description |
---|---|
maxout_pieces |
The number of maxout pieces to use. Recommended values are 2 or 3 . |
hidden_size |
Size of the hidden layer of the model. |
n_characters |
The window of characters - e.g. if n_characters = 2 , the model will try to predict the first two and last two characters of the word. |
CREATES | A callable function that can create the Model, given the vocab of the pipeline and the tok2vec layer to pretrain. |
Parser & NER architectures
spacy.TransitionBasedParser.v2
Example Config
[model] @architectures = "spacy.TransitionBasedParser.v2" state_type = "ner" extra_state_tokens = false hidden_width = 64 maxout_pieces = 2 use_upper = true [model.tok2vec] @architectures = "spacy.HashEmbedCNN.v2" pretrained_vectors = null width = 96 depth = 4 embed_size = 2000 window_size = 1 maxout_pieces = 3 subword_features = true
Build a transition-based parser model. Can apply to NER or dependency parsing. Transition-based parsing is an approach to structured prediction where the task of predicting the structure is mapped to a series of state transitions. You might find this tutorial helpful for background information. The neural network state prediction model consists of either two or three subnetworks:
- tok2vec: Map each token into a vector representation. This subnetwork is run once for each batch.
- lower: Construct a feature-specific vector for each
(token, feature)
pair. This is also run once for each batch. Constructing the state representation is then a matter of summing the component features and applying the non-linearity. - upper (optional): A feed-forward network that predicts scores from the state representation. If not present, the output from the lower model is used as action scores directly.
Name | Description |
---|---|
tok2vec |
Subnetwork to map tokens into vector representations. |
state_type |
Which task to extract features for. Possible values are "ner" and "parser". |
extra_state_tokens |
Whether to use an expanded feature set when extracting the state tokens. Slightly slower, but sometimes improves accuracy slightly. Defaults to False . |
hidden_width |
The width of the hidden layer. |
maxout_pieces |
How many pieces to use in the state prediction layer. Recommended values are 1 , 2 or 3 . If 1 , the maxout non-linearity is replaced with a Relu non-linearity if use_upper is True , and no non-linearity if False . |
use_upper |
Whether to use an additional hidden layer after the state vector in order to predict the action scores. It is recommended to set this to False for large pretrained models such as transformers, and True for smaller networks. The upper layer is computed on CPU, which becomes a bottleneck on larger GPU-based models, where it's also less necessary. |
nO |
The number of actions the model will predict between. Usually inferred from data at the beginning of training, or loaded from disk. |
CREATES | The model using the architecture. |
TransitionBasedParser.v1 had the exact
same signature, but the use_upper
argument was True
by default.
Tagging architectures
spacy.Tagger.v2
Example Config
[model] @architectures = "spacy.Tagger.v2" nO = null normalize = false [model.tok2vec] # ...
Build a tagger model, using a provided token-to-vector component. The tagger model adds a linear layer with softmax activation to predict scores given the token vectors.
Name | Description |
---|---|
tok2vec |
Subnetwork to map tokens into vector representations. |
nO |
The number of tags to output. Inferred from the data if None . |
normalize |
Normalize probabilities during inference. Defaults to False . |
CREATES | The model using the architecture. |
- The
normalize
argument was added inspacy.Tagger.v2
.spacy.Tagger.v1
always normalizes probabilities during inference.
The other arguments are shared between all versions.
Text classification architectures
A text classification architecture needs to take a Doc
as input,
and produce a score for each potential label class. Textcat challenges can be
binary (e.g. sentiment analysis) or involve multiple possible labels.
Multi-label challenges can either have mutually exclusive labels (each example
has exactly one label), or multiple labels may be applicable at the same time.
As the properties of text classification problems can vary widely, we provide several different built-in architectures. It is recommended to experiment with different architectures and settings to determine what works best on your specific data and challenge.
When the architecture for a text classification challenge contains a setting for
exclusive_classes
, it is important to use the correct value for the correct
pipeline component. The textcat
component should always be used for
single-label use-cases where exclusive_classes = true
, while the
textcat_multilabel
should be used for multi-label settings with
exclusive_classes = false
.
spacy.TextCatEnsemble.v2
Example Config
[model] @architectures = "spacy.TextCatEnsemble.v2" nO = null [model.linear_model] @architectures = "spacy.TextCatBOW.v2" exclusive_classes = true ngram_size = 1 no_output_layer = false [model.tok2vec] @architectures = "spacy.Tok2Vec.v2" [model.tok2vec.embed] @architectures = "spacy.MultiHashEmbed.v2" width = 64 rows = [2000, 2000, 1000, 1000, 1000, 1000] attrs = ["ORTH", "LOWER", "PREFIX", "SUFFIX", "SHAPE", "ID"] include_static_vectors = false [model.tok2vec.encode] @architectures = "spacy.MaxoutWindowEncoder.v2" width = ${model.tok2vec.embed.width} window_size = 1 maxout_pieces = 3 depth = 2
Stacked ensemble of a linear bag-of-words model and a neural network model. The
neural network is built upon a Tok2Vec layer and uses attention. The setting for
whether or not this model should cater for multi-label classification, is taken
from the linear model, where it is stored in model.attrs["multi_label"]
.
Name | Description |
---|---|
linear_model |
The linear bag-of-words model. |
tok2vec |
The tok2vec layer to build the neural network upon. |
nO |
Output dimension, determined by the number of different labels. If not set, the TextCategorizer component will set it when initialize is called. |
CREATES | The model using the architecture. |
TextCatEnsemble.v1 was functionally similar,
but used an internal tok2vec
instead of taking it as argument:
Name | Description |
---|---|
exclusive_classes |
Whether or not categories are mutually exclusive. |
pretrained_vectors |
Whether or not pretrained vectors will be used in addition to the feature vectors. |
width |
Output dimension of the feature encoding step. |
embed_size |
Input dimension of the feature encoding step. |
conv_depth |
Depth of the tok2vec layer. |
window_size |
The number of contextual vectors to concatenate from the left and from the right. |
ngram_size |
Determines the maximum length of the n-grams in the BOW model. For instance, ngram_size=3 would give unigram, trigram and bigram features. |
dropout |
The dropout rate. |
nO |
Output dimension, determined by the number of different labels. If not set, the TextCategorizer component will set it when initialize is called. |
CREATES | The model using the architecture. |
spacy.TextCatCNN.v2
Example Config
[model] @architectures = "spacy.TextCatCNN.v2" exclusive_classes = false nO = null [model.tok2vec] @architectures = "spacy.HashEmbedCNN.v2" pretrained_vectors = null width = 96 depth = 4 embed_size = 2000 window_size = 1 maxout_pieces = 3 subword_features = true
A neural network model where token vectors are calculated using a CNN. The vectors are mean pooled and used as features in a feed-forward network. This architecture is usually less accurate than the ensemble, but runs faster.
Name | Description |
---|---|
exclusive_classes |
Whether or not categories are mutually exclusive. |
tok2vec |
The tok2vec layer of the model. |
nO |
Output dimension, determined by the number of different labels. If not set, the TextCategorizer component will set it when initialize is called. |
CREATES | The model using the architecture. |
TextCatCNN.v1 had the exact same signature, but was not yet resizable. Since v2, new labels can be added to this component, even after training.
spacy.TextCatBOW.v2
Example Config
[model] @architectures = "spacy.TextCatBOW.v2" exclusive_classes = false ngram_size = 1 no_output_layer = false nO = null
An n-gram "bag-of-words" model. This architecture should run much faster than the others, but may not be as accurate, especially if texts are short.
Name | Description |
---|---|
exclusive_classes |
Whether or not categories are mutually exclusive. |
ngram_size |
Determines the maximum length of the n-grams in the BOW model. For instance, ngram_size=3 would give unigram, trigram and bigram features. |
no_output_layer |
Whether or not to add an output layer to the model (Softmax activation if exclusive_classes is True , else Logistic ). |
nO |
Output dimension, determined by the number of different labels. If not set, the TextCategorizer component will set it when initialize is called. |
CREATES | The model using the architecture. |
TextCatBOW.v1 had the exact same signature, but was not yet resizable. Since v2, new labels can be added to this component, even after training.
Span classification architectures
spacy.SpanCategorizer.v1
Example Config
[model] @architectures = "spacy.SpanCategorizer.v1" scorer = {"@layers": "spacy.LinearLogistic.v1"} [model.reducer] @layers = spacy.mean_max_reducer.v1" hidden_size = 128 [model.tok2vec] @architectures = "spacy.Tok2Vec.v1" [model.tok2vec.embed] @architectures = "spacy.MultiHashEmbed.v1" # ... [model.tok2vec.encode] @architectures = "spacy.MaxoutWindowEncoder.v1" # ...
Build a span categorizer model to power a
SpanCategorizer
component, given a token-to-vector
model, a reducer model to map the sequence of vectors for each span down to a
single vector, and a scorer model to map the vectors to probabilities.
Name | Description |
---|---|
tok2vec |
The token-to-vector model. |
reducer |
The reducer model. |
scorer |
The scorer model. |
CREATES | The model using the architecture. |
spacy.mean_max_reducer.v1
Reduce sequences by concatenating their mean and max pooled vectors, and then combine the concatenated vectors with a hidden layer.
Name | Description |
---|---|
hidden_size |
The size of the hidden layer. |
Entity linking architectures
An EntityLinker
component disambiguates textual mentions
(tagged as named entities) to unique identifiers, grounding the named entities
into the "real world". This requires 3 main components:
- A
KnowledgeBase
(KB) holding the unique identifiers, potential synonyms and prior probabilities. - A candidate generation step to produce a set of likely identifiers, given a certain textual mention.
- A machine learning
Model
that picks the most plausible ID from the set of candidates.
spacy.EntityLinker.v2
Example Config
[model] @architectures = "spacy.EntityLinker.v2" nO = null [model.tok2vec] @architectures = "spacy.HashEmbedCNN.v2" pretrained_vectors = null width = 96 depth = 2 embed_size = 2000 window_size = 1 maxout_pieces = 3 subword_features = true
The EntityLinker
model architecture is a Thinc Model
with a
Linear
output layer.
Name | Description |
---|---|
tok2vec |
The tok2vec layer of the model. |
nO |
Output dimension, determined by the length of the vectors encoding each entity in the KB. If the nO dimension is not set, the entity linking component will set it when initialize is called. |
CREATES | The model using the architecture. |
spacy.EmptyKB.v1
A function that creates an empty KnowledgeBase
from a Vocab
instance. This is the default when a new entity linker component is created.
Name | Description |
---|---|
entity_vector_length |
The length of the vectors encoding each entity in the KB. Defaults to 64 . |
spacy.KBFromFile.v1
A function that reads an existing KnowledgeBase
from file.
Name | Description |
---|---|
kb_path |
The location of the KB that was stored to file. |
spacy.CandidateGenerator.v1
A function that takes as input a KnowledgeBase
and a
Span
object denoting a named entity, and returns a list of
plausible Candidate
objects. The default
CandidateGenerator
uses the text of a mention to find its potential aliases in
the KnowledgeBase
. Note that this function is case-dependent.