Naive Bayes¶
In this lecture, we will learn about the Naive Bayes classifier for binary classification.
Naive Bayes is a simple but powerful classifier that doesn't require to find any hyperparameters.
It is very fast to train and predict, and can perform surprisingly well.
TL;DR¶
When using Naive Bayes for binary classification, we need to calculate the likelihood of a tweet being positive or negative.
To do this, we need to build the log ratio of probabilities for each word in the vocabulary.
For example, if the word "happy" appears 20 times in positive tweets and 5 times in negative tweets, then the ratio of probabilities is \(20/5=4\). This means that the word "happy" is more likely to appear in a positive tweet. If the ratio would be less than 1, then the word is more likely to appear in a negative tweet.
Taking the logarithm is a mathematical trick to avoid numerical underflow and simplify the calculations.
Using the log ratio of probabilities, we can calculate the log likelihood of a tweet being positive or negative by summing up the log ratio of probabilities for each word in the tweet, and thus, predict the class of the tweet.
Probability Recap¶
Let
- \(A\) be the event that a tweet being labeled positive
- \(N_{pos}\) be the number of positive tweets
- \(N\) be the total number of tweets
Then the probability \(P(A)\) of a tweet being positive is the number of positive tweets divided by the total number of tweets:
Note
For binary classification, if there a tweet can only be either positive or negative, then the probability of a tweet being negative is \(1-P(A)\).
Example
If there are 35 positive tweets and 100 tweets in total, then the probability \(P(A)\) of a tweet being positive is calculated as
The probability of the tweet being negative is then calculated as \(1-P(A) = 0.65\).
Let \(B\) be the event that a tweet contains the word "amazing". Then the probability \(P(B)\) of a tweet containing the word "amazing" is the number of tweets containing the word divided by the total number of tweets:
Example
If there are 5 tweets containing the word "amazing" and 100 tweets in total, then the probability \(P(B)\) of a tweet containing the word "amazing" is calculated as
Intersection of Two Events¶
Let \(A \cap B\) be the event that a tweet is positive and contains the word "amazing".
Then the probability \(P(A \cap B)\) is calculated as the number of tweets that are positive and contain the word "amazing" divided by the total number of tweets:
The following Venn diagram illustrates this:
Example
Let's assume a corpus of 100 tweets:
- 35 tweets are positive
- 65 tweets are negative
- 5 tweets contain the word "amazing", but one of them is negative (e.g. "I thought this movie was amazing, but it was actually terrible!")
Then the probability \(P(A \cap B)\) of a tweet being positive and containing the word "amazing" is calculated as
Conditional Probability¶
Continuing the example from above, let's assume we want to calculate the probability of a tweet being positive, but knowing that the tweet contains the word "amazing".
Looking at the diagram from above, this means we only consider the blue circle.
In our example, this is the probability of the intersection of the tweets being positive and containing the word "amazing" divided by the probability of all tweets containing the word "amazing".
This is called the conditional probability of a tweet being positive, given that it contains the word "amazing".
Conditional Probability
Generally speaking, the conditional probability \(P(A|B)\) is the probability of event \(A\) given that event \(B\) has already occurred.
It is calculated as the probability of both events occuring divided by the probability of the event that has already occurred:
Example
Let's continue the example from above, where we have 5 tweets containing the word "amazing" and 4 of them are positive.
Then the probability \(P(positive|amazing)\) of a tweet being positive, given that it contains the word "amazing" is calculated as
Now let's turn it around and calculate the probability of a tweet containing the word "amazing", given that it is positive.
This is calculated as follows:
Bayes Rule¶
Now we can derive Bayes Rule, which is based on conditional probabilities.
We know that the conditional probability \(P(A|B)\) is calculated as follows:
and we also know that the conditional probability \(P(B|A)\) is calculated as follows:
We can rewrite this as:
Given that
we can plug in the previous equation and get:
With that, we have derived Bayes Rule.
Bayes Rule
Bayes Rule is a way to calculate the conditional probability \(P(A|B)\), given that we know \(P(B|A)\).
It is calculated as follows:
In other words: Out of all the times \(B\) happens, what fraction are due to \(A\)?
Example
Suppose that in your dataset, 25% of the positive tweets contain the word "amazing". You also know that a total of 13% of the tweets in your dataset contain the word "amazing", and that 40% of the total number of tweets are positive. Given the tweet "amazing to be here". What is the probability that this tweet is positive?
Let \(A\) be the event that a tweet is positive and \(B\) be the event that a tweet contains the word "amazing".
The probability that the tweet "amazing to be here" is positive is 0.7692.
Thomas Bayes
Thomas Bayes (1701 - 1761) was an English statistician, philosopher and Presbyterian minister. Bayes never published what would become his most famous accomplishment; his notes were edited and published posthumously by Richard Price.
In NLP, Bayes' Theorem can be used for:
- classification: given a document, what is the probability that it belongs to a certain class? (e.g. spam or not spam or sentiment analysis)
- information retrieval: given a query, what is the probability that a document is relevant?
- word sense disambiguation: given a word, what is the probability that it has a certain meaning?
Besides machine learning and NLP, Bayes' Theorem is also used in many other fields, such as:
- medicine: given a symptom, what is the probability that a patient has a certain disease?
- biology: given a genetic profile, what is the probability that a person will develop a certain disease?
- economics: given a set of economic conditions, what is the probability that the economy will be in a recession next year?
- finance: given a set of financial conditions, what is the probability that a stock will increase in value next year?
Laplacian Smoothing¶
Using Bayes Rule, we can calculate the probability of a word given a class \(P(w|c)\) as follows:
However, for OOV words, if a word has not been seen in the training data, then \(freq(w,c) = 0\) and thus, \(P(w|c) = 0\).
To account for this, we can use Laplacian Smoothing (aka Additive Smoothing).
This is done by adding the smoothing constant \(\alpha\) to the numerator and \(\alpha|V|\) to the denominator:
Info
If we add a constant \(\alpha\) to the numerator, and since there are \(|V|\) words in the vocabulary to normalize, we have to add \(\alpha|V|\) to the denominator. This way, the probabilities will sum up to 1.
Note that \(\alpha\) is usually set to 1.
Word Probabilities¶
Let's assume we have the following table of word frequencies (as from the feature extraction lecture):
\(V\) | \(n_{pos}\) | \(n_{neg}\) |
---|---|---|
I | 3 | 3 |
am | 2 | 2 |
happy | 2 | 0 |
sad | 0 | 2 |
because | 1 | 1 |
love | 1 | 0 |
hate | 0 | 1 |
the | 1 | 1 |
weather | 1 | 1 |
\(\sum\) | 11 | 11 |
Note that we added the last row to calculate the total number of words per class. This allows us to calculate the probabilities \(P(w|pos)\) and \(P(w|neg)\) for each word \(w\) in a class.
Using the formula for Laplacian Smoothing with \(\alpha=1\)
We end up with the following table:
\(V\) | \(P(w \vert pos)\) | \(P(w \vert neg)\) |
---|---|---|
I | 0.2 | 0.2 |
am | 0.15 | 0.15 |
happy | 0.15 | 0.05 |
sad | 0.05 | 0.15 |
because | 0.1 | 0.1 |
love | 0.1 | 0.05 |
hate | 0.05 | 0.1 |
the | 0.1 | 0.1 |
weather | 0.1 | 0.1 |
\(\sum\) | \(1\) | \(1\) |
Example
Let's calculate the probability \(P(\text{happy}|\text{pos})\) of the word "happy" given that the tweet is positive.
Let's calculate the probability \(P(\text{happy}|\text{neg})\) of the word "happy" given that the tweet is negative.
Ratio of Probabilities¶
Now that we have the probabilities \(P(w|pos)\) and \(P(w|neg)\) for each word \(w\) in a class, we can calculate the ratio of probabilities for each word \(w\) in the vocabulary:
Based on the ratio, we can make the following observations:
- If the ratio is greater than 1, then the word is more likely to appear in a positive tweet.
- If the ratio is less than 1, then the word is more likely to appear in a negative tweet.
- If the ratio is equal to 1, then the word is considered neutral and equally likely to appear in a positive or negative tweet.
\(V\) | \(P(w \vert pos)\) | \(P(w \vert neg)\) | \(\frac{P(w \vert pos)}{P(w \vert neg)}\) |
---|---|---|---|
I | 0.2 | 0.2 | 1.0 |
am | 0.15 | 0.15 | 1.0 |
happy | 0.15 | 0.05 | 3.0 |
sad | 0.05 | 0.15 | 0.3333 |
because | 0.1 | 0.1 | 1.0 |
love | 0.1 | 0.05 | 2.0 |
hate | 0.05 | 0.1 | 0.5 |
the | 0.1 | 0.1 | 1.0 |
weather | 0.1 | 0.1 | 1.0 |
Note
Words that are neutral don't provide any information for classification.
Likelihood¶
Now that we have the ratio of probabilities for each word \(w\) in the vocabulary, we can calculate the probability of a tweet being positive or negative.
To classify a whole tweet, we need to multiply the ratios of probabilities for each word in the tweet.
This is called the likelihood \(P(tweet|pos)\) of a tweet being positive and is calculated as follows:
where
- \(m\) is the number of words in the tweet and
- \(w_i\) is the \(i\)-th word in the tweet.
Note
- If the likelihood is greater than 1, then the tweet is more likely to be positive.
- If the likelihood is less than 1, then the tweet is more likely to be negative.
- If the likelihood is equal to 1, then the tweet is equally likely to be positive or negative and thus, neutral.
Example
Given the table above, let's see if the following tweet is positive or negative:
I am happy because I love ice cream
We have the following ratios of probabilities:
Note that the words "ice" and "cream" are not in the vocabulary, so we ignore them.
Given these ratios, we can calculate the likelihood of the tweet being positive as follows:
Prior¶
The prior \(P(pos)\) is the probability of a tweet being positive, regardless of the words in the tweet.
The prior probability represents the probability of a particular class before considering any features.
The prior is especially important when the dataset is unbalanced.
In a binary classification problem, the prior for a class is calculated as follows:
where
- \(N_c\) is the number of tweets in the class and
- \(N\) is the total number of tweets.
Example
Let's assume we have the following corpus of 100 tweets:
- 35 tweets are positive
- 65 tweets are negative
Then the prior probability of a tweet being positive is calculated as
and the prior probability of a tweet being negative is calculated as
Prior Ratio¶
The prior ratio is the ratio of the prior probabilities of the two classes.
In a binary classification problem, the prior ratio is calculated as follows:
Example
Let's assume we have the following corpus of 100 tweets:
- 35 tweets are positive
- 65 tweets are negative
Then the prior ratio is calculated as
If we apply the prior to the likelihood, we get the following formula:
Using Logarithms¶
The likelihood is the product of many probabilities, i.e. values between 0 and 1.
This can have several consequences, and numbers can become so small that computers have trouble representing them.
This is called numerical underflow.
To avoid this, we can use the logarithm instead.
Numerical Underflow
Numerical underflow occurs when the result of a calculation is too small to be represented by the computer.
This can happen when multiplying many small numbers, because the result gets smaller and smaller with each multiplication.
The computer can only represent numbers up to a certain precision, so at some point the result will be rounded to zero.
This is a problem and can lead to errors, as we lose information about the probabilities.
Tip
Because they avoid the risk of numerical underflow and they are way more convenient to work with, logarithms appear throughout deep-learning and NLP.
Log Likelihood¶
Applying the logarithm to the likelihood formula from above, we get the following formula:
Logarithm
Besides avoiding numerical underflow, another advantage of logarithms is that they allow us to use simpler operations, such as addition instead of multiplication.
This is because of the following property of logarithms:
Thus, the product changes to a sum in the formula above.
Log Prior Ratio¶
When using the logarithm, we speak of the prior as the log prior, and of the prior ratio as the log prior ratio.
Log Ratio of Probabilities¶
Now, if we calculate the ratio of probabilities using the logarithm, the table above looks as follows:
\(V\) | \(P(w \vert pos)\) | \(P(w \vert neg)\) | \(\log \frac{P(w \vert pos)}{P(w \vert neg)}\) |
---|---|---|---|
I | 0.2 | 0.2 | 0.0 |
am | 0.15 | 0.15 | 0.0 |
happy | 0.15 | 0.05 | 1.0986 |
sad | 0.05 | 0.15 | -1.0986 |
because | 0.1 | 0.1 | 0.0 |
love | 0.1 | 0.05 | 0.6931 |
hate | 0.05 | 0.1 | -0.6931 |
the | 0.1 | 0.1 | 0.0 |
weather | 0.1 | 0.1 | 0.0 |
Example
Let's look at a single example, e.g. the word "happy". The ratio of probabilities is calculated as follows:
Training¶
For training of the Naive Bayes classifier for binary classification, we need to do the following:
- Calculate the log prior ratio
- Compute the table of word frequencies for each class
- Compute the table of conditional probabilities of a word given a class using Laplacian Smoothing
- Compute the log ratio of the conditional probabilities
Of course, we need to apply the desired preprocessing steps before the training.
Prediction¶
To predict a tweet using the Naive Bayes classifier for binary classification, we need to apply the likelihood formula to the tweet, and check if the log likelihood is greater than 0.
So for every word in the tweet, we look up the log ratio of probabilities in our likelihood table and sum them up. Then we add the log prior ratio to the sum.
OOV Words are ignored. They are considered neutral and do not contribute to the log likelihood, as the model can only give a score for words that it has seen in the training data.
Example
Let's assume we have a balanced corpus:
Given the table above, let's see if the following tweet is positive or negative:
I am happy because I love ice cream
We have the following ratios of probabilities:
Note that the words "ice" and "cream" are not in the vocabulary, so we ignore them.
Given these ratios, and considering the log prior, we can calculate the log likelihood of the tweet being positive as follows:
Since \(1.7917 > 0\), the tweet is classified as positive.
Note how only the words "happy" and "love" contribute to the log likelihood, since the other words are neutral.
Limitations¶
Naive Bayes is a very simple but powerful classifier and doesn't require to find any hyperparameters.
However, it has some limitations, with the most important one being the independence assumption.
The independence assumption in Naive Bayes refers to the assumption that the presence or absence of a particular feature is independent of the presence or absence of any other feature, given the class label.
In other words, Naive Bayes assumes that the features are independent of each other, which typically isn't the case in NLP.
Some words are more likely to appear together than others, and are thus not independent. Also words can be related to the thing they describe.
Example
It is sunny and hot in the Sahara desert.
- the word "sunny" is more likely to appear with the word "hot" than with the word "cold"
- the word "Sahara" is more likely to appear with the word "desert" than with the word "ocean"
- the words "sunny" and "hot" are related to the word "desert"
Example
Which word to fill in the blank?
It is always cold and snowy in ...
For Naive Bayes, the words "spring", "summer", "autumn" and "winter" are all equally likely, but from the context, we know that "winter" is the most obvious candidate.
Key Takeaways¶
- Naive Bayes is a simple but powerful classifier that doesn't require to find any hyperparameters.
- Naive Bayes is based on Bayes Rule, which is a way to calculate the conditional probability \(P(A|B)\), given that we know \(P(B|A)\).
- By using Logarithms, we can avoid numerical underflow and simplify the calculations.
- For training a Naive Bayes classifier, we need to obtain the log ratio of probabilities for each word in the vocabulary.
- For prediction, we need to use those ratios to calculate the log likelihood of a tweet being positive or negative.
- The main limitation of Naive Bayes is the independence assumption, which assumes that the features are independent of each other, which typically isn't the case in NLP.
- However, because of its simplicity, Naive Bayes is often used as a baseline for text classification tasks and can perform surprisingly well.