Transcript
00:00:00最近のAI機能やアプリはどれも同じ問題を抱えています。見た目はいいのですが、実態はただのチャットボックスです。
00:00:06画面の端に貼り付けられたような存在です。何か尋ねれば、マークダウンや、もしかすると表を表示してくれて、
00:00:11あなたがすべき作業を説明する段落がいくつか添えられる程度。でも、もしエージェントが
00:00:17ただ会話するだけじゃなかったら?これがCopilotKitです。本物のコンポーネントを描画し、アプリとライブ状態を共有し、
00:00:23変更を加える前に確認を求めることもできます。これならAI機能が
00:00:29製品の一部のように感じられるはずです。確かめてみましょう。
00:00:37まず、多くの人がアプリにAIを追加しているつもりで、実際には
00:00:43アプリの中に「もう一つのアプリ」を追加してしまっています。製品はあちら、AIはこちら、という状態で、ユーザーは
00:00:49頭の中でコンテキストをコピーし合う必要があります。単純なQ&A構造だけが必要なら
00:00:54それでもいいのですが、エージェントに状態の更新をさせたり、
00:01:00ツールを呼び出させたり、実際のワークフローの中でユーザーと連携させようとすると、壁にぶつかります。今や
00:01:07ストリーミングイベント、状態同期、承認フローなどを実装することになり、誰もが同じようなものを
00:01:14少しずつ形を変えて再開発しています。CopilotKitが狙っているのは、単なるチャットボット作りではなく、
00:01:20いかにしてエージェントをアプリ自体にネイティブな感覚で組み込むかという点です。デモから始めましょう。その後で、
00:01:26何が本物で、何が有用で、何がやりすぎなのかを分析します。コーディングツールを使って
00:01:32ワークフローを効率化したいなら、ぜひチャンネル登録してください。動画をどんどん出しています。よし、それでは
00:01:37これを見てください。クリーンなターミナルから始めて、CopilotKitから取得したインストールコマンドを実行します。
00:01:42これでアプリの骨組みができ、作業の出発点として機能します。空っぽのチャットの吹き出しではなく、
00:01:49実用的な要素が既にフロントエンドとして連携されており、
00:01:56実際に作りたい体験をすぐにテストできます。開発モードを
00:02:02実行すると、ローカルでアプリが立ち上がります。もちろん、この部分は見慣れたチャットインターフェースですが、
00:02:09ここからが本当の面白さです。エージェントが
00:02:13UIと接続されるとどうなるか。インターフェースで質問をしてみます。さあ、どうなるでしょう。
00:02:21注目してほしいのは、エージェントが単なるテキストの塊で返答するのではなく、
00:02:26応答をストリーミングし、ツールを呼び出し、アプリ内で実際のコンポーネントをレンダリングできるという点です。CopilotKitにおける
00:02:32最大の変化は、AIがインターフェースを記述するだけでなく、
00:02:38その構成要素の一部になったということです。もう一歩踏み込んで、フォローアップの質問をしてみます。
00:02:46さて、ここが他のエージェントが飛ばしがちな部分です。エージェントが一時停止し、
00:02:52承認を求めてきました。この「承認を求める」プロセスこそが重要で、私が非常に気に入っている点です。なぜなら、
00:02:57実際のソフトウェアにおいて、操作権限は妥協できないからです。ユーザーには最終的な判断力が必要です。
00:03:03素晴らしいデモでしょう?CopilotKitを簡単に説明すると、
00:03:09エージェント主導型アプリのためのフロントエンドスタックです。単なるチャットコンポーネントでも、
00:03:15LLM APIのラッパーでもありません。製品内部に息づくAI体験のために必要なピースを提供してくれるものです。
00:03:23理解しておくべき要素が4つあります。まずは「AGUI」。AGUIはオープンなイベントベースのプロトコルで、
00:03:31エージェントがフロントエンドと対話するための仕組みです。現在のエージェントツールは接続の問題を抱えています。LangGraph、
00:03:37CrewAI、独自のカスタムエージェント、そして今朝発表された新しいフレームワークを
00:03:43アプリに導入しようとすると、Reactアプリやモバイルアプリ、ダッシュボードなど、
00:03:48膨大な要素を調整しなければなりません。しかも、共通のプロトコルがないまま、
00:03:55すべてのバックエンドがフロントエンドごとにカスタムコードを書いています。AGUIは、エージェントとインターフェースの間で
00:04:01共通言語になることを目指しています。メッセージ、状態更新、ツール呼び出し、UIイベントなどが、
00:04:07共通のイベントストリームを通ります。次は「生成UI」。モデルがテキストを返すだけではなく、エージェントが
00:04:14実際のコンポーネントをトリガーできます。単なるHTMLではなく、必要な瞬間にUIをレンダリングするのです。次に
00:04:22「共有状態」、またはCopilotKitが「Co-agents」と呼ぶもの。フロントエンドとエージェントバックエンドで、双方向に
00:04:29状態を共有できます。ユーザーが何かを変更すればエージェントが反応し、エージェントが更新すればUIに
00:04:35反映されます。これは、ユーザーとエージェントが同じ対象を操作するツールやダッシュボードを構築する上で、非常に強力です。
00:04:41最後に、「Human-in-the-loop(人間による監視)」です。これは、
00:04:47非常に重要な要素です。多くのエージェントデモは、完全な自律性こそが最高の体験であるかのように見せますが、
00:04:52実際は必ずしもそうではありません。現実の製品において、ユーザーは権力と
00:04:59制御を求めています。「送信前に確認」「作成前に承認」「選択肢から選ぶ」といったことが必要で、CopilotKitは
00:05:05まさにそれを実現するための機能を提供します。もちろん、CopilotKitが万人に最適とは限りません。
00:05:10Vercel AI SDKのようなものと比較すると、CopilotKitはより「バッテリー付属(多機能)」な選択肢です。ストリーミングチャット、
00:05:17生成UI、共有状態、人間による承認パターンなどが標準で備わっており、
00:05:23製品レイヤーに近づけてくれるものです。Vercel AI SDKはより軽量で、
00:05:31低レベルな制御ができるため、アーキテクチャ全体を自分で管理したい場合は、そちらの方が遥かに適しています。
00:05:38すべてを自分でゼロから構築するのと比較すると、CopilotKitの価値は明らかです。
00:05:43なぜなら、チャットの吹き出しをレンダリングするのは今や簡単な部分であり、難しいのは
00:05:49その周辺のすべてだからです。もちろんトレードオフもあります。最小限のAI SDKに比べると
00:05:54重く感じられることもありますし、CopilotKitのパターンに適応する必要もあります。また、個人開発では無料で
00:06:02利用できて非常にクールですが、スケールさせて使おうとすると、
00:06:08すべてが無料というわけにはいかなくなります。もしこれに代わる完全な
00:06:14オープンソースの代替手段を知っているなら、コメントで教えてください。私はまさにそれを探しています。
00:06:19CopilotKitを使うなら、何がオープンソースで、何に鍵が必要で、
00:06:25何がホストされ、何が有料なのかを理解する必要があります。これはCopilotKitを批判しているのではなく、
00:06:32無料のものとそうでないものを理解しておく必要があるということです。単純なサポートボットが必要なだけなら、CopilotKitは恐らく
00:06:38過剰です。しかし、エージェントがアプリの状態を考慮してUIと連携するようなUXを作りたいなら、
00:06:44非常に素晴らしいツールです。使ってみるべきでしょうか?
00:06:50本格的なアプリ内AIを構築していて、特にReactやNext.jsを使っていて、AIを
00:06:56サイドパネルとしてではなく、製品の一部のように感じさせたいのであれば、これは本当にクールな選択肢です。素早く
00:07:02立ち上げられますし、豊富なコンポーネントが用意されているので、ワークフローに組み込むのも非常に現実的です。もしあなたが
00:07:07既に独自のストリーミング、状態管理、ツール呼び出し、UI切り替えのシステムを構築しているなら、乗り換える価値はないかもしれません。
00:07:13もし機能が「質問して回答を得る」だけなら、CopilotKitでは過剰すぎて
00:07:19能力を持て余すでしょう。より軽量なものを使って、さっさと
00:07:25実装を進めてください。このようなコーディングツールを楽しんでいるなら、Better Stackチャンネルを登録してください。
00:07:30また別の動画でお会いしましょう。
Community Posts
No posts yet. Be the first to write about this video!
Write about this video