通話後の文字起こしカテゴリの作成 - Amazon Transcribe

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

通話後の文字起こしカテゴリの作成

通話後分析ではカスタムカテゴリの作成がサポートされているため、特定のビジネスニーズに合わせてトランスクリプト分析を調整できます。

さまざまなシナリオをカバーするカテゴリをいくつでも作成できます。作成するカテゴリごとに、1 から 20 のルールを作成する必要があります。各ルールは、中断、キーワード、非通話時間、感情という 4 つの基準のいずれかに基づいています。CreateCallAnalyticsCategory オペレーションでこれらの基準を使用する詳細については、「通話後分析カテゴリのルールの条件 セクション」を参照してください。

メディア内のコンテンツが、指定したカテゴリのすべてのルールに一致する場合、 Amazon Transcribe は出力にそのカテゴリのラベル付けを行います。出力のカテゴリ一致の例については、「通話分類JSON出力」を参照してください。

カスタムカテゴリを使用してできるその他の例を紹介します。

  • ネガティブなカスタマー感情で終わった通話など、特定の特徴を持つ通話を分離します。

  • 特定のキーワードセットにフラグを付けて追跡することで、お客様の問題の傾向を特定します。

  • エージェントが通話の最初の数秒間に特定のフレーズを話す (または省略する) などのコンプライアンスをモニタリングします。

  • エージェントによる中断やお客様からのネガティブな感情が多い通話にフラグを立てることで、カスタマーエクスペリエンスに関するインサイトを得られます。

  • 複数のカテゴリを比較して相関関係を測定します。たとえば、ウェルカムフレーズを使用するエージェントがお客様のポジティブな感情と相関関係があるかどうかの分析などです。

通話後カテゴリとリアルタイムカテゴリ

新しいカテゴリを作成する場合、通話後分析カテゴリ (POST_CALL) として作成するか、リアルタイム通話分析カテゴリ (REAL_TIME) として作成するかを指定できます。オプションを指定しない場合、カテゴリはデフォルトで通話後カテゴリとして作成されます。通話後分析カテゴリマッチは、通話後分析の文字起こしが完了すると、出力に表示されます。

通話後分析用の新しいカテゴリを作成するには、、AWS Management ConsoleAWS CLI、または を使用できますAWS SDKs。例については、以下を参照してください。

  1. ナビゲーションペインで、Amazon Transcribe 分析の呼び出し Amazon Transcribeを選択します。

  2. [コール分析カテゴリ] を選択すると、[コール分析カテゴリ] ページに移動します。[カテゴリの作成] を選択します。

    Amazon Transcribe コンソールのスクリーンショット: 「コール分析」の「カテゴリ」ページ。
  3. [カテゴリの作成ページ] が表示されます。カテゴリの名前を入力し、カテゴリタイプのドロップダウンメニューで [バッチコール分析] を選択します。

    Amazon Transcribe コンソールのスクリーンショット:「カテゴリ設定」パネル。
  4. テンプレートを選択してカテゴリを作成することも、一から作成することもできます。

    テンプレートを使用する場合: [テンプレートを使用する (推奨)] を選択し、必要なテンプレートを選択してから [カテゴリの作成] を選択します。

    Amazon Transcribe コンソールのスクリーンショット: オプションのテンプレートを示す「カテゴリ設定」パネル。
  5. カスタムカテゴリを作成する場合: [最初から作成] を選択します。

    Amazon Transcribe コンソールのスクリーンショット:「ルール」ペインを示す「カテゴリの作成」ページ。
  6. ドロップダウンメニューを使用して、カテゴリにルールを追加します。1 つのカテゴリには最大 20 ルールまで追加できます。

    Amazon Transcribe コンソールのスクリーンショット: ルールタイプのリストを含む「ルール」ペイン。
  7. これは、2 つのルールがあるカテゴリの例です。1 つは、通話中に 15 秒以上お客様の話を中断したエージェントと、もう 1 つは通話の最後の 2 分間にお客様またはエージェントが感じたネガティブな感情です。

    Amazon Transcribe コンソールのスクリーンショット: 2 つのルール例を含む「ルール」ペイン。
  8. カテゴリにルールを追加し終えたら、[カテゴリの作成] を選択します。

