Aspect Extraction in Opinion Mining

  1. Introduction

Recently, Aspect based in opinion mining is the field that is very interested in Text Mining and Natural Language Processing. With the development of the Internet, Social networks, Forum, e-commerce websites, etc. expressing and sharing your opinion, news are exploding. Because the content on the Internet is increasing rapidly in the form of reviews, comments, blogs, status, tweets, etc., analyzing and classifying their aspects is essential so we need a system to classify it. Nowadays, most online social reviews include many topics in it, aspect extraction helps us better understand the document. This is a challenge because users often use very different words to express the same topic or even try to hide the topic of the question.


  1. How to approach to text classification.

There are many techniques used to extract aspects of document on social networks. But I will introduce the approach steps to solve the problem based on two typical extraction methods: BoW and TF-IDF along with typical learning algorithms such as Naïve Bayes, Support Vector Machine, Random Forest.

Screenshot 2019-08-16 at 14.03.19 

  • Create Training Data: Crawling data from, the biggest social website in the culinary field in Vietnam. Then, I will pre-processing the data and manually labeling for each sentence.
  • Features extraction: The input of the model needs to be scalar values or scalar matrix values. However, the input usually a words or a sentences. Therefore, you must to convert each word in the sentence into vector, this processing step called text extraction feature. In this article, I will present two ways to extract features: Bag of Words (BoW) and Term Frequency - Inverse Document Frequency (TF-IDF).
  • Training model: Using various supervised machine learning algorithms such as Naïve Bayes, Support Vector Machine or Random Forest combined with the text feature extraction methods mentioned above to training the model. After that, I will evaluate the model to calculate the accuracy.


  1. Feature Extraction methods

    • Bag of Word (BoW)

Bag-of-Words is a way to extract features from text to use in modeling with machine learning algorithms. This is a way to represent textual data when modeling text with machine learning algorithms. Bag-of-Words is simple, easy to understand and used very effectively in issues such as language modeling to extract features and classify documents and BoW describes the appearance of words in a document.

For Example: We have 2 documents:

  1. nhà_hàng này có món cá sốt cà rất là ngon ngon.
  2. không_gian nhà_hàng này rất là sang_chảnh.

Based on these two documents, there will be a list of words used, called "dictionaries" with 12 words as follows:

[“nhà_hàng”, “này”, “có”, “món”, “cá”, “sốt”, “cà”, “rất”, “là”, “ngon”, “không_gian”, “sang_chảnh”]

For each document will create a vector with 10 dimensions and representing the corresponding number of words that appear in that text. With the above two documents, there are two characteristic vectors:

  1. [1,1,1,1,1,1,1,1,1,2,0,0]
  2. [0,1,0,0,0,0,0,1,1,0,1,1]
  • Term Frequency – Inverse Document Frequency (TF-IDF)

In data mining, the term TF-IDF (term frequency - inverse document) is the most widely known statistical method for determining the importance of a word in the paragraph in a series of paragraphs. It is often used as a weight of each word, TF-IDF converts text representation form into vector space (VSM) or into sparse vectors.

  • Term Frequency

TF – Term Frequency: used to estimate the frequency of words in the text. However, for each text, there are different lengths, so the number of occurrences of the word may be more. So the number of occurrences of the word will be divided by the length of the text (the total number of words in that text). Screenshot 2019-08-16 at 14.43.48

IDF-Inverse Document Frequency: used to estimate the important level of words. When Term Frequency is calculated, the words are considered equally important. However, there are some words that are commonly used but are not important to express the meaning of the paragraph, for example:

  • Connection: và, nhưng, tuy nhiên, vì thế, vì vậy, …
  • Prepositions: và, nhưng, tuy nhiên, vì thế, vì vậy, …
  • Demonstravetive: ấy, đó, nhỉ, …

Therefore, it is necessary to reduce the importance of those words by using IDF: Screenshot 2019-08-16 at 14.44.36

TF-IDF: Screenshot 2019-08-16 at 14.44.40

Words with a high TF-IDF value are words that appear much in this document, and appear less in other documents. This helps filter out common words and retain high-value words (keywords of that document).


  1. Algorithms using to extract aspect

    • Naïve Bayes algorithm

