4
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【UiPath】Azure AI Servicesと連携して画像分析・感情分析・翻訳サービスを利用する手順

Last updated at Posted at 2024-01-22

はじめに

  • 本記事ではUiPath Automation CloudとAzure AI Servicesの下記サービスを連携する手順について説明します。

    • Computer Visionサービス: 画像を分析して説明文の生成や文字の抽出などを行います。
    • 言語サービス: 文章を分析して書き手の感情が肯定的か否定的か判断します。
    • 翻訳サービス: ある言語の文章を他の言語に翻訳します。
  • これらの連携によってAzure AI Servicesによる画像分析・感情分析・翻訳処理を自動化ワークフローに組み込むことが可能になります。

構成図とIntegration Service概要

  • 本記事での構成図を示します。

    00a.png

  • Azure AI Servicesを利用するクライアントとしてUiPath StudioまたはUiPath Studio Webを使用します。

  • Integration Service はUiPathがAutomation Cloud上で提供するiPaaS(Integration Platform as a Service)です。さまざまなサードパーティアプリケーションやSaaSの認証と認可を標準化してAPI接続の管理を行い、容易に連携することが可能になります。

  • Integration Serviceを利用するメリットは下記の通りです。

    • Azure AI Servicesの認証情報となるAPIキーをサーバー側で保管するため、クライアント側にAPIキーを保存することによって生じる漏洩リスクを軽減できます。またこのAPIキーはAutomation Cloudに接続しているクライアントのみ利用可能となるため、管理者によって利用ユーザーを制御することができます。
    • クライアントからのAzure AI Serviceの利用要求はIntegration Serviceによってプロキシされるため、それぞれのAzure AI Servicesのネットワーク設定ではIntegration Serviceからのアクセスのみを許可(IPフィルター)することによって安全性を高められます。

    ただし翻訳サービスではIntegration Serviceの送信IPが動的になってしまうようなのでIPフィルターは使用しません。

Azure AI Servicesの設定

  • まずAzure AI Servicesを利用するための準備を行います。利用したいサービスのみをデプロイします。なお既にAzureサブスクリプションが準備されていることが前提となります。

Computer Visionサービス (画像分析) のインスタンス作成

  1. ブラウザーで Azureポータル にサインインします。

  2. Azure AI Servicesにアクセスします。 (上部の検索フィールドに azure ai と入力してジャンプします)

    01.png

  3. 左メニューにて Computer Vision をクリックし、作成 をクリックします。

    02.png

    単独のComputer Visionサービスではない マルチサービスリソース や画像認識をカスタマイズするCustom Visionは現時点ではIntegration Serviceと連携できないためご注意ください。

  4. 各設定項目を入力します。

    03.png

    • 既存の リソースグループ を選択するか、新規で作成します。

    • Computer Visionインスタンスの リージョン を選択します。一般的にはクライアントマシンに近いリージョンとして Japan East などを選択します。

    • 名前 はグローバルで一意な名前を入力します。

    • 価格レベル として Free F0 または Standard S1 を選択します。詳細は Azure AI Vision の価格 をご参照ください。

    • 「このボックスをオンにすることで、上記すべての条項を承認し、同意したことを確認します」 のチェックボックスをオンにし、確認と作成 をクリックします。

  5. 入力項目のチェックが走ります。エラーが発生した場合には内容を確認して修正します。問題なければ 作成 をクリックしてインスタンスを作成します。

  6. デプロイが成功することを確認します。リソースに移動 をクリックします。

  7. 左メニューの キーとエンドポイント をクリックし、キー 1場所/地域(リージョン) をそれぞれクリップボードにコピーしてメモします。

    04.png

