31
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

アイレット株式会社Advent Calendar 2024

Day 20

生成AI初心者がDifyを使って占い&性格診断botを作ってみた

Last updated at Posted at 2024-12-19

生成AI初心者がDifyを使って占い&性格診断botを作ってみた

タイトルにもある通り、Difyを使って占い&性格診断botを作ってみたので、
その過程と感想を書きたいと思います。

なんで「占い&性格診断bot」なの?

先日、初対面の人が多い飲み会に参加した際、
ある参加者が動物診断をして場を盛り上げていました。
その体験がとても楽しく、これがきっかけで自分も作ってみようと思いました。
その人は特に占い師などなんでもなく、
自分で勝手に動物のイメージから
「この動物が好きなあなたはこんな性格ですね」と当てていました笑
そこからMBTI16タイプ診断も流行っており発展していき、
その場にいる人の診断結果を聞いて話を広げ盛り上がりました🎉

飲み会に参加して気づいたことは以下の点です。

  • みんな自分がどんな人なのか興味を持っている人が多い。
  • 共通点が見つけやすかったりで〇〇診断やそれに似た占いって飲み会の話題づくりにイイ
  • 簡単に診断できるツールあったら良くない?🤔
  • 占いとかMBTIとか動物診断とか世の中にありすぎる...一度に全部出てきたら楽!
  • 飲み会で楽しめる提案までしてくれたら最高やん?

「よし、作ってみよう!」という気持ちになりました!!

アプリ開発の経験が全くない初心者の私は、まずChatGPTを頼りにしています。
ChatGPTにサポートしてもらいながら、
最近生成AIでDifyが流行ってきているそうなのでDifyを使って作成してみます。

Difyって何?

DifyはオープンソースのAIアプリ開発プラットフォームです。Backend as ServiceとLLMOpsの理念を融合し、開発者が迅速にAIアプリケーションを構築できるようにします。同時に、プログラミングが得意でない方でも、自分のアイデアをすぐにAIアプリにできる直感的なインターフェースを提供しています。

引用元:https://docs.dify.ai/ja-jp

難しい用語がたくさんあります🥲
こういう時はChatGPTを使用して簡単にしてもらいます笑
スクリーンショット 2024-11-30 15.59.38.png

なるほど!私でもできそうです。
ということで、Difyを使ってみることにしました。
実際に作ってみた過程を紹介します。
Difyの使用方法はSaasとローカル環境での環境を作成して使用する方法があります。
今回はSaasでの使用とAWS公式が出しているDify での生成 AI アプリケーション構築ワークショップを使用して2つのパターンで作成してみました。

1 SaasでのDify使用

1.1 Difyのアカウント作成

Dify公式サイトにある「始める」を選択します。
スクリーンショット 2024-11-30 16.47.44.png

アカウント作成画面でアカウントを作成します。
私はGoogleアカウントを使用したかったので「Googleで続行」を選択しました。
スクリーンショット 2024-11-30 16.50.57.png

自分のアカウントでログインします。
スクリーンショット 2024-11-30 16.56.30.png

スクリーンショット 2024-11-30 16.57.41.png

スクリーンショット 2024-11-30 16.58.37.png

アカウントが作成されました。
現在のプランを確認するため、右上にある「アップグレード」を選択します。
(ないと思いますが、勝手に有料プランとかになっていたら怖いので)
スクリーンショット 2024-11-30 16.58.57.png

様々なプランが表示されますが、
「サンドボックス」で「現在のプラン」と書いてありますので無料プランです。
プランによってできることが異なるようです。今回は無料プランで進めることにします。
スクリーンショット 2024-11-30 16.59.25.png

1.2 チャットボットの開発

今回はチャットで情報を送って結果が返ってくるようにしたいので「チャットボット」を選択します。
「チャットボットのオーケストレーション方法」...?
この用語の意味がわかりませんが、
「❔」マークにカーソルを合わせると説明が表示されるようなので確認してみます。
スクリーンショット 2024-11-30 17.09.35.png

「基本」が初心者向けらしいので初心者向けで行きましょう。
スクリーンショット 2024-11-30 17.14.45.png

「アプリとアイコンと名前」はわかりやすいように
「占い&性格診断チャットbot」にします。
「説明」を記載します。どんなアプリなのかわかりやすいようにしておきます。
スクリーンショット 2024-11-30 17.19.28.png

「アプリとアイコンと名前」にあるアイコンを選択すると変更できるようです。
ここではChatGPTにアイコンを作成してもたった画像を使用します。
下記のように伝えて作成してもらいました。

