Opinion mining, sentiment analysis
IA161 NLP in Practice Course, Course Guarantee: Aleš Horák
Prepared by: Zuzana Nevěřilová
State of the Art
Sentiment analysis can be seen as a text categorization task (i.e. is the writer's opinion on a discussed topic X or Y?). It consists of detection of the topic (which can be easy in focused reviews) and detection of the sentiment (which is generally difficult). Opinions are sometimes expressed in a very subtle manner (e.g. the sentence How could anyone sit through this movie? contains no negative word) . The sentiments are usually simply classified by their polarity (positive, negative) but they can be recognized more in depth (e.g. strongly negative). Recognized opinions are also subject to summarization (e.g. how many people like this new iPhone design?).
- Bing Liu. Sentiment Analysis and Opinion Mining. Synthesis Lectures on Human Language Technologies. 2012, 5(1): 1-167. DOI: 10.2200/s00416ed1v01y201204hlt016. Draft version available at http://www.cs.uic.edu/~liub/FBS/SentimentAnalysis-and-OpinionMining.pdf
- Bing Liu. Sentiment Analysis Tutorial. AAAI-2011, August 8, 2011. Slides available at http://www.cs.uic.edu/~liub/FBS/Sentiment-Analysis-tutorial-AAAI-2011.pdf
- Bo Pang, Lillian Lee, and Shivakumar Vaithyanathan, Thumbs up? Sentiment Classification using Machine Learning Techniques, Proceedings of EMNLP 2002. http://www.cs.cornell.edu/home/llee/papers/sentiment.pdf
- Liviu P. Dinu and Iulia Iuga. The Naive Bayes classifier in opinion mining: In search of the best feature set. In Alexander Gelbukh, editor, Computational Linguistics and Intelligent Text Processing, volume 7181 of Lecture Notes in Computer Science, pages 556–567. Springer Berlin Heidelberg, 2012.
- Zhang, L. J., Wang, S., and Liu, B. (2018). Deep learning for sentiment analysis: A survey. Wiley Interdiscip. Rev. Data Min. Knowl. Discov., 8.
Bing Liu's References: http://www.cs.uic.edu/~liub/FBS/AAAI-2011-tutorial-references.pdf
The task will proceed using Python notebook run in web browser in the Google Colaboratory environment with the MU G-Suite disk access.
In case of running the codes in a local environment, the requirements are Python 3, jupyter notebook, modules NLTK, scipy, numpy, pandas, and sklearn.
In this workshop, we try two methods for opinion mining. We use the Liu's Opinion Lexion. For Czech SA, we use the automatically translated version. Next, we try to compensate drawbacks of the lexicon by computing word vectors in a simple way.
Access the Python notebook in the Google Colab environment. Do not forget to save your work if you want to see your changes later, leaving the browser will throw away all changes!
Files: Word_Vectors_and_Sentiment.ipynb, cestina20.csv, cestina20_annotation.csv, urban_dictionary.csv, negative-words-en.txt, negative-words-cs.txt, positive-words-en.txt, positive-words-cs.txt
<YOUR_FILE>, a text file named ia161-UCO-01.txt where UCO is your university ID.
- Enter the name of the dataset you were working on.
- Do tasks marked in the python notebook as TASK X. You don't have to do optional tasks.
Do not forget to upload your resulting file to the homework vault (odevzdávárna).