レッスン 2:フローの頭と尾(開始ノードと出力ノード)¶
Note: ⚠️ このドキュメントはAIによって自動翻訳されています。不正確な部分がある場合は、英語版を参照してください。
前回のレッスンでは、ワークフローをレシピに例えました。今日は実際にキッチンに入り、材料の下ごしらえ(開始)とお皿の準備(出力)をしていきましょう。
アプリを作成する¶
空白から作成¶
画面上部の**スタジオ**をクリックします。左側のアプリ作成メニューから、**空白から作成**をクリックします。

アプリタイプを設定¶
アプリタイプとして**ワークフロー**を選択し、**アプリ名とアイコン**を入力して、**作成**をクリックします。

開始ノードのタイプを選択¶
ポップアップウィンドウが表示されます。ここには、アプリの実行方法を決める2つのオプションがあります。
- **ユーザー入力**
これは**手動モード**です。あなた(ユーザー)がチャットボックスに何かを入力したときにのみ、ワークフローが動き始めます。
適した用途:ほとんどのAIアプリ。例えば、チャットボット、文章作成アシスタント、翻訳など。
- **トリガー**
これは**自動モード**です。特定のシグナル(毎朝8時、特定のイベントなど)に基づいて自動的に実行されます。
適した用途:特定の時間に繰り返し実行するタスクや、別のタスクが完了した後にこのワークフローを実行する場合。例えば、毎日のニュースまとめなど。

オーケストレーションキャンバスを知ろう¶
開始ノードを選択すると、大きな空白のエリアが表示されます。これがオーケストレーションキャンバスです。ここでワークフローを設計し、構築し、テストしていきます。

レッスン1で学んだノードを覚えていますか?今キャンバスに表示されているユーザー入力ノードが、すべての出発点です。
すべての完全なワークフローは、基本的な骨格に支えられています。それが開始ノード(頭)と出力ノード(尾)です。
開始ノード¶

開始ノードは、ワークフロー全体の唯一の入口です。料理でいう材料の下ごしらえのステップのようなものです。ワークフローが動き始めるために、ユーザーからどんな情報を受け取る必要があるかを定義する役割を持っています。
先ほど、ユーザー入力を開始ノードとして選択しました。
コアコンセプト:変数¶
開始ノードの中に、変数という言葉が出てきます。難しく考えなくて大丈夫です!変数とは、ラベルが貼られた収納ボックスのようなものです。
それぞれのボックスは、特定の種類の情報を入れるために用意されています。
例えば、旅行プランナーを作る場合、ユーザーに Destination(目的地)と Travel Days(旅行日数)の2つの情報を提供してもらう必要があります。
ユーザーAは日本に5日間行きたいかもしれません。ユーザーBはパリに3日間行きたいかもしれません。
ユーザーごとに入力する内容は異なるので、アプリが実行されるたびに、これらのボックスの中身は変わります。
これが変数の意味です。ユーザーが埋めるための枠を用意しておくことで、ワークフローが毎回異なるリクエストに柔軟に対応できるようになります。
終了ノード(出力)¶

これはワークフローのゴールです。料理でいう盛り付けのステップで、最終的にユーザーが目にする結果を定義します。
例えば、先ほどの旅行プランナーを思い出してください。ユーザーがユーザー入力ノードで目的地:パリ、期間:5日間と入力した場合、出力ノードでシステムが最終結果を返します:「こちらがパリ5日間の旅行プランです。」
まとめると、開始ノードと終了ノードが基本的な入力と出力を定義し、アプリの骨格を形作ります。
ハンズオン実践:AIメールアシスタントを作ろう¶
メール作成を手伝ってくれるAIアシスタントの基本的なフレームワークを構築しましょう。
アプリを作成¶
以下のどちらかを選べます:
- 先ほど開いたキャンバスでそのまま続ける
- スタジオに戻り、空白から作成 → ワークフローを選択して、*メールアシスタント*と名前を付ける(ポップアップで**ユーザー入力**を選択するのを忘れずに!)
開始ノードを設定する(材料の準備)¶
AIにメールの返信を手伝ってもらうには、どんな情報を渡す必要があるでしょうか?
そうです。通常は、顧客の名前とメールの原文です。
1. **開始**ノードをクリックします。右側のパネルで**入力フィールド**を探し、**\+** ボタンをクリックします。

2. ポップアップで、2つの変数(2つの収納ボックス)を作成します:
**変数 1(顧客名用)**

- フィールドタイプ:テキスト(短文テキスト)
- 変数名:`customer_name`
- 表示名:顧客名
- その他のオプションはデフォルトのままにします
**変数 2(メール内容用)**

- フィールドタイプ:ドロップダウンをクリックして**段落**を選択します(メールは通常長いため、段落ボックスの方が大きく、より多くのテキストを入力できます)
- 変数名:`email_content`
- 表示名:メール原文
- 最大長:長いメールに対応できるよう、手動で **2000** に変更します
Tip:
**変数名 vs 表示名**
2つの名前を入力したことに気づいたかもしれません。それぞれの違いは何でしょうか?
- **変数名**:これはシステム用のIDです。一意であること、英字を使用すること、スペースを含まないことが必要です。
- **表示名**:これはユーザー向けのラベルです。日本語など、どの言語でも名前を付けることができます。画面上に表示されます。
終了ノードを作成する(ゴールを設定)¶
キャンバスの空白部分を右クリックします。**ノードを追加**を選択し、一覧から**出力**を選択します。

キャンバスの状態を確認しましょう。名前とメールを受け取る準備ができた開始ノードと、最終結果を送る出力ノードがあります。

ワークフローの基本フレームが完成しました。真ん中の空白スペースは、次のレッスンでLLM(AIの頭脳)ノードを配置して情報を処理する場所です。
ミニチャレンジ¶
課題:旅行プラン生成器を作るとしたら、開始ノードにはどのような変数を含めるべきでしょうか?
Tip:
変数を追加のフィールドタイプを探索してみてください。