<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Oden David</title>
    <description>The latest articles on DEV Community by Oden David (@odendavid).</description>
    <link>https://dev.to/odendavid</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F1064878%2F0863cdc9-acd2-410f-b8bf-22ac27a769fb.jpeg</url>
      <title>DEV Community: Oden David</title>
      <link>https://dev.to/odendavid</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/odendavid"/>
    <language>en</language>
    <item>
      <title>NLP Made Easy: Sentiment Analysis with Amazon Comprehend</title>
      <dc:creator>Oden David</dc:creator>
      <pubDate>Thu, 03 Aug 2023 16:59:21 +0000</pubDate>
      <link>https://dev.to/odendavid/nlp-made-easy-sentiment-analysis-with-amazon-comprehend-4e2e</link>
      <guid>https://dev.to/odendavid/nlp-made-easy-sentiment-analysis-with-amazon-comprehend-4e2e</guid>
      <description>&lt;p&gt;Natural Language processing has become an integral part of many AI driven products around the world today, and sentiment analysis makes up a good percentage of these products, because of its importance in business and decision-making.&lt;br&gt;
However, being able to build, deploy and monitor a model of this sort isn't easy!&lt;/p&gt;

&lt;p&gt;In this short tutorial, we'd see how Amazon comprehend helps us achieve sentiment analysis in a faster and more efficient way.&lt;/p&gt;
&lt;h2&gt;
  
  
  What is Amazon Comprehend?
&lt;/h2&gt;

&lt;p&gt;Amazon Comprehend is a Natural Language Processing(NLP) service that provides Custom Entity Recognition, Custom Classification, Key phrase Extraction, Sentiment Analysis, Entity Recognition, and more APIs that you can easily integrate into your applications. The great thing about it is it also offers medical insights and protected health information (PHI) detection via &lt;strong&gt;Amazon Comprehend Medical.&lt;/strong&gt;&lt;/p&gt;
&lt;h2&gt;
  
  
  Getting Started with Amazon Comprehend
&lt;/h2&gt;

&lt;p&gt;Getting started with Amazon Comprehend is a straightforward process.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step1: Create an AWS Account&lt;/strong&gt;&lt;br&gt;
First thing to do would be to &lt;a href="https://aws.amazon.com/"&gt;create an AWS account&lt;/a&gt; if you do not have one.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step2: Open Comprehend&lt;/strong&gt;&lt;br&gt;
Inside the AWS Management Console, search for "Comprehend" in the services search bar. Click on the Amazon Comprehend to open the service dashboard. You should have an interface like this:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--m7x7qHPR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/81mgyinel2wp9ryj3lsz.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--m7x7qHPR--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/81mgyinel2wp9ryj3lsz.png" alt="Amazon Comprehend" width="800" height="452"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Next, click on "Launch Amazon Comprehend" to start analyzing texts.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Step3: Real Time Analysis&lt;/strong&gt;&lt;br&gt;
With Amazon Comprehend, we can analyze text in real time by using built-in or custom models. Creating a custom model to classify our sentiments is not in the scope of this tutorial. We would use a built-in model by Comprehend to perform real time sentiment analysis on our texts in two separate ways:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Amazon Comprehend Interface&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Sentiment analysis using text can be performed easily and fast inside Comprehend's real time analysis interface. Simply scroll down to input data, type in your own text and click on "Analyze". Scroll further down and choose the sentiment tab to view the sentiments and their confidence scores.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--k6no9Hl1--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/731x10mrnwcjagwdva4e.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--k6no9Hl1--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/731x10mrnwcjagwdva4e.png" alt="Sentiment analysis via input text" width="800" height="742"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;From the result above, our text review, "My order was delayed by several days without any updates or communication from the seller. Terrible shipping service." has a negative review with a 99% confidence score.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Via API calls using Python's Boto3&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;We can programmatically access this sentiment model and perform analysis via an API using Boto3. Boto3 is the official Python Software Development Kit (SDK) provided by Amazon Web Services (AWS) to interact with AWS services using Python programming language. For comprehend, the &lt;a href="https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/comprehend.html"&gt;full documentation&lt;/a&gt; shows us all the available methods that can be accessed via the comprehend service.&lt;/p&gt;

&lt;p&gt;In order to do this, we need to an &lt;code&gt;access key&lt;/code&gt; and &lt;code&gt;secret access key&lt;/code&gt; to enable us remotely connect and access services within our account. To do this, follow the simple steps in &lt;a href="https://docs.aws.amazon.com/powershell/latest/userguide/pstools-appendix-sign-up.html"&gt;this link&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;Import boto3 library and initiate our client.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="nn"&gt;boto3&lt;/span&gt;

