Skip to main contentThinking Levels (/think directives)
What it does
- Inline directive in any inbound body:
/t <level>, /think:<level>, or /thinking <level>.
- Levels (aliases):
off | minimal | low | medium | high
- minimal → “think”
- low → “think hard”
- medium → “think harder”
- high → “ultrathink” (max budget)
highest, max map to high.
Resolution order
- Inline directive on the message (applies only to that message).
- Session override (set by sending a directive-only message).
- Global default (
agent.thinkingDefault in config).
- Fallback: low for reasoning-capable models; off otherwise.
Setting a session default
- Send a message that is only the directive (whitespace allowed), e.g.
/think:medium or /t high.
- That sticks for the current session (per-sender by default); cleared by
/think:off or session idle reset.
- Confirmation reply is sent (
Thinking level set to high. / Thinking disabled.). If the level is invalid (e.g. /thinking big), the command is rejected with a hint and the session state is left unchanged.
- Send
/think (or /think:) with no argument to see the current thinking level.
Application by agent
- Embedded Pi: the resolved level is passed to the in-process Pi agent runtime.
Verbose directives (/verbose or /v)
- Levels:
on|full or off (default).
- Directive-only message toggles session verbose and replies
Verbose logging enabled. / Verbose logging disabled.; invalid levels return a hint without changing state.
- Inline directive affects only that message; session/global defaults apply otherwise.
- Send
/verbose (or /verbose:) with no argument to see the current verbose level.
- When verbose is on, agents that emit structured tool results (Pi, other JSON agents) send each tool result back as its own metadata-only message, prefixed with
<emoji> <tool-name>: <arg> when available (path/command); the tool output itself is not forwarded. These tool summaries are sent as soon as each tool finishes (separate bubbles), not as streaming deltas. If you toggle /verbose on|off while a run is in-flight, subsequent tool bubbles honor the new setting.
Reasoning visibility (/reasoning)
- Levels:
on|off|stream.
- Directive-only message toggles whether thinking blocks are shown as italic text in replies.
- When enabled, any model-provided reasoning content is appended as a separate italic block.
stream (Telegram only): streams reasoning into the Telegram draft bubble while the reply is generating, then sends the final answer without reasoning.
- Alias:
/reason.
- Send
/reasoning (or /reasoning:) with no argument to see the current reasoning level.
Heartbeats
- Heartbeat probe body is the configured heartbeat prompt (default:
Read HEARTBEAT.md if exists. Consider outstanding tasks. Checkup sometimes on your human during (user local) day time.). Inline directives in a heartbeat message apply as usual (but avoid changing session defaults from heartbeats).
Web chat UI
- The web chat thinking selector mirrors the session’s stored level from the inbound session store/config when the page loads.
- Picking another level applies only to the next message (
thinkingOnce); after sending, the selector snaps back to the stored session level.
- To change the session default, send a
/think:<level> directive (as before); the selector will reflect it after the next reload.