Skip to main content

Open source Generative Engine Optimization (GEO) analysis tool — SEO analytics for AI search engines

Project description

Voyage GEO

Quick Start · Claude Code · CLI Reference · Models · Docs

PyPI MIT License Python 3.11+ Async


Open source Generative Engine Optimization (GEO) CLI tool. Analyze how AI models (ChatGPT, Claude, Gemini, Perplexity, DeepSeek, Grok, Llama) reference and recommend your brand.

SEO analytics, but for AI search engines.

How It Works

Brand Input → Research → Generate Queries → Run Against AI Models → Analyze → Report
  1. Research your brand — scrapes your website, builds a brand profile with competitors, USPs, keywords
  2. Generate queries — creates realistic search queries real people would type into ChatGPT/Perplexity (brand-blind, so queries never mention your brand)
  3. Execute — sends queries to multiple AI models via OpenRouter (or direct API keys)
  4. Analyze — measures mention rate, sentiment, mindshare, competitor positioning, narrative themes, USP coverage gaps
  5. Report — generates interactive HTML reports with charts, plus JSON/CSV/Markdown exports

Quick Start

Prerequisites

  • Python 3.11+
  • An OpenRouter API key (one key for all AI models), or individual provider API keys

Install

pip install voyage-geo

Or install from source:

git clone https://github.com/Onvoyage-AI/voyage-geo-agent.git
cd voyage-geo-agent
pip install -e .

Configure API Keys

cp .env.example .env
# Edit .env — at minimum, set OPENROUTER_API_KEY

Run an Analysis

# Full pipeline
python3 -m voyage_geo run -b "YourBrand" -w "https://yourbrand.com" --no-interactive

# Or with specific providers
python3 -m voyage_geo run -b "YourBrand" -w "https://yourbrand.com" \
  -p chatgpt,gemini,claude,perplexity-or -f html,json,csv,markdown --no-interactive

Using with AI Agents

Voyage GEO ships 8 interactive skills that work with Claude Code, OpenClaw, and any agent that supports the SKILL.md format.

Install Skills

pip install voyage-geo
voyage-geo install-skills

Auto-detects your platform:

  • OpenClaw — installs to ~/.openclaw/skills/
  • Claude Code — installs to .claude/skills/ in your project

Custom target: voyage-geo install-skills --target /path/to/skills

Available Skills

Command Description
/geo-setup First-time onboarding. Installs deps, configures API keys, verifies everything works.
/geo-run Full GEO analysis. The agent interviews you about your brand, runs the pipeline, reviews results.
/geo-research Deep-dive brand research with web search and site scraping.
/geo-explore Explore past analysis results interactively.
/geo-report Generate shareable reports from existing runs.
/geo-leaderboard Category-wide brand comparison. Ranks all brands by AI visibility.
/geo-add-provider Add a new AI model provider with guided implementation.
/geo-debug Diagnose and fix failed runs.

CLI Reference

# Full analysis pipeline
python3 -m voyage_geo run -b "<brand>" -w "<url>" -p chatgpt,gemini,claude --no-interactive

# Research a brand (builds profile)
python3 -m voyage_geo research "<brand>" -w "<url>"

# List configured providers
python3 -m voyage_geo providers

# Health check providers
python3 -m voyage_geo providers --test

# Generate reports from an existing run
python3 -m voyage_geo report -r <run-id> -f html,json,csv,markdown

# List past runs
python3 -m voyage_geo runs

# Show version
python3 -m voyage_geo version

Key Flags for run

Flag Description
-b, --brand Brand name (required)
-w, --website Brand website URL
-p, --providers Comma-separated providers (default: all via OpenRouter)
-q, --queries Number of queries to generate (default: 20)
-f, --formats Report formats: html, json, csv, markdown (default: html,json)
-r, --resume Resume from existing run ID
--stop-after Stop after a stage (research, query-generation)
--no-interactive Skip interactive review prompts

Supported AI Models

All models are accessible through a single OpenRouter API key:

CLI Name Model Provider
chatgpt GPT-5 Mini OpenAI
gemini Gemini 3 Flash Preview Google
claude Claude Sonnet 4.5 Anthropic
perplexity-or Sonar Pro Perplexity
deepseek DeepSeek V3.2 DeepSeek
grok Grok 3 xAI
llama Llama 4 Maverick Meta

