digital-oracle

Answer prediction questions using market trading data, not opinions. Use when the user asks probability questions about geopolitics, economics, markets, industries, or any topic where real money is being traded on the outcome. Examples: 'What's the probability of WW3?', 'Will there be a recession?', 'Is AI in a bubble?', 'When will the Russia-Ukraine war end?', 'Is it a good time to buy gold?', 'Will SPY drop 5% this month?', 'Is NVDA options premium overpriced?'. The skill reads prices from prediction markets, commodities, equities, options chains, derivatives, yield curves, and currencies, then cross-validates multiple signals to produce a structured probability report.

Safety Notice

This listing is from the official public ClawHub registry. Review SKILL.md and referenced scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "digital-oracle" with this command: npx skills add komako-workshop/digital-oracle

digital-oracle

Markets are efficient. Price contains all public information. Reading price = reading market consensus.

Methodology

Answer questions using only market trading data — no news, opinions, or statistical reports as causal evidence. If something is true, some market has already priced it in.

Five iron rules:

  1. Trading data only — prices, volume, open interest, spreads, premiums. Never cite analyst opinions.
  2. Explicit reasoning from price to judgment — explain clearly "why this price answers this question."
  3. Multi-signal cross-validation — never conclude from a single signal. At least 3 independent dimensions.
  4. Label the time horizon of each signal — options price 3 months, equipment orders price 3 years — don't mix them in the same vote.
  5. Structured output — the final report must follow the Step 5 template: layered signal tables → contradiction analysis → probability scenarios → signal consistency assessment. Do not substitute prose for structured reporting.

Workflow

Step 1: Understand the question

Decompose the user's question into:

  • Core variable: What event or trend?
  • Time window: Is the user asking about 3 months, 1 year, or 5 years?
  • Priceability: Is there real money being traded on this outcome?

Step 2: Select signals

Based on question type, select from the signal menu below. Don't use just one category — cover at least 3.

Geopolitical conflict / War risk

  • Polymarket: Search for related event contracts (ceasefire, invasion, regime change, declaration of war)
  • Kalshi: Search for related binary contracts
  • Safe-haven assets: Gold (GC=F), silver (SI=F), Swiss franc (USDCHF=X)
  • Conflict proxies: Crude oil (CL=F), natural gas (NG=F), wheat (ZW=F), defense ETF (ITA), defense stocks
  • Risk ratios: Copper/Gold ratio (risk-off indicator), Gold/Silver ratio
  • CFTC COT: Institutional positioning changes in crude/gold/wheat (which direction is smart money betting)
  • BIS: Central bank policy rate trends in relevant countries
  • FearGreedProvider: CNN Fear & Greed Index (composite of 7 price signals)
  • Web search: VIX, MOVE index, sovereign CDS, war risk premiums, BDI freight rates, high-yield OAS
  • Currencies: Currency pairs of relevant countries (e.g. USDRUB=X, USDCNY=X)
  • Country ETFs: Asset flows in relevant countries (e.g. FXI, EWY)

Economic recession / Macro cycle

  • Treasury: Yield curve shape (10Y-2Y spread, 10Y-3M spread), real rates, breakeven inflation
  • YahooPriceProvider: SPY, copper (HG=F), crude oil (CL=F), price trends
  • Risk ratios: Copper/Gold ratio
  • CFTC COT: Speculative net positions in copper/crude (is managed money bullish or bearish)
  • BIS: Credit-to-GDP gap (credit overheating = late cycle), policy rate directions
  • World Bank: GDP growth rate historical trends, cross-country comparisons
  • Deribit: BTC futures basis (risk appetite proxy)
  • CoinGecko: Crypto total market cap + BTC dominance (risk appetite proxy)
  • FearGreedProvider: CNN Fear & Greed Index (7 price signals composite → 0-100)
  • CMEFedWatchProvider: Market-implied FOMC rate change probabilities from futures
  • Polymarket: Recession-related contracts, central bank rate path
  • Currencies: DXY/dollar strength, emerging market currencies
  • Web search: High-yield bond spread (HY OAS), TED spread, MOVE index, TTF gas, BDI freight rates