Naive Bayes Classification (NBC) is an algorithm based on Bayes' theorem to calculate the probability to make judgments as well as classify data based on observed and statistical data. Naive Bayes Classification is one of the most widely used algorithms in the field of machine learning.

The Bayes theorem allows the probability of a random event A when a related event B has occurred. This quantity is called conditional probability because it is derived from the given value of B or depends on that value.

 Screenshot 2019-08-16 at 14.45.21

It can be seen that the probability of hypothesis A depends on the probability of hypothesis B, but in fact probability A may depend on the probability of many factors B1, B2, B3 ... Bn. So Bayes theorem can be extended by the following formula: Screenshot 2019-08-16 at 14.45.25

  • Support Vector Machine (SVM)

The idea of SVM is finding a hyperplane that can separate the dataset so that the distance from the hyperplane to the classifier is equal and largest. The SVM algorithm was originally designed to solve the binary classification problem with the following main ideas: Picture1-6

In two-dimensional space, the distance from a point with coordinates ,) to the line with equation  is calculated by:

 Screenshot 2019-08-16 at 14.46.20

In the other hand, in two-dimensional space, the distance from a point with coordinates ,) to the line with equation  is calculated by:

Screenshot 2019-08-16 at 14.46.27

Calculate the distance on multidimensional space is more complicated than 2-dimensional space or 3-dimensinoal space and the formula of a hyperplane is . The distance is calculated by:

Screenshot 2019-08-16 at 14.46.31

The quality of hyperplane is judged by the distance h between the two class, we try to maximize the distance h to have a better result.

Suppose that the data pairs of the training set are (x1, y1 ), (x2, y2 ),…, (x(n), y(n)) where x(i) is the input vector of a data point and y(i) is the label of the data point. Suppose the data point label has 2 values of 1 and -1. Picture2-2

Then the distance from the point to hyperplane Screenshot 2019-08-16 at 14.55.13 is:Screenshot 2019-08-16 at 14.48.03

Margin is calculated as the closest distance of a point to the hyperplane:Screenshot 2019-08-16 at 14.48.20

The purpose of SVM is finding w and b so that the margin reaches the maximum value:Screenshot 2019-08-16 at 14.48.24

  • Random Forest

Random Forest is a machine learning algorithm based on assembly techniques, combining classification trees. Random Forest builds a subclass tree by randomly selecting a small group of attributes at each node of the tree to classifier trees. In addition, the sample set of each tree was also randomly selected by Bootstrap method from the original sample set. The number of classification trees in the forest is unlimited and the algorithm using the predicted results of all trees in the forest is the final result of the algorithm.

 Screenshot 2019-08-16 at 14.56.19 

A. Training:

  • Giving training dataset
  • For each tree in the forest
  • Building classification tree Tk with Sk, Sk get with bootstrap method from S
  • At each node of the tree select the best attribute to divide the tree from the set of Fi attributes randomly selected in the attribute set F
  • Each tree is built to the maximum depth (without pruning)

B. Predict:

The algorithm predicts the label for each object
  • Classification: using major voting
  • Regression: take the average value of all trees


  1. DEMO

I used Flask to build a web app for demo:


If you don't write anything but still click the "Trích Xuất" button, a message " Vui lòng điền vào trường này" will appear:


When you put a document like: “Ăn ngon, phù hợp với giá. Mình đi buổi trưa nên nhà hàng không đông khách quá, phục vụ rất tốt (đoàn mình đi 16 người). Đồ ăn kèm khá phong phú & ngon. Thịt lợn thì mình chỉ thích ba chỉ thái mỏng ướp tẩm nướng. Nhân viên có thể nói tiếng Hàn. Quán cũng ko quá khó tìm, ở ngõ gần trường Ngôi Sao. Không gian ngồi khá thoải mái.” This is a reviews from website


After we enter the document and click the "Trích Xuất" button, the system will proceed to separate the documents into individual sentences and proceed with the data processing of each sentence. The pre-processing sentences will be displayed on the left column of the results table. The right column of the results table is the aspect of each sentence after being predicted by the model.



Add Comment