Word embeddings

Introduction to Natural Language Processing in R

Kasey Jones

Research Data Scientist

The flaw in word counts

Two statements:

  • Bob is the smartest person I know.
  • Bob is the most brilliant person I know.

Without stop words:

  • Bob smartest person
  • Bob brilliant person
Introduction to Natural Language Processing in R

Word meanings

Additional data:

  • The smartest people ...
  • He was the smartest ...
  • Brilliant people ...
  • His was so brilliant ...
Introduction to Natural Language Processing in R

word2vec

  • represents words as a large vector space
  • captures multiple similarities between words
  • words of similarly meaning are closer within the space

With a word2vec representation, similar words are clustered closer together within a multidimensional vector space.

1 https://www.adityathakker.com/introduction-to-word2vec-how-it-works/
Introduction to Natural Language Processing in R

Preparing data

library(h2o)
h2o.init()
h2o_object = as.h2o(animal_farm)

Tokenize using h2o:

words <- h2o.tokenize(h2o_object$text_column, "\\\\W+")
words <- h2o.tolower(words)
words = words[is.na(words) || (!words %in% stop_words$word),]
Introduction to Natural Language Processing in R

word2vec modeling

word2vec_model <-
    h2o.word2vec(words, min_word_freq = 5, epochs = 5)
  • min_word_freq: removes words used fewer than 5 times
  • epochs: number of training iterations to run
Introduction to Natural Language Processing in R

Word synonyms

h2o.findSynonyms(w2v.model, "animal")
    synonym     score
1     drink 0.8209088
2       age 0.7952490
3   alcohol 0.7867004
4       act 0.7710537
5      hero 0.7658424
h2o.findSynonyms(w2v.model, "jones")
      synonym     score
1      battle 0.7996588
2  discovered 0.7944554
3     cowshed 0.7823287
4     enemies 0.7766532
5       yards 0.7679787
Introduction to Natural Language Processing in R

Additional uses

  • classification modeling
  • sentiment analysis
  • topic modeling
Introduction to Natural Language Processing in R

Apply word2vec

Introduction to Natural Language Processing in R

Preparing Video For Download...