この例では、 create-call-analytics-category コマンドを使用します。詳細については、CreateCallAnalyticsCategoryCategoryProperties、およびRuleを参照してください。

以下の例では、ルールを含むカテゴリを作成します。

  • カスタマーは最初の 60 秒間で中断されました。これらの中断時間は少なくとも 10 秒続きました。

  • 通話の 10% から 80% の間では少なくとも20 秒の無音が続きました。

  • エージェントは、通話中のある時点でネガティブな感情を抱いていました。

  • 通話の最初の 10 秒の間に、「ようこそ」や「こんにちは」という単語は使われていません。

この例では、 create-call-analytics-category コマンドと、カテゴリに複数のルールを追加するリクエスト本文を使用します。

aws transcribe create-call-analytics-category \ --cli-input-json file://filepath/my-first-analytics-category.json

ファイル my-first-analytics-category.json には、次のリクエスト本文が含まれています。

{ "CategoryName": "my-new-category", "InputType": "POST_CALL", "Rules": [ { "InterruptionFilter": { "AbsoluteTimeRange": { "First": 60000 }, "Negate": false, "ParticipantRole": "CUSTOMER", "Threshold": 10000 } }, { "NonTalkTimeFilter": { "Negate": false, "RelativeTimeRange": { "EndPercentage": 80, "StartPercentage": 10 }, "Threshold": 20000 } }, { "SentimentFilter": { "ParticipantRole": "AGENT", "Sentiments": [ "NEGATIVE" ] } }, { "TranscriptFilter": { "Negate": true, "AbsoluteTimeRange": { "First": 10000 }, "Targets": [ "welcome", "hello" ], "TranscriptFilterType": "EXACT" } } ] }

この例では AWS SDK for Python (Boto3) 、 を使用して、create_call_analytics_category メソッドの 引数CategoryNameRules引数を使用してカテゴリを作成します。詳細については、CreateCallAnalyticsCategoryCategoryProperties、およびRuleを参照してください。

機能固有の例 AWS SDKs、シナリオ例、クロスサービスの例など、 を使用したその他の例については、を使用した Amazon Transcribe のコード例 AWS SDKs「」の章を参照してください。

以下の例では、ルールを含むカテゴリを作成します。

  • カスタマーは最初の 60 秒間で中断されました。これらの中断時間は少なくとも 10 秒続きました。

  • 通話の 10% から 80% の間では少なくとも20 秒の無音が続きました。

  • エージェントは、通話中のある時点でネガティブな感情を抱いていました。

  • 通話の最初の 10 秒の間に、「ようこそ」や「こんにちは」という単語は使われていません。

from __future__ import print_function import time import boto3 transcribe = boto3.client('transcribe', 'us-west-2') category_name = "my-new-category" transcribe.create_call_analytics_category( CategoryName = category_name, InputType = POST_CALL, Rules = [ { 'InterruptionFilter': { 'AbsoluteTimeRange': { 'First': 60000 }, 'Negate': False, 'ParticipantRole': 'CUSTOMER', 'Threshold': 10000 } }, { 'NonTalkTimeFilter': { 'Negate': False, 'RelativeTimeRange': { 'EndPercentage': 80, 'StartPercentage': 10 }, 'Threshold': 20000 } }, { 'SentimentFilter': { 'ParticipantRole': 'AGENT', 'Sentiments': [ 'NEGATIVE' ] } }, { 'TranscriptFilter': { 'Negate': True, 'AbsoluteTimeRange': { 'First': 10000 }, 'Targets': [ 'welcome', 'hello' ], 'TranscriptFilterType': 'EXACT' } } ] ) result = transcribe.get_call_analytics_category(CategoryName = category_name) print(result)

通話後分析カテゴリのルールの条件

このセクションでは、 CreateCallAnalyticsCategoryAPIオペレーションを使用して作成できるカスタムPOST_CALLルールのタイプの概要を説明します。

中断マッチ

