0 / 0
Analyze text for hotel satisfaction
Last updated: Dec 12, 2024
Analyze text for hotel satisfaction

This tutorial helps you analyze text by using nodes that specialize in handling text. For example, you can perform sentiment analysis.

In this tutorial, a hotel manager wants to analyze reviews for the hotel to see what customers think. The reviews express opinions about hotel personnel, comfort, cleanliness, price, and other areas of interest.

Figure 1. Chart of positive opinions
Chart of positive opinions. It shows terms and phrases, such as location, budget, and hotel amenities. These terms are varying sizes depending on their importance. They arranged the central most important term which is in the center and is the biggest.
Figure 2. Chart of negative opinions
Chart of negative opinions. It shows terms and phrases, such as location, budget, and hotel amenities. These terms are varying sizes depending on their importance. They arranged the central most important term which is in the center and is the biggest.

Try the tutorial

In this tutorial, you will complete these tasks:

Sample modeler flow and data set

This tutorial uses the Hotel Satisfaction flow in the sample project. The flow uses Text Analytics nodes to analyze fictional reviews about the hotel. The data file used is hotelSatisfaction.csv. The following image shows the sample modeler flow.

Completed flow
The following image shows the sample data set.
Sample data set

Task 1: Open the sample project

The sample project contains several data sets and sample modeler flows. If you don't already have the sample project, then refer to the Tutorials topic to create the sample project. Then follow these steps to open the sample project:

  1. In watsonx, from the Navigation menu Navigation menu, choose Projects > View all Projects.
  2. Click SPSS Modeler Project.
  3. Click the Assets tab to see the data sets and modeler flows.

Checkpoint icon Check your progress

The following image shows the project Assets tab. You are now ready to work with the sample modeler flow associated with this tutorial.

alt text

Back to the top

Task 2: Examine the Data Asset node

Hotel Satisfaction includes several nodes. Follow these steps to examine the Data Asset node:

  1. From the Assets tab, open the Hotel Satisfaction modeler flow, and wait for the canvas to load.
  2. Double-click the hotelSatisfaction.csv node. This node is a Data Asset node that points to the hotelSatisfaction.csv file in the project.
  3. Review the File format properties.
  4. Optional: Click Preview data to see the full data set.

Checkpoint icon Check your progress

The following image shows the Data Asset node. You are now ready to examine the Text Mining node.

Filter node

Back to the top

Task 3: Examine the Text Mining node

Text mining is an iterative process that identifies relevant concepts and patterns in the text data. When you run the Text Mining node, the extraction engine reads through the text data, identifies the relevant concepts, and assigns a type to each. You can then review the extraction results by using the Text Analytics Workbench to fine-tune the extraction process. You can rerun the Text Mining node to produce new results, and then evaluate the new results. Note the Type node in between the Data Asset node and the Text Mining node. The Type node is required to correctly identify the fields in the data set. Follow these steps to examine the Text mining node:

  1. Double-click the Comments (Text Mining) node to see its properties.
  2. Set these properties in the Fields section:
    1. For the Text field, select Comments.
    2. For the ID field, select id.
      Note: Only the Text field is required.
      Figure 3. Text Mining node properties
      Text Mining node build properties. It shows some field settings in the window like the Text field and ID field.
  3. In the Model section, notice that the selected Text analysis package is Hotel Satisfaction (English)/Topic + Opinion.

    A text analysis package (TAP) is a predefined set of libraries and advanced linguistic and nonlinguistic resources, which are bundled with one or more sets of predefined categories. If no text analysis package is relevant for your application, you can instead select a Resource template instead. A resource template is a predefined set of libraries and advanced linguistic and nonlinguistic resources that were fine-tuned for a particular domain or usage.

  4. In the Build models section, set these properties:
    1. Verify that the Build modes field is set to Build interactively (category model nugget). Later when you run the node, this option starts Text Analytics Workbench, which is an interactive interface where you can explore and fine-tune the extraction results.
    2. Verify that the Begin session by field is set to Extracting concepts and text links. The Extracting concepts option extracts only concepts, whereas TLA extraction outputs both concepts and text links that are connections between topics (such as service, personnel, and food) and opinions.
  5. Expand the Expert section, and verify that the Accommodate spelling for a minimum word character length of option is selected with a Spelling limit of 5. This option applies a fuzzy grouping technique that helps group commonly misspelled words or closely spelled words under one concept. The fuzzy grouping algorithm temporarily strips double or triple consonants and all vowels (except the first one) from extracted words. It then compares them to see whether they're the same. For example, location and locattoin are grouped.

    Figure 4. Text Mining node expert properties.
    Text Mining node expert properties. It shows property settings for the Text Mining node. Some major settings groups are Settings, Build models, and Expert. In the Expert grouping are check boxes for setting such as Accommodate spelling for a minimum root character limit, Extract uniterms, Extract nonlinguistic entities, Uppercase algorithm, Group partial and full person names together when possible, and Use derivation when grouping compound nouns.
  6. Click Save.
  7. Hover over the Comments (Text Mining) node, and click the Run icon Run icon.
  8. In the Outputs and models pane, click the results with the name Comments to open the Text Analytics Workbench.

