npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@sinjin/think-different-framework

v0.6.1

Published

Multi-lens structured divergence framework for Claude Code CLI. Multiple cognitive lenses think together, then distil their collisions into insight.

Readme

💞🪷  ⏳💀  👁️🔍  🧿🪞  💣🌶️  🗣️🔥  🧒❓  ⚔️❤️‍🔥  🏺⚖️  🪑👤  🔮🧬  🧐🕸️  🧭🌀  🔍🫧  💎👁️‍🗨️ 

┌───────────────────────────┐     ┌──────────────────┐          ┌──────────────────────────┐
  │░░░▒▒▒▓▓▓█████▓▓▓▒▒▒░░░░░│     │░░░░░░░░░░░░░░░░░░├┐         │░░░▒▒▒▓▓▓███▓▓▓▒▒▒░░░░░░░│
  │▒▒▒▓▓▓████████████▓▓▓▒▒▒░│     │▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒│├┐         │▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓ │
  │▓▓▓███████████████████▓▓▓│     │▓▓▓▓▓▓▓▓      ░░▒▒▓▓▓│├│       │█████████████████████████│
  └────────┐███████┌─────────┘     │████████       ░░▒▒███│├│      ├───────┐
           │▓▓▓▓▓▓▓│               │████████       ░▒▓████││┘       │░▒▓████├────────────┐
           │▒▒▒▒▒▒▒│               │████████       ░▒█████│┘        │░▒███████████████▓▒░│
           │░░░░░░░│               │████████       ░▒▓████│         │░▒▓████████████▓▒░░│
           │▒▒▒▒▒▒▒│               │████████       ░░▒▒███├┐        ├───────┘
           │▓▓▓▓▓▓▓│               │▓▓▓▓▓▓▓▓      ░░▒▒▓▓▓│├┐       │████████
           │███████│               │▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒│├│         │▓▓▓▓▓▓▓▓
           │▓▓▓▓▓▓▓│               │░░░░░░░░░░░░░░░░░░├┘│         │▒▒▒▒▒▒▒▒
           │▒▒▒▒▒▒▒│               └──────────────────┘ ┘         │░░░░░░░░

 
                T H I N K   D I F F E R E N T   F R A M E W O R K
            21 lenses  ·  3 modes  ·  structured divergence via Claude

🔭🔬  🪢🌉  💎👁️‍🗨️  🔍🫧  🧭🌀  🧐🕸️  🔮🧬  🧩🧮  ⚖️🎚️  📜🏛️  ✂️🪶  🏺⚖️  🪑👤  ⚔️❤️‍🔥  🧒❓

Here's to the crazy ones. The misfits. The rebels. The troublemakers. The round pegs in square holes.

Multi-lens structured divergence via Claude Code CLI. Multiple cognitive lenses think together, then distil their collisions into a publishable presentation. You plant a seed. They see differently. You harvest the insight.

Autonomous mode is on by default. A conductor orchestrates lenses with autonomous decision-making, lenses skip turns when they have nothing new to add, mechanisms return structured decisions that shape session flow, and a reviewer can restart sessions with mutations when output stays conventional. Use --no-autonomous to fall back to hardcoded composition sequences.

Why

AI tools are good at answering questions. But creative breakthroughs come from the collision of ideas that should not be in the same room.

Made By Dyslexia and GCHQ have demonstrated that dyslexic thinking - pattern completion from fragments, involuntary lateral thinking, simultaneous multi-scale processing, comfort with ambiguity - is one of the most valuable cognitive modes for complex problem-solving. GCHQ actively recruits dyslexic thinkers because they spot patterns in data that neurotypical analysts miss.

This framework embodies the "Think Different" philosophy: it does not just use divergent thinking as a technique. It is built from the ground up to see the world through neurodivergent lenses.

No single lens is thinking differently. The system is. The divergent thinking is an emergent property of the architecture.

Quick Start

Install via npm

npm install -g @sinjin/think-different-framework

# Then run from anywhere
think-different "Your seed topic or question"
td "Your seed topic or question"              # short alias

Or clone the repo

git clone https://github.com/sinjin-studio/think-different-framework.git
cd think-different-framework
chmod +x think.sh

./think.sh "Your seed topic or question"
./think.sh --brief ./client-brief.pdf