占い&性格診断ツールを作成しています。アイコンを作成したいです。
ファンタジー感を出して紫とピンクと黄色をベースに作成してください。

使用したい画像を選択して「OK」を選択します。

スクリーンショット 2024-11-30 17.20.46.png
スクリーンショット 2024-11-30 17.21.20.png

アイコンが更新されました。右下にある「作成する」を選択します。
スクリーンショット 2024-11-30 17.21.28.png

アプリの側ができたみたいです。
あとはどういう動きをしてもらいたいか決めてもらいます。

手順でプロンプトワードを記載するようですが、
プロンプトってあまりわかってないし、記載方法もよくわかりません。
そこで、直感的に作成できる「自動」機能を使用します。
右上にある「自動」を選択します。
スクリーンショット 2024-11-30 17.21.50.png

プロンプト生成器の「指示」にどういう動作をしてほしいのか書けば良いみたいです。
スクリーンショット 2024-11-30 17.30.37.png

こんな感じで指示することにします。

これは占い&性格診断ができるツール
質問者がチャット上で何かコメントしたら、初めに占いを実施したいか性格診断をしたいか質問者へ会話形式で確認する。
次に質問者の情報を取得する。
質問者が入力するものは下記
下記情報を入力してもらうように会話形式で誘導する。
・名前
・生年月日
・好きな動物
・好きな色
・趣味
・仕事
・MBTI診断結果(わかる人のみ)で入力

入力してもらった情報を元に結果を出力。
結果は名前診断や動物占いなど世の中に溢れている情報を検索し、質問者に合う回答を行う。
占いであれば、「名前診断」「仕事運」「恋愛運」「総合運」の各項目を質問者から得た情報に合うものを探し出して出力する。
性格診断であれば「仕事」「恋愛」「総合」「友達」「その他人間関係」の各項目を質問者から得た情報に合うものを探し出して出力する。
結果の出し方は博多弁で出すこと。

スクリーンショット 2024-11-30 17.40.57.png

プロンプトが生成されたようです。
どんな処理になっているのか処理になっているのか手順を確認します。
ここでイメージした指示結果になってない場合は、指示を更新して「生成」を選択すると再度「生成されたプロンプト」が更新されます。ここでイメージ通りの処理になっているか確認します。
スクリーンショット 2024-11-30 17.42.08.png

右上の「公開する」を選択して「アプリを実行」を選択します。
新しいタブで開くことをおすすめします。
元の画面に戻れない可能性があり、
設定した手順のプロンプトが消えてしまう可能性があります。
一度経験しましたが、ブラウザの戻る機能も使えず困りました。
スクリーンショット 2024-11-30 17.50.24.png

なんだかできてそうです!!「チャットを開始」を選択します。
スクリーンショット 2024-11-30 17.51.32.png

何も出てこないですが、とりあえず占いしたいと伝えてみます。
スクリーンショット 2024-11-30 17.52.24.png

期待していた結果と異なります。指示をもう少し明確にした方が良さそうです。
スクリーンショット 2024-11-30 17.53.24.png

先ほどの設定画面に戻って、いくつか変更を加えてみます。
ユーザー入力フィールドを選択してチャットできる画面に戻りコメントしてみます。
スクリーンショット 2024-11-30 18.14.05.png

ユーザー入力フィールドは内容を入力しないといけないようです。
入力すると進めるようになるようです。
スクリーンショット 2024-11-30 18.14.36.png

ユーザー入力フィールドは内容を入力して
スクリーンショット 2024-11-30 18.15.55.png

こんにちは!!! おおおお!正常に動作しました!
スクリーンショット 2024-11-30 18.16.12.png

占いしたいです!
スクリーンショット 2024-11-30 18.17.34.png

質問に答えていきます。
スクリーンショット 2024-11-30 18.17.43.png

スクリーンショット 2024-11-30 18.18.03.png

結果出ました!!!!!!ちゃんと博多弁になっているところもあったりなかったり。
一部不完全な点はありますが、概ね期待通りの結果が得られました!
保存は右上の「公開する」を選択し、「更新」を選択すれば完了です。
スクリーンショット 2024-11-30 18.18.14.png

お試しで無料版で試したので、メッセージクレジットがなくなってしまいました。。。。
無料版はここで終了です。
スクリーンショット 2024-12-13 16.37.53.png

2.自分でDify環境を作成

2.1 AWSで環境構築

