Skip to main content
Glama
BlueWaterCorp

RiskModels

RiskModels provides factor decompositions and ETF-executable hedge ratios for US equities. The dataset is simulation-grade: it covers on the order of 16,000 US stocks across the full historical panel, while at each month end the model’s headline universe is the largest ~3,000 by market cap—the set the API surfaces for everyday risk and hedging.

Post-regression outputs (hedge ratios, explained-risk decompositions, and related L1–L3 series) are on daily history from 2007 through present; split- and dividend-adjusted returns (the inputs to the rolling regressions) begin 2006-01-04. The API is AI-agent ready, including a built-in Model Context Protocol (MCP) server for seamless integration with LLMs.

RiskModels API Developer Portal

CI Live Docs OpenAPI PyPI

RiskModels — MAG7 macro correlations & cross-sectional rank snapshot

This repository is the authoritative public API reference for the RiskModels equity risk model API, featuring:

  • 📖 Model methodology (wiki)ERM3 L3 overview (same URI as API wiki_uri in response metadata)

  • 📚 Comprehensive API Documentation — OpenAPI 3.0.3 specification, guides, and examples

  • 🌐 Developer Portal — Beautiful Next.js site (this repo) deployed at riskmodels.app

  • 🐍 Python & TypeScript Examples — Production-ready code in examples/

  • 🤖 AI Agent Integration — MCP server, OAuth2, and agent manifest


Canonical URLs (REST, OpenAPI, and docs)

Use these only for integrations and tooling:

What

URL

REST base (OpenAPI servers)

https://riskmodels.app/api

Deployed OpenAPI JSON (same spec as OPENAPI_SPEC.yaml)

https://riskmodels.app/openapi.json

Interactive API reference (this portal)

/api-reference

Important: The hostname api.riskmodels.app is not used for the public API or machine-readable docs. Older links or docs that mention it should be treated as obsolete; use riskmodels.app (apex) as above.


Related MCP server: riskstate-mcp

📖 API Overview

The RiskModels API provides institutional-grade equity risk analysis:

  • Daily factor decompositions — market, sector, subsector explained-risk fractions for the headline ~3,000 largest US stocks by market cap (month-end universe)

  • Hedge ratios — dollar-denominated ETF hedge amounts (L1/L2/L3) designed to remain executable with liquid raw ETFs

  • Historical time series — split- and dividend-adjusted returns (2006–present) plus rolling hedge ratios and ER (2007–present; factor outputs need a full regression window)

  • AI-agent ready — OAuth2, per-request billing, machine-readable manifests

Data coverage: ~16,000 US stocks in the historical panel; ~3,000 largest by market cap at each month end for headline outputs. Updated daily. Factor outputs (HR/ER): 2007 through present. Adjusted return series: 2006-01-04 through present.


Why The Engine Matters

RiskModels is designed to be useful for real portfolio work, not just descriptive analytics:

  • Built to be time-safe — the engine is designed to avoid common sources of forward contamination such as recycled tickers, snapshot shares, and retroactive universe contraction

  • Grounded in a real Security Master — ticker-level outputs sit on top of a point-in-time identity layer built for identifier continuity, symbol changes, and historically defensible shares data

  • Hierarchical by design — the model separates market, sector, and subsector structure rather than collapsing everything into a flat beta view

  • Tradeable in practice — the published hedge ratios are designed to work with liquid ETFs at execution time, not only with synthetic or orthogonalized factors

  • Built on adjusted return series — split- and dividend-adjusted returns make the decomposition and hedge ratios more economically consistent over long horizons

For a deeper explanation of the engine design choices behind these claims, see the methodology docs and API reference.


🐍 Python SDK (riskmodels-py)

Prefer the Python SDK over raw REST for agent-native workflows — ticker resolution, semantic field normalization, validation with instructional errors, and LLM-ready context formatting are built in.

Install (PyPI):

PyPI version

pip install riskmodels-py
# Optional — xarray cube from batch Parquet/CSV:
# pip install riskmodels-py[xarray]
# Optional — snapshot PDF rendering:
# pip install riskmodels-py[pdf]

Quickstart:

from riskmodels import RiskModelsClient, to_llm_context

client = RiskModelsClient.from_env()
pa = client.analyze({"NVDA": 0.4, "AAPL": 0.6})
print(to_llm_context(pa))

Snapshot generation (institutional PDF reports):

from riskmodels.snapshots import get_data_for_r1, render_r1_to_pdf

client = RiskModelsClient.from_env()
data = get_data_for_r1("NVDA", client)       # fetch → R1Data (caches to JSON)
render_r1_to_pdf(data, "NVDA_R1_Risk.pdf")   # render → PDF (~0.3s, no API)

