> ## Documentation Index
> Fetch the complete documentation index at: https://wb-21fd5541-docs-sandboxes-integrations-placement.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# クラス: LLM

> TypeScript SDK リファレンス

[weave](../) / LLM

LLM の Call です。`gen_ai.*` 属性を持つ `chat` span を生成します。

`weave.startLLM()` (または `turn.startLLM()`) で作成され、
`end()` で終了します。async コンテキストごとに一度にアクティブにできる LLM は 1 つだけです。`startTool` / `startSubagent` を使用して、その配下に
tool/subagent の Call をネストしてください。

`inputMessages` / `outputMessages` / `usage` / `reasoning` には、値を直接設定するか、
ヘルパー関数 (`output`、`think`、`attachMedia`、`record`) を使用して設定します。

記録されたすべてのデータは、`end()` 時に span にフラッシュされます。

`Example`

```ts theme={null}
const llm = weave.startLLM({model: 'gpt-4o-mini', providerName: 'openai'});
try {
  llm.inputMessages = [{role: 'user', content: prompt}];
  const resp = await openai.chat.completions.create({...});
  llm.output(resp.choices[0].message.content ?? '');
  llm.record({usage: {inputTokens: resp.usage?.prompt_tokens}});
} finally {
  llm.end();
}
```

<div id="table-of-contents">
  ## 目次
</div>

<div id="properties">
  ### プロパティ
</div>

