README.md 2.04 KB
Newer Older
1
2
# Networks

3
4
Networks are combinations of layers (and possibly other networks).
They are sub-units of models that would not be trained alone. It
5
6
7
8
encapsulates common network structures like a classification head
or a transformer encoder into an easily handled object with a
standardized configuration.

A. Unique TensorFlower's avatar
A. Unique TensorFlower committed
9
* [`BertEncoder`](bert_encoder.py) implements a bi-directional
10
Transformer-based encoder as described in ["BERT: Pre-training of Deep
11
12
Bidirectional Transformers for Language Understanding"](https://arxiv.org/abs/1810.04805).
It includes the embedding lookups, transformer layers and pooling layer.
13

Chen Chen's avatar
Chen Chen committed
14
* [`AlbertEncoder`](albert_encoder.py) implements a
15
Transformer-encoder described in the paper ["ALBERT: A Lite BERT for
Chen Chen's avatar
Chen Chen committed
16
Self-supervised Learning of Language Representations"]
17
18
19
(https://arxiv.org/abs/1909.11942). Compared with [BERT](https://arxiv.org/abs/1810.04805),
ALBERT refactorizes embedding parameters into two smaller matrices and shares
parameters across layers.
20

Chen Chen's avatar
Chen Chen committed
21
22
23
24
* [`MobileBERTEncoder`](mobile_bert_encoder.py) implements the
MobileBERT network described in the paper ["MobileBERT: a Compact Task-Agnostic
BERT for Resource-Limited Devices"](https://arxiv.org/abs/2004.02984).

25
26
27
* [`Classification`](classification.py) contains a single hidden layer, and is
intended for use as a classification or regression (if number of classes is set
to 1) head.
28

29
30
* [`PackedSequenceEmbedding`](packed_sequence_embedding.py) implements an
embedding network that supports packed sequences and position ids.
31

32
33
34
35
36
37
38
39
40
* [`SpanLabeling`](span_labeling.py) implements a single-span labeler
(that is, a prediction head that can predict one start and end index per batch
item) based on a single dense hidden layer. It can be used in the SQuAD task.

* [`XLNetBase`](xlnet_base.py) implements the base network used in "XLNet:
Generalized Autoregressive Pretraining for Language Understanding"
(https://arxiv.org/abs/1906.08237). It includes embedding lookups,
relative position encodings, mask computations, segment matrix computations and
Transformer XL layers using one or two stream relative self-attention.