La rappresentazione bag-of-words

Introduzione all'Elaborazione del Linguaggio Naturale in R

Kasey Jones

Research Data Scientist

L’esempio precedente

animal_farm %>%
  unnest_tokens(output = "word", token = "words",
                input = text_column) %>%
  anti_join(stop_words) %>%
  count(word, sort = TRUE)
# A tibble: 3,611 x 2
   word         n
   <chr>    <int>
 1 animals    248
 2 farm       163
 ...
Introduzione all'Elaborazione del Linguaggio Naturale in R

La rappresentazione bag-of-words

text1 <- c("Few words are important.")
text2 <- c("All words are important.")
text3 <- c("Most words are important.")

Parole uniche:

  • few: solo in text1
  • all: solo in text2
  • most: solo in text3
  • words, are, important
Introduzione all'Elaborazione del Linguaggio Naturale in R

Rappresentazioni vettoriali tipiche

# Minuscole, senza stop word
word_vector <- c("few", "all", "most", "words", "important")
# Rappresentazione per text1
text1 <- c("Few words are important.")
text1_vector <- c(1, 0, 0, 1, 1)
# Rappresentazione per text2
text2 <- c("All words are important.")
text2_vector <- c(0, 1, 0, 1, 1)
# Rappresentazione per text3
text3 <- c("Most words are important.")
text3_vector <- c(0, 0, 1, 1, 1)
Introduzione all'Elaborazione del Linguaggio Naturale in R

Rappresentazione tidytext

words <- animal_farm %>%
    unnest_tokens(output = "word", token = "words", input = text_column) %>%
    anti_join(stop_words) %>%
    count(chapter, word, sort = TRUE)
words
# A tibble: 6,807 x 3
   chapter    word         n
   <chr>      <chr>    <int>
 1 Chapter 8  napoleon    43
 2 Chapter 8  animals     41
 3 Chapter 9  boxer       34
...
Introduzione all'Elaborazione del Linguaggio Naturale in R

Esempio con una parola

words %>%
  filter(word == 'napoleon') %>%
  arrange(desc(n))
# A tibble: 9 x 3
  chapter    word         n
  <chr>      <chr>    <int>
1 Chapter 8  napoleon    43
2 Chapter 7  napoleon    24
3 Chapter 5  napoleon    22
...
8 Chapter 3  napoleon     3
9 Chapter 4  napoleon     1
Introduzione all'Elaborazione del Linguaggio Naturale in R

Matrici sparse

library(tidytext); library(dplyr)
russian_tweets <- read.csv("russian_1.csv")
russian_tweets <- as_tibble(russian_tweets)

tidy_tweets <- russian_tweets %>%
  unnest_tokens(word, content) %>%
  anti_join(stop_words)
tidy_tweets %>%
  count(word, sort = TRUE)
# A tibble: 43,666 x 2
...
Introduzione all'Elaborazione del Linguaggio Naturale in R

Matrici sparse (continua)

Matrice sparsa

  • 20.000 righe (tweet)
  • 43.000 colonne (parole)
  • 20.000 × 43.000 = 860.000.000
  • Solo 177.000 valori non zero. Circa 0,02%

Esempio di matrice sparsa: Le matrici sparse hanno pochissimi valori non zero. Vederne una significa vedere quasi solo zeri.

Introduzione all'Elaborazione del Linguaggio Naturale in R

Pratica BoW

Introduzione all'Elaborazione del Linguaggio Naturale in R

Preparing Video For Download...