{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "#
\n", "\n", "
\n", "\n", "Apple is a simple word, yet it can mean different things in different contexts. What if I said the following: \"My Apple is better than a PC.\" Now, what image comes to mind? Perhaps this?\n", "\n", "\n", "
\n", "This is an example of textual ambiguity. Syntactical context helps eliminate textual ambiguity. Apple is a single word here that contains a single concept. It's a relatively simple word. Perhaps one of the earliest a native speaker of English learns as a child. And yet it has textual ambiguity. Because \"apple\" is a single word, it is known as a unigram. A **unigram** is a single word that represents a single concept.\n", "\n", "Textual ambiguity, however, occurs in more dynamic ways when we think about concepts beyond the single span of a single word. In this notebook, we will focus on two such cases that are essential for natural language processing: bigrams and trigrams. **Bigrams** are two words that contain a distinct meaning when used together, while **trigrams** are three words that contain a distinct meaning when used together.\n", "\n", "Understanding bigrams and trigrams are essential because in order for a computer to truly understand langauge the way a human does, it must be able to understand the nuances of a single word and how a word's meaning not only shifts in context, but shifts in meaning when used in conjunction with other words." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Bigrams" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "As noted above, a bigram is a combination of two words that have a distinct meaning. To demonstrate this, let us consider quickly the word \"French\". A single word, that may have multiple meanings. Perhaps the word French refers to the language:\n", "\n", "\n", "
\n", "Perhaps it references a French person:\n", "\n", "\n", "
\n", "Let's hold off on the word French for just a moment. Let's now use the word \"revolution\". Again, there is textual ambiguity, but perhaps I am referencing the concept of revolution in the sense of the Earth.\n", "\n", "\n", "
\n", "\n", "Now you may already see where I am going with this, but let's now think about what happens when I put those two textually ambiguous unigrams together \"The French Revolution\". \"The\" here is a stop word that is frequently dropped in natural language processing, so \"French Revolution\" is all that we should consider. This two words when combined have a distinct concept. Now, you may be thinking of this:\n", "\n", "\n", "
\n", "But we can think about language in even more nuanced ways." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Trigrams" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Trigrams, as noted above, are the same as bigrams, except with three words, instead of two. Let's continue with our example of \"French\". What might you think about if I used the word \"army\". Perhaps something distinct to your own experiences with the word. For me, as a modern American, I think initially about the American Army in the modern sense of the word. So I may picture something like this:\n", "\n", "\n", "
\n", "For others in other parts of the world, other images may be more relevant. However, when I use the phrase \"The French Revolutionary Army\", I now have something defined, something distinct. I have this:\n", "\n", "\n", "
\n", "This is a trigram, a distinct concept consisting of three words that may have individual meanings when used alone." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## Why are these Important?" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "So, why are bigrams and trigrams so important? The reason comes down to getting machines to understand that when certain words are used together, they bear a distinct meaning. In order to produce a good topic model, therefore, the model must be able to understand and process words in this manner, the way we humans use the language we are trying to get the machine to understand." ] }, { "cell_type": "code", "execution_count": 5, "metadata": {}, "outputs": [ { "data": { "text/html": [ "