Skip to content

Node-REDでVisual Recognition APIを使って顔を認識するアプリ

Notifications You must be signed in to change notification settings

kifumi/visualrecognition_nodered

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Watson Visual Recognition APIを使った画像認識アプリの作成

概要

IBM Watsonのサービスの一つであるVisual Recognition APIを呼びだす簡単なサンプルです。 Node-REDを使って簡単に呼び出しているのが特徴です。IBM Bluemixを使えば簡単に、迅速にアプリケーションを作ることが可能です。

ノード解説 - visual recognition node

IBMがBluemixは様々なコグニティブAPIを提供しています。その中でも画像認識サービスである、Visual Recognition image_alt_text は画像解析から年齢や人物判定まで行う機能を持ったサービスです。IBM Watsonのカテゴリに入っているので確認してみてください。

全体フロー概要

画像のURL(例:"http://xxxxx.jpg" )をVisual Recognition のAPIにかけると画像解析を行い、顔認識の結果を返してくれるサンプルアプリです。 image_alt_text


1. BluemixでNode-REDサービスを設定する

大学の先生や学生さんは、IBM Academic Initiativeが使えます。まず、こちらAI登録&Bluemixプロモコード取得・登録説明.pdfを参照して設定してください。

次に、Bluemix Hands-On #1の資料を参照してNode-REDサービスを設定します。

2. Visual Recognition APIを追加する

Node-REDのノードに画像認識のための Visual Recognition があるのですが、このままでは使えません。 このNode-REDのアプリケーションにVisual Recognition APIを追加してあげる必要があります。 Bluemixのメニュー画面左上の「IBM Bluemix」をクリックし、「すべてのアプリ」一覧のなかから、1.で作ったNode-REDのアプリケーションをクリックしてください。 image_alt_text 左側の「接続」をクリックし、右側の「新規に接続」のアイコンをクリックします。 image_alt_text 左側の「Watson」をクリックし、「Visual Recognition」を選択します。 image_alt_text 「作成」をクリックします。 image_alt_text 「アプリケーションの再ステージ」のポップアップ画面が現れるので「再ステージ」をクリックします。 再ステージングし正常に再起動すればOKです!

3. Node-REDでプログラミング

「アプリの表示」をクリックし、「Go to your Node-RED flow editor」をクリックして、Node-REDがを起動します。 image_alt_text Node-REDエディターが立ち上がったら、上側右寄りの「+」をクリックして、新しいフロー画面「Flow 2」を立ち上げます。

3-1. HTTP Input node

Visual Recognition API は REST の GET メソッドでアクセスして画像を解析します。 左側のパレットの Input カテゴリ内の http のノード image_alt_textをドラッグ&ドロップし、キャンバス内に配置します。 プロパティー内のURL欄にアクセスポイントを記載します。ここでは/callwatson にしておきます。Name の欄はノードの名前をわかりやすいようにしておくために記述しておきます。任意ですが、ここでは HTTP Input にしておきます。image_alt_text

3-2. switch node

画像のURLをチェックするノードを準備します。 左側のリソースパレットの function カテゴリ内のswitch ノードimage_alt_textをフローエディタ中央のキャンバスにドラッグ&ドロップします。 プロパティー内の左下にある「+add」をクリックして、分岐ロジックを2つ用意します。Propertyは、右図の通りに imagurl属性に含まれるペイロードのnullチェックを行います。nullであれば、"1"にそれ以外であれば"2"に値が渡されます。image_alt_text

3-3. template node (初期画面)

画面のHTMLを表示したり、Inputとなる画像を送信するためのメニューを提供するためにHTMLを記述します。 templateノードimage_alt_textをフローエディタ中央のキャンバスにドラッグ&ドロップします。 プロパティを以下のように記述します。

<h1>Welcome to a Watson Visual Recognition sample Face Detection app</h1>
<H2>Recognize anyone?</H2>
<form  action="{{req._parsedUrl.pathname}}">
<img src="http://sysrun.haifa.il.ibm.com/ibm/history/exhibits/chairmen/images/watsonsr.jpg" height='200'/> 
<img src="http://www.awaken.com/wp-content/uploads/2015/05/forbes.jpg" height='200'/>  
<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/5/52/LinuxCon_Europe_Linus_Torvalds_03.jpg/220px-LinuxCon_Europe_Linus_Torvalds_03.jpg" height='200'/>   
<img src="http://smashinghub.com/wp-content/uploads/2012/01/nb5.jpg" height='200'/>     
<br/>Right-click one of the above images and select Copy image location and paste the URL in the box below.<br>Do an image search for faces, try multiple faces. After you click on an image, to the right it usually says "View image" click that to get the URL.<br/>
<br>Image URL: <input type="text" name="imageurl"/>   
<input type="submit" value="Analyze"/>
</form>

image_alt_text

3-4. change node

入力画面から画像URLを抽出するchangeノードimage_alt_textを定義します。 左側のリソースパレットの function カテゴリ内のchangeノードをフロー・エディタ中央のキャンバスにドラッグ&ドロップします。 ここからpayload属性をimageurl属性に変換します。以下の通りにプロパティを設定します。 image_alt_text

3-5. Image Analysis

画像解析のための visual recognitionノードimage_alt_textを定義します。 左側のリソースパレットの IBM_Watson カテゴリ内の visual recognitionノードをフロー・エディタ中央のキャンバスにドラッグ&ドロップします。 プロパティーでは顔認識を行うため、以下の通りにDetectをDetect Facesに設定します。image_alt_text

3-6. template node (結果)

WatsonのImage Analysisから返ってきた結果を表示させるためのHTMLを記載します。 temlplateノードimage_alt_textをフローエディタ中央のキャンバスにドラッグ&ドロップします。 プロパティを以下のように記述します。

    <h1>Visual Recognition v3 Image Analysis</h1>    
    <p>Analyzed image: {{result.images.0.resolved_url}}<br/><img id="image” 
    src="{{result.images.0.resolved_url}}" height="200"/></p>    
    {{^result}}        
    <P>No Face detected</P>    
    {{/result}}    
    <p>Images Processed: {{result.images_processed}}</p>    
    <table border='1'>        
    <thead><tr><th>Age Range</th><th>Confidence</th><th>Gender</th><th>Confidence</th><th>Name</th></tr></thead>        
    {{#result.images.0.faces}}<tr>            
    <td><b>{{age.min}} - {{age.max}}</b></td><td><i>{{age.score}}</i></td>            <td>{{gender.gender}}</td>
    <td>{{gender.score}}</td>            <td>{{identity.name}} ({{identity.score}})</td>       
    </tr>{{/result.images.0.faces}}    
    </table>    
    <form  action="{{req._parsedUrl.pathname}}">        
    <br><input type="submit" value="Try again or go back to the home page"/>    
    </form>

image_alt_text

3-7. フローをつなげる

最後に http responseノードimage_alt_textをフローエディタ中央のキャンバスにドラッグ&ドロップします。 出来上がった各ノードをつなげて、右上のDeployをクリックすれば完成です!エラーが出ていないことを確認してください。 image_alt_text

4. 動作確認

ブラウザのURL欄に http://xxxx.mybluemix.net/callwatson をインプットして呼び出してみましょう。 Image URLの入力欄にWatsonに読ませたい画像URLを入れてみてください。

About

Node-REDでVisual Recognition APIを使って顔を認識するアプリ

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published