* [inputMessages](./llm#inputmessages)
* [model](./llm#model)
* [outputMessages](./llm#outputmessages)
* [providerName](./llm#providername)
* [reasoning](./llm#reasoning)
* [usage](./llm#usage)

<div id="methods">
  ### メソッド
</div>

* [attachMedia](./llm#attachmedia)
* [attachMediaUrl](./llm#attachmediaurl)
* [end](./llm#end)
* [output](./llm#output)
* [record](./llm#record)
* [startSubagent](./llm#startsubagent)
* [startTool](./llm#starttool)
* [think](./llm#think)
* [create](./llm#create)

## プロパティ

<div id="inputmessages">
  ### inputMessages
</div>

• **inputMessages**: [`Message`](../interfaces/message)\[] = `[]`

モデルに送信される入力メッセージです。`end()` の際に
`gen_ai.input.messages` に書き出されます。

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:78](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L78)

***

<div id="model">
  ### model
</div>

• `Readonly` **model**: `string`

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:98](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L98)

***

<div id="outputmessages">
  ### outputMessages
</div>

• **outputMessages**: [`Message`](../interfaces/message)\[] = `[]`

モデルから返されるアシスタント メッセージです。`end()` の呼び出し時に
`gen_ai.output.messages` にフラッシュされます。

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:83](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L83)

***

<div id="providername">
  ### providerName
</div>

• `Readonly` **providerName**: `string`

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:99](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L99)

***

<div id="reasoning">
  ### reasoning
</div>

• `Optional` **reasoning**: [`Reasoning`](../interfaces/reasoning)

推論の内容です。シリアル化時に、`ReasoningPart` として最後の assistant メッセージに組み込まれます。

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:90](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L90)

***

<div id="usage">
  ### usage
</div>

• **usage**: [`Usage`](../interfaces/usage) = `{}`

トークン数とキャッシュの統計情報。`end()` で `gen_ai.usage.*` にフラッシュされます。

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:85](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L85)

## メソッド

<div id="attachmedia">
  ### attachMedia
</div>

▸ **attachMedia**(`opts`): `this`

最後の入力メッセージにメディアパートを追加します。`content` (インラインの base64 エンコード済みバイト列) 、`uri` (URI reference) 、または `fileId`
(事前にアップロードされた file ID) のうち、指定できるのは 1 つだけです。

<div id="parameters">
  #### パラメーター
</div>

| 名      | タイプ               |
| :----- | :---------------- |
| `opts` | `AttachMediaOpts` |

<div id="returns">
  #### 戻り値
</div>

`this`

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:168](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L168)

***

<div id="attachmediaurl">
  ### attachMediaUrl
</div>

▸ **attachMediaUrl**(`url`, `opts`): `this`

`attachMedia({uri, modality})` の便利なショートカットです。

<div id="parameters">
  #### パラメーター
</div>

| 名               | タイプ                        |
| :-------------- | :------------------------- |
| `url`           | `string`                   |
| `opts`          | `Object`                   |
| `opts.modality` | [`Modality`](../#modality) |

<div id="returns">
  #### 戻り値
</div>

`this`

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:186](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L186)

***

<div id="end">
  ### end
</div>

▸ **end**(`opts?`): `void`

蓄積された状態を span にフラッシュして閉じます。冪等です。span を失敗としてマークするには、`error` を渡します。

<div id="parameters">
  #### パラメーター
</div>

| 名             | タイプ      |
| :------------ | :------- |
| `opts?`       | `Object` |
| `opts.error?` | `Error`  |

<div id="returns">
  #### 戻り値
</div>

`void`

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:246](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L246)

***

<div id="output">
  ### output
</div>

▸ **output**(`content`): `this`

レスポンスにアシスタント メッセージを追加します。

<div id="parameters">
  #### パラメーター
</div>

| 名         | タイプ      |
| :-------- | :------- |
| `content` | `string` |

<div id="returns">
  #### 戻り値
</div>

`this`

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:141](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L141)

***

<div id="record">
  ### record
</div>

▸ **record**(`opts`): `this`

変更可能なフィールドの任意の部分集合を一括で設定します。マージではなく、置き換えです。
プロバイダの呼び出し結果が返された後に、すべてをまとめて設定する場合に便利です。

<div id="parameters">
  #### パラメーター
</div>

| 名      | タイプ             |
| :----- | :-------------- |
| `opts` | `LLMRecordOpts` |

<div id="returns">
  #### 戻り値
</div>

`this`

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:197](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L197)

***

<div id="startsubagent">
  ### startSubagent
</div>

▸ **startSubagent**(`opts`): [`SubAgent`](./subagent)

この LLM の配下にネストされた子 SubAgent spanを開始します。

<div id="parameters">
  #### パラメーター
</div>

| 名      | タイプ                                          |
| :----- | :------------------------------------------- |
| `opts` | [`SubAgentInit`](../interfaces/subagentinit) |

<div id="returns">
  #### 戻り値
</div>

[`SubAgent`](./subagent)

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:230](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L230)

***

<div id="starttool">
  ### startTool
</div>

▸ **startTool**(`opts`): [`Tool`](./tool)

この LLM の子としてネストされた Tool span を開始します。

<div id="parameters">
  #### パラメーター
</div>

| 名      | タイプ                                  |
| :----- | :----------------------------------- |
| `opts` | [`ToolInit`](../interfaces/toolinit) |

<div id="returns">
  #### 戻り値
</div>

[`Tool`](./tool)

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:221](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L221)

***

<div id="think">
  ### think
</div>

▸ **think**(`content`): `this`

モデルの推論/chain-of-thought の内容を設定または追加します。内容は `this.reasoning.content` に蓄積され、シリアル化時に `ReasoningPart` として最後のアシスタント メッセージに組み込まれます。これは Python SDK の on-the-wire 形式と一致します。

<div id="parameters">
  #### パラメーター
</div>

| 名         | タイプ      |
| :-------- | :------- |
| `content` | `string` |

<div id="returns">
  #### 戻り値
</div>

`this`

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:153](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L153)

***

<div id="create">
  ### create
</div>

▸ **create**(`opts`): [`LLM`](./llm)

<div id="parameters">
  #### パラメーター
</div>

| 名      | タイプ                                                     |
| :----- | :------------------------------------------------------ |
| `opts` | [`LLMInit`](../interfaces/llminit) & `ChildSpanContext` |

<div id="returns">
  #### 戻り値
</div>

[`LLM`](./llm)

<div id="defined-in">
  #### 定義元
</div>

[genai/llm.ts:102](https://github.com/wandb/weave/blob/6538626556c93d6f31ae725fdefe4e6b8b71bc2c/sdks/node/src/genai/llm.ts#L102)
