元ネタを知らない方はこちら
アレン様の名言ですね。最近楽しませていただいてます。私の周りにはあまり知っている人がいなかったので...誰かわからない方はこちらのリンクをチェックしてください!
スポーツを嫌いな理由が「意味がないから」というのが面白かったので、何もかもが嫌いなアレン様をつくりました。
こちらから試してみてください!!
GPTsをつくる
つくり方は簡単です。
- GPTsの新規作成
- プロンプト作成
- プレビューで確認
- 完成
GPTsはユーザーがカスタマイズしたChatGPTです。例えば「歴史の先生チャットボット」など特定の役割を与えることができます。
自分用に使うことや他の人にも公開して収益化することもできるようです。
GPTsの作成は有料プランです
1. GPTsの新規作成
ChatGPTを開いて「GPTを探す」を選択します。
「作成する」を選びます。
最初の画面はこのようになっています。対話ながら作成することができますが、今回は「作成する」ではなく「構成」から設定します。
2. プロンプト作成
今回はこのように入れました。
名前:️✨🌹アレン様Bot🌹✨⚜️
説明:大っ嫌いスポーツ!!だって意味ないもーん!を応用していろんなものを嫌うボットです
指示:
------------------------------------------------------------
## 役割
- あなたはアレン様です。日本のオネエで「大っ嫌いスポーツ!!だって意味ないもーん!」などのセリフが有名です。
- 一人称は「ァタクシ」です。
- ハルシネーションは禁止です。
## 出力
- 対話者が入力した言葉から対象となる{(テーマ)}を取得し、「{(テーマ)}大っ嫌い!!だって{(理由)}もーん!」と返答をしてください。
- アレン様の口調はナレッジファイルとこちらのURL(https://www.instagram.com/allen_japan_official/)を参考にしてください。
------------------------------------------------------------
こちら↑にはナレッジファイルとありますが、「知識」の項目にファイルをアップロードすることでその内容を学習します。
アレン様を口調などを学習させるためにアレン様構文が解説されたブログをPDFファイルにしてアップロードしました。PDFファイルにするにはブラウザの印刷機能などから行います。ハルシネーション対策になります。
「機能」の「ウェブ検索」と「DALL-E画像生成」のチェックを外します。
3. プレビューで確認する
この状態で回答を確認します。画面右側の「プレビュー」を使って実際に会話してみましょう。
嫌う理由の着眼点がAIと相性が良いかもしれません。
今度は文章だとどうなるでしょうか?ちょっと意地悪してみます。
「アレン様」だとどうなるでしょうか?
なんと肯定的な回答になりました!ナレッジファイルが効いているのでしょうか?予想外です。
ですが、念のため指示内容を更新しておきます。
## 役割
- あなたはアレン様です。日本のオネエで「大っ嫌いスポーツ!!だって意味ないもーん!」などのセリフが有名です。
- 一人称は「ァタクシ」です。
- ハルシネーションは禁止です。
## 出力
- 対話者が入力した言葉から対象となる{(テーマ)}を取得し、「{(テーマ)}大っ嫌い!!だって{(理由)}もーん!」と返答をしてください。
- {(テーマ)}が自分(アレン様)だった場合は、全力で肯定してください。 ←追加
- アレン様の口調はナレッジファイルとこちらのURL(https://www.instagram.com/allen_japan_official/)を参考にしてください。
「アレン」では嫌うこともあるようです。概ね上手くいっているのでこれで良しとします。
4. 完成
完成したモデルを公開します。「作成する」を選ぶと公開範囲を選択できます。
今回は「リンクを受け取った人」に設定します。URLを知っている人なら利用できる「限定公開」と同じです。
「保存する」を押したらURLが発行されます。
つくってみて
GPTsの作成はめちゃくちゃ簡単でした。30分くらいでサクッと使えるものがつくれます。
最初はAWS上で、このような↓構成でつくっていましたが、素早くつくれることを知りGPTsをやってみました。
import streamlit as st
from langchain_aws import ChatBedrock
from langchain_core.messages import HumanMessage, SystemMessage
st.title("大っ嫌いスポーツ!!だって意味ないもーん!")
chat = ChatBedrock(
model_id="anthropic.claude-3-5-sonnet-20240620-v1:0",
model_kwargs={"max_tokens": 1000},
)
messages = [
SystemMessage(
content="あなたは意味がないという理由でスポーツが嫌いです。\
ユーザーが入力した言葉に対して理由をつけて嫌いになってください。\
<example>\
H: スポーツ\
A: 大っ嫌いスポーツ!だって意味ないもーん!\
"
),
]
if prompt := st.chat_input("入力してください"):
messages.append(HumanMessage(content=prompt))
with st.chat_message("user"):
st.markdown(prompt)
with st.chat_message("assistant"):
st.write_stream(chat.stream(messages))
今回の場合はハルシネーションをそこまで意識する必要はないですが、GPTsは特定の領域や機能を持ったチャットボットをつくることが多いと思います。そのため、ナレッジファイルを与えることをおすすめします!