言語サービス (感情分析) のインスタンス作成

  1. ブラウザーで Azureポータル にサインインします。

  2. Azure AI Servicesにアクセスします。 (上部の検索フィールドに azure ai と入力してジャンプします)

  3. 左メニューにて 言語サービス をクリックし、作成 をクリックします。

    05.png

    単独の言語サービスではない マルチサービスリソース は現時点ではIntegration Serviceと連携できないためご注意ください。

  4. 追加機能の選択画面では既定値のまま リソースの作成を続行する をクリックします。

    06.png

  5. 各設定項目を入力します。

    07.png

    • 既存の リソースグループ を選択するか、新規で作成します。
    • 言語サービスの リージョン を選択します。一般的にはクライアントマシンに近いリージョンとして Japan East などを選択します。
    • 名前 はグローバルで一意な名前を入力します。
    • 価格レベル として Free F0 または S を選択します。詳細は Azure AI Language の価格 をご参照ください。
    • 「このボックスをオンにすることで、責任ある AI 通知の条項を承認し、同意したことを確認します」 のチェックボックスをオンにし、確認と作成 をクリックします。
  6. 入力項目のチェックが走ります。エラーが発生した場合には内容を確認して修正します。問題なければ 作成 をクリックしてインスタンスを作成します。

  7. デプロイが成功することを確認します。リソースグループに移動し、作成された言語サービスのインスタンスをクリックします。

  8. 左メニューの キーとエンドポイント をクリックし、キー 1エンドポイント をそれぞれクリップボードにコピーしてメモします。

    08.png

翻訳サービスのインスタンス作成

  1. ブラウザーで Azureポータル にサインインします。

  2. Azure AI Servicesにアクセスします。 (上部の検索フィールドに azure ai と入力してジャンプします)

  3. 左メニューにて 翻訳 をクリックし、作成 をクリックします。

    09.png

    単独の翻訳サービスではない マルチサービスリソース は現時点ではIntegration Serviceと連携できないためご注意ください。

  4. 各設定項目を入力します。

    10.png

    • 既存の リソースグループ を選択するか、新規で作成します。
    • 言語サービスの リージョン を選択します。一般的にはクライアントマシンに近いリージョンとして Japan East などを選択します。
    • 名前 はグローバルで一意な名前を入力します。
    • 価格レベル として Free F0 または Standard S1 などを選択します。詳細は Azure AI 翻訳 の価格 をご参照ください。
    • 確認と作成 をクリックします。
  5. 入力項目のチェックが走ります。エラーが発生した場合には内容を確認して修正します。問題なければ 作成 をクリックしてインスタンスを作成します。

  6. デプロイが成功することを確認します。リソースに移動 をクリックします。

  7. 左メニューの キーとエンドポイント をクリックし、キー 1場所/地域(リージョン) をそれぞれクリップボードにコピーしてメモします。

    11.png

Automation Cloudの設定

  • Automation CloudにてAzure AI Servicesと連携する設定を行います。
  1. ブラウザーで Automation Cloud にサインインします。

  2. 左メニューにて Integration Service のアイコンをクリックします。

    11b.png

  3. 作業対象のOrchestratorフォルダーを選択します。以降は利用するAzure AI Servicesごとにコネクタの設定を行います。

Computer Visionサービスとの連携

  1. Integration Serviceのコネクタとして Microsoft Vision をクリックします。

    12.png

  2. Microsoft Vision に接続 をクリックします。

  3. 先ほどメモしたComputer Visionのリージョンとキーを入力して、接続 をクリックし、正常に接続できることを確認します。

    13.png

  4. コネクションの名前は既定値では時刻になってしまうため、編集アイコンをクリックし識別しやすい名前(例: MS-Vision01)を入力しEnterキーを押下してリネームします。

    14.png

  5. Computer Visionの既定値ではすべてのネットワークからアクセスが許可されていますので、セキュリティ強化のためIntegration Serviceからのアクセスのみに制限します。

    • オンプレミス アプリケーション コネクタのサポート にて該当するAutomation CloudテナントのリージョンのIPアドレスを確認し、メモします。コミュニティユーザーの場合には欧州のIPアドレスが使用されます。
    • Azureポータル > 作成したComputer Visionのインスタンス > ネットワーク をクリックし、選択したネットワークとプライベートエンドポイント を選択します。

    15.png

  6. 先ほどメモしたIPアドレスをすべて入力し Save をクリックして保存します。

    16.png

  7. 設定変更が反映されるまで数分ほど待ちます。Automation Cloudにて先ほどコネクションを作成したフォルダーを選択し、コネクションの縦三点リーダー > コネクションを確認 をクリックし、正常に接続できることを確認します。

    17.png