Industry cycle / Bubble assessment

  • YahooPriceProvider: Industry leader stock trends, sector ETFs
  • Find the industry's "single-purpose commodity" (e.g. GPU rental price → AI, rebar → construction)
  • Upstream equipment maker orders/stock price (e.g. ASML → semiconductors)
  • Leader company valuation discount (e.g. TSMC vs peers → Taiwan Strait risk pricing)
  • EDGAR: Industry leader insider trading cadence (Form 4) — concentrated selling = bearish signal
  • CFTC COT: Institutional positioning changes in related commodities
  • CoinGecko: For crypto industry, look at BTC/ETH/altcoin market cap distribution
  • Web search: VC funding concentration, leveraged ETF concentration, margin debt levels
  • Deribit: Implied volatility of related crypto assets

Asset pricing / Whether to buy

  • YahooPriceProvider: Target asset price trend (daily/weekly/monthly)
  • Relative price changes of correlated assets (divergence between two commodities = structural signal)
  • Treasury: Risk-free rate as valuation anchor
  • YFinance: Options chain (IV, put/call ratio, max pain, Greeks, implied move)
  • EDGAR: Insider selling cadence (heavy Form 4 selling = insiders bearish)
  • CFTC COT: Speculative vs commercial net position divergence for commodity assets
  • CoinGecko: For crypto assets, check market cap, ATH/ATL distance, 24h volatility
  • Deribit: Crypto options chain (implied volatility = market's expected range)
  • Polymarket/Kalshi: Probability pricing of related events
  • FearGreedProvider: CNN Fear & Greed composite score (momentum, breadth, VIX, put/call, junk bond demand, volatility, safe haven)
  • Web search: VIX, corporate bond issuance volume, analyst rating distribution

Stock/Options analysis / Crash probability

  • YFinance: Options chain → ATM IV (expected volatility), IV skew (upside/downside fear asymmetry), put/call ratio (bull/bear sentiment), max pain (market maker profit zone), implied move (expected price range), Greeks (delta ≈ ITM probability)
  • YahooPriceProvider: Underlying historical price → realized volatility (compare vs implied volatility to judge options premium)
  • Kalshi: SPY/NASDAQ price range markets → direct probability pricing
  • CFTC COT: S&P 500/VIX futures positioning → institutional direction
  • Defensive rotation: XLY (cyclical) vs XLP (defensive) vs XLU (utilities) relative performance → market defensiveness
  • Treasury: Yield curve shape → recession signal
  • FearGreedProvider: CNN Fear & Greed Index
  • Web search: VIX level, margin debt level, leveraged ETF concentration

Available trading symbols directory: See references/symbols.md Provider API reference: See references/providers.md

Step 3: Signal routing

Before fetching data, evaluate each candidate signal from Step 2 against three criteria:

  1. Relevance: Can this signal actually answer the user's specific question? (e.g., asking about Taiwan → skip CoinGecko)
  2. Time match: Does the signal's pricing horizon match the question's time window? (e.g., asking about 3 months → skip World Bank GDP which lags 1-2 years)
  3. Information increment: Does this signal provide an independent perspective not already covered by other signals? Avoid redundancy, keep complementary signals.

Only keep signals that pass all three checks. This reduces noise, saves fetch time, and produces cleaner analysis.

Step 4: Fetch data

Use digital-oracle's Python providers to fetch structured data, calling all sources in parallel with gather() (including web search):

from digital_oracle import (
    PolymarketProvider, PolymarketEventQuery,
    KalshiProvider, KalshiMarketQuery,
    YahooPriceProvider, PriceHistoryQuery,   # requires uv pip install yfinance
    DeribitProvider, DeribitFuturesCurveQuery,
    USTreasuryProvider, YieldCurveQuery,
    WebSearchProvider,
    CftcCotProvider, CftcCotQuery,
    CoinGeckoProvider, CoinGeckoPriceQuery,
    EdgarProvider, EdgarInsiderQuery,
    BisProvider, BisRateQuery,
    WorldBankProvider, WorldBankQuery,
    YFinanceProvider, OptionsChainQuery,      # requires uv pip install yfinance
    FearGreedProvider,
    CMEFedWatchProvider,
    gather,
)

pm = PolymarketProvider()
kalshi = KalshiProvider()
yahoo = YahooPriceProvider()  # requires uv pip install yfinance
deribit = DeribitProvider()
treasury = USTreasuryProvider()
web = WebSearchProvider()
cftc = CftcCotProvider()
coingecko = CoinGeckoProvider()
edgar = EdgarProvider(user_email="you@example.com")  # SEC requires email in User-Agent, otherwise 403
bis = BisProvider()
wb = WorldBankProvider()
yf = YFinanceProvider()  # requires uv pip install yfinance
fear_greed = FearGreedProvider()
fedwatch = CMEFedWatchProvider()

result = gather({
    "pm_events": lambda: pm.list_events(PolymarketEventQuery(slug_contains="...", limit=10)),
    "yield_curve": lambda: treasury.latest_yield_curve(),
    "gold": lambda: yahoo.get_history(PriceHistoryQuery(symbol="GC=F", limit=30)),
    # Institutional positioning
    "gold_cot": lambda: cftc.list_reports(CftcCotQuery(commodity_name="GOLD", limit=4)),
    # Crypto market sentiment
    "crypto": lambda: coingecko.get_prices(CoinGeckoPriceQuery(coin_ids=("bitcoin", "ethereum"))),
    # Insider trades
    "insider": lambda: edgar.get_insider_transactions(EdgarInsiderQuery(ticker="AAPL", limit=10)),
    # Central bank policy rates
    "rates": lambda: bis.get_policy_rates(BisRateQuery(countries=("US", "CN"), start_year=2023)),
    # GDP data
    "gdp": lambda: wb.get_indicator(WorldBankQuery(indicator="NY.GDP.MKTP.CD", countries=("US", "CN"))),
    # BTC futures term structure (risk appetite proxy)
    "btc_futures": lambda: deribit.get_futures_term_structure(DeribitFuturesCurveQuery(currency="BTC")),
    # Kalshi event markets (use event_ticker or series_ticker, not keyword search)
    "kalshi_fed": lambda: kalshi.list_markets(KalshiMarketQuery(series_ticker="KXFED", limit=10)),
    # Options chain (with Greeks)
    "spy_options": lambda: yf.get_chain(OptionsChainQuery(ticker="SPY", expiration="2026-04-17")),
    # CNN Fear & Greed (composite of 7 price signals)
    "fear_greed": lambda: fear_greed.get_index(),
    # CME FedWatch (implied rate probabilities from futures)
    "fedwatch": lambda: fedwatch.get_probabilities(),
    # Web search runs in parallel with structured providers
    "vix": lambda: web.search("VIX index current level"),
    "hy_spread": lambda: web.search("US high yield bond spread OAS"),
})

# Partial failures don't affect other results
curve = result.get("yield_curve")
vix_info = result.get_or("vix", None)  # WebSearchResult — use .text() to render

# Options data usage
chain = result.get_or("spy_options", None)
if chain:
    print(f"ATM IV: {chain.atm_iv:.1%}, Implied move: {chain.implied_move():.1%}")
    print(f"Put/Call OI ratio: {chain.put_call_oi_ratio:.2f}")
    print(f"Max pain: {chain.max_pain()}")

All 14 Providers:

ProviderData TypePurposeDependency
PolymarketProviderPrediction market contractsEvent probability pricingstdlib
KalshiProviderBinary contractsUS regulated event contractsstdlib
YahooPriceProviderPrice historyStocks/ETFs/FX/Commoditiesyfinance
DeribitProviderCrypto derivativesFutures term structure, options IVstdlib
USTreasuryProviderTreasury yieldsYield curves, inflation expectationsstdlib
WebSearchProviderWeb searchVIX/MOVE/CDS/BDI supplementary datastdlib
CftcCotProviderFutures positioningInstitutional direction (smart money)stdlib
CoinGeckoProviderCrypto spotBTC/ETH price, market cap, dominancestdlib
EdgarProviderSEC filingsInsider trades Form 4, filing searchstdlib
BisProviderCentral bank dataPolicy rates, credit-to-GDP gapstdlib
WorldBankProviderDevelopment indicatorsGDP, population, trade, macro datastdlib
YFinanceProviderUS options chainsIV, Greeks, put/call ratio, max painyfinance
FearGreedProviderMarket sentimentCNN 7-signal composite → 0-100 scorestdlib
CMEFedWatchProviderRate probabilitiesFOMC rate change implied from futuresstdlib

12 out of 14 providers have zero external dependencies and zero API keys. YahooPriceProvider and YFinanceProvider require pip install yfinance.

WebSearchProvider usage:

  • web.search("query") → returns WebSearchResult (search summary) — render with .text()
  • web.fetch_page("url") → returns WebPageContent (page body extraction)
  • Search engine is DuckDuckGo, zero API keys needed

Data not available via structured providers — use web search instead: VIX, MOVE, CDS spreads, TTF natural gas, BDI freight rates, war risk premiums, high-yield OAS — these need to be fetched from financial web pages. They are still trading data and comply with the methodology.

Step 5: Data analysis

This is the key to report quality. Don't just summarize data — derive judgment from data.

Four analysis dimensions:

  1. Signal interpretation: What is each data point saying? Derive meaning from price. Not "gold up 3%" but "the market is pricing in tail risk." e.g., Copper/Gold ratio declining → industrial demand weaker than safe-haven demand → risk-off.

  2. Cross-validation: Which signals point in the same direction (resonance)? Which signals disagree (divergence)? Divergence itself is a high-value signal. e.g., gold says "disaster" but equities say "fine" → two markets pricing different time windows.

  3. Time alignment: Group signals by their pricing horizon. Don't mix signals from different time windows in the same vote.

    • Short-term (3-12mo): Prediction market contracts, VIX/MOVE, price reaction patterns, executive selling
    • Medium-term (1-3yr): Leader revenue consensus, CapEx plans, VC concentration, leverage concentration
    • Long-term (3-10yr): Equipment maker orders, irreversible capital allocation, ultra-long infrastructure investment
    • Short-term bearish + long-term bullish ≠ contradiction, = S-curve inflection
  4. Weight judgment: Not all signals are equally reliable. Signals backed by real money > surveys. Liquid markets > illiquid markets. Direct pricing > indirect proxies. e.g., Polymarket high-liquidity contract > CDS quotes (slow updates, low liquidity).

Core principle: Don't vote by majority. When signals diverge:

  • Check the time dimension first — different signals price different future windows
  • Look for "two things happening at once" — old economy Japanification + new economy boom can coexist
  • Consider "direction right but timing wrong" — long-term bullish but short-term overheated → wait for a pullback

Step 6: Output report

Must follow this structure. You can adjust the number of layers and wording, but the four main sections (data summary, analysis, probability estimates, conclusion) cannot be omitted or merged into prose paragraphs:

# [Question Title]: Multi-Signal Synthesis

## Data Summary

### Layer 1: [Most direct signal source]
| Signal | Data | What it's saying |
|--------|------|-----------------|
(table, one signal per row, third column is reasoning from price to meaning)

### Layer 2: [Secondary signal source]
(same format)

### Layer N: ...
(as needed, typically 3-5 layers)

## Analysis

### Resonance signals
(which signals point in the same direction, and what judgment they form)

### Key divergences
(A says X, B says Y → explain why + who is more credible)

### Time stratification
(what do short-term / medium-term / long-term signals each point to)

## Probability Estimates
| Scenario | Probability | Basis |
|----------|-------------|-------|

### Most likely path: [one-sentence summary]
**Core logic chain:** (2-3 paragraphs, reasoning from data to conclusion)

## Conclusion

> [One-sentence summary, preferably including a specific probability estimate]

### Sub-conclusions
| Dimension | Judgment | Confidence |
|-----------|----------|------------|
| Short-term (6-12mo) | ... | High/Medium/Low |
| Medium-term (1-3yr) | ... | High/Medium/Low |
| Long-term (3-5yr) | ... | High/Medium/Low |
| Systemic risk | ... | High/Medium/Low |
(adjust dimensions to match the question — e.g., replace "systemic risk" with whatever dimension is most relevant)

### Risk factors
- **Upside risk:** what scenario would make things better than expected
- **Downside risk:** what scenario would make things worse than expected

### Signals to monitor
| Signal | Current value | Threshold | Meaning |
|--------|--------------|-----------|---------|
| ... | ... | if crosses X | then Y |
(3-5 concrete signals with specific trigger levels and what they would imply)

---
*Data sources: [list all structured and web data sources]*
*Fetched at: [date]*

Notes

  • Polymarket slug_contains search is fuzzy — filter results by title keywords after fetching
  • YahooPriceProvider uses Yahoo Finance symbols: futures use =F suffix (e.g. GC=F, CL=F, HG=F), forex uses =X suffix (e.g. EURUSD=X), US stocks/ETFs use plain tickers (e.g. SPY, LMT)
  • YahooPriceProvider requires yfinance — install with uv pip install --target .deps yfinance
  • European stocks available on Yahoo Finance with exchange suffix (e.g. RHM.DE for Rheinmetall, BA.L for BAE Systems)
  • Prediction market contracts vary in liquidity — contracts with volume < $100K should be discounted
  • Different signals update at different frequencies: prediction markets real-time, Yahoo Finance daily delayed, Treasury weekly
  • CFTC COT updates Tuesday, published Friday. commodity_name uses uppercase ("GOLD", "CRUDE OIL", "S&P 500")
  • CoinGecko free API has rate limits (~10-30 req/min) — don't pack too many CoinGecko calls in gather
  • EDGAR requires EdgarProvider(user_email="you@example.com") — SEC requires email in User-Agent, otherwise 403. First call parses ticker→CIK mapping, slightly slow
  • BIS data updates infrequently (monthly/quarterly) — suitable for long-term trends, not short-term trading
  • World Bank GDP data typically lags 1-2 years — latest year may return None
  • YFinance requires uv pip install yfinance (auto-installs pandas). After-hours IV may be inaccurate (bid/ask = 0) — use during market hours
  • YFinance get_chain() auto-computes Black-Scholes Greeks (pure stdlib math.erf, no scipy needed)
  • Absolute value of put delta ≈ probability of that strike being ITM at expiration (rough estimate)
  • Put/Call ratio > 1.5 is typically bearish, but as a contrarian indicator, extreme values (> 3) may signal a bottom
  • Max pain is the strike price maximizing market maker profit — actual expiration price often converges toward max pain
  • Kalshi does NOT support keyword search — use series_ticker or event_ticker to filter markets. Find tickers by browsing kalshi.com or listing markets without filters first. Common series: KXFED (Fed rates), KXINX (S&P 500 range), KXGDP (GDP)
  • Deribit futures method is get_futures_term_structure(), not get_futures_curve(). Option chain method is get_option_chain()
  • FearGreedProvider has no API key requirement. Returns a single composite score (0-100) synthesizing 7 market price signals: stock momentum, breadth, VIX, put/call ratio, junk bond demand, volatility, safe haven demand. Score < 25 = Extreme Fear, > 75 = Extreme Greed
  • CMEFedWatchProvider has no API key requirement. Returns implied rate change probabilities for upcoming FOMC meetings, derived from 30-day Fed Funds futures prices. Note: the CME endpoint may occasionally be unavailable or change format — if it fails, fall back to Kalshi KXFED series for rate probabilities
  • When reporting dollar amounts, use USD instead of $ to avoid markdown renderers interpreting $...$ as LaTeX

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Web3

Stock Market Intelligence

Market data API for AI agents. Equities, fixed income, crypto, and macro. Bitcoin Lightning micropayments.

Registry SourceRecently Updated
1.7K6Profile unavailable
Web3

Polymarket Scout — Orion

Analyzes Polymarket BTC prediction markets to show active market sentiment, crowd consensus, and alignment with on-chain data via Orion's oracle.

Registry SourceRecently Updated
2690Profile unavailable
Web3

Prediction Market Sentinel

Monitor Polymarket prediction market wallets and detect new trades in real-time. Use when tracking whale wallets, detecting new positions, or monitoring pred...

Registry SourceRecently Updated
2870Profile unavailable
Web3

QuantOracle

63 deterministic quantitative finance calculations via MCP. Options pricing, Greeks, implied volatility, exotic derivatives, risk metrics, portfolio optimiza...

Registry SourceRecently Updated
1030Profile unavailable