ホームページ  >  記事  >  バックエンド開発  >  Amazon Bedrock と Shopify を使用してコーヒーショップエージェントを作成する

Amazon Bedrock と Shopify を使用してコーヒーショップエージェントを作成する

Patricia Arquette
Patricia Arquetteオリジナル
2024-10-30 18:02:31568ブラウズ

今日は、Bedrock を安全かつ確実に使用する方法を説明し、同時にコーヒーについて少し学びます。

Python を使用してテキスト モデルとマルチモーダル モデルの Amazon Bedrock API を使用して、カフェの名前、ロゴ、メニューを生成し、Shopify API に接続して注文を受けるエージェントを作成する方法を学びます。

Shopify は (私の意見では) 存在する中で最高の e コマース プラットフォームです。

AWS と同じように、Shopify にはあらゆるものに対応する API と開発者向けのプラットフォームがあります

最後に、Streamlit を使用してフロントエンドを作成し、独自のユーザー エクスペリエンスを提供し、エージェントに命を吹き込みます。

?索引

  • Bedrock API の呼び出し
  • Shopify と対話する Amazon Bedrock エージェントの作成

? Amazon Bedrock API を呼び出してコーヒーショップの名前、ロゴ、メニューを生成する

カフェテリアをオープンしたり、あらゆるビジネスについて創造的なアイデアを思いついた瞬間は、生成 AI (GenAI) に頼って最大限に活用する絶好の機会です。

Amazon Bedrock を通じて使用できますが...そのサービスはどのように利用されますか?

AWS のすべてのサービスには API があり、Amazon Bedrock も例外ではありません。以下では、外出先でカフェテリアの名前とメニューを生成する例を通じて、Amazon Bedrock API を使用する方法を説明します。

また、画像を分析できるマルチモーダル モデルを使用する方法も示します。

ローカルで実行するか、Amazon Bedrock を呼び出す Lambda 関数内で実行する Python スクリプトをプログラムする手順:

まず、ここで Bedrock 手順のモデルへのアクセスを有効にする必要があります

要件:

  • AWS のアカウント。アカウントをお持ちでない場合は、ここでアカウントを開設できます。
  • AWS CLI の手順はこちら
  • Python 3.11 以降

ステップ 1) 仮想 Python 環境を作成します。手順はこちら

このリポジトリの bedrock_examples フォルダーには、基本モデルを呼び出すために以下で使用されるさまざまな例があります。

プロンプトフォルダーには、プロンプトの例があり、名前、メニュー、および Amazon Bedrock プレイグラウンドとPython から API を呼び出します。

ステップ 2) 要件をインストールします

pip install -r requirements.txt

ステップ 3) Boto3 を構成する boto3 に関する詳細情報

ここでは、コンピューターにインストールされている genaiday プロファイルを使用し、基本モデルを呼び出すことができる bedrock-runtime クライアントを呼び出すように AWS クライアントを設定します。

#Cambiar la region y el perfil de AWS
aws = boto3.session.Session(profile_name='genaiday', region_name=region)
client = aws.client('bedrock-runtime')

ステップ 4) 例: テキスト モデルを呼び出す

この関数はメソッド invoke_model を呼び出し、ユーザーが指定したプロンプトを渡して応答を返します

最も重要な部分は送信されるメッセージです:

pip install -r requirements.txt
#Cambiar la region y el perfil de AWS
aws = boto3.session.Session(profile_name='genaiday', region_name=region)
client = aws.client('bedrock-runtime')

例:

{
                "role": "user",
                "content": [{
                    "type": "text",
                    "text": prompt
                }]
            }

ステップ 5) 例: マルチモーダル モデルを呼び出します。

ここでもプロセスは似ていますが、送信されたファイルの MIME タイプを追加する必要があるだけです。このために、ファイル名に基づいて MIME タイプ
を取得する関数があります。

def call_text(prompt,modelId="anthropic.claude-3-haiku-20240307-v1:0"):
    #esta función es para llamar un modelo de texto
    config = {
        "anthropic_version": "bedrock-2023-05-31",
        "max_tokens": 4096,
        "messages": [
            {
                "role": "user",
                "content": [{
                    "type": "text",
                    "text": prompt
                }]
            }
        ]
    }

    body = json.dumps(config)
    modelId = modelId
    accept = "application/json"
    contentType = "application/json"

    response = client.invoke_model(
        body=body, modelId=modelId, accept=accept, contentType=contentType)
    response_body = json.loads(response.get("body").read())
    results = response_body.get("content")[0].get("text")
    return results

モデルを呼び出すには、メッセージは次のようにする必要があります:

