1
0

bedrock knowledge baseを使ってAI総務社員を作ってみた

Last updated at Posted at 2024-05-14

:tent: 背景

弊社では社内規定に対する質問が全社員から総務部に問い合わせがあり総務の負荷が増えております。「社内規定を見てください!」と常々周知はしていますが聞いた方が早いため気軽に総務にチャットで聞いてしまうのが現状です…これは「どげんかせんといかん!」(どうにかしなくては)ということで最近AI関連の技術でbedrock knowledge baseでRAG検索とかいう社内規定文章をベースにいい感じに回答してくれる仕組みがあるらしいので試してみました。

:raised_hands: ゴール

・teamsで社内規定の質問を投稿するとAIが自動で回答すること
・一般的な情報ではなく社内規定文章を元にした回答であること
・嘘をつかないこと
・総務の若い子からQiiZiro(私)さん素敵です:couple_mm:と愛が芽生えること:seedling:

ムフ、ムフフフフ...
AIの勉強にもなって念願の彼女もできる(かもしれない)ので燃えてまいりましたぞ:muscle:

:tools: アーキテクチャ

teamsとの親和性を考えるとバックエンドはazureになりそうなところですが、私はAWSを学びたいためあえてAWSでの構成としました。

構成図.png

:chart_with_upwards_trend: AIモデルについて

bedrockにおける自然言語AIモデルで最近巷で噂になっているが「Claude3」簡単に言ってしまうとめちゃめちゃ賢いそうです。一説によるとチャットGPTを超えたとか…要はより人間っぽい挙動ができそうということで、Claude3 Haikuというモデルを使用することにしました。Claude3は3つのモデルがあるらしく用途によって使い分けるみたい。Haikuの特徴は「早くて安い」とのこと。

...あと「美味い」があれば最高やな:ramen:

:moneybag: 運用費用について

運用費用はこんな感じでした。
image.png
1日あたり1.3$程度でした。ほぼRDS代が占めておりますね。
当然ですが質問の頻度によってはlambda/bedrockのモデル使用料が蓄積していきます。

費用削減ポイント

  • データストレージにAuroraを使用(Opensearchは高い)
  • Auroraを日中のみ起動
  • 安いモデル(Claude3 haiku)を使用

:runner_tone4: 実際に動かしてみよう

実験1:休職について聞いてみた
image.png
社内規定は開示できませんが、社内規定に即していい感じに回答してくれています。
image.png
有給の付与日数についても正しく回答してくれています。

実験2:一般常識について聞いてみた
image.png
回答してくれました。社内規定以外の事は全く回答しないわけではないようですね…

実験3:社内規定には書いていない規定について聞いてみた
image.png
むむ、英語で「回答できません」という旨の回答が来ました。
プロンプトの調整が必要ですな…

実験結果から、基本的には取り込んだデータソースを元に回答してくれて、世間一般の当たり前のことも回答してくれています。ただ、社内規定に書いていないことをあたかも書いているように回答することもあるようです…体感ですが社内規定に関する回答はある程度性格でした。AIに100%を求めるのは酷ってことなんですかね:robot:

:ramen: 〆

「bedrock knowledge base/RAG検索」

聞きなれない言葉でしたが、自社のプライベートなデータを基にして人間のようにいい感じに回答してくれるというものでした。汎用性は高いと思うので、社員プロフィール情報をデータソースにすることで「〇〇さんの誕生日プレゼント何がいいかな?」と聞いたらいい感じに回答しれくれたりするかな?とかいろいろ考えてみるのも楽しそうですね:smiley:

最後に…勇気を振り絞って映画に誘ってみました。
image.png
えっ…そんな業務規程あったっけ?会社の承認てwww なぜか規定を理由に断られました:sob:

1
0
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
1
0