You can also use direct API keys (OPENAI_API_KEY, ANTHROPIC_API_KEY, etc.) for individual providers.

Environment Variables

# OpenRouter (recommended — one key for all models)
OPENROUTER_API_KEY=sk-or-v1-...

# Direct provider keys (optional)
OPENAI_API_KEY=sk-...
ANTHROPIC_API_KEY=sk-ant-...
GOOGLE_API_KEY=AI...
PERPLEXITY_API_KEY=pplx-...

# Optional
LOG_LEVEL=info
VOYAGE_GEO_OUTPUT_DIR=./data/runs
VOYAGE_GEO_CONCURRENCY=3

Output Structure

Each run creates a self-contained directory:

data/runs/<run-id>/
├── metadata.json           # Run config and status
├── brand-profile.json      # Brand research output
├── queries.json            # Generated search queries
├── results/
│   ├── results.json        # All raw AI responses
│   └── by-provider/        # Split by provider
├── analysis/
│   ├── analysis.json       # Full analysis
│   ├── summary.json        # Executive summary
│   └── *.csv               # CSV exports
└── reports/
    ├── report.html         # Interactive HTML report
    ├── report.json
    ├── report.md
    └── charts/             # PNG chart images

Architecture

src/voyage_geo/
├── cli.py                # CLI entry (Typer + Rich)
├── config/               # Pydantic schemas, defaults, config loader
├── core/                 # Engine, pipeline, context, errors
├── providers/            # AI model providers (OpenRouter, OpenAI, Anthropic, Google, Perplexity)
├── stages/
│   ├── research/         # Stage 1: Brand research + web scraping
│   ├── query_generation/ # Stage 2: Generate search queries (keyword, persona, intent strategies)
│   ├── execution/        # Stage 3: Run queries against providers
│   ├── analysis/         # Stage 4: Analyze results (6 analyzers)
│   └── reporting/        # Stage 5: Generate reports (HTML/JSON/CSV/Markdown)
├── storage/              # File-based persistence
├── types/                # Shared Pydantic type definitions
└── utils/                # Text helpers, Rich progress displays

Extending

What Interface Location
AI Provider BaseProvider ABC src/voyage_geo/providers/
Query Strategy async generate() function src/voyage_geo/stages/query_generation/strategies/
Analyzer Analyzer Protocol src/voyage_geo/stages/analysis/analyzers/
Report Format Method in ReportingStage src/voyage_geo/stages/reporting/stage.py

See the docs/ directory for detailed guides on adding providers, analyzers, and query strategies.

Development

pip install -e ".[dev]"
python3 -m pytest tests/ -v
python3 -m ruff check src/ tests/
python3 -m mypy src/voyage_geo/ --ignore-missing-imports

Contributing

See CONTRIBUTING.md for guidelines.

License

MIT — see LICENSE for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

voyage_geo-0.1.1.tar.gz (128.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

voyage_geo-0.1.1-py3-none-any.whl (98.6 kB view details)

Uploaded Python 3

File details

Details for the file voyage_geo-0.1.1.tar.gz.

File metadata

  • Download URL: voyage_geo-0.1.1.tar.gz
  • Upload date:
  • Size: 128.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.9

File hashes

Hashes for voyage_geo-0.1.1.tar.gz
Algorithm Hash digest
SHA256 32a4561576705c4cda1fc21b6f4637a2f31d6adb3da0dbf9f86e4e37fe32cdd8
MD5 e65030f5bd7d618c018762428370bf5e
BLAKE2b-256 332c84bbb36e39d608259497d669a6bcc3f1f641c97ebb3bbd3b171726366b19

See more details on using hashes here.

File details

Details for the file voyage_geo-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: voyage_geo-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 98.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.9

File hashes

Hashes for voyage_geo-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 3dc6d797b6635673e60586e2b3b864217fe2112426e67b9aaf27473cfe51b61e
MD5 dd5973f12e04c55bf69a0ef1f41049b1
BLAKE2b-256 6204d037a6a9e854914422606b1ab4bf7277ac736ecefbdeefbfb54347fbfa77

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page