はじめに: 進化するチャットボット
生成AIが流行している2023年現在、生成AIのみならずAI全般に関する話題は尽きることがないですが、最近は「社内業務でも生成AIを活用していこう」という動きが様々なところから聞こえてきます。
よくある話題の1つとして、「生成AIを使って業務知識を覚えたチャットボットが作れないか?」 というトピックが挙がります。
確かに、生成AIを使ったチャットボットには以下のようなメリットがあります。
- 質問を1つずつ覚え込ませることなく、良きに計らって未知の質問への回答を生成してくれる
- 他のユースケース向けにファインチューニングしたモデルを流用できる
ところが実際に生成AIを使ってチャットボットを作ってみると、以下のような課題に当たります。
- トークン数の制限により、あまり多くの業務知識を取り込めない
- 生成AIのモデル自体に取り込まれている前提知識に影響され、予期しない / 誤った回答が返ってくる
- 回答生成に時間を要すため、従来型チャットボットに比べて応答時間が大幅に長い
以上の課題から、特にチャットボットのユースケースにおいては、
- 外部の文書検索エンジンにクエリーする仕組み
-
RAG (Retrieval Augmented Generation) の手法を使い、都度外部DBに結果を探しに行く仕組みを作る
などの方法が主流です。
一方で、上記のようなシステムの実装には非常に手間がかかり、外部に実装を依頼する場合には継続的なメンテナンスが行いづらくなる等の課題も発生します。また、ボットの組み込み先として想定されるTeamsやSlackとどのように連携するのか、等の考慮も必要です。
Watson AssitantのTeams連携対応
最近、IBM社のチャットボットであるWatson Assistantの機能拡張が発表され、Teamsへのチャットボットの組み込みや、文書検索ソリューションであるWatson Discoveryとの連携が強化されました。
これにより、例えば下記の様に社内文書から情報検索を行うボットの構築が簡単にできるようになります。
手順:
(0) 事前にTeamsのチャット履歴をWatson Discovery (文書検索エンジン) に取り込んでおく。
(1) Teams上のチャットボットから質問を投げかける。例:「3年目の社員が取得可能な有給休暇の日数は?」
(2) 質問内容がチャットボット (Watson Assistant) に連携され、更に自動でWatson Discoveryの社内文書から検索し、結果が連携される。
(3) Teamsのチャット上で回答が得られる。例:「このような文書が見つかりました。
『有給休暇は、在籍年数に応じて取得が可能です。・・・在籍1年以上5年未満: 15日・・・』」
Teams連携の手順
本記事の手順は全てクラウドサービス上で簡単にトライ可能で、大体2時間~半日もあれば、自分のデータを取り込んでTeams上で動く社内情報検索チャットボットを作ることが可能です。
IBM社によるガイドもありますが、下記に「人事規則の検索ボット」を例として作成する手順を、画面キャプチャーも入れながら記載しました。
Teams連携の事前準備
下記が事前に必要となります。 (作業所要時間:30-60分)
-
IBM Cloudアカウント作成
- 手順:Qiita
-
Watson Assistantのトライアルプラン作成 (無料: 30日間まで)
- 手順:Qiita
-
Watson DiscoveryのPlusプラン作成 (1アカウント1回30日間まで無料)
- 手順:Qiita ("Watson Discovery での事前準備" まで)
-
チャットボットを動かしたいTeams環境 (管理者権限付き)
- デモとして動かすだけであれば、手順3-2で後述するMicrosoft 365 Developerプログラムで取得したMicrosoftアカウントのTeams環境でも可能ですので、現時点でお持ちで無い場合は無視して構いません
手順1: Watson Discoveryのプロジェクト作成・文書を読み込ませる (30-60分)
こちらのQiitaの "Watson Discovery での事前準備" までを参考に、Watson Discoveryのプロジェクトを作成し、適当な文書を読み込ませます。
- 今回私は、ダミーで作成した社内人事規則や就業規則のデータを入れてみました。
- Teamsのチャット履歴から元データを取ってくることも可能です。コピペしてtxtファイル/Wordに貼り付けても良いですし、Microsoft社が提供するAPIやエクスポートのページから取得したjsonの利用も可能です。
手順2: Watson AssistantとWatson Discoveryの接続 (10-20分)
こちらのQiita の "Watson Assistant との連携" を参考に、Watson AssistantとWatson Discoveryの接続を行います。
ここまで完了すると、Watson Assistant上で文書検索を行うことができるようになります。
手順3: Watson AssistantとTeamsの接続 (30-90分)
ここからは、Watson AssistantのボットをTeams上で使えるようにするための手順を紹介します。
いくつかのMicrosoft社のポータル・サービス上を行き来して設定するため、迷子になりやすいのですが、
Watson Assistantには設定ウィザードが用意されているので、このウィザードに各ポータルで取得した接続情報などを入れながら設定することができます。これにより作業の現在地も分かり、中断した場合などでも比較的安心して作業を再開できます。
手順3-1: Watson AssistantでTeams接続の設定ウィザードを開く
事前準備で作成したWatson Assistantの画面にログインし、画面左側にカーソルを持って行くとメニューが出てきます。下側に"Integrations"がありますので、こちらを開きます。
"Channels"という項目にTeamsがありますので、こちらの"Add"をクリックしてさらに"Add"を押します。
- "Get Started"の項目では特に手順がありませんので、"Next"を押します。
- "App registration"の項目に進みますが、こちらの作業のためにMicrosoft 365 Developerプログラムのアカウントが必要になるので、一旦この画面はそのままにして、別のタブなどを開いて手順3-2に進みます。
手順3-2: Microsoft 365 Developerプログラムアカウントの取得
注意:本手順でのアカウント作成時、まずは普通のMicrosoftアカウントでのログインが必要です。うまくアクセスできない場合などは、フリーメールアドレスでアカウントを作成しログインしてからアクセスするなどの手順を試してみてください。
- Microsoft Dev Centerにアクセスし、"Join now"をクリックします。
https://developer.microsoft.com/en-us/microsoft-365/dev-program
- 必要事項を入力していきます。環境選択はどちらでも問題ありませんが、基本は"Instant Sandbox"で問題ありません。
- こんな画面が出れば完了です。発行されたメールアドレスをメモしておきます。(あとでダッシュボードからも戻ってこれます:https://developer.microsoft.com/en-us/microsoft-365/profile)
手順3-3: アプリケーションの登録 (App registration)
- Watson AssistantのTeamsウィザードに戻ります。
- Azureポータルを開き、手順3-2のアカウントでログインします。https://portal.azure.com/#view/Microsoft_AAD_RegisteredApps/ApplicationsListBlade
- "アプリケーションの登録"から、"新規登録"をクリックします。
- 情報を選択・記入したら、"登録"をクリックします。
- 登録後の画面から、アプリケーションIDが確認できるので、コピーします。 (日本語設定の場合は文字が見切れていますが、一番上の項目です)
- Watson Assistantのウィザードに戻り、アプリケーションIDをペーストする箇所がありますので、こちらに貼り付けます。
- Azureに戻り、"証明書またはシークレットの追加"をクリックします。
- "新しいクライアント シークレット"から、シークレット情報を取得します。デモ用途では有効期限はデフォルトの180日で問題ありません。
- "値"をコピーして、同様にウィザードに貼り付けます。(シークレットの有効期限をデフォルトから変えている場合は、そちらも変更しておきます)
手順3-4: ボットの作成
- Microsoft Bot Framework 開発者ポータルにアクセスし、手順3-2で作成したアカウントでログインします。
- "Tell us about your bot"のページで、必要情報を入力していきます。
- "Register"を押せば登録完了です。登録完了後の"Connect to channels"というページで、"Add a featured channel"という項目があり、Teamsのアイコンがありますのでこちらをクリックします。
- 設定画面では、Teamsの種類を選択し、Saveします。(通常はデフォルトのままで良いです)
- "Calling"、"Publish"の項目も設定できますが、特に何も無ければそのままで問題ありません。
手順3-5: Teamsアプリの作成
-
Microsoft Teams 開発者ポータルにアクセスし、ログインします。
https://dev.teams.microsoft.com/home -
画面左側のメニューから"Apps"を選択し、"New App"をクリックします。Appの名前を入れて"Add"をクリックします。
-
必要情報を入力していきます。
- "Application (client) ID"は、ウィザードからコピー&ペーストします。
-
情報の入力が完了したら"Save"します。
-
必要情報を入力していきます。
-
右上の"Publish"を押して、Teamsに必要なアプリのダウンロードやアプリケーションの登録が可能です。今回は、一旦パッケージをダウンロードします。
手順3-6: Teamsアプリの登録
- お使いの組織のTeamsの管理者権限を持ったアカウントにログインします。
注意:管理者権限がない場合などは、手順3-2で作成しているアカウントでもTeamsの利用が可能です。 - 画面左下の"アプリを管理"をクリックし、"アプリをアップロード"を選択します。
- 先ほどダウンロードしたパッケージを選択してアップロードします。
- アプリを追加します。
手順4: 実際にTeams上から文書検索ボットを使ってみる
- 手順3まで完了すると、TeamsのチャットからWatson Assistantのチャットボットが利用できるようになっており、そのチャットボットから文書検索が行えるようになっています。
- 実際に質問を投げかけてみると、文書検索が実装できていることが分かります。
おわりに: この仕組みのポイント
ここまで、Watson Assitant (チャットボット) とWatson Disovery (文書検索) を使って、Teams上から社内情報検索を行うチャットボットの実装を行いました。
実際に設定・構築を行ったり、利用してみると、下記の様なポイントがあることが分かります。
- 誰でもノーコードで短時間で構築できる:最短1時間~半日程度あれば誰でもTeams連携まで構築でき、コーディング無し + 無料で最新の文書検索ボットの能力を知ることができる (注:一部ライセンスは無料期間の制限あり)
- 継続してカスタム可能:自分でカスタムすることができ、文書追加などを行うことで自分で継続的にレベルアップできる。よくある質問は自分でチャットボット側に追加して、確度を高めるようなことも可能
- AIへの業務知識の取り込みが簡単かつ低リスク:業務知識の取り込みは、文書のアップロードだけで行える。生成AI利用時に懸念されるファインチューニング・プロンプトエンジニアリングの労力や、AIモデルへの機密情報への取り込みリスクも無い
AI関連の技術は玉石混淆で日々発展を遂げていますが、どれだけ高度な技術でも、ユーザーに使ってもらえなければ意味がありません。
今回ご紹介した社内情報検索Teamsチャットボットは、Teamsという身近なインターフェースであり、とりあえずユーザーに使ってもらうという意味で非常にハードルを下げてくれます。
また、開発側にとっても、この仕組みは数時間あれば自分たちで構築・検証可能で、かつ文書検索のエンジンもほぼ全自動で解析を行ってくれるということで、「まずは試してみる」という障壁を減らしてくれます。
本記事にご関心いただけましたら、是非一度試してみて下さい。