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 にはごく小さな基本コンポーネントが用意されています。
- エージェント: instructions とツールを備えた LLM
- ハンドオフ: 特定タスクを他のエージェントへ委任
- ガードレール: エージェントへの入力を検証
これらのプリミティブは、 TypeScript と組み合わせることでツールとエージェント間の複雑な関係を表現でき、急な学習コストなしに実運用レベルのアプリを構築できます。さらに SDK には組み込み トレーシング があり、エージェントフローの可視化やデバッグ、評価、さらにはモデルのファインチューニングまで行えます。
Agents SDK を使用する理由
Section titled “Agents SDK を使用する理由”SDK には次の 2 つの設計原則があります。
- 十分に使う価値がある機能を備えつつ、学習が容易な最小限のプリミティブ
- デフォルトで高い使いやすさを提供しつつ、処理内容を細かくカスタマイズ可能
主な機能は以下のとおりです。
- エージェントループ: ツール呼び出し、結果の LLM への送信、LLM が完了するまでのループ処理を自動で実行
- TypeScript ファースト: 新しい抽象化を学ばずに、言語機能だけでエージェントのオーケストレーションやチェーン化が可能
- ハンドオフ: 複数エージェント間の協調・委任を行う強力な機能
- ガードレール: 入力検証をエージェントと並行して実行し、失敗時は早期終了
- 関数ツール: 任意の TypeScript 関数を自動スキーマ生成と Zod ベースの検証付きツールに変換
- トレーシング: ワークフローの可視化・デバッグ・モニタリングに加え、OpenAI の評価・ファインチューニング・蒸留ツールを利用可能
- Realtime Agents: 自動割り込み検知、コンテキスト管理、ガードレールなどを備えた高機能な音声エージェントを構築
インストール
Section titled “インストール”npm install @openai/agents
Hello 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-...