言語サービスとの連携

  1. Integration Serviceのコネクタとして Microsoft Sentiment をクリックします。

    18.png

  2. Microsoft Sentiment に接続 をクリックします。

  3. 先ほどメモした言語サービスのエンドポイントとキーを入力して、接続 をクリックし、正常に接続できることを確認します。

    19.png

  4. コネクションの名前は既定値では時刻になってしまうため、編集アイコンをクリックし識別しやすい名前(例: MS-Sentiment01)を入力しEnterキーを押下してリネームします。

    20.png

  5. 言語サービスの既定値ではすべてのネットワークからアクセスが許可されていますので、セキュリティ強化のためIntegration Serviceからのアクセスのみに制限します。

    • オンプレミス アプリケーション コネクタのサポート にて該当するAutomation CloudテナントのリージョンのIPアドレスを確認し、メモします。コミュニティユーザーの場合には欧州のIPアドレスが使用されます。
    • Azureポータル > 作成したComputer Visionのインスタンス > ネットワーク をクリックし、選択したネットワークとプライベートエンドポイント を選択します。

    21.png

  6. 先ほどメモしたIPアドレスをすべて入力し Save をクリックして保存します。

    22.png

  7. 設定変更が反映されるまで数分ほど待ちます。Automation Cloudにて先ほどコネクションを作成したフォルダーを選択し、コネクションの縦三点リーダー > コネクションを確認 をクリックし、正常に接続できることを確認します。

    23.png

翻訳サービスとの連携

  1. Integration Serviceのコネクタとして Microsoft Translator をクリックします。

    24.png

  2. Microsoft Translator に接続 をクリックします。

  3. 先ほどメモした翻訳サービスのキーとリージョンを入力して、接続 をクリックし、正常に接続できることを確認します。

    25.png

  4. コネクションの名前は既定値では時刻になってしまうため、編集アイコンをクリックし識別しやすい名前(例: MS-Translator01)を入力しEnterキーを押下してリネームします。

    26.png

  • 前述の通り翻訳サービスとの連携においてはIntegration Serviceの送信IPが固定されないためネットワーク設定は既定値を使用します。

Studio WebからのAzure AI Services利用

  • ここまでで準備が整いましたのでUiPath Studio WebからAzure AI Servicesを利用してみましょう!

    現時点ではMicrosoft SentimentとMicrosoft TranslatorはStudio Webから利用可能ですが、Microsoft Visionは利用できないようです。Microsoft Visionは 後述のStudioを利用する手順 をご参照ください。

  1. Automation Cloud の左メニューにて Studio のアイコンをクリックします。

    21a.png

  2. プロジェクト > [新しいプロジェクト] をクリックします。

    22a.png

  3. プロジェクト名と説明を入力して [作成] をクリックします。

    31.png

  4. プロジェクトが作成されましたら (+) をクリックしてアクティビティを追加します。以降は利用するAzure AI Servicesに応じてアクティビティを選択します。