print("Haiku")
print(call_text("Estoy buscando armar un local de café al paso, dame 5 nombres para un local.")

モデルの呼び出しは次のようになります:

def read_mime_type(file_path):
    # Este hack es para versiones de python anteriores a 3.13
    # Esta función lee el mime type de un archivo
    mimetypes.add_type('image/webp', '.webp')
    mime_type = mimetypes.guess_type(file_path)
    return mime_type[0]

例:

 "messages": [
        {
            "role": "user",
            "content": [
                {
                     "type": "image",
                        "source": {
                            "type": "base64",
                            "media_type": read_mime_type(file),
                            "data": base64.b64encode(open(file, "rb").read()).decode("utf-8")
                        }
                },
                {
                    "type": "text",
                    "text": caption
            }]
        }
    ]

? Shopify と対話する Amazon Bedrock エージェントの作成

Amazon Bedrock エージェントを作成するには:

アクセスを有効にして使用したい Bedrock モデルがあることを確認してください。手順はここにあります。この場合は、Claude 3 Haiku と Sonnet を使用します

次に、AWS コンソールで Bedrock エージェントを作成します。

1) Bedrock サービスにアクセスします
2) エージェント
3) エージェントを作成します

Creación de un agente de cafetería con Amazon Bedrock y Shopify

4) エージェントに名前を付けます。この場合は「Pause-Coffee-Agent
」です。 5) 説明はオプションです。
6) 最も重要なステップの 1 つは、エージェントが適切に機能するための基本モデルを選択することです。ユースケースに適した最適なモデルを選択する方法を知りたい場合は、Amazon Bedrock サービスに関するガイドを参照してください。評価 .
7) 次のステップは、モデルをガイドするプロンプトです。ここでは、できるだけ正確に、プロンプト エンジニアとしてのスキルを引き出す必要があります。どこから始めればよいかわからない場合は、このガイドにアクセスすることをお勧めします。使用しているモデルに最適なガイドラインが見つかります。もう 1 つの非常に便利なリソースは、人間コンソールです。

Creación de un agente de cafetería con Amazon Bedrock y Shopify

これはエージェントの例に使用したプロンプトです。モデルは英語でトレーニングされており、トレーニング ソース言語で記述すると誤った動作を回避できる場合があるため、プロンプトは英語で記述することをお勧めします。

def call_multimodal(file,caption,modelId="anthropic.claude-3-haiku-20240307-v1:0"):
    #esta funcion es para llamar a un modelo multimodal con una imagen y un texto
    config = {
    "anthropic_version": "bedrock-2023-05-31",
    "max_tokens": 4096,
    "messages": [
        {
            "role": "user",
            "content": [
                {
                     "type": "image",
                        "source": {
                            "type": "base64",
                            "media_type": read_mime_type(file),
                            "data": base64.b64encode(open(file, "rb").read()).decode("utf-8")
                        }
                },
                {
                    "type": "text",
                    "text": caption
            }]
        }
    ]
    }

    body = json.dumps(config)
    modelId = modelId
    accept = "application/json"
    contentType = "application/json"

    response = client.invoke_model(
    body=body, modelId=modelId, accept=accept, contentType=contentType)
    response_body = json.loads(response.get("body").read())
    results = response_body.get("content")[0].get("text")
    return results

8) 追加の設定。注文を処理するための情報が確実に不足していることを考慮して、エージェントがユーザーからの入力をキャプチャできるようにする必要があります。たとえば、次のとおりです。顧客が希望する製品、名前を尋ねる必要があります。 、とりわけ。

Creación de un agente de cafetería con Amazon Bedrock y Shopify

9) アクション グループ: アクション グループは、エージェントがユーザーを支援できるアクションを定義します。たとえば、次のアクションを持つことができる TakeOrder というアクション グループを定義できます

  • 商品一覧
  • 注文の処理

アクション グループを作成するには、各アクションに必要なものがあります:

  • 名前
  • パラメータ

実行するアクション グループは通常、Lambda 関数を呼び出します。Bedrock からは次のことができます。

  • Bedrock コンソールからラムダ関数を作成します (ラムダ関数のクイック作成を選択します)

Creación de un agente de cafetería con Amazon Bedrock y Shopify

  • ここですでに作成されているラムダ関数を選択します。イベントの内容と各アクション グループの予想される応答の指示が表示されます

Bedrock コンソールから lambda 関数を作成することを選択した場合、関数は基本的なソース コードを使用して Python で作成され、その後、このリポジトリのファイル Agents/action_group/lambda.py で変更する必要があります。エージェントで動作するように変更されたサンプル コードが含まれています。

必要な情報を提供する変数は次のとおりです:

  • function: 呼び出されるアクションの名前です。この例の場合、get_products (製品をリストするため)、place_order (Shopify で注文を生成するため) が可能です
  • parameters: パラメータの辞書です。

次の例では、2 つのアクションがあることがわかります:

Creación de un agente de cafetería con Amazon Bedrock y Shopify

Crear agente Paso 6

  • パラメータを必要としない get_products
  • place_order には 3 つのパラメータがあります:
