Tools
思考レベル
機能
- 任意の受信本文内のインラインディレクティブ:
/t <level>、/think:<level>、または/thinking <level>。 - レベル(エイリアス):
off | minimal | low | medium | high | xhigh | adaptive | max- minimal → "think"
- low → "think hard"
- medium → "think harder"
- high → "ultrathink"(最大予算)
- xhigh → "ultrathink+"(GPT-5.2+ と Codex モデル、および Anthropic Claude Opus 4.7+ effort)
- adaptive → プロバイダー管理の adaptive thinking(Anthropic/Bedrock の Claude 4.6、Anthropic Claude Opus 4.7+、および Google Gemini dynamic thinking で対応)
- max → プロバイダー最大推論(Anthropic Claude Opus 4.7+。Ollama はこれをネイティブの最高
thinkeffort にマップ) x-high、x_high、extra-high、extra high、extra_highはxhighにマップされます。highestはhighにマップされます。
- プロバイダーメモ:
- Thinking メニューとピッカーはプロバイダープロファイル駆動です。プロバイダー Plugin は、バイナリの
onなどのラベルを含め、選択したモデルの正確なレベルセットを宣言します。 adaptive、xhigh、maxは、それらをサポートするプロバイダー/モデルプロファイルでのみ表示されます。未対応レベルの型付きディレクティブは、そのモデルの有効な選択肢とともに拒否されます。- 既存の保存済み未対応レベルは、プロバイダープロファイルのランクにより再マップされます。
adaptiveは非 adaptive モデルではmediumにフォールバックし、xhighとmaxは選択したモデルでサポートされる最大の非 off レベルにフォールバックします。 - Anthropic Claude 4.6 モデルは、明示的な thinking レベルが設定されていない場合、デフォルトで
adaptiveになります。 - Anthropic Claude Opus 4.8 と Opus 4.7 は、thinking レベルを明示的に設定しない限り thinking を off のままにします。Opus 4.8 のプロバイダー所有 effort デフォルトは、adaptive thinking が有効になった後は
highです。 - Anthropic Claude Opus 4.7+ は
/think xhighを adaptive thinking とoutput_config.effort: "xhigh"にマップします。これは/thinkが thinking ディレクティブで、xhighが Opus の effort 設定であるためです。 - Anthropic Claude Opus 4.7+ は
/think maxも公開します。これは同じプロバイダー所有の max effort パスにマップされます。 - 直接の DeepSeek V4 モデルは
/think xhigh|maxを公開します。どちらも DeepSeekreasoning_effort: "max"にマップされ、より低い非 off レベルはhighにマップされます。 - OpenRouter 経由の DeepSeek V4 モデルは
/think xhighを公開し、DeepSeek ネイティブのトップレベルreasoning_effortではなく、OpenRouter 対応のreasoning.effort値を送信します。より低い非 off レベルはhighにマップされ、保存済みのmaxオーバーライドはxhighにフォールバックします。 - Ollama の thinking 対応モデルは
/think low|medium|high|maxを公開します。Ollama のネイティブ API はlow、medium、highの effort 文字列を受け入れるため、maxはネイティブのthink: "high"にマップされます。 - OpenAI GPT モデルは、モデル固有の Responses API effort 対応を通じて
/thinkをマップします。/think offは、対象モデルが対応する場合にのみreasoning.effort: "none"を送信します。それ以外の場合、OpenClaw は未対応値を送信する代わりに、無効化された reasoning ペイロードを省略します。 - カスタムの OpenAI 互換カタログエントリは、
models.providers.<provider>.models[].compat.supportedReasoningEffortsに"xhigh"を含めることで/think xhighにオプトインできます。これは送信時の OpenAI reasoning effort ペイロードをマップするものと同じ compat メタデータを使用するため、メニュー、セッション検証、エージェント CLI、llm-taskはトランスポート動作と一致します。 - 古い設定済み OpenRouter Hunter Alpha 参照は、廃止されたルートが reasoning フィールドを通じて最終回答テキストを返す可能性があったため、プロキシ reasoning 注入をスキップします。
- Google Gemini は
/think adaptiveを Gemini のプロバイダー所有 dynamic thinking にマップします。Gemini 3 リクエストは固定のthinkingLevelを省略し、Gemini 2.5 リクエストはthinkingBudget: -1を送信します。固定レベルは引き続き、そのモデルファミリーで最も近い Gemini のthinkingLevelまたは budget にマップされます。 - Anthropic 互換ストリーミングパス上の MiniMax M2.x(
minimax/MiniMax-M2*)は、モデル params またはリクエスト params で thinking を明示的に設定しない限り、デフォルトでthinking: { type: "disabled" }になります。これにより、M2.x の非ネイティブ Anthropic ストリーム形式からreasoning_contentデルタが漏れるのを避けます。MiniMax-M3(および M3.x)は例外です。M3 は適切な Anthropic thinking ブロックを出力し、thinking が無効な場合は空の content を返すため、OpenClaw は M3 をプロバイダーの omitted/adaptive thinking パスのままにします。 - Z.AI(
zai/*)は、ほとんどの GLM モデルでバイナリ(on/off)です。GLM-5.2 は例外です。/think off|low|high|maxを公開し、lowとhighを Z.AIreasoning_effort: "high"にマップし、maxをreasoning_effort: "max"にマップします。 - Moonshot Kimi K2.7 Code(
moonshot/kimi-k2.7-code)は常に thinking します。そのプロファイルはonのみを公開し、OpenClaw は Moonshot が要求する通り、送信時のthinkingフィールドを省略します。その他のmoonshot/*モデルは、/think offをthinking: { type: "disabled" }に、非offレベルをthinking: { type: "enabled" }にマップします。thinking が有効な場合、Moonshot はtool_choiceauto|noneのみを受け入れます。OpenClaw は互換性のない値をautoに正規化します。
- Thinking メニューとピッカーはプロバイダープロファイル駆動です。プロバイダー Plugin は、バイナリの
解決順序
- メッセージ上のインラインディレクティブ(そのメッセージにのみ適用)。
- セッションオーバーライド(ディレクティブのみのメッセージ送信で設定)。
- エージェントごとのデフォルト(config の
agents.list[].thinkingDefault)。 - グローバルデフォルト(config の
agents.defaults.thinkingDefault)。 - フォールバック: プロバイダー宣言のデフォルトが利用可能な場合はそれを使用します。それ以外の場合、reasoning 対応モデルは
mediumまたはそのモデルでサポートされる最も近い非offレベルに解決され、非 reasoning モデルはoffのままです。
セッションデフォルトの設定
- ディレクティブのみのメッセージ(空白は許可)を送信します。例:
/think:mediumまたは/t high。 - これは現在のセッションに固定されます(デフォルトでは送信者ごと)。セッションオーバーライドをクリアして設定済み/プロバイダーデフォルトを継承するには、
/think defaultを使用します。エイリアスにはinherit、clear、reset、unpinがあります。 /think offは明示的な off オーバーライドを保存します。セッションオーバーライドを変更またはクリアするまで、thinking を無効にします。- 確認返信が送信されます(
Thinking level set to high./Thinking disabled.)。レベルが無効な場合(例:/thinking big)、コマンドはヒント付きで拒否され、セッション状態は変更されません。 - 現在の thinking レベルを確認するには、引数なしで
/think(または/think:)を送信します。
エージェントごとの適用
- Embedded OpenClaw: 解決されたレベルは、インプロセスの OpenClaw エージェントランタイムに渡されます。
- Claude CLI バックエンド:
claude-cli使用時、非 off レベルは--effortとして Claude Code に渡されます。CLI バックエンドを参照してください。
高速モード(/fast)
- レベル:
auto|on|off|default。 - ディレクティブのみのメッセージは、セッションの高速モードオーバーライドを切り替え、
Fast mode set to auto.、Fast mode enabled.、またはFast mode disabled.を返信します。セッションオーバーライドをクリアして設定済みデフォルトを継承するには、/fast defaultを使用します。エイリアスにはinherit、clear、reset、unpinがあります。 - 現在有効な高速モード状態を確認するには、モードなしで
/fast(または/fast status)を送信します。 - OpenClaw は高速モードを次の順序で解決します:
- インライン/ディレクティブのみの
/fast auto|on|offオーバーライド(/fast defaultはこのレイヤーをクリア) - セッションオーバーライド
- エージェントごとのデフォルト(
agents.list[].fastModeDefault) - モデルごとの config:
agents.defaults.models["<provider>/<model>"].params.fastMode - フォールバック:
off
- インライン/ディレクティブのみの
autoはセッション/config モードを auto のまま保持しますが、新しいモデル呼び出しごとに独立して解決します。auto カットオフ前に開始した呼び出しでは高速モードが有効になり、それ以降の retry、fallback、tool-result、または continuation 呼び出しは高速モード無効で開始します。カットオフのデフォルトは 60 秒です。変更するには、アクティブモデルにagents.defaults.models["<provider>/<model>"].params.fastAutoOnSecondsを設定します。openai/*では、高速モードは対応する Responses リクエストでservice_tier=priorityを送信することで OpenAI priority processing にマップされます。- Codex バックエンドの
openai/*/openai-codex/*モデルでは、高速モードは Codex Responses に同じservice_tier=priorityフラグを送信します。ネイティブ Codex app-server ターンはturn/startまたは thread start/resume でのみ tier を受け取るため、autoはすでに実行中の app-server ターンの tier を変更できません。OpenClaw が開始する次のモデルターンに適用されます。 - OAuth 認証済みで
api.anthropic.comに送信されるトラフィックを含む直接の公開anthropic/*リクエストでは、高速モードは Anthropic service tiers にマップされます。/fast onはservice_tier=autoを設定し、/fast offはservice_tier=standard_onlyを設定します。 - Anthropic 互換パス上の
minimax/*では、/fast on(またはparams.fastMode: true)がMiniMax-M2.7をMiniMax-M2.7-highspeedに書き換えます。 - 明示的な Anthropic
serviceTier/service_tierモデル params は、両方が設定されている場合、高速モードデフォルトを上書きします。OpenClaw は引き続き、非 Anthropic プロキシベース URL では Anthropic service-tier 注入をスキップします。 /statusは、高速モードが有効な場合はFastを、設定済みモードが auto の場合はFast:autoを表示します。
詳細ディレクティブ(/verbose または /v)
- レベル:
on(最小) |full|off(デフォルト)。 - ディレクティブのみのメッセージはセッション verbose を切り替え、
Verbose logging enabled./Verbose logging disabled.を返信します。無効なレベルは、状態を変更せずにヒントを返します。 /verbose offは明示的なセッションオーバーライドを保存します。Sessions UI でinheritを選択してクリアします。- 認可された外部チャネル送信者は、セッション verbose オーバーライドを永続化できます。内部 Gateway/webchat クライアントが永続化するには
operator.adminが必要です。 - インラインディレクティブはそのメッセージにのみ影響します。それ以外の場合はセッション/グローバルデフォルトが適用されます。
- 現在の verbose レベルを確認するには、引数なしで
/verbose(または/verbose:)を送信します。 - verbose が on の場合、構造化ツール結果を出力するエージェントは、各ツール呼び出しを、それぞれ独立したメタデータのみのメッセージとして送り返します。利用可能な場合は
<emoji> <tool-name>: <arg>が接頭辞として付きます。これらのツール概要は、各ツールの開始直後に送信されます(別々の吹き出し)。ストリーミングデルタとしては送信されません。 - ツール失敗の概要は通常モードでも表示されたままですが、生のエラー詳細サフィックスは verbose が
fullでない限り非表示です。 - verbose が
fullの場合、ツール出力も完了後に転送されます(別の吹き出し、安全な長さに切り詰め)。実行中に/verbose on|full|offを切り替えた場合、以降のツール吹き出しは新しい設定に従います。 agents.defaults.toolProgressDetailは、/verboseツール概要と進行中ドラフトのツール行の形式を制御します。🛠️ Exec: checking JS syntaxのようなコンパクトな人間向けラベルには"explain"(デフォルト)を使用します。デバッグ用に生のコマンド/詳細も追加したい場合は"raw"を使用します。エージェントごとのagents.list[].toolProgressDetailはデフォルトを上書きします。explain:🛠️ Exec: check JS syntax for /tmp/app.jsraw:🛠️ Exec: check JS syntax for /tmp/app.js, node --check /tmp/app.js
Plugin トレースディレクティブ(/trace)
- レベル:
on|off(デフォルト)。 - ディレクティブのみのメッセージはセッションの Plugin トレース出力を切り替え、
Plugin trace enabled./Plugin trace disabled.を返信します。 - インラインディレクティブはそのメッセージにのみ影響します。それ以外の場合はセッション/グローバルデフォルトが適用されます。
- 現在の trace レベルを確認するには、引数なしで
/trace(または/trace:)を送信します。 /traceは/verboseより範囲が狭く、Active Memory デバッグ概要のような Plugin 所有の trace/debug 行のみを公開します。- trace 行は
/statusに表示される場合があり、通常のアシスタント返信後のフォローアップ診断メッセージとして表示される場合もあります。
Reasoning の表示(/reasoning)
- レベル:
on|off|stream。 - ディレクティブのみのメッセージは、thinking ブロックを返信に表示するかどうかを切り替えます。
- 有効な場合、reasoning は
Thinkingを接頭辞にした別メッセージとして送信されます。 stream: アクティブなチャネルが reasoning プレビューに対応している場合、返信生成中に reasoning をストリーミングし、その後 reasoning なしの最終回答を送信します。- エイリアス:
/reason。 - 現在の reasoning レベルを確認するには、引数なしで
/reasoning(または/reasoning:)を送信します。 - 解決順序: インラインディレクティブ、次にセッションオーバーライド、次にエージェントごとのデフォルト(
agents.list[].reasoningDefault)、次にグローバルデフォルト(agents.defaults.reasoningDefault)、次にフォールバック(off)。
不正な形式のローカルモデル推論タグは保守的に処理されます。閉じられた <think>...</think> ブロックは通常の返信では非表示のままで、すでに表示されたテキストの後にある閉じられていない推論も非表示になります。返信全体が単一の閉じられていない開始タグで囲まれており、そのままだと空テキストとして配信される場合、OpenClaw は不正な形式の開始タグを削除し、残りのテキストを配信します。
関連
- 昇格モードのドキュメントは 昇格モード にあります。
Heartbeat
- Heartbeat プローブ本文は設定済みの Heartbeat プロンプトです(デフォルト:
Read HEARTBEAT.md if it exists (workspace context). Follow it strictly. Do not infer or repeat old tasks from prior chats. If nothing needs attention, reply HEARTBEAT_OK.)。Heartbeat メッセージ内のインライン指示は通常どおり適用されます(ただし、Heartbeat からセッションのデフォルトを変更することは避けてください)。 - Heartbeat の配信は、デフォルトでは最終ペイロードのみです。別個の
Thinkingメッセージも送信するには(利用可能な場合)、agents.defaults.heartbeat.includeReasoning: trueまたはエージェントごとのagents.list[].heartbeat.includeReasoning: trueを設定します。
Web チャット UI
- Web チャットの思考セレクターは、ページ読み込み時にインバウンドセッションストア/設定からセッションに保存されているレベルを反映します。
- 別のレベルを選択すると、
sessions.patch経由でセッションの上書きが即座に書き込まれます。次の送信を待たず、1 回限りのthinkingOnce上書きでもありません。 - 最初のオプションは常に上書き解除の選択肢です。継承された思考が無効な場合の
Inherited: Offを含め、Inherited: <resolved level>と表示されます。 - 明示的なピッカー選択では、プロバイダーラベルがある場合はそれを保持しながら、直接のレベルラベルを使用します(たとえば、プロバイダーラベル付きの
maxオプションではMaximum)。 - ピッカーは Gateway セッション行/デフォルトから返される
thinkingLevelsを使用し、thinkingOptionsはレガシーラベルリストとして保持されます。ブラウザー UI は独自のプロバイダー正規表現リストを保持しません。Plugin がモデル固有のレベルセットを所有します。 /think:<level>は引き続き機能し、同じ保存済みセッションレベルを更新するため、チャット指示とピッカーは同期したままになります。
プロバイダープロファイル
- プロバイダー Plugin は、モデルでサポートされるレベルとデフォルトを定義するために
resolveThinkingProfile(ctx)を公開できます。 - Claude モデルをプロキシするプロバイダー Plugin は、直接の Anthropic カタログとプロキシカタログの整合性を保つため、
openclaw/plugin-sdk/provider-model-sharedのresolveClaudeThinkingProfile(modelId)を再利用する必要があります。 - 各プロファイルレベルには、保存される正規の
id(off、minimal、low、medium、high、xhigh、adaptive、またはmax)があり、表示用のlabelを含めることもできます。バイナリプロバイダーは{ id: "low", label: "on" }を使用します。 - プロファイルフックは、利用可能な場合、
reasoning、compat.thinkingFormat、compat.supportedReasoningEffortsを含むマージ済みカタログ情報を受け取ります。設定済みのリクエスト契約が対応するペイロードをサポートする場合にのみ、これらの情報を使ってバイナリまたはカスタムプロファイルを公開してください。 - 明示的な思考上書きを検証する必要があるツール Plugin は、
api.runtime.agent.resolveThinkingPolicy({ provider, model })とapi.runtime.agent.normalizeThinkingLevel(...)を使用する必要があります。独自のプロバイダー/モデルレベルリストを保持してはいけません。 - 設定済みカスタムモデルメタデータにアクセスできるツール Plugin は、
catalogをresolveThinkingPolicyに渡すことで、compat.supportedReasoningEffortsのオプトインを Plugin 側の検証に反映できます。 - 公開済みのレガシーフック(
supportsXHighThinking、isBinaryThinking、resolveDefaultThinkingLevel)は互換アダプターとして残りますが、新しいカスタムレベルセットではresolveThinkingProfileを使用してください。 - Gateway 行/デフォルトは
thinkingLevels、thinkingOptions、thinkingDefaultを公開し、ACP/チャットクライアントがランタイム検証で使用されるものと同じプロファイル ID とラベルをレンダリングできるようにします。
Was this useful?