言語サービス (感情分析) のアクティビティ

  1. センチメント分析 アクティビティを追加します。

    32.png

  2. 先ほど作成したコネクションが表示されることを確認します。

  3. テキスト には感情分析を行うための文章を入力します。

    47a.png

  4. その他のオプションを表示 をクリックし、分析に使用する 言語 として japanese - ja を指定します。

    48a.png

  5. 言語サービスの応答を出力するために (+) をクリックし、メッセージをログ アクティビティを追加します。

    35.png

  6. センチメント分析 の出力変数 センチメント を選択します。ログレベルは Info を選択します。

    36.png

  7. テスト をクリックし、ワークフローをテストします。

    37.png

  8. 分析対象のテキストの感情分析の結果が、positive(肯定的), negative(否定的)またはneutral(中立的)が返されることを確認します。

    49a.png

  9. さらに細かく分析したい場合はそれぞれの感情を数値として取得することもできます。ログアクティビティに下記のメッセージを指定します。それぞれの信頼度スコアはセンチメント分析アクティビティの出力変数を使用します。

    positive: <[ポジティブ信頼度スコア]>
    negative: <[ネガティブ信頼度スコア]>
    neutral: <[ニュートラル信頼度スコア]>
    
  10. 出力結果としてpositive, negativeおよびneutralのそれぞれの度合いが0~1の数値で返されることを確認します。

    51a.png

翻訳サービスのアクティビティ

  1. 言語を翻訳 アクティビティを追加します。

    41.png

  2. 先ほど作成したコネクションが表示されることを確認します。

  3. テキスト には翻訳対象となる原文を入力し、宛先 には訳語となる言語を選択します。今回は日本語訳にするために japanese - ja を指定します。

    42.png

  4. その他のオプションを表示 をクリックすると原文の言語を明示的に選択することができます。既定値では自動検出となります。

  5. 翻訳サービスの応答を出力するために (+) をクリックし、メッセージをログ アクティビティを追加します。

    43.png

  6. 言語を翻訳 の出力変数 テキスト を選択します。ログレベルは Info を選択します。

    44.png

  7. テスト をクリックし、ワークフローをテストします。

    45.png

  8. テキストの訳語が正しく表示されることを確認します。

    46.png

StudioからのAzure AI Services利用

  • 次にUiPath StudioからAzure AI Servicesを利用してみます。あらかじめStudioをAutomation Cloudに接続しておきます。
  1. Studioを起動しプロジェクトを作成します。対応OSは Windows または クロスプラットフォーム を選択します。

    56.png

  2. アクティビティの依存関係を右クリック > 管理 をクリックします。利用するAzure AI Servicesに応じてアクティビティを追加します。

    80.png

Microsoft Vision (画像分析) のアクティビティ

  1. Studioのアクティビティ管理画面にて Microsoft Vision バージョン 5.0.2-preview 以降をインストールします。表示されない場合にはフィルタアイコンをクリックして プレリリースを含む を選択します。

    53.png

  2. Studioの [アクティビティ] パネル > Integration Service > Microsoft > Microsoft Vision が表示されることを確認します。

  3. 利用可能なアクティビティの一覧は Microsoft Vision アクティビティガイド をご覧ください。

    • 今回は Describe Image (画像の説明文を生成) アクティビティと Read Text (画像内の文字抽出) アクティビティを試してみます。
    • 検証用の画像として Microsoft Learn: AI エンジニア演習 のサンプル画像を利用します。こちらのサイト から Lincoln.jpg をダウンロードしてStudioプロジェクト配下の image というフォルダーに配置します。

    81.png

Describe Image (画像の説明文を生成)

  1. Describe Image アクティビティを追加し、既定のMicrosoft Visionコネクションが表示されることを確認します。

    58.png

  2. アクティビティの各項目を設定します。

    61a.png

    • File Resource は分析対象の画像を選択します。
    • Language は説明文の言語を選択します。今回は ja (日本語) を指定します。
    • Output > Captions に変数(例: caption)を設定します。
  3. メッセージをログ アクティビティを追加し、 caption(0).Text を指定し説明文を出力します。

    62a.png

  4. デバッグ実行して画像の関する説明文が正常に表示されることを確認します。

    63a.png

  5. ログ出力値として String.Format("[Confidence: {0:F2}] ", caption(0).Confidence) + caption(0).Text のように指定すると信頼度も合わせて表示することができます。

    64a.png

