OpenAI Agents SDK TypeScript
import { Agent, run } from '@openai/agents';
const agent = new Agent({ name: 'Assistant', instructions: 'You are a helpful assistant.',});
const result = await run( agent, 'Write a haiku about recursion in programming.',);
console.log(result.finalOutput);import { RealtimeAgent, RealtimeSession } from '@openai/agents/realtime';
const agent = new RealtimeAgent({ name: 'Assistant', instructions: 'You are a helpful assistant.',});
// Automatically connects your microphone and audio output in the browser via WebRTC.const session = new RealtimeSession(agent);await session.connect({ apiKey: '<client-api-key>',});OpenAI Agents SDK for TypeScript は、抽象化を最小限に抑えた軽量で使いやすいパッケージで、エージェント型の AI アプリを構築できます。これは、以前のエージェント向け実験である Swarm の本番利用可能なアップグレードで、Python 版 もあります。Agents SDK の基本的な構成要素(basic components)は非常に少数です。
- エージェント: instructions と tools を備えた LLM
- ハンドオフ: 特定のタスクを他のエージェントに委任するしくみ
- ガードレール: エージェントへの入力を検証するしくみ
TypeScript と組み合わせることで、これらの基本的な構成要素はツールとエージェント間の複雑な関係を表現でき、急な学習コストなしに実アプリケーションを構築できます。さらに、SDK には組み込みの トレーシング があり、エージェントのフローを可視化・デバッグできるほか、評価したり、アプリケーション向けにモデルのファインチューニングまで行えます。
Agents SDK を使う理由
Section titled “Agents SDK を使う理由”SDK の設計原則は 2 つあります。
- 使う価値のある十分な機能を持ちながら、学習を素早くするための少数の基本的な構成要素に絞ること
- すぐに使えて素晴らしく動作しつつ、挙動を細部までカスタマイズできること
主な機能は次のとおりです。
- エージェントループ: ツールの呼び出し、結果の LLM への送信、LLM が完了するまでのループ処理を内蔵
- TypeScript ファースト: 新しい抽象化を学ぶのではなく、言語の機能でエージェントをオーケストレーション・連携
- ハンドオフ: 複数エージェント間の調整や委任を可能にする強力な機能
- ガードレール: エージェントと並行して入力の検証やチェックを実行し、失敗時は早期に停止
- 関数ツール: 任意の TypeScript 関数をツール化し、スキーマ自動生成と Zod によるバリデーションを提供
- トレーシング: ワークフローを可視化・デバッグ・監視でき、OpenAI の評価、ファインチューニング、蒸留ツールも活用可能
- リアルタイムエージェント: 自動割り込み検知、コンテキスト管理、ガードレールなどを備えた強力な音声エージェントを構築
インストール
Section titled “インストール”npm install @openai/agents zod@3Hello World のコード例
Section titled “Hello World のコード例”import { Agent, run } from '@openai/agents';
const agent = new Agent({ name: 'Assistant', instructions: 'You are a helpful assistant',});
const result = await run( agent, 'Write a haiku about recursion in programming.',);console.log(result.finalOutput);
// Code within the code,// Functions calling themselves,// Infinite loop's dance.(実行する場合は、OPENAI_API_KEY 環境変数を設定してください)
export OPENAI_API_KEY=sk-...