中断 (InterruptionFilter データタイプ) を使用するルールは、以下と一致するように設計されています。

  • エージェントがお客様を中断させるインスタンス

  • お客様がエージェントを中断させるインスタンス

  • いずれかの参加者が他の参加者を中断させる

  • 中断がないこと

InterruptionFilter で使用できるパラメータの例を以下に示します。

"InterruptionFilter": { "AbsoluteTimeRange": { Specify the time frame, in milliseconds, when the match should occur }, "RelativeTimeRange": { Specify the time frame, in percentage, when the match should occur }, "Negate": Specify if you want to match the presence or absence of interruptions, "ParticipantRole": Specify if you want to match speech from the agent, the customer, or both, "Threshold": Specify a threshold for the amount of time, in seconds, interruptions occurred during the call },

これらのパラメータとそれぞれに関連する有効な値の詳細については、「CreateCallAnalyticsCategory」および「InterruptionFilter」を参照してください。

キーワードマッチ

キーワード (TranscriptFilter データタイプ) を使用するルールは、以下と一致するように設計されています。

  • エージェント、お客様、あるいはその両方が話すカスタム単語またはフレーズ

  • エージェント、お客様、あるいはその両方が口にしないカスタム単語またはフレーズ

  • 特定の期間に出現するカスタム単語またはフレーズ

TranscriptFilter で使用できるパラメータの例を以下に示します。

"TranscriptFilter": { "AbsoluteTimeRange": { Specify the time frame, in milliseconds, when the match should occur }, "RelativeTimeRange": { Specify the time frame, in percentage, when the match should occur }, "Negate": Specify if you want to match the presence or absence of your custom keywords, "ParticipantRole": Specify if you want to match speech from the agent, the customer, or both, "Targets": [ The custom words and phrases you want to match ], "TranscriptFilterType": Use this parameter to specify an exact match for the specified targets }

これらのパラメータとそれぞれに関連する有効な値の詳細については、「CreateCallAnalyticsCategory」および「TranscriptFilter」を参照してください。

非通話時間マッチ

非通話時間 (NonTalkTimeFilter データタイプ) を使用するルールは、以下と一致するように設計されています。

  • 通話中、指定された時間帯に無音状態が続いていること

  • 通話中、指定された時間帯に発話状態が続いていること

NonTalkTimeFilter で使用できるパラメータの例を以下に示します。

"NonTalkTimeFilter": { "AbsoluteTimeRange": { Specify the time frame, in milliseconds, when the match should occur }, "RelativeTimeRange": { Specify the time frame, in percentage, when the match should occur }, "Negate": Specify if you want to match the presence or absence of speech, "Threshold": Specify a threshold for the amount of time, in seconds, silence (or speech) occurred during the call },

これらのパラメータとそれぞれに関連する有効な値の詳細については、「CreateCallAnalyticsCategory」および「NonTalkTimeFilter」を参照してください。

感情マッチ

感情 (SentimentFilter データタイプ) を使用するルールは、以下と一致するように設計されています。

  • 通話中の特定の時点で、お客様、エージェント、あるいはその両方が表現したポジティブな感情の有無

  • 通話中の特定の時点で、お客様、エージェント、あるいはその両方が表明したネガティブな感情の有無

  • 通話中の特定の時点で、お客様、エージェント、あるいはその両方が表明した中立的な感情の有無

  • 通話中の特定の時点で、お客様、エージェント、あるいはその両方が表明したさまざまな感情の有無

SentimentFilter で使用できるパラメータの例を以下に示します。

"SentimentFilter": { "AbsoluteTimeRange": { Specify the time frame, in milliseconds, when the match should occur }, "RelativeTimeRange": { Specify the time frame, in percentage, when the match should occur }, "Negate": Specify if you want to match the presence or absence of your chosen sentiment, "ParticipantRole": Specify if you want to match speech from the agent, the customer, or both, "Sentiments": [ The sentiments you want to match ] },

これらのパラメータとそれぞれに関連する有効な値の詳細については、「CreateCallAnalyticsCategory」および「SentimentFilter」を参照してください。