Requires: Claude Code CLI installed and authenticated.

Works with: bash 3.2+ (macOS and Linux).

[!WARNING] This will eat your tokens. Every session fires 19+ lenses, each reading the full conversation history. In autonomous mode, the conductor, reviewer, and tools add further calls. A single run can burn through a good chunk of your session budget. It is a deliberate, token-heavy collision engine. The framework auto-detects your Claude plan (Pro=1 seed, Max/Team/Enterprise=3 seeds). Override with --seeds N. See Plan Recommendations for details.

How It Works

The framework has three levels, like colour theory. Perceivers are pigments - how you see. Cognitions are operations - what you do with what you see. Compositions are palettes - how you sequence perceivers and cognitions together to produce a particular kind of thinking.

Each composition picks from a shared pool of perceivers and pairs them with a set of cognitions, then sequences them across rounds or spirals. The same perceiver (say, The Empath) behaves differently depending on which cognitions surround it and when in the sequence it speaks.

Taxonomy - concentric rings showing compositions, cognitions, and perceivers with colour-coded connections

Perceivers - HOW you see

Shared pool. Every composition draws from these. Each is a productive cognitive bias - a way of seeing that rebels against some default.

| Lens | Bias | What it rebels against | |-------|------|----------------------| | 💞🪷 The Empath | Empathy bias | Treating people as abstractions | | 💣🌶️ The Provocateur | Compression bias | Complexity and politeness | | 👁️🔍 The Observer | Literal bias | Social filtering and convention | | ⏳💀 The Mortal | Finitude, impermanence, urgency & trajectory | The illusion of infinite time, deferral as strategy | | 🧒❓ The Child | Naivety bias | "Grown-up" assumptions | | 🪑👤 The Includer | Absence perception | Uninvited constituencies, forgotten people, the empty chair | | 🧿🪞 The Skeptic | Incongruence detection | What doesn't fit, what's in plain sight but invisible | | 🏺⚖️ The Connoisseur | Quality, proportion & resonance | Indifference to quality, the flattening of taste | | ⚔️❤️‍🔥 The Achala | Devotion, interconnection & the sacred | Transactionalism, reducing every motivation to incentive | | 🗣️🔥 The Mouth | Register, rhythm & the right word | Deck-voice, sanitised language, dead phrases |

Cognitions - WHAT you do with what you see

Compositions choose which cognition set to use. The Logician is a hybrid - it fuses structural perception with causal reasoning and participates in both dyslexic and lapidary compositions.

| Set | Lenses | Operations | |-----|--------|------------| | Fragmentary | 🔍🫧 Decomposer, 🪢🌉 Associator, 🔭🔬 Scaler, 💎👁️‍🗨️ Reifier | Break, leap, shift, name | | Deepening | 🧭🌀 Diverger, 🔮🧬 Analogiser, 🧐🕸️ Integrator | Open, rhyme, integrate | | Evaluative | ⚖️🎚️ Appraiser, 📜🏛️ Historian, ✂️🪶 Editor | Weigh, root, pare |

Compositions - HOW you sequence them

Each composition pairs a cognition set with a selection of perceivers and defines the rhythm - how many rounds, which lenses speak when, where friction and bias checks fall.

| Mode | Cognitions | Perceivers | Character | |------|------------|------------|-----------| | 💫🔀 dyslexic | Fragmentary + Logician | All except Skeptic | Leaping, collision-driven. Rounds of decompose-associate-scale-reify with perceivers woven between | | 🌀🌿 spiral | Deepening | Empath, Provocateur, Observer, Skeptic, Includer, Achala, Mouth | Spirals of diverge-analogise-integrate, each reseeding the next | | 🪨✨ lapidary | Evaluative + Logician | Empath, Connoisseur, Provocateur, Observer, Skeptic, Mouth, Achala | Iterative refinement. Passes of weigh-root-pare, each more precise than the last |

Usage

Direct seed (single session)

./think.sh "How might luxury wellness appeal to Gen Z?"
./think.sh "Your seed topic" --mode spiral --words 1500
./think.sh "Your seed topic" --mode lapidary --words 500

From raw input (distillation phase)