Read Text (画像内の文字抽出)

  1. Read Text アクティビティを追加し、既定のMicrosoft Visionコネクションが表示されることを確認します。

  2. アクティビティの各項目を設定します。

    66a.png

    • File Resource は分析対象の画像を選択します。
    • Language は画像内の言語を選択します。今回は en (英語) を指定します。
    • Output > Operation ID に変数(例: operationId)を設定します。
  3. Get Read Result アクティビティを追加します。

    67a.png

    • Operation IDに先ほどの出力変数 operationId を指定します。
    • Output > Full Text に変数(例: resultText)を設定します。
  4. メッセージをログ アクティビティを追加し、先ほどの出力変数 resultText を指定し説明文を出力します。

    68a.png

  5. デバッグ実行して画像内の文字列が正常に抽出されることを確認します。

    82.png

Microsoft Sentiment (感情分析) のアクティビティ

  1. Studioのアクティビティ管理画面にて Microsoft Sentiment バージョン 5.0.5-preview 以降をインストールします。表示されない場合にはフィルタアイコンをクリックして プレリリースを含む を選択します。

    70.png

  2. Studioの [アクティビティ] パネル > Integration Service > Microsoft > Microsoft Sentiment が表示されることを確認します。

  3. Sentiment Analysis アクティビティを追加し、既定のMicrosoft Sentimentコネクションが表示されることを確認します。

    71.png

  4. アクティビティの各項目を設定します。

    73a.png

    • Text には感情分析の対象となる文章を指定します。
    • ID には感情分析の結果のGUIDを指定します。今回は Guid.NewGuid().ToString と指定して新しいGUIDを割り当てます。
    • Language には文章の言語を指定します。
    • Output > Sentiment には感情分析の結果を変数(例 sentiment)として指定します。
    • Output > Neutral confidence score には分析結果の中立的な信頼度を変数(例: neutral)として指定します。
    • Output > Negative confidence score には分析結果の否定的な信頼度を変数(例: negative)として指定します。
    • Output > Positive confidence score には分析結果の肯定的な信頼度を変数(例: positive) として指定します。
  5. メッセージをログ アクティビティを追加し、下記のようにメッセージを指定して結果を出力します。

    "Sentiment: " + sentiment + Environment.NewLine _
    	+ String.Format("Positive: {0:F2}", positive) + Environment.NewLine _
    	+ String.Format("Negative: {0:F2}", negative) + Environment.NewLine _
    	+ String.Format("Neutral: {0:F2}", neutral)
    
  6. デバッグ実行し、感情分析の結果が出力されることを確認します。

    74a.png

Microsoft Translator (翻訳) のアクティビティ

  1. Studioのアクティビティ管理画面にて Microsoft Translator バージョン 5.0.5-preview 以降をインストールします。表示されない場合にはフィルタアイコンをクリックして プレリリースを含む を選択します。

    75.png

  2. Studioの [アクティビティ] パネル > Integration Service > Microsoft > Microsoft Translator が表示されることを確認します。

  3. Translate Languages アクティビティを追加し、既定のMicrosoft Translatorコネクションが表示されることを確認します。

    76.png

  4. アクティビティの各項目を設定します。

    77.png

    • To には訳語の言語を指定します。
    • Text には翻訳対象の原文を指定します。
    • From には原文の言語を指定します。
    • Output > Translated text には訳語を変数(例: translatedText)として指定します。
  5. メッセージをログ アクティビティを追加し、メッセージに出力変数 translatedText を指定して結果を出力します。

    78.png

  6. デバッグ実行し、翻訳の結果が出力されることを確認します。

    79.png

おわりに

  • このようにAzure AI ServicesとUiPath Automation Cloudを組み合わせて使用することによって、画像分析・感情分析・翻訳サービスを自動化処理に容易に組み込みできるようになります。ぜひお試しください!
4
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?