RNN modelsLucidworks AI custom embedding model training
Lucidworks AI supports general and eCommerce recurrent neural network (RNN) models.
The following table contains the default information for the general and eCommerce RNN models. The suggested default information is pertinent to most use cases.
General RNN model | eCommerce RNN model |
---|---|
The general model is typically used by knowledge management sites that contain information, such as news or documentation. |
The eCommerce model is typically used by sites that provide products for purchase. |
English pre-trained word tokenization and embeddings. The default text processor is |
English pre-trained word tokenization and embeddings seed the model. The default text processor is Word embeddings are fine-tuned during training:
|
One bi-directional gated recurrent unit (GRU) RNN layer with 128 units. Due to the bi-directional nature, the output vector is 256 dimensions. The other available value is long short-term memory (LSTM). You must specify number of units for each RNN layer used. For example, if you have two layers specified ["gru", "gru"] you must specify two values for number of units like [128, 64]. |
One bi-directional gated recurrent unit (GRU) RNN layer with 128 units. Due to the bi-directional nature, the output vector is 256 dimensions. The other available value is long short-term memory (LSTM). You must specify number of units for each RNN layer used. For example, if you have two layers specified ["gru", "gru"] you must specify two values for number of units like [128, 64]. |
Batch size is set automatically based on the dataset size. |
Batch size is set automatically based on the dataset size. |
64 training epochs |
64 training epochs |
8 monitor patience epochs that training passes before it stops if there is no validation metric improvement during the epochs. The best model state based on the monitor validation metric is used as the final model. |
16 monitor patience epochs that training passes before it stops if there is no validation metric improvement during the epochs. The best model state based on the monitor validation metric is used as the final model. |
|
If your eCommerce data does not have a |
Text processor
This determines which type of tokenization and embedding is used as the base for the recurrent neural network (RNN) model. For example, word or byte-pair encoding (BPE).
The word text processor defaults to English, and uses word-based tokenization and English pre-trained word embeddings. The maximum word vocabulary result is 100,000.
The BPE text processors use the same tokenization, but different vocabulary sizes:
-
bpe_*_small
embeddings have 10,000 vocabulary tokens -
bpe_*_large
embeddings have 100,000 vocabulary tokens -
bpe_multi
multilingual embeddings have 320,000 vocabulary tokens
The options for text processors are:
-
English
-
word_en
(default) -
bpe_en_small
-
bpe_en_large
-
-
Multilingual
-
bpe_multi
-
-
Bulgarian
-
bpe_bg_small
-
bpe_bg_large
-
-
German
-
bpe_de_small
-
bpe_de_large
-
-
Spanish
-
bpe_es_small
-
bpe_es_large
-
-
French
-
bpe_fr_small
-
bpe_fr_large
-
-
Italian
-
bpe_it_small
-
bpe_it_large
-
-
Japanese
-
bpe_ja_small
-
bpe_ja_large
-
-
Korean
-
bpe_ko_small
-
bpe_ko_large
-
-
Dutch
-
bpe_nl_small
-
bpe_nl_large
-
-
Romanian
-
bpe_ro_small
-
bpe_ro_large
-
-
Chinese
-
bpe_zh_small
-
bpe_zh_large
-
-
Custom
-
word_custom
-
bpe_custom
-
Word text processor
If you use the defaults or explicitly set the word_en
text processor, the training process uses pre-trained English word embeddings. It builds vocabulary based on your training data and selects word embeddings that correspond to it.
Preprocessing completes the following changes:
-
Text is set to all lowercase characters.
-
Numbers are split into single digits. For example,
"12345"
is set to["1", "2", "3", "4", "5"]
. -
Corrects as many misspelled words as possible.
-
Identifies words that are identified as Out-Of-Vocabulary (OOV) and matches to as many known words as possible. The resulting vocabulary is restricted to a maximum of 100,000 words.
BPE text processors
To use pre-trained byte pair encoding (BPE) tokenization and embeddings, set the text processor to one of the bpe_*
values based on the language you want to train.
The BPE versions use the same tokenization, but different vocabulary sizes:
-
bpe_*_small
embeddings have 10,000 vocabulary tokens -
bpe_*_large
embeddings have 100,000 vocabulary tokens -
bpe_multi
multilingual embeddings have 320,000 vocabulary tokens
Pre-trained BPE tokenization replaces all numbers with a zero (0 ) token. These pre-trained models cannot be changed. If your data contains semantically-meaningful numbers, consider using custom trained BPE embeddings. For more information, see custom text processors.
|
Custom text processors
If your content includes unusual, very domain-specific vocabulary or you need to train a model for a non-supported language, you can train custom word or BPE embeddings.
This training is language-agnostic, but Lucidworks recommends you use custom BPE training for non-Latin languages or in multilingual scenarios.
To train custom token embeddings, set textProcessor
to one of the following:
-
word_custom
trains word embeddings with up to 100,000 vocabulary size -
bpe_custom
trains BPE embeddings with up to 10,000 vocabulary sizeThe
bpe_custom
text processor also learns a custom tokenization function over your data. The value of 10,000 is sufficient for most use cases.