Configuration

Feynman stores all configuration and state under ~/.feynman/. This directory is created on first run and contains settings, authentication tokens, session history, and installed packages.

Directory structure

~/.feynman/
├── settings.json       # Core configuration
├── web-search.json     # Web search routing config
├── auth/               # OAuth tokens and API keys
├── sessions/           # Persisted conversation history
└── packages/           # Installed optional packages

The settings.json file is the primary configuration file. It is created by feynman setup and can be edited manually. A typical configuration looks like:

{
  "defaultProvider": "openai",
  "defaultModel": "<non-pro-model-id-from-model-list>",
  "defaultThinkingLevel": "medium"
}

Model configuration

The defaultProvider and defaultModel fields set which model is used when you launch Feynman without the --model flag. You can change them via the CLI:

feynman model list
feynman model set <provider>/<non-pro-model-id>

To see all models you have configured:

feynman model list

Only authenticated/configured providers appear in feynman model list. If you only see OpenAI models, it usually means only OpenAI auth is configured so far.

To add another provider, authenticate it first:

feynman model login anthropic
feynman model login google
feynman model login amazon-bedrock

Then switch the default model:

feynman model list
feynman model set <provider>/<non-pro-model-id>

The model set command accepts both provider/model and provider:model formats. Feynman rejects Pro-class model IDs here and in --model; choose a non-Pro model for defaults and per-session overrides. feynman model login google opens the API-key flow directly, while feynman model login amazon-bedrock verifies the AWS credential chain that Pi uses for Bedrock access.

Web search configuration

Research workflows use ~/.feynman/web-search.json for web-search routing. The default auto route uses API-backed providers only: Exa, then Perplexity, then Gemini API. It does not read Chromium or Chrome cookies, so it should not trigger a macOS Keychain prompt.

Example:

{
  "provider": "auto",
  "searchProvider": "auto",
  "exaApiKey": "exa_...",
  "perplexityApiKey": "pplx-...",
  "geminiApiKey": "AIza..."
}

Gemini Web browser-cookie access is disabled by default. To opt into it, set "geminiBrowser": true in web-search.json; API-backed search is recommended for /deepresearch.

Subagent model overrides

Feynman’s bundled subagents inherit the main non-Pro default model unless you override them explicitly. Inside the REPL, run:

/feynman-model

This opens an interactive picker where you can either:

  • change the main non-Pro default model for the session environment
  • assign a different non-Pro model to a specific bundled subagent such as researcher, reviewer, writer, or verifier

Per-subagent overrides are persisted in the synced agent files under ~/.feynman/agent/agents/ with a model: frontmatter field. Removing that field makes the subagent inherit the main non-Pro default model again.

Thinking levels

The thinkingLevel field controls how much reasoning the model does before responding. Available levels are off, minimal, low, medium, high, and xhigh. Higher levels produce more thorough analysis at the cost of latency and token usage. You can override per-session:

feynman --thinking high

Environment variables

Feynman respects the following environment variables, which take precedence over settings.json:

VariableDescription
FEYNMAN_MODELOverride the default model with a non-Pro model
FEYNMAN_HOMEOverride the config directory (default: ~/.feynman)
FEYNMAN_THINKINGOverride the thinking level
ANTHROPIC_API_KEYAnthropic API key
OPENAI_API_KEYOpenAI API key
GEMINI_API_KEYGoogle Gemini API key
AWS_PROFILEPreferred AWS profile for Amazon Bedrock
TAVILY_API_KEYTavily web search API key
SERPER_API_KEYSerper web search API key
FEYNMAN_TELEMETRYSet to off to disable Feynman analytics, logs, and traces
FEYNMAN_POSTHOG_HOSTOverride the PostHog ingest host
FEYNMAN_POSTHOG_PROJECT_IDOverride the PostHog project ID used in telemetry metadata
FEYNMAN_POSTHOG_KEYOverride the PostHog project token
PI_OTEL_CAPTURE_CONTENTControls Pi runtime span content capture. Feynman defaults this to metadata_only
OTEL_EXPORTER_OTLP_TRACES_ENDPOINTPi runtime trace endpoint. Feynman sets this to PostHog AI Observability by default
OTEL_EXPORTER_OTLP_LOGS_ENDPOINTFeynman CLI log endpoint. Feynman sets this to PostHog Logs by default

Observability

Feynman sends three bounded telemetry streams to the configured PostHog project when telemetry is enabled:

  • product analytics events from the CLI through the PostHog SDK
  • CLI logs through PostHog Logs at /i/v1/logs
  • OpenTelemetry spans for the CLI and Pi runtime

The CLI’s generic spans use PostHog distributed tracing at /i/v1/traces; query them in HogQL from posthog.trace_spans. The Pi runtime’s LLM/tool spans use PostHog AI Observability at /i/v0/ai/otel; inspect them in the AI Observability traces UI or query their metadata as $ai_* events in events. Large AI properties live in posthog.ai_events during PostHog’s AI-event retention window. Do not query bare traces, spans, or trace_spans table names; PostHog registers distributed trace spans as posthog.trace_spans.

Feynman sets PI_OTEL_CAPTURE_CONTENT=metadata_only, so Pi spans carry model, tool, timing, count, and status metadata without prompt text or tool payload bodies. Set FEYNMAN_TELEMETRY=off to disable analytics, logs, and traces; Feynman also clears inherited OTLP/PostHog environment variables before launching Pi in that mode.

Session storage

Each conversation is persisted as a JSON file in ~/.feynman/sessions/. To start a fresh session:

feynman --new-session

To point sessions at a different directory (useful for per-project session isolation):

feynman --session-dir ~/myproject/.feynman/sessions

Diagnostics

Run feynman doctor to verify your configuration is valid, check authentication status for all configured providers, and detect missing optional dependencies. The doctor command outputs a checklist showing what is working and what needs attention.