&lt;span class="n"&gt;client&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt;  &lt;span class="n"&gt;boto3&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;client&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;'comprehend'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="n"&gt;region_name&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s"&gt;'us-east-1'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="n"&gt;aws_access_key_id&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s"&gt;''&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="n"&gt;aws_secret_access_key&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s"&gt;''&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="n"&gt;client&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Next, pass our text into the &lt;code&gt;detect_sentiment&lt;/code&gt; method to predict its sentiment.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="n"&gt;text&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="s"&gt;"""My order was delayed by several days without any updates or communication from the seller. Terrible shipping service."""&lt;/span&gt;

&lt;span class="n"&gt;client&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;detect_sentiment&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;Text&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="n"&gt;text&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;LanguageCode&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s"&gt;'en'&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;The response looks like this:&lt;br&gt;
&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--bhvDyB2v--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/ntd12zvjdzdg03lj85zk.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--bhvDyB2v--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/ntd12zvjdzdg03lj85zk.png" alt="Single text sentiment detection response" width="800" height="170"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Now, let's make it a bit more interesting. We'd download a review dataset from kaggle, link &lt;a href="https://www.kaggle.com/datasets/tarkkaanko/amazon"&gt;here&lt;/a&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="nn"&gt;pandas&lt;/span&gt; &lt;span class="k"&gt;as&lt;/span&gt; &lt;span class="n"&gt;pd&lt;/span&gt;

&lt;span class="n"&gt;data&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;pd&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;read_csv&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s"&gt;"amazon_reviews.csv"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="n"&gt;data&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;data&lt;/span&gt;&lt;span class="p"&gt;[[&lt;/span&gt;&lt;span class="s"&gt;'reviewText'&lt;/span&gt;&lt;span class="p"&gt;]]&lt;/span&gt;
&lt;span class="n"&gt;data&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--HQOAdWQ0--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/3vwvgqnow2w87qo06onp.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--HQOAdWQ0--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/3vwvgqnow2w87qo06onp.png" alt="Data" width="800" height="245"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;The Data is made up of 4915 rows but for the purpose of this tutorial we'd choose 100 random samples for prediction.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="n"&gt;data_100&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;data&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;sample&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;100&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

&lt;span class="k"&gt;def&lt;/span&gt; &lt;span class="nf"&gt;detect_sentiment&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;review&lt;/span&gt;&lt;span class="p"&gt;):&lt;/span&gt;
    &lt;span class="n"&gt;response&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;client&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;detect_sentiment&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;Text&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="n"&gt;review&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt; &lt;span class="n"&gt;LanguageCode&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s"&gt;'en'&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;response&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="s"&gt;"Sentiment"&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt;

&lt;span class="n"&gt;data_100&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="s"&gt;'Sentiment'&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;data_100&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nb"&gt;apply&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;detect_sentiment&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;axis&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--nBBriD3o--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/kwurilojvrjptoqinq1g.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--nBBriD3o--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_800/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/kwurilojvrjptoqinq1g.png" alt="Sentiment Data" width="800" height="298"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Predicting 100 reviews took 1 min, 34 seconds, which is relatively fast for a model that performs well.&lt;/p&gt;

&lt;h2&gt;
  
  
  Pricing
&lt;/h2&gt;

&lt;p&gt;According to the official pricing information &lt;a href="https://aws.amazon.com/comprehend/pricing/"&gt;here&lt;/a&gt; requests made to Amazon Comprehend's APIs for entity recognition, sentiment analysis, syntax analysis, key phrase extraction, and language detection are measured in units of 100 characters, (1 unit = 100 characters), with a 3 unit (300 character) minimum charge per request. &lt;code&gt;Total cost = [No. of units] x [Cost per unit]&lt;/code&gt;. And cost per unit is &lt;code&gt;$0.0001&lt;/code&gt;.&lt;/p&gt;

&lt;h2&gt;
  
  
  Conclusion
&lt;/h2&gt;

&lt;p&gt;In conclusion, Sentiment Analysis, a crucial aspect of Natural Language Processing (NLP), has become an indispensable tool for businesses and organizations seeking to understand and harness the power of human sentiment and emotions.&lt;/p&gt;

&lt;p&gt;Amazon Comprehend, offers a user-friendly and powerful platform for Sentiment Analysis, empowering businesses of all sizes an ability to leverage NLP without the need for extensive expertise or infrastructure. By utilizing Amazon Comprehend, companies can unlock valuable insights from vast amounts of text data.&lt;/p&gt;

</description>
      <category>nlp</category>
      <category>python</category>
      <category>aws</category>
    </item>
  </channel>
</rss>