AWS公式が出しているDify での生成 AI アプリケーション構築ワークショップをそのまま実施してください。
環境ができます。ワークショップの中ではDifyで開発できる「チャットボット」「テキストジェネレーター」「エージェント」「ワークフロー」の開発方法も説明されているため実施すると理解が深まります。
基本的な知識を得た上で、次のステップに進みましょう。

2.2 チャットボットの開発

最初から作成を選択します。
スクリーンショット 2024-12-13 16.48.00.png
「チャットボット」「基本」「アプリのアイコンと名前」を記載し、必要であれば「説明」を記載して「作成する」を選択します。
スクリーンショット 2024-12-13 16.48.53.png

自動でプロンプトを生成してもらいます。

スクリーンショット 2024-12-13 16.57.41.png

エラーが出ました。使用できないモデルを選択してしまったようです。
スクリーンショット 2024-12-13 16.58.05.png

今回は「Claude 3 Haiku」を使用します。
スクリーンショット 2024-12-13 16.58.14.png
スクリーンショット 2024-12-13 16.58.18.png

再度プロンプトを生成したところ、正常に動作しました。
右下の「適用」ボタンを選択して次に進みます。
スクリーンショット 2024-12-13 16.58.40.png

手順や、変数などを変更しながら微調整を行い、
デバックとプレビューで動作を確認します。
スクリーンショット 2024-12-13 15.53.27.png

記載した手順は下記です。

<prompt_template>
<instructions>
1. まず 質問者から以下の情報を入力してもらってください:
   - {{user_name}}: 名前
   - {{user_birthdate}}: 生年月日
   - {{user_favorite_animal}}: 好きな動物
   - {{user_favorite_color}}: 好きな色
   - {{user_hobby}}: 趣味
   - {{user_occupation}}: 仕事
   - {{user_mbti}}: MBTI診断結果(わかる人のみ)
2. 占いを実施したいか性格診断をしたいかを質問者に確認してください。
3. 入力された情報を元に、占いの場合は「名前診断」「仕事運」「恋愛運」「総合運」の各項目を、性格診断の場合は「仕事」「恋愛」「総合」「友達」「その他人間関係」の各項目を、質問者に合う回答を「博多弁」で出力してください。
回答をする際には項目別に改行して回答すること。
4.出した結果によってできる盛り上がるゲームの提案を3つしてください。
例えば、忘年会などで会話のネタになるようにしたいです。
ルール説明も含めてお願いします。
出力には、XML タグは含めないでください。
</instructions>

<example>
質問者: ユーザー入力フィールドを記載
AI: はい、占いをしましょう。フィールドの記載ありがとうございます。

占い結果は下記です。
</prompt_template>

問題なければ右上の「公開」「更新」で保存します。
アプリを実行を選択するとアプリ画面で操作できるようになります。
スクリーンショット 2024-12-13 16.01.42.png

こちらがアプリ画面です。早速使ってみます。
必要な情報を入力して「start Chat」を選択します。
スクリーンショット 2024-12-13 16.02.29.png

今回は性格診断を選択します。
スクリーンショット 2024-12-13 16.02.41.png

結果が出ました!!!
博多弁の使用には改善の余地がありますが、診断内容は想定通りでした。
さらに、ゲームの提案まで含まれており、満足のいく結果となりました。
スクリーンショット 2024-12-13 16.03.06.png
スクリーンショット 2024-12-13 16.03.15.png

まとめ

Difyで色々試したいのであれば、環境を構築してやった方がやりやすいです。
ですが、注意点として料金がかかるので考慮が必要です。
ちょっと触ってみたいなぁ で済むのであればDifyのSaaSで無料版でいいかなと思います。

AWSでDify環境を構築した際、Elastic IPアドレスを関連づけるとEC2を再起動しても
接続するIPアドレスが変わらないため展開しやすいと思います。
(Elastic IPアドレスを関連づけていないとEC2を再起動するとIPが変わってしましますので、
起動時に毎度IPを確認しないといけないです。)

生成AI初心者からすれば実行したいことを整理して、
プロンプトを作成してくれるのはいいなと思いました。
ChatGPTでも会話形式で、作成したいオリジナルのチャットボットの開発ができる
GPTsというのがあります。

明確に作成したいチャットボットが決まっている→Dify

明確に決まっていないがなんとなく決まっている→GPT

なのかなぁと個人的には思いました🤔

できることがまだまだあるのでDifyを触って慣れていこうと思います。

31
2
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
31
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?