Title: | Provide Tools to Extract and Analyze Word Vectors |
---|---|
Description: | Provides access to various word embedding methods (GloVe, fasttext and word2vec) to extract word vectors using a unified framework to increase reproducibility and correctness. |
Authors: | Emil Hvitfeldt [aut, cre] |
Maintainer: | Emil Hvitfeldt <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.2.0.9000 |
Built: | 2025-01-06 02:46:15 UTC |
Source: | https://github.com/emilhvitfeldt/wordsalad |
A dataset containing 5 of H.C. andersens fairy tales translated to English. The UTF-8 plain text was sourced from http://www.andersenstories.com/.
fairy_tales
fairy_tales
A character vector with 5 elements.
This is not representive of the size needed to generate good word vectors. It is just used for examples.
The calculations are done with the fastTextR package.
fasttext( text, tokenizer = text2vec::space_tokenizer, dim = 10L, type = c("skip-gram", "cbow"), window = 5L, loss = "hs", negative = 5L, n_iter = 5L, min_count = 5L, threads = 1L, composition = c("tibble", "data.frame", "matrix"), verbose = FALSE )
fasttext( text, tokenizer = text2vec::space_tokenizer, dim = 10L, type = c("skip-gram", "cbow"), window = 5L, loss = "hs", negative = 5L, n_iter = 5L, min_count = 5L, threads = 1L, composition = c("tibble", "data.frame", "matrix"), verbose = FALSE )
text |
Character string. |
tokenizer |
Function, function to perform tokenization. Defaults to text2vec::space_tokenizer. |
dim |
Integer, number of dimension of the resulting word vectors. |
type |
Character, the type of algorithm to use, either 'cbow' or 'skip-gram'. Defaults to 'skip-gram'. |
window |
Integer, skip length between words. Defaults to 5. |
loss |
Charcter, choice of loss function must be one of "ns", "hs", or "softmax". See details for more Defaults to "hs". |
negative |
integer with the number of negative samples. Only used when loss = "ns". |
n_iter |
Integer, number of training iterations. Defaults to 5.
|
min_count |
Integer, number of times a token should appear to be considered in the model. Defaults to 5. |
threads |
number of CPU threads to use. Defaults to 1. |
composition |
Character, Either "tibble", "matrix", or "data.frame" for the format out the resulting word vectors. |
verbose |
Logical, controls whether progress is reported as operations are executed. |
The choice of loss functions are one of:
"ns" negative sampling
"hs" hierarchical softmax
"softmax" full softmax
A tibble, data.frame or matrix containing the token in the first column and word vectors in the remaining columns.
Enriching Word Vectors with Subword Information, 2016, P. Bojanowski, E. Grave, A. Joulin, T. Mikolov.
fasttext(fairy_tales, n_iter = 2) # Custom tokenizer that splits on non-alphanumeric characters fasttext(fairy_tales, n_iter = 2, tokenizer = function(x) strsplit(x, "[^[:alnum:]]+"))
fasttext(fairy_tales, n_iter = 2) # Custom tokenizer that splits on non-alphanumeric characters fasttext(fairy_tales, n_iter = 2, tokenizer = function(x) strsplit(x, "[^[:alnum:]]+"))
The calculations are done with the text2vec package.
glove( text, tokenizer = text2vec::space_tokenizer, dim = 10L, window = 5L, min_count = 5L, n_iter = 10L, x_max = 10L, stopwords = character(), convergence_tol = -1, threads = 1, composition = c("tibble", "data.frame", "matrix"), verbose = FALSE )
glove( text, tokenizer = text2vec::space_tokenizer, dim = 10L, window = 5L, min_count = 5L, n_iter = 10L, x_max = 10L, stopwords = character(), convergence_tol = -1, threads = 1, composition = c("tibble", "data.frame", "matrix"), verbose = FALSE )
text |
Character string. |
tokenizer |
Function, function to perform tokenization. Defaults to text2vec::space_tokenizer. |
dim |
Integer, number of dimension of the resulting word vectors. |
window |
Integer, skip length between words. Defaults to 5. |
min_count |
Integer, number of times a token should appear to be considered in the model. Defaults to 5. |
n_iter |
Integer, number of training iterations. Defaults to 10. |
x_max |
Integer, maximum number of co-occurrences to use in the weighting function. Defaults to 10. |
stopwords |
Character, a vector of stop words to exclude from training. |
convergence_tol |
Numeric, value determining the convergence criteria.
|
threads |
number of CPU threads to use. Defaults to 1. |
composition |
Character, Either "tibble", "matrix", or "data.frame" for the format out the resulting word vectors. |
verbose |
Logical, controls whether progress is reported as operations are executed. |
A tibble, data.frame or matrix containing the token in the first column and word vectors in the remaining columns.
https://nlp.stanford.edu/projects/glove/
Jeffrey Pennington, Richard Socher, and Christopher D. Manning. 2014. GloVe: Global Vectors for Word Representation.
glove(fairy_tales, x_max = 5)
glove(fairy_tales, x_max = 5)
The calculations are done with the word2vec package.
word2vec( text, tokenizer = text2vec::space_tokenizer, dim = 50, type = c("cbow", "skip-gram"), window = 5L, min_count = 5L, loss = c("ns", "hs"), negative = 5L, n_iter = 5L, lr = 0.05, sample = 0.001, stopwords = character(), threads = 1L, collapse_character = "\t", composition = c("tibble", "data.frame", "matrix") )
word2vec( text, tokenizer = text2vec::space_tokenizer, dim = 50, type = c("cbow", "skip-gram"), window = 5L, min_count = 5L, loss = c("ns", "hs"), negative = 5L, n_iter = 5L, lr = 0.05, sample = 0.001, stopwords = character(), threads = 1L, collapse_character = "\t", composition = c("tibble", "data.frame", "matrix") )
text |
Character string. |
tokenizer |
Function, function to perform tokenization. Defaults to text2vec::space_tokenizer. |
dim |
dimension of the word vectors. Defaults to 50. |
type |
the type of algorithm to use, either 'cbow' or 'skip-gram'. Defaults to 'cbow' |
window |
skip length between words. Defaults to 5. |
min_count |
integer indicating the number of time a word should occur to be considered as part of the training vocabulary. Defaults to 5. |
loss |
Charcter, choice of loss function must be one of "ns" or "hs". See detaulsfor more Defaults to "ns". |
negative |
integer with the number of negative samples. Only used in case hs is set to FALSE |
n_iter |
Integer, number of training iterations. Defaults to 5. |
lr |
initial learning rate also known as alpha. Defaults to 0.05 |
sample |
threshold for occurrence of words. Defaults to 0.001 |
stopwords |
a character vector of stopwords to exclude from training |
threads |
number of CPU threads to use. Defaults to 1. |
collapse_character |
Character vector with length 1. Character used to
glue together tokens after tokenizing. See details for more information.
Defaults to |
composition |
Character, Either "tibble", "matrix", or "data.frame" for the format out the resulting word vectors. |
A trade-off have been made to allow for an arbitrary tokenizing function. The
text is first passed through the tokenizer. Then it is being collapsed back
together into strings using collapse_character
as the separator. You
need to pick collapse_character
to be a character that will not appear
in any of the tokens after tokenizing is done. The default value is a "tab"
character. If you pick a character that is present in the tokens then those
words will be split.
The choice of loss functions are one of:
"ns" negative sampling
"hs" hierarchical softmax
A tibble, data.frame or matrix containing the token in the first column and word vectors in the remaining columns.
Mikolov, Tomas and Sutskever, Ilya and Chen, Kai and Corrado, Greg S and Dean, Jeff. 2013. Distributed Representations of Words and Phrases and their Compositionality
word2vec(fairy_tales) # Custom tokenizer that splits on non-alphanumeric characters word2vec(fairy_tales, tokenizer = function(x) strsplit(x, "[^[:alnum:]]+"))
word2vec(fairy_tales) # Custom tokenizer that splits on non-alphanumeric characters word2vec(fairy_tales, tokenizer = function(x) strsplit(x, "[^[:alnum:]]+"))