Checkpoint icon Check your progress

The following image shows the Text Analytics Workbench. You are now ready to tune the results.

Text Analytics Workbench

Back to the top

Task 4: Tune the results in the Text Analytics Workbench

The Text Analytics Workbench contains the extraction results and the category model that is contained in the text analytics package. It is an interactive workbench where you can explore and fine-tune the extracted results, build and refine categories, and build category model nuggets. Follow these steps to tune the results in the Text Analytics Workbench:

Concepts

  1. Click the Concepts tab.

    During the extraction process, the text data is analyzed to identify interesting or relevant single words such as airport or location, and word phrases such as airport pick-up. These words and phrases are collectively referred to as terms. Using the linguistic resources, the relevant terms are extracted, and similar terms are grouped under a lead term that is called a concept.

    In this way, a concept might represent multiple underlying terms. It depends on how the term is used in your text and the set of linguistic resources you're using.

  2. Click the Filter icon Filter icon
  3. You can also use a Filter to select a subset of concepts. The following image shows the different options:

    Figure 5. Text Analytics Workbench - filter options
    Text Analytics Workbench - filter options

    If you want to remove the filters and display all concepts, click Clear Filter.

    Click Cancel to close the Filter pane.

Text links

  1. Click the Text links tab.

    Text link analysis (TLA) is a pattern-matching technology that compares TLA rules to extracted concepts and relationships that are found in your text. On the Text links tab, you can build and explore the TLA patterns that are found in your text data.

  2. Select a Type Pattern (for example, <Services> + <Positive> to see a preview of the text in the document. If the text in the Document preview is truncated, click the View entire document icon View entire document icon to display the entire text.
    Text Analytics Workbench - Text links tab. Shows the type patterns in the Text link tab. On the side is the Preview pane, which has a table with three columns. The three columns are Entry, Document Preview, and Category path.

Categories

  1. Click the Categories tab.

    You can build and manage your categories. After the concepts and types are extracted from your text data, you can begin building categories automatically by using techniques such as concept inclusion, semantic network (in English only), or manually.

    Since this example flow uses a text analysis package template, the category model is already populated.

  2. Click Score all to score the documents or records. Each time a category is created or updated, you can see whether any text matches a descriptor in a specific category. If a match is found, the document or record is assigned to that category. The result is that most, if not all, of the documents or records are assigned to categories based on the descriptors in the categories.
  3. Expand a category, for example, Hotel Amenities > Cleanliness > Neg > not cleaned.
  4. View the documents on the Preview tab and the Descriptors tab to see the source data.

Checkpoint icon Check your progress

The following image shows the document preview for the Cleanliness category. You are now ready to build the model.

Filler node

Back to the top

Task 5: Build the model

Once you finish tuning the extraction process, you can generate a category model from the customizations and the categories that you built. Follow these steps to build and deploy the model:

  1. Click Generate a model to generate a category model.
    Image showing the button to Generate a model
  2. Click Build to confirm that you want to generate a category model.
  3. When you see the Success! message click Return to flow.
  4. Click Save and exit to save your changes and Text Mining node in the flow.
    The generated category model nugget is displayed on your flow canvas.
    Figure 6. Generated category model nugget
    Generated category model nugget. Shows a flow with a Text Mining node and a category model nugget.
  5. Notice the two Satisfaction Model nodes in the example flow. Now that the Text Analytics Workbench validated and generated a category model, you can deploy it in your flow and score the same data set or score new data. Each model uses a different mode for scoring.
    Figure 7. Example flow with two modes for scoring
    Example flow with two modes for scoring
  6. Double-click the first Satisfaction Model node.
    1. Expand the Settings section to see that this node uses the Categories as fields scoring mode. With this scoring mode, there are just as many output records as there were in the input.
    2. Click Preview data. You can see that each record now contains one new field for every category that was selected on the Model tab. For each field, enter a flag value for true and for false, such as True/False, or 1/0. In this flow, values are set to 1 and 0 to aggregate results and count the number of positive, negative, mixed (both positive and negative), or no score (no opinion) answers.

      Figure 8. Model results - categories as fields (1).
      Model results - categories as fields. It is a table with the columns ID, Comments, Gender, Reason, Neg, Pos, Cont, and Sentiment. Entries for the ID column are numbers. Entries for the Comments column show short phrases extracted from the text. For example, one entry says very quiet, but very expensive. Entries for the Reason column show if the trip was for business or leisure. Neg and Pos show a count of negative and positive sentiments for each short phrase. Sentiment shows whether the review was positive (only numbers in the Pos column), negative (only numbers in the Neg column), or mixed (numbers in both the Neg and Pos columns).
    3. Close the Preview window.
    4. Click Cancel.
  7. Double-click the second Satisfaction Model node.
    1. Expand the Settings section to see that this node uses the Categories as records scoring mode. A new record is created for each category, document pair. Typically, there are more records in the output than there were in the input.
    2. Click Preview data. You can see that, along with the input fields, new fields are also added to the data depending on what kind of model it is.

      Figure 9. Model results - categories as records (2).
      Model results - categories as records. It is a table with the columns ID, Comments, Gender, Reason, Category, and Sentiment. Entries for the ID column are numbers. Entries for the Comments column show short phrases extracted from the text. For example, one entry says very quiet, but very expensive. Entries for the Reason column show if the trip was for business or leisure. Neg and Pos show a count of negative and positive sentiments for each short phrase. Sentiment shows whether the review was positive (only numbers in the Pos column), negative (only numbers in the Neg column), or mixed (numbers in both the Neg and Pos columns).
    3. Close the Preview window.
    4. Click Cancel.

Checkpoint icon Check your progress

The following image shows the satisfaction model with a document preview. You are now ready to visualize the comments.

Model node

Back to the top

Task 6: Visualize the comments

You can gain quick insights about what guests appreciate about the hotel by visualizing the comments. Follow these steps to create a word cloud chart:

  1. Select the positive comments:
    1. In the palette, expand the Record Operations section.
    2. Drag the Select node onto the canvas.
    3. Connect the Derive Sentiment supernode to the Select node.
    4. Double-click the Select node to view its properties.
    5. For the Mode, select Include.
    6. For the Condition, type Sentiment = "Pos".
    7. Click Save.
  2. Add a chart:
    1. In the palette, expand the Graphs section.
    2. Drag the Charts node onto the canvas.
    3. Connect the Select node to the Charts node.
  3. Build a word cloud chart:
    1. Double-click the Charts node to view its properties.
    2. Click Launch Chart Builder.
    3. For the Columns to visualize, select Comments.
    4. Display the list of all chart types, and select Word cloud.

      Figure 10. All chart types
      All chart types
  4. When you done, click Return to flow.

Checkpoint icon Check your progress

The following image shows a word cloud chart. You are now ready to examine the Text Link Analysis node.

Word cloud chart

Back to the top

Task 7: Examine the Text Link Analysis node

Sometimes, you might not need to create a category model to score. The Text Link Analysis node adds a pattern-matching technology to text mining's concept extraction. Text Link Analysis node identifies relationships between the concepts in the text data based on known patterns. These relationships can describe how a customer feels about a product, which companies are doing business together, or even the relationships between genes or pharmaceutical agents. Follow these steps to examine the Text Link Analysis node:
Text Link Analysis node
  1. Double-click the Text Link Analysis node to see its properties.
  2. Set these properties in the Fields section:
    1. For the Text field, select Comments.
    2. For the ID field, select id.
      Note: Only the Text field is required.

      Figure 11. Text Link Analysis node FIELD properties.
      Text Link Analysis node FIELD properties. It shows field settings like the ID field, Text field, Language field, Document Type, Textual Unity and Paragraph mode settings.
  3. In the Copy resources from section, notice that the selected Resource template is Hotel Satisfaction (English).

    A resource template is a predefined set of libraries and advanced linguistic and nonlinguistic resources that were fine-tuned for a particular domain or usage.

  4. Expand the Expert section, and verify that the Accommodate spelling for a minimum word character length of option is selected with a Spelling limit of 5.

    Figure 12. Text Link Analysis node Expert properties.
    Text Link Analysis node Expert properties. It shows check boxes for setting such as Accommodate spelling for a minimum root character limit, Extract uniterms, Extract nonlinguistic entities, Uppercase algorithm, Group partial and full person names together when possible, and Use derivation when grouping compound nouns.
  5. Click Save.
  6. Hover over the Raw TLA output node, and click the Run icon Run icon.
  7. In the Outputs and models pane, click the results with the name Raw TLA output to see the results.

    Figure 13. Raw TLA output.
    Raw TLA output. It is a table with columns such as Concept1, Type1, Concept2, Type2, ID, and Matched text. Entries for concept columns are words such as room or parking. Entries for type columns are words such as Budget or Services. The rows show how a concept is related to a type or other concepts. Each row also shows how these words appear in the text.

    Figure 14. Counting sentiments on a TLA node.
    Counting sentiments on a TLA node. It is a table with the columns ID, Comments, Pos_Count_Sum, and Neg_Count_Sum. Entries for the ID column are numbers for each row. Entries for the Comments column show short phrases extracted from the text. For example, one entry says Comfortable rooms, outstanding breakfast, and nice service. Entries for the Pos_Count_Sum, and Neg_Count_Sum columns show numbers counting the number of positive or negative sentiments for each short phrase. For example, for the previous phrase, it counted three positive sentiments.

Checkpoint icon Check your progress

The following image shows the completed flow.

Completed flow

Back to the top

Summary

This Hotel Satisfaction flow showed you how a hotel manager could analyze hotel reviews to see the customers' expressed opinions about hotel personnel, comfort, cleanliness, price, and other areas of interest. This flow illustrates two ways of analyzing text data, by using a Text Mining node or a Text Link Analysis node.

Next steps

You are now ready to try other SPSS® Modeler tutorials.

Generative AI search and answer
These answers are generated by a large language model in watsonx.ai based on content from the product documentation. Learn more