Problem Statement:
Sentiment analysis is the process of computationally determining the emotional tone or opinion expressed in a piece of text (e.g., Tweet or product review), helping to understand whether the sentiment is positive, negative, or neutral.
Video demo
Abstract
A text can provide extensive insight into the sentiment conveyed by the author. Consequently, sentiment analysis derived from textual input is a well-established problem statement in the domains of machine learning and natural language processing (NLP). In this project, we aimed to address this challenge by employing a conventional machine learning methodology to analyze a dataset of over 30,000 tweets from Twitter. The objective was to implement and analyze different classifiers on the Sentiment Analysis Dataset, utilizing various preprocessing techniques (LDA & PCA) and tokenizers (BERTTokenizer and TFIDtokenizer). The project explored and thoroughly analyzed the performance of classifiers- Decision Trees, Random Forests, SVMs, Naive-Bayes, Perceptron and Logistic Regression, optimizing each to yield maximum accuracy by modifying any parameters or hyperparameter tuning. Finally, ensemble learning was employed to achieve optimum performance of the model. It was observed that TFID gave the maximum accuracy, which reached as high as 71.5%.
Results
data:image/s3,"s3://crabby-images/4369f/4369f160cd48af5939ab9265cc8bd86b2f0130e8" alt=""
data:image/s3,"s3://crabby-images/5edfc/5edfc33e9926e8825fb9fcfdd7249dd50a2a908a" alt=""
data:image/s3,"s3://crabby-images/49a87/49a87ec94b2a5f3c5158108582ddec6b58f26fbd" alt=""
data:image/s3,"s3://crabby-images/8b3d9/8b3d9e3f61f7192b9041e1e7a3d057588f5a930c" alt=""
data:image/s3,"s3://crabby-images/e6801/e6801156b2529d37692ddb44d8c8d3a6434d538f" alt=""
data:image/s3,"s3://crabby-images/c67c0/c67c06dd2481b33df875e2fecb72e36e6d21ca70" alt=""
Performance Overview:
data:image/s3,"s3://crabby-images/6cafb/6cafb45f622d530088af54aa9ecb6c3587215890" alt=""