メインコンテンツへスキップ
Track LLM inputs & outputs チュートリアルでは、 LLM の入力と出力を記録する基礎について説明しました。 このチュートリアルでは、以下の方法を学びます:
  • アプリケーションを流れる データ を追跡する
  • 呼び出し時に メタデータ を追跡する

ネストされた関数呼び出しの追跡

LLM を活用した アプリケーション には、複数の LLM 呼び出しや、監視が重要な追加の データ プロセッシング およびバリデーションロジックが含まれることがよくあります。多くのアプリで一般的な深くネストされた呼び出し構造であっても、追跡したいすべての関数に weave.op() を追加するだけで、 Weave はネストされた関数内の親子関係を維持します。 クイックスタート の例 をベースに、次の コード では LLM から返されたアイテムをカウントし、それらを上位レベルの関数でラップするロジックを追加しています。さらに、この例では weave.op() を使用して、すべての関数、その呼び出し順序、および親子関係をトレースしています。
import weave
import json
from openai import OpenAI

client = OpenAI()

@weave.op()
def extract_dinos(sentence: str) -> dict:
    response = client.chat.completions.create(
        model="gpt-4o",
        messages=[
            {
                "role": "system",
                "content": """Extract any dinosaur `name`, their `common_name`, \
names and whether its `diet` is a herbivore or carnivore, in JSON format."""
            },
            {
                "role": "user",
                "content": sentence
            }
            ],
            response_format={ "type": "json_object" }
        )
    return response.choices[0].message.content

@weave.op()
def count_dinos(dino_data: dict) -> int:
    # 返されたリスト内のアイテム数をカウントする
    k = list(dino_data.keys())[0]
    return len(dino_data[k])

@weave.op()
def dino_tracker(sentence: str) -> dict:
    # LLM を使用して恐竜を抽出する
    dino_data = extract_dinos(sentence)

    # 返された恐竜の数をカウントする
    dino_data = json.loads(dino_data)
    n_dinos = count_dinos(dino_data)
    return {"n_dinosaurs": n_dinos, "dinosaurs": dino_data}

weave.init('jurassic-park')

sentence = """I watched as a Tyrannosaurus rex (T. rex) chased after a Triceratops (Trike), \
both carnivore and herbivore locked in an ancient dance. Meanwhile, a gentle giant \
Brachiosaurus (Brachi) calmly munched on treetops, blissfully unaware of the chaos below."""

result = dino_tracker(sentence)
print(result)
ネストされた関数上記の コード を実行すると、2つのネストされた関数( extract_dinoscount_dinos )からの入力と出力、および自動的に ログ 記録された OpenAI のトレースが表示されます。Nested Weave Trace

メタデータの追跡

weave.attributes コンテキストマネージャーを使用し、呼び出し時に追跡する メタデータ の 辞書 を渡すことで、 メタデータ を追跡できます。 上記の例の続きです:
import weave

weave.init('jurassic-park')

sentence = """I watched as a Tyrannosaurus rex (T. rex) chased after a Triceratops (Trike), \
both carnivore and herbivore locked in an ancient dance. Meanwhile, a gentle giant \
Brachiosaurus (Brachi) calmly munched on treetops, blissfully unaware of the chaos below."""

# 以前に定義した関数とともにメタデータを追跡する
with weave.attributes({'user_id': 'lukas', 'env': 'production'}):
    result = dino_tracker(sentence)
ユーザー ID や コード の 環境 ステータス(開発、ステージング、 プロダクション など)、実行時の メタデータ を追跡することをお勧めします。システムプロンプトなどの システム 設定 を追跡するには、 Weave Models の使用をお勧めします。

次のステップ

  • App Versioning チュートリアル に従って、アドホックなプロンプト、 モデル 、 アプリケーション の変更をキャプチャ、 バージョン管理 、整理する方法を確認してください。