Documentation:


Risk intelligence

Charts below are generated from live API data (MAG7 batch correlation + get_rankings + MAG7 L3 batch metrics) via scripts/generate_readme_assets.py. Set RISKMODELS_API_KEY (free tier is sufficient), run the script from the repo root, then commit ./assets/ and ./public/docs/readme/.

MAG7 — L3 σ-scaled decomposition

Macro sensitivity

Cross-sectional rankings


🤖 MCP Server (v3.0.0-agent)

RiskModels includes a first-class MCP (Model Context Protocol) server, enabling AI agents to directly query risk data and perform factor analysis.

MCP Connection (hosted API):

  • SSE Endpoint: https://riskmodels.app/api/mcp/sse

  • Authentication: Bearer token (API key or OAuth2 JWT)

  • Discovery: https://riskmodels.app/.well-known/mcp.json (see OPENAPI_SPEC.yaml)

Local MCP server (mcp/ in this repo) — stdio transport for Cursor / Claude Desktop / Zed: discovers capabilities, schemas, OpenAPI, and SDK-backed live-paper risk tools. Tools shipped here include:

  • riskmodels_list_endpoints — List API capabilities (id, method, endpoint, short description)

  • riskmodels_get_capability — Full capability record by id (parameters, pricing, examples)

  • riskmodels_get_schema — JSON Schema for a response type (e.g. ticker-returns-v2.json)

  • riskmodels_decompose, riskmodels_compare, riskmodels_hedge_position, riskmodels_portfolio_decompose, riskmodels_whitepaper_example — Agent-ready SDK outputs with chart_data, suggested_chart, and plain-English summaries

For live risk data and portfolio math, call the REST API (e.g. GET /api/metrics/{ticker}, POST /api/batch/analyze, GET /api/l3-decomposition), the Python SDK (riskmodels-py), or the listed MCP tools.

See mcp/README.md for install and config.

Anthropic Claude (Managed Agents vs Messages API): internal engineering design for optional cloud-hosted agents, billing, and compliance — see docs/ANTHROPIC_CLOUD_AGENTS.md.


⌨️ Command-line CLI (riskmodels)

The npm package in cli/ installs the riskmodels binary: config, SQL query (billed API or direct Supabase), schema introspection, balance, and static agent manifests.

Install from npm:

npm install -g riskmodels
riskmodels --help

Develop from this repo:

cd cli
npm ci
npm run build
npm run install:global   # optional: npm link for local testing

Publish to npm (maintainers): procedure is documented in the private BWMACRO monorepo (docs/RISKMODELS_CLI_NPM_PUBLISHING.md), not here. Only publish from the cli/ directory — the repo root Next.js app is not published to npm.


💻 Developer Portal (This Repo)

This repo now includes a Next.js developer portal with:

  • ✨ Hero landing page with feature highlights

  • 📚 MDX-powered documentation (README_API.md, AUTHENTICATION_GUIDE.md)

  • 🔍 Interactive API reference (Redoc OpenAPI viewer)

  • 💡 Code examples with syntax highlighting and copy buttons

  • 🎯 Step-by-step quickstart guide

Local Development

# Install dependencies
npm install

# Option A: Copy env template and fill in Supabase/Stripe keys manually
cp .env.example .env.local

# Option B: Use Doppler (recommended for team consistency)
# Ensure `doppler login` is done, then:
doppler secrets download --no-file --format env > .env.local

# Generate OpenAPI JSON for Redoc
npm run build:openapi

# Run dev server
npm run dev

Screenshot Capture Hygiene:

When capturing site screenshots for audit or documentation:

  1. Ensure the build passes first: npm run build must complete without errors

  2. Verify the dev server serves HTTP 200: Visit http://localhost:3000 and confirm pages render (not "Internal Server Error")

  3. Run the capture script: python3 capture_site.py (requires Playwright)

The script will skip pages returning HTTP 500 or containing "Internal Server Error" content. Screenshots with server errors should never be committed to the repository.

Environment Management with Doppler:

This repo uses Doppler for secrets management. The doppler.yaml is pre-configured for the erm3 project:

# Verify setup (should show project: erm3, config: dev)
doppler setup

# List all secrets
doppler secrets

# Get a specific secret
doppler secrets get STRIPE_SECRET_KEY

# Export dev secrets to .env.local for curl testing and local dev
npm run doppler:env

# Push production secrets to Vercel (requires vercel login + project link)
npm run vercel:sync-env:doppler

For curl/API testing with Doppler secrets:

# 1. Export secrets to .env.local
npm run doppler:env

# 2. Source them for your shell session
source .env.local