Parametro Descripcion Tipo Obligatorio
customerEmail Email of the customer string False
customerName Name of the customer string True
products SKUs and quantities to add to the cart in the format [{ variantId: variantId, quantity: QUANTITY }] array True

たとえば、ラムダ関数で get_products 関数を呼び出すと、次のように処理されます。

Shopify API のクエリを担当する get_products 関数が定義されています (教育目的のため、すべての商品を返します)

これを Shopify で機能させたい場合は、次の変数をストアの変数に置き換える必要があります:

pip install -r requirements.txt
#Cambiar la region y el perfil de AWS
aws = boto3.session.Session(profile_name='genaiday', region_name=region)
client = aws.client('bedrock-runtime')

その後、ラムダ関数のハンドラーで、呼び出された関数の名前が検証され、action_group が必要とする形式で応答が返されます。

{
                "role": "user",
                "content": [{
                    "type": "text",
                    "text": prompt
                }]
            }

上記のコード スニペットは、ここにあるラムダ関数の一部です

10) [保存して終了] を押すと、エージェントをテストする準備が整います。

アクション中のエージェント

次は、エージェントをテストして動作することを検証します。Bedrock からエージェントをテストできます。会話中に [トレースを表示] または [トレースを表示] をクリックすると、推論プロセスが表示されます。特に注意して、プロンプトで必要と思われる調整を行うか、選択したモデルが期待どおりに動作しない場合は別のモデルを探す必要があります。

エージェントに満足したら、エイリアスを作成できます。エイリアスは、Amazon Bedrock API からエージェントを呼び出すことができる ID です。エイリアスを作成すると、次のバージョンが作成されます。エージェントを自動的に指定することも、既存のバージョンを指定することもできます。異なるエイリアスと異なるバージョンを使用すると、エージェントの展開プロセスを制御するのに役立ちます。次に例を示します。

  • 最新のエージェント テストに使用するエイリアス「開発」を作成できます
  • 実稼働前モードのエージェントとなる「preprod」エイリアス
  • エイリアス「prod」で、これがライブ エージェントです。

あとは、ライブにしたいバージョンに対応するプロダクションエイリアスを書き留めるだけです。

エージェントの呼び出し方法

このために、agents/frontend フォルダーに、agent.py というファイルを残しました。

この開発では、サンプル機械学習アプリケーションを作成するための強力なフレームワークである Streamlit を使用します

エージェントを呼び出すコードの部分は次のとおりです:

def call_text(prompt,modelId="anthropic.claude-3-haiku-20240307-v1:0"):
    #esta función es para llamar un modelo de texto
    config = {
        "anthropic_version": "bedrock-2023-05-31",
        "max_tokens": 4096,
        "messages": [
            {
                "role": "user",
                "content": [{
                    "type": "text",
                    "text": prompt
                }]
            }
        ]
    }

    body = json.dumps(config)
    modelId = modelId
    accept = "application/json"
    contentType = "application/json"

    response = client.invoke_model(
        body=body, modelId=modelId, accept=accept, contentType=contentType)
    response_body = json.loads(response.get("body").read())
    results = response_body.get("content")[0].get("text")
    return results

boto3 を使用して AWS API を使用し、bedrock-agent-runtime クライアントを呼び出してエージェントを呼び出せるようにします。

それに渡す必要があるパラメータは次のとおりです:

  • エージェントID
  • エージェントエイリアス ID
  • inputText (プロンプト)
  • sessionId (会話を識別するためのセッション)

この例では、次の変数を定義しています:

print("Haiku")
print(call_text("Estoy buscando armar un local de café al paso, dame 5 nombres para un local.")

施設:

まず、ここで Bedrock 手順のモデルへのアクセスを有効にする必要があります

要件:

  • AWS CLI の手順はこちら
  • Python 3.11 以降

仮想 Python 環境を作成することをお勧めします。手順はこちら

pip install -r requirements.txt

実行

#Cambiar la region y el perfil de AWS
aws = boto3.session.Session(profile_name='genaiday', region_name=region)
client = aws.client('bedrock-runtime')

これにより、ポート 8501 で streamlit の実行が開始され、次の URL: http://localhost:8501/ にアクセスして、エージェントを呼び出すフロントエンドを確認できます

Creación de un agente de cafetería con Amazon Bedrock y Shopify

結論

すべての手順を実行した場合:

  • Bedrock Playground および Python から Amazon Bedrock API を使用しました
  • 基本的なテキストとマルチモーダル モデルを呼び出しました
  • Shopify API を使用するエージェントを最初から作成しました

GenerativeAI 内のパスをたどるためのいくつかのリンク

AWS 生成 AI ワークショップ
基礎知識ベース
Anthropic Console (プロンプトをデバッグするため)
Community.aws (コミュニティによって、コミュニティのために生成されたその他の記事)

以上がAmazon Bedrock と Shopify を使用してコーヒーショップエージェントを作成するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。