The framework meets you wherever you are. Give it a brief, a brand name, or some notes. It generates provocations, runs each as a separate session, then synthesises into one presentation.

./think.sh --brief ./client-brief.pdf
./think.sh --brand "Nike"
./think.sh --notes "luxury wellness, Gen Z, sustainability"
./think.sh                                        # auto-detect from project directory
./think.sh --brief ./brief.pdf --pick             # interactive provocation selection
./think.sh --brand "Nike" --audience "runners who need permission to start"
./think.sh --brief ./brief.pdf --mode spiral      # all flags combine

With project context

Run from inside a project directory to automatically ground the thinking in what the project actually is.

cd ~/projects/my-project && ~/think.sh "seed topic"
./think.sh "seed topic" --context ./brief.md

Presentation operations

# Re-run presentation at different length
./think.sh --regenerate ./think-different-output/my-session/session.md --words 2000

# Manual synthesis of existing transcripts
./think.sh --synthesise ./run1/*.md ./run2/*.md --words 1500

Control provocation character with --tone (default: provocative). See Tones. Control perceiver depth with --depth (default: deep). See Depth.

Options

| Flag | Description | |------|-------------| | Core | | | --mode MODE | Composition: dyslexic (default), spiral, lapidary | | --words N | Target word count for presentation (default: 1500) | | --output DIR | Output directory (default: ./think-different-output) | | --context FILE | Explicit context file to ground the session | | --no-context | Skip project context gathering entirely | | Input | | | --brief FILE | Generate provocations from a brief file | | --brand NAME | Generate provocations from a brand name | | --notes TEXT | Generate provocations from working notes | | --audience TEXT | Target audience (auto-inferred from input if not set) | | --tone TONE / -t | Provocation tone (default: provocative). See Tones | | --seeds N | Number of provocations to generate (auto-detected from plan, max: 12) | | --pick | Interactively select which provocations to run | | Output | | | --sections LIST | Presentation sections: insight, brief, manifesto (default: all three). Controls which sections appear in presentation.md | | --monologue | Generate monologue as separate file (monologue.md) - first-person internal monologue | | --lines N | Number of rallying lines to generate (default: 3, max: 7) | | --practitioners LIST | Comma-separated creative practitioners as quality bar for The Line | | --html | Enable HTML presentation generation (experimental, off by default) | | --formats LIST | Output formats for --regenerate: all, md, doc, html (comma-separated) | | --regenerate FILE | Regenerate presentation from existing transcript | | --synthesise | Synthesise existing transcript files into one presentation | | --resume FILE | Resume an interrupted session from state file | | Tuning | | | --depth LEVEL | Lens depth: deep (default), deeper, deepest. Per-lens: mortal:deepest,achala:deeper. See Depth | | --rounds N | Number of rounds (dyslexic default: 7) | | --spirals N | Number of spirals (spiral default: 5) | | --passes N | Number of passes (lapidary default: 5) | | --turns N | Max turns for autonomous conductor (default: 35) | | --min-turns N | Min turns before conductor can end session (default: 15) | | --shuffle | Randomize lens order within each round/phase | | --include A,B | Force-include lenses by key name | | --exclude A,B | Force-exclude lenses by key name | | Mechanisms | | | --no-friction | Skip friction detection between rounds | | --no-bias | Skip cognitive bias checks | | --no-sensory | Skip sensory/context re-injection | | --no-negative-space | Skip negative space mapping | | --no-transcendence | Skip transcendence check | | --no-ground | Skip assumption grounding embedded in seed prep | | --ground-only | Run only the grounding step, then exit | | Mode | | | --autonomous | Enable agentic mode (default: on) | | --no-autonomous | Disable agentic mode, use hardcoded composition sequences (also disables auto-wait) | | --no-wait | Disable auto-wait on rate limit (default: polls for reset in autonomous mode, for overnight runs) | | --skip-strict | Use separate pre-call for skip-turn instead of inline detection | | --compact | Enable context compaction (off by default, opt in for very long sessions) | | --multistep | Multi-step lens calls for tool-enabled lenses (experimental, off by default) | | --no-progressive | Disable progressive compression (on by default, compresses views for conductor/lens) | | --allowedTools TOOLS | Tools for Claude CLI (default: "WebSearch,WebFetch", use "" to disable) |

Output

Each session produces:

  • Presentation (presentation.md / .docx / .html) - The Line (winning platform + expression), the experiment, the asset (sensory/tactile creative description), creative brief, manifesto, insight article, and session findings (novel ideas for inspiration). Sections controlled by --sections. The presentation pipeline distils session findings first, then all sections are anchored on the deepest material. HTML version features cinematic scroll effects with GSAP ScrollTrigger
  • Monologue (monologue.md) - Opt-in via --monologue. Rewrites the session as continuous first-person internal monologue, stripping all lens attribution. Written as a separate file, not embedded in the presentation
  • Transcript (session_*.md) - Full markdown transcript of the thinking session
  • JSON (session_*.json) - Machine-readable transcript for analysis
  • Session diagram (diagram.html) - D3 force-directed visualization of the session's thinking process. Shows lens dispatch order, conductor reasoning at each decision point, mechanism interventions, skips, and user questions. Hover nodes for detail. Auto-generated from log.jsonl
  • Context (context_*.md) - Project context brief (if gathered)

Advanced

Everything below is for tuning, experimenting, and understanding the internals. You don't need any of this to run your first session.

Plan Recommendations

  • Pro plan - Framework defaults to 1 provocation. Enough for single-seed exploration. Multi-provocation sessions will likely hit rate limits.
  • Max plan (recommended) - Defaults to 3 provocations. Best for brief/brand/notes input where multiple angles matter.
  • Enterprise/Team - Defaults to 3 provocations. Higher rate limits for intensive use.

The framework detects your Claude plan automatically via claude auth status and sets the default seed count. Override with --seeds N. Use --pick to generate provocations then select which to run.

Auto-wait on rate limit: In autonomous mode (default), the framework automatically polls for rate limit reset when credits are exhausted - start at 5-minute intervals, increasing to 10 minutes, for up to 4 hours. This enables unattended overnight runs. Disable with --no-wait.

Tones

The --tone flag controls the character of provocation generation. Each tone shapes how the framework turns your input into a seed worth thinking about.

| Tone | Description | |------|-------------| | 💣🌶️ provocative (default) | Uncomfortable, not safe. Forces a position. Pushes beyond input material | | 🌷🎁 generous | Radically positive, finds hidden strength, reveals untapped potential | | 🤲🫀 personal | Zoomed to one human, one moment, sensory detail. Turns market into person | | 🦞📞 absurd | Surreal, lateral, alien. Breaks fundamental assumptions | | ☁️💭 daydream | Loose, wandering, permission-giving. Drifts past edges | | 🎲✨ mixed | All five tones, assigned round-robin across seeds |

Comma-separate tones to assign them round-robin across seeds. With --tone provocative,generous,personal and 6 seeds, seed 1 gets provocative, seed 2 generous, seed 3 personal, seed 4 provocative again, and so on.

./think.sh --brand "Nike" --tone generous
./think.sh --brief ./brief.pdf --tone provocative,personal,absurd
./think.sh --brand "Patagonia" --tone mixed --seeds 5

Depth

The --depth flag controls how deep into fundamental human drivers the perceiver lenses go. Each level contains the previous - deeper prompts layer on top, they don't replace. Affects six lenses: Mortal, Achala, Empath, Child, Provocateur, Mouth.

| Level | Description | |-------|-------------| | deep (default) | Current lens behaviour - already meaningful depth | | deeper | The drivers behind the drivers - legacy & trajectory, fierce compassion, desire beneath desire, pre-assumption, uncomfortable truth | | deepest | Full humanity, nothing hidden - mortality salience, immovable determination, the wound beneath the desire, beginner's mind as epistemology, identity-threatening truth |

# All depth-aware lenses at deepest
./think.sh "seed" --depth deepest

# Per-lens control
./think.sh "seed" --depth mortal:deepest,achala:deeper

# Global deeper, mortal override to deepest
./think.sh "seed" --depth deeper,mortal:deepest

Experimentation

The framework is experimental. These flags let you test different configurations without editing mode files.

Lens inclusion/exclusion

./think.sh "seed" --include skeptic          # Force-include Skeptic in dyslexic mode (Round 3)
./think.sh "seed" --exclude mortal,child    # Run without Mortal and Child
./think.sh "seed" --mode spiral --exclude skeptic  # Spiral without Skeptic

Lens key names: empath, provocateur, observer, mortal, child, skeptic, includer, connoisseur, achala, mouth, decomposer, associator, scaler, reifier, diverger, analogiser, integrator, appraiser, historian, editor, logician.

Explicit --exclude wins over --include. --include overrides mode defaults (e.g. Skeptic excluded from dyslexic by default).

Mechanism toggles

./think.sh "seed" --no-friction    # Skip friction detection between rounds
./think.sh "seed" --no-bias        # Skip cognitive bias checks
./think.sh "seed" --no-sensory     # Skip sensory/context re-injection
./think.sh "seed" --no-transcendence  # Skip transcendence check
./think.sh "seed" --no-negative-space        # Skip negative space mapping

Round/spiral/pass count

./think.sh "seed" --rounds 2       # Truncated 2-round dyslexic session
./think.sh "seed" --rounds 6       # Extended 6-round session
./think.sh "seed" --mode spiral --spirals 5  # 5-spiral deep session
./think.sh "seed" --mode lapidary --passes 5 # 5-pass deep refinement

Fewer rounds/passes truncates from the end (keeps early rounds). More rounds/passes repeats the middle pattern with fresh instructions.

Shuffle

./think.sh "seed" --shuffle         # Randomize lens order within each round

Lenses are shuffled within each round/phase, not across rounds. The sequence of rounds remains fixed.

Combining flags

./think.sh "seed" --include skeptic --shuffle --no-sensory
./think.sh "seed" --exclude child --no-friction --rounds 3

When experimental flags are active, the session banner shows what's different:

  🪟 THINK DIFFERENT FRAMEWORK
  ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  Seed: How might luxury wellness...
  Mode: dyslexic
  Audience: Gen Z consumers seeking wellness that...
  Presentation: ~500 words
  Experiments:
    + skeptic (included via --include)
    - mortal (excluded via --exclude)
    - friction (disabled via --no-friction)
    ~ shuffle (lens order randomized)
  ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

Autonomous Mode (default)

Genuinely agentic behaviour, on by default:

  • Conductor - Replaces hardcoded composition sequences. An agent that operates in two phases per turn: Phase 1 picks the next lens and instruction (reading the room for unexplored territory), Phase 2 reacts to what the lens actually said - deciding whether to trigger a mechanism, review, or end the session. This lets the conductor respond to surprises rather than predict outcomes. Three conductor presets (dyslexic/spiral/lapidary) shape its orchestration style. Every decision includes a reasoning field logged to log.jsonl. Can pause the session to ask the operator a question (max 2 per session) when genuinely stuck between divergent paths.
  • Multi-step lens calls (--multistep, experimental) - Tool-enabled lenses (Observer, Empath, Skeptic, Mortal, Logician) get a two-step internal deliberation: explore with tools (search, react, find surprising connections), then respond without tools (write the final 150-200 word response building on what was found). Only the final response enters the conversation. This gives tool-enabled lenses autonomy-of-thought without autonomy-of-action. Non-tool lenses remain single-shot.
  • Inline skip-turn - Each lens decides within its response whether it has something genuinely new to add. If not, it responds with SKIP: reason and the turn is logged without wasting a separate pre-call. Use --skip-strict to restore the original two-call pattern if inline detection proves unreliable.
  • Progressive compression (on by default) - Generates compressed views of the conversation for different callers without modifying the raw history. The conductor gets a territory-focused digest optimized for gap detection. Lenses get a phrasing-focused digest preserving exact breakthrough quotes. Three tiers: turns 1-10 (full), 11-20 (conductor compressed), 21+ (both compressed). Reduces conversation data sent by ~60%. Disable with --no-progressive.
  • Context compaction (opt-in) - Separate from progressive compression. When enabled via --compact, replaces the conversation history itself with a digest. Off by default because breakthroughs at iteration 10+ need raw phrasing. Full transcript always preserved in output files.
  • Structured mechanism decisions - Friction returns {recommendation: "deepen|redirect|continue"} and can inject a specific lens. Transcendence returns {has_breakthrough: bool} and can skip to grounding. Negative space returns {recommendation: "redirect_to_void|note_and_continue|void_is_intentional"} and identifies unexplored territories with suggested lenses. Mechanisms receive a structured history of prior mechanism findings, so each builds on the last.
  • Provocation verification - Before each session, provocations containing quantitative claims are fact-checked via web search. Fabricated statistics are replaced with the closest verified data. Rhetorical word choices (e.g. "admits" implying confession) are flagged as FRAMING NOTES so downstream lenses know which words are doing rhetorical work vs. reporting reality. The original user input is preserved separately from the generated provocation.
  • Provocation review - When multiple provocations are generated, they pass through two gates: a distinctness review (merge similar, reframe weak) and a quality prosecution (is it genuinely provocative or just unusual phrasing? sharpen if needed).
  • Adversarial session reviewer - Post-composition quality gate using a prosecution/defense/verdict pattern. The prosecution assumes the session failed and searches for prior art (WebSearch). The defense concedes weak ideas and argues only for genuine divergence. The verdict decides restart/proceed from the adversarial exchange. Can restart with mutations: different mode, shuffled lens order, reframed seed. 2-run ceiling per provocation. Synthesises across both runs.
  • Line prosecution - After The Line is generated and the strongest expression picked, the winning pair passes through an adversarial prosecution loop (max 2 iterations). Tests briefability, cold-readability, and specificity. Generates alternatives if weak and re-judges.
# Autonomous is the default - just run:
./think.sh "seed"
./think.sh --brief ./brief.pdf --mode spiral

# Opt out to use hardcoded sequences:
./think.sh "seed" --no-autonomous

Mechanisms

Beyond lenses, the framework uses metacognitive mechanisms that operate outside the conversation to shape session flow. Each receives structured history of prior mechanism findings, so they build on each other rather than re-discovering the same patterns.

| Mechanism | Emoji | When | What it does | Structured output | |-----------|-------|------|--------------|-------------------| | Assumption Grounding | 🌍🔬 | Seed prep | Surfaces assumptions most likely to be wrong, verifies via web search | Verified/unverified assumptions | | Friction | 🔥⚡ | Between rounds | Finds where lenses contradict each other - signal is in the mismatch | {recommendation, inject_lens} | | Sensory | 🎨👃 | Mid-session | Re-injects project context so abstract thinking collides with ground truth | Context collision | | Bias | 🧠🪤 | Before convergence | Identifies cognitive biases as creative fuel - craft, not manipulation | {biases_detected, recommendation} | | Transcendence | ✨🚀 | Late session (2-strike) | Checks if session has reached beyond starting assumptions | {has_breakthrough, recommendation} | | Negative Space | 🔭🌑 | Mid-late session | Maps unexplored territory - the dark patches between the lit areas | {territories, pattern_of_avoidance, recommendation} | | Reseed | 🌱🔄 | Between spirals | Extracts most surprising insight to seed next spiral | Reframed seed | | Polish | 💎🔍 | Between passes | Assesses what survived and what was revealed | Quality assessment | | Review | ⚖️🔎 | Post-session | Adversarial prosecution/defense/verdict quality gate | Restart or proceed |

  • Provocation verification runs before seed preparation when the provocation contains quantitative claims. Verifies stats via web search and corrects fabricated ones with the closest real data. Flags rhetorical word choices as FRAMING NOTES. When verification runs, it replaces the embedded grounding in seed prep (to avoid double-verification).
  • Assumption grounding is embedded in seed preparation (fracture/tune/appraise) when provocation verification did not run (no quantitative claims, or web search unavailable). Surfaces assumptions most likely to be wrong and verifies factual claims via web search.
  • Friction detection is Clark-inspired prediction error detection. Finds where lenses contradict each other. The signal is in the mismatch, not the agreement.
  • Sensory check re-injects project context mid-session so abstract thinking collides with ground truth.
  • Cognitive bias as creative fuel identifies which cognitive biases are alive in the conversation and asks how each could be channelled into something authentic. Loss aversion becomes urgency, identity bias becomes belonging, scarcity becomes desire. Craft, not manipulation.
  • Transcendence uses a two-strike pattern: first positive signal is noted but the session continues, second consecutive signal triggers early grounding. This prevents premature exit - research shows breakthroughs often arrive at iteration 10+.
  • Negative space is mid-session cartography of absence. Maps what the conversation has NOT explored relative to the provocation - scales, audiences, emotions, time horizons, domains that no lens has entered. Like the Hubble Deep Field: points at the dark patches precisely because the absence of foreground noise is the condition for seeing further. Can redirect a lens into the dark patches. In synthesis, maps the collective blind spot across multiple runs.
  • Mechanism memory ensures each mechanism receives a structured history of what previous mechanisms discovered, so friction at round 3 knows what friction at round 1 flagged and focuses on what's new or evolved. Prevents the same tensions being re-discovered without progress.
  • Spiral re-seeding extracts the most surprising insight from integration and uses it to seed the next spiral (spiral mode only).
  • Polish is between-pass quality assessment. What survived? What was revealed? Is the material getting denser or losing life? (lapidary mode only).

Provocation Verification

When provocations contain quantitative claims (numbers, percentages, citations), a verification step runs before seed preparation (verify_provocation() in context/ground.sh). It:

  1. Verifies every statistic and factual claim via web search
  2. Corrects fabricated stats with the closest verified data (preserving rhetorical energy)
  3. Flags rhetorical word choices as FRAMING NOTES (e.g. "admits" implying confession)

The corrected provocation replaces $SEED_TOPIC. The verification report ($SEED_VERIFICATION) is injected into the conversation context so downstream lenses have provenance awareness. When verification runs, it disables embedded grounding in seed prep to avoid double-verification.

Why this matters: Without correction, fabricated numbers contaminate downstream creative work. A debunked "61%" can echo as a sleep score of "62" in a fictional scene, which then becomes the emotional anchor of the entire session. The framework was verifying without correcting - flagging bad data but still building on it.

Assumption Grounding

When provocation verification does not run (no quantitative claims, or web search unavailable), grounding remains embedded in seed preparation (fracture, tune, or appraise). Before breaking apart or assessing the seed, the model surfaces 3-4 assumptions about the problem, audience, or situation most likely to be wrong, with alternative realities for each.

Web search is enabled by default (WebSearch,WebFetch). When available, the model verifies factual claims and marks each assumption as VERIFIED or UNVERIFIED. When unavailable (via --allowedTools ""), assumptions are marked UNVERIFIED and held loosely.

This matters because assumptions form during seed preparation, BEFORE any of the existing checking mechanisms fire (friction, bias, sensory, Observer, Skeptic all run DURING composition rounds). Without grounding, contaminated assumptions bake into the conversation that every lens builds on.

./think.sh "your seed topic" --ground-only
./think.sh "your seed topic" --context ./brief.md --ground-only

Session Flow

Two paths to a presentation. A direct seed runs one session. Raw input (brief, brand, notes) gets distilled into provocations, each provocation runs a full session, then all sessions are synthesised into one presentation.

Session flow - two paths converging to presentation

Composition Flows

💫🔀 Dyslexic Composition - step by step

7 rounds (default). Cognitions and perceivers interleave. Friction between every round. Sensory check mid-session. Bias check before convergence. Negative space and transcendence checks from round 5 onwards (two-strike pattern - first signal noted, second triggers grounding).

Dyslexic composition flow - 7 rounds with friction, sensory, negative space, bias, and transcendence checks

🌀🌿 Spiral Composition - step by step

5 spirals (default). Each spiral widens then crystallises. The Integrator's insight reseeds the next spiral. Friction, bias, negative space and transcendence checks from spiral 3 onwards.

Spiral composition flow - 5 spirals converging inward with reseed connections

🪨✨ Lapidary Composition - step by step

5 passes (default). Each pass works the same material with increasing precision. Polish mechanism between passes assesses what survived and what was revealed. Negative space and transcendence checks from pass 3 onwards. Mature judgement only - Child excluded by default.

Lapidary composition flow - 5 passes with polish, friction, negative space, and transcendence checks

Lens Exclusion Defaults

The Skeptic is excluded from the dyslexic composition by default. Dyslexic thinking naturally produces incongruence detection as a perceptual byproduct - adding an explicit Skeptic lens can over-anchor on what doesn't fit before the leaps have had space to form. Use --include skeptic to override this and place it in Round 3.

The Child is excluded from the lapidary composition by default. Lapidary thinking requires mature judgement - the discernment of a craftsperson, not wild generation. The Connoisseur takes the evaluative seat that the Child cannot occupy.

Architecture

think.sh                          # CLI entry point
lib/
  call_lens.sh                   # Core lens invocation + COMMON_RULES + compaction (opt-in) + mechanism memory + flow control
  conductor_loop.sh              # Agentic orchestration loop (--autonomous)
  cap_check.sh                   # Rate limit detection + claude_call / claude_call_json wrappers
  json.sh                        # JSON output helpers
  md.sh                          # Markdown output helpers
  markers.sh                     # Round/spiral/phase markers
lenses/
  conductor.sh                   # The Conductor - first true agent, orchestrates lenses
  perceivers/                    # Shared perceiver lenses (10 lenses)
  cognitions/
    fragmentary/                 # Break, leap, shift, name (4 lenses)
    deepening/                   # Open, rhyme, integrate (3 lenses)
    evaluative/                  # Weigh, root, pare (3 lenses)
  hybrids/                       # Lenses that break the perceiver/cognition boundary
    logician.sh                  # Fused structural perception + causal reasoning
context/
  gather.sh                      # Project context gathering
  ground.sh                      # Standalone grounding (--ground-only) + shared preamble
  provoke.sh                     # Provocation generation + review gate (--autonomous)
  fracture.sh                    # Seed fracturing (dyslexic)
  tune.sh                        # Seed tuning (spiral)
  appraise.sh                    # Seed appraisal (lapidary)
mechanisms/
  friction.sh                    # Between-round friction detection (structured decisions)
  sensory.sh                     # Project context re-injection
  bias.sh                        # Cognitive bias detection (structured decisions)
  transcendence.sh               # Transcendence check (structured decisions)
  review.sh                      # Adversarial session reviewer - prosecution/defense/verdict
  negative_space.sh              # Negative space mapping (mid-session + synthesis)
  reseed.sh                      # Spiral re-seeding
  polish.sh                      # Between-pass quality assessment (lapidary)
modes/
  dyslexic.sh                    # Fragmentary composition (conductor preset in --autonomous)
  spiral.sh                      # Deepening composition (conductor preset in --autonomous)
  lapidary.sh                    # Evaluative composition (conductor preset in --autonomous)
report/
  generate.sh                    # Single transcript to presentation
  synthesise.sh                  # Multiple transcripts to one presentation
  session-diagram.py             # D3 visualization of session thinking process from log.jsonl

The Ralph Wiggam Loop

Every lens call is a stateless claude -p invocation - a fresh context window with no memory of prior reasoning. The conversation output accumulates as input (each lens reads "the minutes of the meeting so far"), but the internal chain-of-thought from every previous call is discarded completely. Lens 20 reasons as freshly as lens 1. No attention degradation, no compounding drift across a 30+ turn session.

Progressive compression (on by default) keeps the raw conversation intact but generates compressed views tailored to each caller type - the conductor sees a territory map, lenses see preserved breakthrough phrasing. This cuts conversation data sent by ~60% without losing the raw material that fuels later breakthroughs. Context compaction (--compact) is a more aggressive option that replaces the conversation itself, available for very long sessions. Anthropic's harness design research informed the tiered approach - breakthroughs arrive at iteration 10+, so early turns always get full context.

This architecture is Geoffrey Huntley's Ralph Wiggam loop - a pattern he originated for agentic AI systems where the model is called in a loop, with the context window clearing between iterations to prevent accumulated reasoning from degrading output quality.

This framework applies the Ralph Wiggam loop to a different problem. Where the pattern is typically used for task automation - retrying, refining, converging on a correct answer - here it drives creative divergence. Each lens gets a clean reasoning slate specifically so it can see differently. The accumulated conversation is raw material, not instructions. The fresh window is not a workaround for context limits - it is the mechanism that keeps 20 lenses from collapsing into one voice.

Credits

Inspired by the cognitive science of dyslexic thinking (Made By Dyslexia, GCHQ), the Ralph Wiggam loop architecture (Geoffrey Huntley), predictive processing ('The Experience Machine' Andy Clark), behavioural science (Rory Sutherland), and the philosophy that the people who are crazy enough to think they can change the world are the ones who do (Apple).