Skip to content

Latest commit

 

History

History
82 lines (44 loc) · 8.96 KB

README.md

File metadata and controls

82 lines (44 loc) · 8.96 KB

Predicting Tweet Sentiment With Emojis

Do emojis in tweets impact sentiment prediction models? This is the question that I wanted to answer in my project. I am studying how emojis affect tweet sentiment to improve sentiment analysis accuracy and learn more about their role in text sentiment. To test my question, I used a Naive Bayes model. Through my testing, I found that adding emojis to tweet text input increases the accuracy of categorization. Surprisingly, the most accurate model that I tested on involved training the model on only emojis, not text.

Twitter (now X) is a platform where people can share their thoughts and opinions through words, pictures, or videos. Many tweets contain emojis, and they can change or add to the meaning of tweets. Many tweet sentiment analysis models only focus on the words in the tweets when training and testing - and we did it this way in class too (JamesMTucker, n.d.). However, emojis add a lot to the meaning of some tweets. For example, "I LOVE this artist 😍" vs "I LOVE this artist 🙄" have two very different meanings. This is why I chose to focus on this topic for my project. By incorporating emojis into text sentiment analysis, it could create a more accurate model.

The dataset that I used was taken from Kaggle (Tweets With Emoji, 2023). It contained 43 separate csv files, categorized by emoji. Each csv file had about 20k tweets per emoji. If a tweet contained multiple emojis, the creators just picked one of the emojis in the tweet to categorize it under. To make it easier for me, I decided to merge the csv files into a large DataFrame. In order to preserve which emoji they were categorized under, I made 2 columns in my DataFrame: Text (tweet) and Emoji, which had the name of the csv file the tweet was in. For example, face_savoring_food or thinking_face.

Next, I took a small subset of the 860,000 total tweets and made a csv file with an equal amount of tweets per emoji. It had 860 total tweets. I did this because the original dataset didn't contain any sentiment labels, so I had to add them manually. Adding sentiment to hundreds of thousands of tweets was out of the question, so I chose to label the subset of the entire dataset. Positive was 1, negative was 0.

After labeling them, I did some exploration of the data by graphing the distribution of positive and negative tweets and their length.

Screenshot 2023-12-18 at 2 32 11 PM

Next, I created a Naive Bayes model using the code that we learned in class (JamesMTucker, n.d.). My X input contained the text stripped of emojis, but I appended the name of the emoji that each tweet was classified under to the end of the tweet. So each input looked something like "I LOVE this artist eyes_with_hearts". I wanted to train my model on all of the labeled data that I had, and test it on a big chunk of the unlabeled data. However, I wasn't able to measure accuracy because the testing data was all unlabeled. To get some sort of result, I decided to make the same graph as above, but with the tweets from the testing data and their newly assigned labels. It wasn't too surprising that the graph for the test data looked similar to the graph for the training data.

Screenshot 2023-12-18 at 2 44 44 PM

To get an accuracy, I decided to both train and test on my labeled data. I performed 4 trials: training and testing on only text, using the text and one emoji, using the text and all of the emojis within the tweet, and finally, using only emojis.

Just Text

During preprocessing, I replaced all the emojis with blank spaces. When doing train, test, split, I only used the Text column as the X input. My test size was 0.2, which was consistent across all of the tests. The accuracy I got for this was 0.691860.

Examples of miscalculated tweets are:

Screenshot 2023-12-18 at 3 34 03 PM
Screenshot 2023-12-18 at 3 35 02 PM

The miscalculated tweets are tweets that depend on the emoji to understand the meaning.

Text + One Emoji

During preprocessing, I replaced all the emojis with blank spaces. When doing train, test, split, I combined the Text and Emoji column as the X input. My accuracy increased to 0.784884.

Examples of miscalculated tweets are:

Screenshot 2023-12-18 at 3 37 09 PM
Screenshot 2023-12-18 at 3 37 27 PM

Tweets that were misclassified in this category likely depend on multiple emojis to get the meaning, such as the last one. That tweet was categorized with the pile_of_poop emoji, which is a primarily negative emoji. However, the other emojis give it a positive (joking) sentiment. This model also doesn't do well with slang or sarcasm, as indicated with the first example tweet. "Fire" and the fire emoji are both, by definition, negative, but slang gives both of these terms a positive meaning.

Text + All Emojis

During preprocessing, I kept all the emojis and their text. When doing train, test, split, I used the Text column but not the Emoji column. The Text contains all of the emojis, including the one listed in the Emoji column. The accuracy of this increased to 0.802326.

Examples of miscalculated tweets are:

Screenshot 2023-12-18 at 3 42 08 PM
Screenshot 2023-12-18 at 3 43 58 PM

Again, the use of slang ("slay") and irony is not caught by the model.

Just Emojis

During preprocessing, I only used emojis and removed all text. When doing train, test, split, I used the Text column but not the Emoji column. The Text contains all of the emojis, including the one listed in the Emoji column. This trial had the highest accuracy of 0.837209.

Examples of miscalculated tweets are:

Screenshot 2023-12-18 at 3 48 34 PM
Screenshot 2023-12-18 at 3 49 05 PM

The miscalculated tweets in this section are mainly tweets where the emoji contradicts the meaning of the phrase, or if the emoji is often used in an opposite context. The tilted laughing emoji in the second tweet is often used in negative contexts, which is why that tweet was marked as negative.

Through my tests, I have found that as the number of emojis increases, the accuracy of the model increases. Also, surprisingly, the accuracy was highest when I was analyzing just emojis and no text. This could mean that emojis carry more sentiment than we think, and should not be discounted from sentiment analysis. The model sometimes still struggles with sarcasm and slang. For example, “slay” and "fire" are positive in slang, but by definition are negative. In the future, because I trained and tested on < 1,000 tweets, I believe that it would be worth training and testing the model on more data.

In conclusion, adding emojis to tweets when doing sentiment analysis greatly improves my Naive Bayes model. I believe that emojis should not be so quickly discounted when doing sentimen analysis because of how they increased the accuracy. Even just adding one emoji made the accuray jump by nearly 0.1. That is a lot for accuracy measurements! Future research into this topic could explore training and testing the model on more tweets. We could also try to figure out a way for the model to understand sarcasm, irony, or slang. That would greatly improve the model's accuracy. Overall, adding emojis to tweets is better for sentiment analysis than using just the text - and using only emojis gives us the most accurate model.

References

emoji. (2023, December 5). PyPI. https://pypi.org/project/emoji/

JamesMTucker. (n.d.). DATA_340_NLP/Fall_2023/notebooks/08_Naive_Bayes_Model.ipynb at master · JamesMTucker/DATA_340_NLP. GitHub. https://github.com/JamesMTucker/DATA_340_NLP/blob/master/Fall_2023/notebooks/08_Naive_Bayes_Model.ipynb

Tweets with emoji. (2023, April 12). Kaggle. https://www.kaggle.com/datasets/ericwang1011/tweets-with-emoji?select=saluting_face.csv