# 3. Use in curl commands
curl -H "Authorization: Bearer $RISKMODELS_API_SERVICE_KEY" \
  https://riskmodels.app/api/health

See DEPLOYMENT.md for detailed Vercel/Doppler integration.

Visit http://localhost:3000

Build & Deploy

# Build for production
npm run build

# Start production server
npm start

Deployment: See DEPLOYMENT.md for Vercel setup, env vars, and Supabase/Stripe config.


📂 Repository Structure

RiskModels_API/
├── app/                      # Next.js app
│   ├── api/                  # API routes (REST)
│   ├── page.tsx              # Hero landing page
│   ├── layout.tsx            # Root layout with Navbar/Footer
│   ├── docs/[[...slug]]/     # MDX docs renderer
│   ├── api-reference/        # Redoc OpenAPI viewer
│   ├── examples/             # Code examples showcase
│   └── quickstart/           # Quickstart guide
├── components/               # React components (new)
│   ├── Navbar.tsx
│   ├── Footer.tsx
│   ├── Hero.tsx
│   ├── CodeBlock.tsx
│   └── Logo.tsx
├── content/docs/             # MDX content (new)
│   ├── api.mdx
│   └── authentication.mdx
├── cli/                      # Command-line CLI (`riskmodels`)
├── sdk/                      # Python SDK (`riskmodels-py`) source
│   └── riskmodels/snapshots/ # Snapshot PDF pipeline (R1 shipped, R2–P4 planned)
├── examples/                 # Runnable examples
│   ├── python/
│   └── typescript/
├── mcp/                      # MCP (Model Context Protocol) server
├── public/                   # Static assets (new)
│   ├── transparent_logo.svg
│   └── openapi.json          # Generated from OPENAPI_SPEC.yaml
├── styles/                   # Global styles (new)
├── lib/                      # Utilities (new)
├── OPENAPI_SPEC.yaml         # Canonical OpenAPI spec
├── README_API.md             # API reference (source for content/docs/api.mdx)
├── AUTHENTICATION_GUIDE.md   # Auth guide (source for content/docs/authentication.mdx)
├── SEMANTIC_ALIASES.md       # Field definitions
└── package.json              # Next.js deps (new)

🛠️ Tech Stack (Developer Portal)

  • Framework: Next.js 15 (App Router)

  • Styling: Tailwind CSS 3.4, dark mode default

  • MDX: @next/mdx for documentation

  • API Reference: Redoc (OpenAPI 3.0 viewer)

  • Code Highlighting: Custom CodeBlock with copy button

  • Fonts: Inter (system-ui fallback)

  • Colors: Blue primary (hsl(217, 91%, 60%)), zinc/slate dark palette


📄 Documentation Files

Document

Description

README_API.md

Complete API overview, endpoints, key concepts

API_TERMS.md

API Terms of Service (riskmodels.net/terms/api)

PLAID_HOLDINGS_UX.md

Plaid connection flow and holdings API user experience

AUTHENTICATION_GUIDE.md

Bearer token, OAuth2, Supabase JWT, rate limits

DOCS_PROCESS.md

Process for adding new documentation

SEMANTIC_ALIASES.md

Field definitions, units, formulas

RESPONSE_METADATA.md

_agent block, response headers, pricing

ERROR_SCHEMA.md

Error codes and recovery patterns

OPENAPI_SPEC.yaml

OpenAPI 3.0.3 specification (v3.0.0-agent)

docs/SNAPSHOT_ROADMAP.md

Snapshot suite roadmap, ADRs, and implementation phases

docs/SNAPSHOT_CONTENT_MAP.md

8-page content spec with wireframes and JSON schemas

docs/SNAPSHOT_FRONTEND_ARCH.md

Pure-Matplotlib rendering pipeline architecture


  • ERM3 — Python risk model computation engine (open source)


🤝 Contributing

We welcome pull requests, especially to improve the OpenAPI spec — clearer descriptions, better schemas, and more examples help everyone.

  1. OpenAPI spec: CONTRIBUTING.md — PRs to OPENAPI_SPEC.yaml are encouraged

  2. Issues: Open an issue for bugs or feature requests

  3. Examples: Submit new examples via PR to examples/

  4. Docs: Improve documentation by editing MDX files in content/docs/


📧 Support


📜 License

See LICENSE for details.

© 2026 Blue Water Macro Corp. All rights reserved.

Deploy trigger: Tue Jun 9 16:13:22 PDT 2026

A
license - permissive license
-
quality - not tested
-
maintenance - not tested

Maintenance

Maintainers
33dResponse time
Release cycle
Releases (12mo)
Commit activity
Issues opened vs closed

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/BlueWaterCorp/RiskModels_API'

If you have feedback or need assistance with the MCP directory API, please join our Discord server